Difference between revisions of "RS-485"
(52 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
− | Here we will log the development of RS-485 interface onto BoSL sensors. | + | Here we will log the development of RS-485 interface onto BoSL sensors. If you are looking for a the library see here: [[RS-485_Library]] |
+ | |||
+ | \#TODO Current ratings of power rails. | ||
Requirements: | Requirements: | ||
Line 15: | Line 17: | ||
Additional wires could also be left exposed on the sensors so that uploading remains possible via these. This solution is is difficult as it introduces another entry point for water. <br> | Additional wires could also be left exposed on the sensors so that uploading remains possible via these. This solution is is difficult as it introduces another entry point for water. <br> | ||
− | A solution which looks promising is illustrated below. It is a 6 wire system. It enables uploading of code over half duplex RS-485 by utilizing the wake line for the programmer to receive data from the sensor. | + | A solution which looks promising is illustrated below. It is a 6 wire system. It enables uploading of code over half duplex RS-485 by utilizing the wake line for the programmer to receive data from the sensor. This allows for the full duplex needed while uploading. It should be noted that this system may have a hard time uploading over very very long cables as the TX from the sensor will not be over RS485. The exact length is yet to be determined however is likely in the range of 10s of meters. |
+ | |||
+ | This solution works because the use of TX and WKE are never needed simultaneously. That is that if the sensor is sleeping TX is not being used so WKE is free to be driven high to wake the ATmega. Conversely, when the sensor is being programmed it is already awake and so WKE signals do not need to be sent, freeing the line for TX. | ||
+ | |||
+ | A full list of wires is: | ||
+ | * 3V3 | ||
+ | * GND | ||
+ | * RST/5V | ||
+ | * WKE/TX | ||
+ | * RS-485 A | ||
+ | * RS-485 B | ||
+ | |||
+ | Some testing will need to be done on what is the best arrangement of these onto 3 twisted pairs but a first iteration is: | ||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! Signal !! Wire | ||
+ | |- | ||
+ | | 3V3 || Orange | ||
+ | |- | ||
+ | | RST/5V|| Half Orange | ||
+ | |- | ||
+ | | GND || Green | ||
+ | |- | ||
+ | | WKE/TX || Half Green | ||
+ | |- | ||
+ | | RS-485 A|| Blue | ||
+ | |- | ||
+ | | RS-485 B|| Half Blue | ||
+ | |} | ||
<gallery> | <gallery> | ||
Line 21: | Line 51: | ||
File:RS-485 Program.png|RS-485 Programming Mode | File:RS-485 Program.png|RS-485 Programming Mode | ||
</gallery> | </gallery> | ||
+ | |||
+ | The option may also be available to use RST as a 5V rail. This is possible if the ATmega reset pin is 5V tolerant. | ||
+ | On reading the data sheet it looks like a diode may be nessesary to protect the reset pin. | ||
+ | |||
+ | https://au.element14.com/texas-instruments/sn65hvd75dgk/rs422-rs485-txrx-20mbps-3-6v-vssop/dp/3119111 | ||
+ | This transceiver is looking promising. It has 5V tolerant inputs too! | ||
+ | |||
+ | == 7 June 2020 == | ||
+ | |||
+ | In thinking about the potential issues with the bus it was decided that and WKE/RX combination offered benefits over a WKE/TX combination. | ||
+ | A WKE/RX combination solves the issues of having a very long cable attached to TX permanently which may cause instability or excess current draw if the TX pin needs to drive the large load of this wire. Additionally, if the cable is too long for an upload to work successfully a more powerful driver on the programmer side can be used. This will help extend the range somewhat. Since the cable is connected to RX on the programmer side, when not uploading it can be disconnected and rewired to the WKE line. This prevents the RX signals from being sent across it when not uploading*. * the RS-485 driver will still be electrically connected to the WKE line during normal operation, so a small buffer gate or diode will be needed to stop this. It remains to be tested which is the better solution. | ||
+ | |||
+ | The RS-485 Driver will also need to automatically be put in the transmit state when the upload process begins. This should be achievable through pull up resistors. | ||
+ | |||
+ | With the changes as described the new operating modes of the bus are: | ||
+ | |||
+ | <gallery> | ||
+ | File:RS-485 RX.png|thumb|BoSL_Bus_Operation, Left: Sleep, Middle: Active, Right: Upload | ||
+ | File:BoSL Bus.png|thumb|BoSL Bus Implementation with complete functionality | ||
+ | File:USART-BoSL Bus.png|thumb|USART to BoSL Bus Translator | ||
+ | </gallery> | ||
+ | |||
+ | An implementation of the BoSL Bus for a ATmega with complete functionality would look like this: | ||
+ | |||
+ | The SN65HVD75 is the RS-485 transceiver. Resistors R1 and R2 ensure that RE and DE are driven correctly during uploading (send data over RS-485), as when programming pins are in a floating state. When sleeping this does mean that DE will need to be pulled down, however this would draw ~8μA, which is negligible. Introducing more circuitry to reduce this would add unnecessary cost and space requirements. A potential future solution is to update the boot loader however this is not an immediate solution. | ||
+ | |||
+ | RE is also used to drive the 74LVC1G126 which is a buffer able to isolate WKE/RX. This helps during active mode as it prevents the RS-485 controller from driving unnecessary load, and makes the bus immune to the impedance state of the WKE pin. Thus, when in a Low-Z state the line is open to signals from WKE/RX, and when in a High-Z state the Arduino is free to receive data from the SN65HVD75. | ||
+ | |||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! Mode !! DE !! RE !! SN65HVD75 !! 74LVC1G126 | ||
+ | |- | ||
+ | | Sleep|| L || H || Off || Low-Z | ||
+ | |- | ||
+ | | Program || H || H || Send || Low-Z | ||
+ | |- | ||
+ | | Active|| H\L || H\L || Send\Receive || High-Z | ||
+ | |} | ||
+ | |||
+ | The diode on RST\5V allows the line to be used as a 5V supply while not having current leak through the reset pin due to the reserved biasing of the diode. When the line is drawn low the diode becomes forward bias and conducting, hence also drawing the line low and pulsing the reset pin. The BAT54W diode was chosen as it has a low forward voltage drop ~300 mV, this is important as the ATmega328p is only guaranteed to reset if the reset voltage goes below 0.1*Vcc, or when powered from a 3V3 supply, 330 mV. | ||
+ | |||
+ | This standard should be modifiable to work with a 5V ATmega328p. It may require switching of the voltages 3V3 and RST/5V, however the deviation should be minimal. | ||
+ | |||
+ | There is also a sketch for a design of a USART to BoSL-Bus converter in the gallery. It does not generate its own 5V supply, however it will be able to connect to a BoSL board and facilitate the communication with BoSL Bus enabled sensors. | ||
+ | |||
+ | == 9 July 2020 == | ||
+ | |||
+ | A PCB was drawn up for the BoSL Bus to USART converter. Testing needs to be done on the system however it is likely that changes will be small. | ||
+ | |||
+ | The converter is small in size ~ 40 mm by 20 mm. It connects via either header pins or header sockets to the BoSL board and via modular connector or header sockets to the BoSL Bus sensor. The changes between programming and active mode are done by connecting different pins to different ports on the BoSL board side. | ||
+ | |||
+ | |||
+ | |||
+ | <gallery> | ||
+ | File:Converter BoSL Bus.png|BoSL Bus converter PCB render | ||
+ | File:Converter Schematic BoSL Bus.png|BoSL Bus converter schematic | ||
+ | </gallery> | ||
+ | |||
+ | == 21th July 2020 == | ||
+ | |||
+ | To get familiar with RS-485, these: https://www.altronics.com.au/p/z6364-ttl-to-rs485-breakout-module, modals were used in a simple setup. With one set to read mode (DE, RE LOW) and the other to send mode (DE, RE HIGH) data could be sent from the TX port of one arduino uno to the TX port of a USB-TTL converter. This worked quite well. The modals operated both on 5V and 3V3. The length over which data could be sent was not tested in this trial. | ||
+ | |||
+ | The same setup also worked for sending data from a BoSL board. | ||
+ | |||
+ | When a ground wire and RX were connected from the USB-TTL converter then code could be uploaded to the BoSL Board using the same method as one normally would. | ||
+ | |||
+ | It was found that the converter PCB had inbuilt pull-up resistors. Once these were removed DE and RE needed to be tied up to allow the uploading to take place. Fortunately, 1 ΜΩ resistors were sufficient to achieve this. This reduces the sleep current consumption to by 7 μA as 330 kΩ pull-up resistors were thought to be needed. | ||
+ | |||
+ | On the BoSL board the reset system does not work as intended, however it was discovered that this was an issue more with the bosl board. It was seen that when the reset button was pressed the 3V3 line dipped down to 2.7V. This is not supposed to happen and should be investigated and fixed in a future version of the BoSL board. | ||
+ | |||
+ | == 22nd July 2020 == | ||
+ | |||
+ | A schematic of the depth sensor was drawn up with the BoSL Bus incorporated. Micheal will be laying out the schematic into a PCB so some prototypes can be manufactured. | ||
+ | |||
+ | <gallery> | ||
+ | File:DepthRS-485.png | ||
+ | </gallery> | ||
+ | |||
+ | == 6th August 2020 == | ||
+ | |||
+ | A new version of the BoSL Bus converter was drawn up, the changes were that the pin sockets on the output were replaced for screw terminals, and directly soldered wires replaced the set of pin headers on the input. The new version is slightly longer to accommodate the extra width taken up by the pin headers. | ||
+ | |||
+ | <gallery> | ||
+ | File:BoSL USART RS485 rev 0.1.1.png|BoSL Bus Converter rev 0.1.1 PCB render | ||
+ | </gallery> | ||
+ | |||
+ | == 10th September 2020 == | ||
+ | |||
+ | The RS-485 depth probes were tested today, programs were able to be uploaded using the BoSL Bus converter with the following wiring table: | ||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! Depth Probe !! BoSL Bus Converter | ||
+ | |- | ||
+ | | Black|| G | ||
+ | |- | ||
+ | | Purple || HG | ||
+ | |- | ||
+ | | Yellow || B | ||
+ | |- | ||
+ | | White || HB | ||
+ | |- | ||
+ | | Red || O | ||
+ | |- | ||
+ | | Blue || HO | ||
+ | |} | ||
+ | |||
+ | Issues were had however when monitoring the current of the device. It was 40 mA in operation, much greater than expected. It is uncertain why this is as it occurs even when all the device components should be put to sleep. | ||
+ | |||
+ | It was found that this issue was due to write enable left high on the RS-485 converter. Once this was changed the sleep mode did use substantially less current, in the μΑ. | ||
+ | |||
+ | It seem the hardware is now working well, efforts were spent in trying to implement a software library. | ||
+ | A standard needs to be designed for this, so considerations will be made into the best method for implementing this. | ||
+ | |||
+ | == 11th September 2020 == | ||
+ | |||
+ | Today was spent developing the RS-485 sensor library. Some issues were had with automating the timing of the system. In particular the RS-485 works when connected directly through a USB-TTL converter however not when connected to a BoSL board. It looks definitely possible to get this working on a BoSL board just more debugging needs to occur. | ||
+ | |||
+ | == 16th September 2020 == | ||
+ | |||
+ | Writing to the RS-485 Bus while the depth sensor is also writing seems to send the depth sensor into a lock state recoverable by reset. | ||
+ | The system was got working and so data can be transferred between the depth sensor and the bosl board. | ||
+ | The baud rate attainable was 38400, this is a bit slower than ideal and seems to be mainly limited by the software serial on the bosl. | ||
+ | |||
+ | commands issued by the bosl will be defined to be 4 bytes long the first is the device byte and the second the a command byte and the next two parameter bytes. | ||
+ | |||
+ | when the sensors send data back i don't think this will need to have a specified limit but we will have a stop byte at the end. | ||
+ | |||
+ | == 18th September 2020== | ||
+ | |||
+ | A unified versions of the BoSL RS485 library was created and tested. It should be very easy to implement in software now. A new page was created for the library to help keep better track and provide specific documentation. It can be found here [[RS-485_Library]] | ||
+ | |||
+ | == 17th November 2021 == | ||
+ | |||
+ | Some RS-485 depth-temperature-ec sensors were not working. The sensors were unable to be uploaded to via BoSL-bus converter when wired in program mode. After some debugging it was decided to see if the BoSL bus converters would be able to be verified as working by connecting one to another and then sending messages over the bus. This was found to be possible. The wiring table used to send data from the USB-to-serial converter to the 'emulated' sensor via TTL and data from the sensor to the USB-to-serial converter via RS-485 was: | ||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! USB-to-Serial !! BoSL-Bus | ||
+ | |- | ||
+ | | GND || GND | ||
+ | |- | ||
+ | | 3V3 || 3V3 | ||
+ | |- | ||
+ | | RX (data in)|| RX | ||
+ | |- | ||
+ | | NC || TX | ||
+ | |- | ||
+ | | TX (data out) || WKE | ||
+ | |- | ||
+ | | RST || RST/5V | ||
+ | |- | ||
+ | | DE || GND | ||
+ | |- | ||
+ | | RE || GND | ||
+ | |} | ||
+ | |||
+ | A small update to the RS485 library was needed to allow communication over longer cables. Once this was done the sensor was able to be spoken with reliably. | ||
+ | |||
+ | However when an actual RS-485 sensor was connected no program was still able to be uploaded. By measuring test points on the sensor, it was found that the sensor has power and ground connections. The reset pin works. And that RE is brought high when reset is pressed (as needed). | ||
+ | |||
+ | The sensor was able to be fixed and a program uploaded, the issues was that the soldering of the sensor was incorrect. The connect the sensor it needed to be wired up as: | ||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! BoSL-Bus !! RS-485 Sensor | ||
+ | |- | ||
+ | | HO || Blue | ||
+ | |- | ||
+ | | O || Red | ||
+ | |- | ||
+ | | HG || White | ||
+ | |- | ||
+ | | G || Black | ||
+ | |- | ||
+ | | HB || Brown | ||
+ | |- | ||
+ | | B || Yellow | ||
+ | |} |
Latest revision as of 04:15, 17 November 2021
Here we will log the development of RS-485 interface onto BoSL sensors. If you are looking for a the library see here: RS-485_Library
\#TODO Current ratings of power rails.
Requirements:
- Upload Code
- Sleep/Wake sensors
- 3V3 5V interoperable
- Minimum wires
- Bus operation
Uploading code is the first issue to be addressed. RS-485 is half-duplex over a single twisted pair. This presents issues during uploading as it requires full duplex operation.
The easiest solution is to move to full duplex. This would require 2 twisted pairs thus a full bus likely 8. Ideally less wires would be needed.
Another solution is to modify the uploading program and use another wire to send to the sensor whether it should be receiving or sending data. This would likely require special programmer hardware and software.
It is also possible to update the Arduino bootload to recognise when it needs to be sending and receiving data. This may be possible, but it is uncertain how reliably this would work or if it is feasible.
Additional wires could also be left exposed on the sensors so that uploading remains possible via these. This solution is is difficult as it introduces another entry point for water.
A solution which looks promising is illustrated below. It is a 6 wire system. It enables uploading of code over half duplex RS-485 by utilizing the wake line for the programmer to receive data from the sensor. This allows for the full duplex needed while uploading. It should be noted that this system may have a hard time uploading over very very long cables as the TX from the sensor will not be over RS485. The exact length is yet to be determined however is likely in the range of 10s of meters.
This solution works because the use of TX and WKE are never needed simultaneously. That is that if the sensor is sleeping TX is not being used so WKE is free to be driven high to wake the ATmega. Conversely, when the sensor is being programmed it is already awake and so WKE signals do not need to be sent, freeing the line for TX.
A full list of wires is:
- 3V3
- GND
- RST/5V
- WKE/TX
- RS-485 A
- RS-485 B
Some testing will need to be done on what is the best arrangement of these onto 3 twisted pairs but a first iteration is:
Signal | Wire |
---|---|
3V3 | Orange |
RST/5V | Half Orange |
GND | Green |
WKE/TX | Half Green |
RS-485 A | Blue |
RS-485 B | Half Blue |
The option may also be available to use RST as a 5V rail. This is possible if the ATmega reset pin is 5V tolerant. On reading the data sheet it looks like a diode may be nessesary to protect the reset pin.
https://au.element14.com/texas-instruments/sn65hvd75dgk/rs422-rs485-txrx-20mbps-3-6v-vssop/dp/3119111 This transceiver is looking promising. It has 5V tolerant inputs too!
Contents
7 June 2020
In thinking about the potential issues with the bus it was decided that and WKE/RX combination offered benefits over a WKE/TX combination. A WKE/RX combination solves the issues of having a very long cable attached to TX permanently which may cause instability or excess current draw if the TX pin needs to drive the large load of this wire. Additionally, if the cable is too long for an upload to work successfully a more powerful driver on the programmer side can be used. This will help extend the range somewhat. Since the cable is connected to RX on the programmer side, when not uploading it can be disconnected and rewired to the WKE line. This prevents the RX signals from being sent across it when not uploading*. * the RS-485 driver will still be electrically connected to the WKE line during normal operation, so a small buffer gate or diode will be needed to stop this. It remains to be tested which is the better solution.
The RS-485 Driver will also need to automatically be put in the transmit state when the upload process begins. This should be achievable through pull up resistors.
With the changes as described the new operating modes of the bus are:
An implementation of the BoSL Bus for a ATmega with complete functionality would look like this:
The SN65HVD75 is the RS-485 transceiver. Resistors R1 and R2 ensure that RE and DE are driven correctly during uploading (send data over RS-485), as when programming pins are in a floating state. When sleeping this does mean that DE will need to be pulled down, however this would draw ~8μA, which is negligible. Introducing more circuitry to reduce this would add unnecessary cost and space requirements. A potential future solution is to update the boot loader however this is not an immediate solution.
RE is also used to drive the 74LVC1G126 which is a buffer able to isolate WKE/RX. This helps during active mode as it prevents the RS-485 controller from driving unnecessary load, and makes the bus immune to the impedance state of the WKE pin. Thus, when in a Low-Z state the line is open to signals from WKE/RX, and when in a High-Z state the Arduino is free to receive data from the SN65HVD75.
Mode | DE | RE | SN65HVD75 | 74LVC1G126 |
---|---|---|---|---|
Sleep | L | H | Off | Low-Z |
Program | H | H | Send | Low-Z |
Active | H\L | H\L | Send\Receive | High-Z |
The diode on RST\5V allows the line to be used as a 5V supply while not having current leak through the reset pin due to the reserved biasing of the diode. When the line is drawn low the diode becomes forward bias and conducting, hence also drawing the line low and pulsing the reset pin. The BAT54W diode was chosen as it has a low forward voltage drop ~300 mV, this is important as the ATmega328p is only guaranteed to reset if the reset voltage goes below 0.1*Vcc, or when powered from a 3V3 supply, 330 mV.
This standard should be modifiable to work with a 5V ATmega328p. It may require switching of the voltages 3V3 and RST/5V, however the deviation should be minimal.
There is also a sketch for a design of a USART to BoSL-Bus converter in the gallery. It does not generate its own 5V supply, however it will be able to connect to a BoSL board and facilitate the communication with BoSL Bus enabled sensors.
9 July 2020
A PCB was drawn up for the BoSL Bus to USART converter. Testing needs to be done on the system however it is likely that changes will be small.
The converter is small in size ~ 40 mm by 20 mm. It connects via either header pins or header sockets to the BoSL board and via modular connector or header sockets to the BoSL Bus sensor. The changes between programming and active mode are done by connecting different pins to different ports on the BoSL board side.
21th July 2020
To get familiar with RS-485, these: https://www.altronics.com.au/p/z6364-ttl-to-rs485-breakout-module, modals were used in a simple setup. With one set to read mode (DE, RE LOW) and the other to send mode (DE, RE HIGH) data could be sent from the TX port of one arduino uno to the TX port of a USB-TTL converter. This worked quite well. The modals operated both on 5V and 3V3. The length over which data could be sent was not tested in this trial.
The same setup also worked for sending data from a BoSL board.
When a ground wire and RX were connected from the USB-TTL converter then code could be uploaded to the BoSL Board using the same method as one normally would.
It was found that the converter PCB had inbuilt pull-up resistors. Once these were removed DE and RE needed to be tied up to allow the uploading to take place. Fortunately, 1 ΜΩ resistors were sufficient to achieve this. This reduces the sleep current consumption to by 7 μA as 330 kΩ pull-up resistors were thought to be needed.
On the BoSL board the reset system does not work as intended, however it was discovered that this was an issue more with the bosl board. It was seen that when the reset button was pressed the 3V3 line dipped down to 2.7V. This is not supposed to happen and should be investigated and fixed in a future version of the BoSL board.
22nd July 2020
A schematic of the depth sensor was drawn up with the BoSL Bus incorporated. Micheal will be laying out the schematic into a PCB so some prototypes can be manufactured.
6th August 2020
A new version of the BoSL Bus converter was drawn up, the changes were that the pin sockets on the output were replaced for screw terminals, and directly soldered wires replaced the set of pin headers on the input. The new version is slightly longer to accommodate the extra width taken up by the pin headers.
10th September 2020
The RS-485 depth probes were tested today, programs were able to be uploaded using the BoSL Bus converter with the following wiring table:
Depth Probe | BoSL Bus Converter |
---|---|
Black | G |
Purple | HG |
Yellow | B |
White | HB |
Red | O |
Blue | HO |
Issues were had however when monitoring the current of the device. It was 40 mA in operation, much greater than expected. It is uncertain why this is as it occurs even when all the device components should be put to sleep.
It was found that this issue was due to write enable left high on the RS-485 converter. Once this was changed the sleep mode did use substantially less current, in the μΑ.
It seem the hardware is now working well, efforts were spent in trying to implement a software library. A standard needs to be designed for this, so considerations will be made into the best method for implementing this.
11th September 2020
Today was spent developing the RS-485 sensor library. Some issues were had with automating the timing of the system. In particular the RS-485 works when connected directly through a USB-TTL converter however not when connected to a BoSL board. It looks definitely possible to get this working on a BoSL board just more debugging needs to occur.
16th September 2020
Writing to the RS-485 Bus while the depth sensor is also writing seems to send the depth sensor into a lock state recoverable by reset. The system was got working and so data can be transferred between the depth sensor and the bosl board. The baud rate attainable was 38400, this is a bit slower than ideal and seems to be mainly limited by the software serial on the bosl.
commands issued by the bosl will be defined to be 4 bytes long the first is the device byte and the second the a command byte and the next two parameter bytes.
when the sensors send data back i don't think this will need to have a specified limit but we will have a stop byte at the end.
18th September 2020
A unified versions of the BoSL RS485 library was created and tested. It should be very easy to implement in software now. A new page was created for the library to help keep better track and provide specific documentation. It can be found here RS-485_Library
17th November 2021
Some RS-485 depth-temperature-ec sensors were not working. The sensors were unable to be uploaded to via BoSL-bus converter when wired in program mode. After some debugging it was decided to see if the BoSL bus converters would be able to be verified as working by connecting one to another and then sending messages over the bus. This was found to be possible. The wiring table used to send data from the USB-to-serial converter to the 'emulated' sensor via TTL and data from the sensor to the USB-to-serial converter via RS-485 was:
USB-to-Serial | BoSL-Bus |
---|---|
GND | GND |
3V3 | 3V3 |
RX (data in) | RX |
NC | TX |
TX (data out) | WKE |
RST | RST/5V |
DE | GND |
RE | GND |
A small update to the RS485 library was needed to allow communication over longer cables. Once this was done the sensor was able to be spoken with reliably.
However when an actual RS-485 sensor was connected no program was still able to be uploaded. By measuring test points on the sensor, it was found that the sensor has power and ground connections. The reset pin works. And that RE is brought high when reset is pressed (as needed).
The sensor was able to be fixed and a program uploaded, the issues was that the soldering of the sensor was incorrect. The connect the sensor it needed to be wired up as:
BoSL-Bus | RS-485 Sensor |
---|---|
HO | Blue |
O | Red |
HG | White |
G | Black |
HB | Brown |
B | Yellow |