View previous topic :: View next topic |
Author |
Message |
bschriek
Joined: 18 Dec 2007 Posts: 80
|
Transmit Data Polarity |
Posted: Mon Dec 16, 2019 2:47 am |
|
|
Transmit Data Polarity
I have a general question about the data polarity of the EUSART in normal ASYNCHRONOUS HARDWARE mode.
I need to communicate with an inverted RS232 signal.
Now I use a pair of inverters and all works fine but I like to keep the hardware as simple as possible and therefore I want to remove one or even two inverters.
PCW compiler 5.091
Underneath the accompanying chapters of the used PIC16(L)F18855/75.
33.1 EUSART Asynchronous Mode
33.1.1.3 Transmit Data Polarity
The polarity of the transmit data can be controlled with the SCKP bit
33.1.2.2 Receiving Data
The receiver data recovery circuit initiates character reception on the falling edge of the first bit
Can I remove the outgoing (TX) inverter IC and use the "Transmit data polarity" function for this line?
Is the RX timing not affected by the "invert" function?
The incoming RX signal has no "data polarity" function right?
What do you suggest to invert the incoming RX signal? For example the COMPARATOR MODULE or CONFIGURABLE LOGIC CELL (CLC)?
Please give me your suggestions. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Mon Dec 16, 2019 4:17 am |
|
|
You have basically answered yourself.
Yes, you can invert the transmit.
Timings don't change.
Yes, you can invert the RX using the CLC. However this still results
in using extra pins, and beware that the ports you can use are
restricted. The CLC output can share a pin with the UART I/P. So only
one extra pin is needed for the CLC input. |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Mon Dec 16, 2019 4:46 am |
|
|
Thank you Ttelmah for your help.
Now I know for sure I have to "invert" the incoming RX signal one way or another.
What's the easiest way to find out the right code for the CLC module? I know the MPLAB X IDE has a feature to create the code for the CLC registers but maybe there is another way. As you know the CLC has an enormous amount of registers to declare. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9296 Location: Greensville,Ontario
|
|
Posted: Mon Dec 16, 2019 5:32 am |
|
|
While you can remove the inverters between the PIC and the other device, you may expose the PIC to possible damage. Normally you use a 'MAX232' type device to connect a PIC( any computer) to other 'RS-232' devices. These 'MAX232' devices are designed to be electrically 'rugged', and can withstand a fair amount of EMI, spikes, noise,etc. Removing them, removes that protection. Depending on cabling, distance, speed, etc. you also run the risk that the PIC will NOT be compatible with other 'RS232' devices. A lot of devices( most today ?) do not conform to the official specs laid out for true 'RS-232'. So while your PIC works on the bench with your device, it may not function 100% in the real world or say with a replacement device.
Now the odds are pretty good, it probably will, maybe, OK, should work but WHY take the chance ? Space can't be an issue, so is it cost ? 50 cents to be 100% compatible and protected is a LOT less than what it cost for the time spent typing this reply !!
Jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Mon Dec 16, 2019 6:16 am |
|
|
Routes:
1) Use the MPLAB code configurator. This contains the CLC configuration
tool.
2) A simple inverter is very basic to do. The XOR basic setup, with the
second input programmed to a logic 1 does this. LCxMODE = 001.
I do agree with Temtronic's comment on ruggedness. A buffer or even
better the MAX232 really is a great safety feature.... |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Mon Dec 16, 2019 8:53 am |
|
|
Yes, you are right. Better use a buffer IC with overvoltage / surge protection.
But now I got the thoughts of the Experts, thanks again. |
|
|
|