please dont rip this site

PIC Microcontoller Input / Output Methods

RS-485 (RS485)

RS485 Networking for intelligent house by Frank A. Vorstenbosch

The practical differences of 232 vs 485 are:

Olin Lathrop says:
The architectural difference between RS-232 and RS-485 is that 232 is a bi-directional point to point link, whereas 485 is a single channel bus. RS-232 can also carry additional signals used for flow control and modem control.

Electrically, each 232 signal uses a single wire with symmetric voltages about a common ground wire. 485 uses two wires to carry the single signal differentially. Both wires use 0 to 5 volts, with the two wires being driven opposite. The purpose of this is to provide noise immunity, because much of the common mode signal can be rejected by the receiver.

{ed: Although it is not a part of the specifications, in most cases...} Both 232 and 485 use the same asynchronous encoding of individual bytes. This is the familiar start bit, followed by data bits (usually 8), followed by stop bits (usually 1 nowadays). Both the transmitter and receiver have to agree on the bit rate in advance. All timing within a byte is relative to the leading edge of the start bit. The PIC USART module was deliberately designed to support this encoding in its asynchronous (UART) mode. The low level PIC code is the same for both 232 and 485 because it is transmitting and receiving bytes via the UART (or a software UART).

The big difference to the software is that only one device on a 485 bus can transmit at a time, whereas there are separate dedicated transmit and receive channels for the single device at the other end of a 232 link. There must also be external hardware that enables driving the bus when transmitting. This hardware is usually controlled from a separate PIC pin, but there are also some "automatic" schemes.

The RS-485 standard (well sortof, "RS" actually stands for "recommended standard") defines how to transmit and receive bytes to/from the bus electrically. Issues like flow control, collision avoidance, and data reliability are left completely as an exercise to the implementer. In a pure RS-485 system, these have to be dealt with in the protocol. As you can imagine, there are lots of ways of dealing with this, and the right choice depends on the particular system. The solution often envolves wrapping data into packets, each with a checksum, and some kind of ACK/retry scheme. So far I've dealt with collision avoidance by having a single master with all other bus devices being slaves that only talk when asked to by the master. Note that this can still give the appearance to upper levels of slaves initiating data transfer if the master polls each slave often enough (this is also how USB works, by the way).

Each RS-485 system is different, and therefore probably requires a different protocol. You inquiry to the PIC list has prompted me to put some RS-485 information on my PIC development resources web page. This includes an excerpt of the protocol specification for one real-world system, provided as an example.

Doesn't RS485 typically use a 9 bit address byte protocol for multidrop communications?

see also:

PICList post "RS485 code?"

See:

Questions:

Claudio J. Osorio Says:

Broken link at: http://www.piclist.com/techref/microchip/rs485.htm

http://www.chipcenter.com/circuitcellar/july99/c79bppdf.pdf 'The Art and Science of RS-485'
+

Code:

See also:


file: /Techref/microchip/rs485.htm, 6KB, , updated: 2010/3/25 10:10, local time: 2024/11/8 16:23, owner: JMN-EFP-786,
TOP NEW HELP FIND: 
3.148.106.201:LOG IN
©2024 PLEASE DON'T RIP! THIS SITE CLOSES OCT 28, 2024 SO LONG AND THANKS FOR ALL THE FISH!

 ©2024 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions?
Please DO link to this page! Digg it! / MAKE!

<A HREF="http://www.piclist.com/techref/microchip/rs485.htm"> RS-485 (RS485)</A>

After you find an appropriate page, you are invited to your to this massmind site! (posts will be visible only to you before review) Just type a nice message (short messages are blocked as spam) in the box and press the Post button. (HTML welcomed, but not the <A tag: Instead, use the link box to link to another page. A tutorial is available Members can login to post directly, become page editors, and be credited for their posts.


Link? Put it here: 
if you want a response, please enter your email address: 
Attn spammers: All posts are reviewed before being made visible to anyone other than the poster.
Did you find what you needed?

  PICList 2024 contributors:
o List host: MIT, Site host massmind.org, Top posters @none found
- Page Editors: James Newton, David Cary, and YOU!
* Roman Black of Black Robotics donates from sales of Linistep stepper controller kits.
* Ashley Roll of Digital Nemesis donates from sales of RCL-1 RS232 to TTL converters.
* Monthly Subscribers: Gregg Rew. on-going support is MOST appreciated!
* Contributors: Richard Seriani, Sr.
 

Welcome to www.piclist.com!

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  .