CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

LPT port

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Invisible
Guest







LPT port
PostPosted: Tue Jan 28, 2003 10:10 am     Reply with quote

hi,

I would like to start a project using LPT port instread of Com,
I had think about 16f87x pic but:

-I am no so clear about conect pic to lpt, I think it can be done directly pin to pin
-No good idea how to �sniff� what is happening in that port, there is something like serial monitor?, I had seen a couple of ms-dos based programs looking realy bad

Thanks for any help!

best regards
Invisible
___________________________
This message was ported from CCS's old forum
Original Post ID: 11074
Shane Rowell
Guest







Re: LPT port
PostPosted: Sat Feb 01, 2003 1:34 pm     Reply with quote

To get up and running fast, I would use Qbasic first. It is dos based and allows direct access to the parallel port. I know that it works under win98, but an not sure how it works on other operating systems.
If you go to the device manager in windows, or look at the screen dos screen right after you turn on your pc, you can get the address to the port. The address is usually in the range 0378-037F. I believe that 0378 will allow you the access that you need.

You will be able to read/write the state of the pins by using the follofing commands in QBasic.



int 8 = inp(888) //read
out(address,value) //write value to address

I recommend that you use the pins as 1-directionl. With this method you will use the pins in the configuration that they are normally used.

As with all pc, dont load the pins and be carefull about esd.

I hope this gets you started.

Shane






:=hi,
:=
:=I would like to start a project using LPT port instread of Com,
:=I had think about 16f87x pic but:
:=
:=-I am no so clear about conect pic to lpt, I think it can be done directly pin to pin
:=-No good idea how to �sniff� what is happening in that port, there is something like serial monitor?, I had seen a couple of ms-dos based programs looking realy bad
:=
:=Thanks for any help!
:=
:=best regards
:=Invisible
___________________________
This message was ported from CCS's old forum
Original Post ID: 11185
Guest








Re: LPT port
PostPosted: Sun Oct 23, 2005 11:49 pm     Reply with quote

Shane Rowell wrote:
To get up and running fast, I would use Qbasic first. It is dos based and allows direct access to the parallel port. I know that it works under win98, but an not sure how it works on other operating systems.
If you go to the device manager in windows, or look at the screen dos screen right after you turn on your pc, you can get the address to the port. The address is usually in the range 0378-037F. I believe that 0378 will allow you the access that you need.

You will be able to read/write the state of the pins by using the follofing commands in QBasic.



int 8 = inp(888) //read
out(address,value) //write value to address

I recommend that you use the pins as 1-directionl. With this method you will use the pins in the configuration that they are normally used.

As with all pc, dont load the pins and be carefull about esd.

I hope this gets you started.

Shane






:=hi,
:=
:=I would like to start a project using LPT port instread of Com,
:=I had think about 16f87x pic but:
:=
:=-I am no so clear about conect pic to lpt, I think it can be done directly pin to pin
:=-No good idea how to �sniff� what is happening in that port, there is something like serial monitor?, I had seen a couple of ms-dos based programs looking realy bad
:=
:=Thanks for any help!
:=
:=best regards
:=Invisible
___________________________
This message was ported from CCS's old forum
Original Post ID: 11185
Ttelmah
Guest







PostPosted: Mon Oct 24, 2005 2:46 am     Reply with quote

What OS are you intending to run on the PC?.
Now the problem here is that MSDOS, and W9x, alow programs to directly access resources like the parallel port, while latter OS's (NT, W2K, WXP), will all prevent 'user mode' programs from talking directly to the port. There are ways to bypass this protection, but they involve either writing your own 'ring0' driver for the port, or bodging the OS, and turning off the protection for some ports. The former is hard work, and the latter raises the possibility of making the OS more fragile (this is why the protection was introduced to prevent programs accessing things they should not...). Remember also, that the parallel port is obsolete, and not provided on many modern computers, so if this project is more than a 'bit of fun', you should consider another approach...
Personally, I'd consider one of the FTDI USB serial modules (remember these can transfer data at 1Mbps, and the FIFO version, can go to 3Mbps). For either the FIFO version mentioned above, or the parallel port, the approach would be basically the same. Data is 8bits wide, presented on 8 lines, with added 'acknowledge', and 'strobe' lines. When a character is output, the sending device generates a 'strobe' signal, and then waits to see the 'ack' from the receiver. These handshakes are neeed to synchronise the transfer. So just to send data to the PIC using this interface, is 8 bits are transferred at a time, requires 10 pins on the PIC. If you want to go bi-directional, you need to add a direction control as well, and a lot more complexity in the code.
Generally, a PIC is straining to do much constructive with data at the highest serial rates, and the wiring is a lot easier than for a parallel interface, so I'd perhaps 'reconsider', and look at the USB serial modules instead.

Best Wishes
neil



Joined: 08 Sep 2003
Posts: 128

View user's profile Send private message

Like it!
PostPosted: Mon Oct 24, 2005 6:10 am     Reply with quote

I like the sound of those FTDI devices. They appear very simple to use! I might see if I can find an excuse to put one on my next design to try them out! They are especially good now that most laptops no longer have serial or parallel ports (mine included). I am thinking on the lines of using one to flash a PIC in situ, using a laptop. Do you know of any pitfalls with them?

Neil.
Ttelmah
Guest







PostPosted: Mon Oct 24, 2005 6:49 am     Reply with quote

Yes. The 'modules', can in some circumstances have a noise problem. This is normally fixable by adding a capacitor between the shield on the USB connector, and the local 0v. In some very noisy enviroments a couple of tiny decoupling capacitors on the incoming USB signals can also help. However in normal fairly 'friendly' enviroments, they work well now, and the current code is reliable. If building completely using the chip, a bit of care in ground plane design, makes them really reliable. they are a pretty good solution.

Best Wishes
neil



Joined: 08 Sep 2003
Posts: 128

View user's profile Send private message

PostPosted: Mon Oct 24, 2005 7:32 am     Reply with quote

Ha! If they will work where we are, they will work anywhere! We have electrical switching noise, loads of controlled rectification around, and some very high power RF! We even have ionising radiation, though not near the electronics for obvious reasons Smile

You say 'tiny' decoupling caps on the USB lines. They must be really tiny not to slug the signal at (what) 3Mbps? The sort of RF we have around here is slap bang on that frequency. We usually survive with good PCB design and putting the sensitive circuitry in a grounded can.

I think I'll stick a few chips on order and have a play anyway.
Cheers, Neil.

Sorry to be using someone elses thread here. A bit off topic, but still of interest!
treitmey



Joined: 23 Jan 2004
Posts: 1094
Location: Appleton,WI USA

View user's profile Send private message Visit poster's website

PostPosted: Mon Oct 24, 2005 8:11 am     Reply with quote

I have the FTDI chips in 4 products now.
Get samples of each chip. There great.
Also pick up some of the I2C FRAM chips. Another great chip.

You see when you get all that data from the PC and its flowing fast and free, you'l need to store it someplace.
Ttelmah
Guest







PostPosted: Mon Oct 24, 2005 8:14 am     Reply with quote

Not as small as you may think. The recommended values were 47pF, from D+ to GND, and 47pF from D- to GND. Then a 470nF from the shield to GND. This was back in USB1.1 days (12Mbps max on the bus). The reactance of these, is still over 280R at the full frequency on such a bus.

Best Wishes
neil



Joined: 08 Sep 2003
Posts: 128

View user's profile Send private message

PostPosted: Tue Oct 25, 2005 2:58 am     Reply with quote

Is USB differential? I guess it is from the names "D+" and "D-", so the caps are in common mode and will shunt common mode noise away, leaving the differential mode signal relatively untouched.

I guess it would pay for me to look up the USB spec. somewhere!

Neil.
newguy



Joined: 24 Jun 2004
Posts: 1911

View user's profile Send private message

PostPosted: Tue Oct 25, 2005 10:32 am     Reply with quote

USB isn't really differential. There are lots of different coded messages/responses, each with a different signalling format. Sometimes the signalling can be single-ended (i.e. one line being driven while the other is grounded), and sometimes it can be differential. Sometimes the D- line is the "positive" line, while the D+ becomes the "negative" one. It's all very complex.

If you want to learn everything there is to know about the USB spec, then "USB Complete" by Jan Axelson is a decent book. It's not great, but it's not bad, either.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group