Hardware Clarifications: Starting from scratch #1044
-
Found this yesterday and have been deep in thre rabbit hole now for a few days.... My plan is to use the RPI and a ram disk (to save the SD card). Watching the "genmon Briggs" YouTube videos, He mentions the W630 is generally easier to setup but one issue is that the Rpi will poll the device every second which could tax the home network. Seems like it could be a big deal and he mentions excluding it on some way. in my mind that's 1 of 2 ways:
So I started reading the not so great documentation on the W630, it isn't clear but can the W630/610 be directly wired to the RPI? seems like it is meant to transmit the data wirelssly. But since Pi and the W630 both have ethernet ports seems it might work. how would I exclude it from the netowrk. I assume those people using thre W610 also have the same issues. so how do you handle that issue, or is it really not that big of a deal? if not, is it better/easier to just get an RS485 hat for my Pi and cut out that interface? is there a significant advantage to the W630/610 over a PiHat? the PiHat are much cheaper. say screw it and go with ESP32 which avoids SD card issues but still has choice between W630 and some add-on card ultimately my plan is to have the data sent to my home assiatnt, likely via MQTT. Leaving this here because I would like some opinions but I'm thinking that if I run some cat6 wire to the integrated rs485 output block on the generator (found a HAT that will accept wires from generator). I can run then run the wire to my network switch located less than 50ft away inside the house. At that point I could use ethernet to tie my Rpi with HAT into my network and have zero latency and totally avoid the wifi congestion and droputs or use wifi if i really wanted but why if that close to switch? |
Beta Was this translation helpful? Give feedback.
Replies: 43 comments
-
I would not worry about taxing your home network. If you use a serial over TCP device like the ESP32 or the WR-630 the network traffic will be minimal due to the serial link communicating at 9600 bits per second and genmon will ask for one modbus register, then wait until one is received. This results in extremely modest network requirements as most networks are a minimum of 10 million bits per second, most are 100 million bits per second. have ran serial over IP with both wifi and Ethernet. The only real issue to be aware of regarding using the WR-630 or other wifi based serial over IP devices is that a weak wifi signal will result in data errors. See issue number 16 on this page. Also review the page on serial over IP in the wiki if you have not already. Also, I have tried running RS-422/485 as my generator is at a distance greater than RS-232 will support. That works well for me also. This page has some info on that. Let me know if you have any other questions. |
Beta Was this translation helpful? Give feedback.
-
My final paragraph about simply running a Cat6 as my transmission line from the generator to the Raspberry Pi RS 485 Hat and plugging it directly into the network would be the most direct and Least Complicated setup though correct? Max distance would be about 75 ft but probably much less. I'm honestly just looking for the most reliable first and then the Least Complicated second and I'm wondering if there is an easy choice |
Beta Was this translation helpful? Give feedback.
-
I think that the RS485 would be the most direct and it is quite reliable. It is what I am currently using in my setup. I used these connectors and a Cat6 cable. You can also use the connector to easily make a loopback. If you have the option, I would stay away from wireless as it is inherently error prone and modbus is not great at handling timeout errors as the protocol does not define a timeout or the canceling of a packet request. When you are wired there at zero errors and it just works. |
Beta Was this translation helpful? Give feedback.
-
OK, i managed to get everything installed. I run genmon and I have no gauges and I have a red exclamation point. I'm obviously getting some data, see screenshots but it's not all coming over and I can't tell why. I'm using this 485 piHat I've checked serialtest and serialconfig and both pass. using the commands that are shown on the link above I get the correct but it tells me i need to be getting the opposite (see above) i followed the plan to have it as above and moved on. I have checked continuity at the generator to the raspberry pi and that is good on all 3 leads. wires are connected A-A B-B and Grd-Grd. https://imgur.com/Ryrc7d6 What else am i missing? only thing I wonder is if the toggles on the pihat are causing an issue? UPDATE: OPENED GENMON ON MY PHONE AND SAW THE DASHBOARD. WENT BACK TO pc AND OPENED IT IN EDGE AND I SEE THE GRAPHICAL DASHBOARD AS WELL BUT STILL NO CONNECTION. |
Beta Was this translation helpful? Give feedback.
-
@thomasshawn The web interface is showing the controller correctly because you have selected the Briggs custom controller in the advanced settings, not because gemon is communicating with the controller. Based on your comments above you are using 2 wire RS485. What are you using on the other end (the controller end)? Two wire RS485 requires that both ends (genmon and the Briggs controller) participate in throttling the direction on communication on the two wires since two wire RS485 is half duplex. Does the other end support automatic tranmit enable / disable? The RS485 adapter you are using has an option in the DIP switch for "Automatic DE/RE control". This should be enabled as genmon does not toggle support separate transmitter / receiver enable signal. Without the "Automatic DE/RE control" enabled the softeware would need to toggle GPIO 18 to determine if it is transmitting or receiving an gnemon does not do this. Another thing to do would be to validate your communications with a loopback test to validate the operation of the pi, RS485 adaption and cable, but you can do this with the "Transmitter connected to Receiver" option enabled, but this needs to be disabled in normal operation as this would confuse gnemon to get back everything that it transmits. See this page for details about running a loopback test. If you run the loopback test make sure you stop genmon as only one program can access the serial port at a time. I use RS422/RS485 trancievers in my setup but I use them in RS422 4 wire mode. It is possible to make 2 wire RS485 work, but both ends need to support the transceiver direction (like the "Automatic DE/RE control" option). Let me know if this makes sense or if you have any other questions. |
Beta Was this translation helpful? Give feedback.
-
I started trying things and as i clicked over the dipswitch on #3 it came alive on the monitor page but still no updates on any of the gauges https://imgur.com/NMO0Z0s so now it looks like i am communicating but not seeing anything on gauges |
Beta Was this translation helpful? Give feedback.
-
did you try refresh the page in your browser? When the page loads it asks genmon for how the gauges are configured so you may need to refresh the page. Also, you have the same number of validation errors as the number of received packets so this tells me that you still have an issue. If you outbound email is working your can submit your logs on the About page and I can look for errors or you can look at these files for errors: /var/log/genmon.log -- validation error are reported here, this should give some more details on the type of validation failure. I don't know about the settings on the Briggs controller, have you validate that the serial rate is 9600 and the modbus ID is 2 on the controller side? |
Beta Was this translation helpful? Give feedback.
-
yes refreshed browser Using python serial library V3.5b0 I'll send the logs but i made an error pin 3 is up (default) pin 2 which is tie the transmitter to the receiver is the one that i turned on and it started working. brigs controller settings are correct and match video of genmon briggs too |
Beta Was this translation helpful? Give feedback.
-
Just to clarify, switch 3 is always on, switch 2 is only on for a loopback. I have not received any logs yet. You can test your outbound email settings on the Settings page. Also when you restart genmon you will get two emails when genmon starts if you outbound email is working. genmon sends the logs via email. you can also issue the command in the browser: http://192.168.11.14:8000/cmd/get_logs this will download a compressed archive (named genmon_logs.tar.gz) of the logs which you can email to [email protected] if your outbound email is not working yet. |
Beta Was this translation helpful? Give feedback.
-
also, keep in mind that if you had switch 2 on while genmon is running, this could be the cause of you getting packets, but with validation errors so there is still a likely possibility that the controller is not getting the data. If switch 2 was on then genmon would receive every packet it sent, but the packets would fail a validation test as they are not in the format expected to be returned from the controller. |
Beta Was this translation helpful? Give feedback.
-
I got your logs |
Beta Was this translation helpful? Give feedback.
-
Also I initially purchased the 2 wire because it was the recommended one from genmon briggs if you weren't going to use the wifi bridge adapter. if 4 wire pihat is easier i can certainly order one and swap them out this week. this was supposed to be a smart device that could handle it all but maybe i'm not setting dip switches correctly. |
Beta Was this translation helpful? Give feedback.
-
is your controller set to Even parity? I would try to set this to No parity and then make genmon the same setting and see if that makes a difference. You are getting errors like this: 2023-09-27 21:04:38,762 : Validation Error, length: Master12 Slave: 3 the received packets are to properly formatted modbus packets so it looks like something is wrong on the serial side of things. also, I checked in a change that corrects an issue that may prevent the serial port from being configured to even parity so you can up the software from the About page and see if that helps. The version number did not change. After you update, send your logs so I can validate if that made a difference. |
Beta Was this translation helpful? Give feedback.
-
with your latest logs it looks like you are getting timeout errors for all packets sent, which indicates that either the controller is not receiving the data that genmon sends, or genmon is not received the data that the controller sends (i.e. genmon sends a request but no response is received). Photographs of your wiring may be needed. Also I never got a response on the connections on the Briggs side, is it native RS485 or do you have a converter of some type? |
Beta Was this translation helpful? Give feedback.
-
2nd set of logs is with the #2 dip switch turned off. and I'm back to getting zero information Per the "genmon briggs" youtube videos that you link in your wiki, he says it is a native rs485 and says we have to use "Use Modbus FC4 instead of FC3" flag. i am able to change many of the settings in the controller on the briggs side but I cannot change the baud rate or the parity. so we are stuck with even parity but that's how he set it up on the youtube vids you sent as well. I used Cat5 cable (~20ft) I test continuity before I used the wire after everything was hooked up. I wonder if it is an issue with the piHat? https://www.youtube.com/watch?v=Kcm8S2HIKFk starts at 10secs talking about RS485 then at 4:50 point on video he discusses the 2 wire hat |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
Perfect. I'm hoping not to switch to the 630. I'm just wondering if I need to try and set any of those other settings for the current serial connection? I'm just looking for a reason why it's not working. I went so far as to pull another RPI 4B out of another application swap cards throw that hat on it hoping that maybe it was a bad RPI however it did exactly the same thing. I then went and got a traditional serial cable and plugged it in to the DB9 port and ran jumpers off of the appropriate pins check for continuity to make sure everything was connected and same results. I've checked loopback I've checked serial. I guess at this point I'm in a holding pattern until the four-wire shows up. two wire 485 setup is actually three wires because one goes to ground. However the four wire setup does not allow for a ground wire. My question, is the ground wire not required on the four wire setup? |
Beta Was this translation helpful? Give feedback.
-
you don't technically need a ground for either of them since it is a differential interface, however a ground certainly will not hurt. A 1 or a 0 is determined by the difference in voltage between A and B so you don't need to be on the same ground reference (e.g. the difference between A and Ground and B and Ground). Your last few logs did not show the validation errors, only timeout errors. Did something change? That may be a clue. Before you change away from serial another data point would be: do you see any difference in the serial communication stats failure if the cable is connected vs disconnected from the controller? |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
The last sentence is a test that would possibly shed some light on why you get validation errors sometimes and you do not at other times. If you get validation errors, do you also get them when you disconnect the cable from the Briggs controller? That is not a great sign about the 485 LED. I guess you don't have any other device that you could use to validate that the RS485 port actually works on the controller? |
Beta Was this translation helpful? Give feedback.
-
I think i was getting timeout errors because I wasn't connecting. jumper on pins 8/10 passes. the only way it passes a test is if it has switch 2 turned to ON. then it passes whether I'm jumpered or not. so I think the PiHat is not doing it's job. |
Beta Was this translation helpful? Give feedback.
-
I am not sure what you mean by "i was getting timeout errors because I wasn't connecting." I was not talking about a loopback test. I was referring to running genmon with serial, not TCP. When you ran genmon you said that switch 2 was off yet you still got validation (not timeout) errors? If that is true then this could be a clue as to why this is not working. Regarding a loopback test, what you describe above with the loopback is normal for two wire 485 with the receiver not always enabled (switch one off). With two wire the transmit wire and receive wires are connected so anything that is transmitted is received instantly, but if the received is disabled when transmitting the loopback will fail. This is great for a loopback, but is not desirable if the application (like genmon) was written for anything else besides 2 wire RS485 as it is not expecting to receive what is just sent out, but rather is is expecting to receive from another device (the controller) only. For loopback you want the receiver on (switch one one) while you transmit. If you set switch 1 on and turn switch 2 off, and switch 3 on, can you jumper across the db9 and run the loopback test? If you can then remove the DB9 jumper and disconnect the cable from the controller, then put the jumper on A-B at the far end of the cable, then run the loopback test again. This should allow you to do a loopback test through your cable. |
Beta Was this translation helpful? Give feedback.
-
i don't think it was connecting it was showing not connected with the exclamation point. If you set switch 1 on and turn switch 2 off, and switch 3 on, can you jumper across the db9 and run the loopback test? that is working but those settings aren't conducive to genmon i guess. so we need to figure something else out. I have a 4 wire and a different 2 wire arriving tomorrow we can try again then. Will I need to rerun setup or do anything different besides swap the piHats? |
Beta Was this translation helpful? Give feedback.
-
if you hover your mouse over the exclamation point it will give you more detail. If it says "Disconnected form server" that means that genmon is not running and the web interface can not communication with genmon.py. This occurs when you stop genmon but the web page is still in a browser window. That message has nothing to do with serial communications. If you have serial communication issues and you get and exclamation point the message will be something like "Not receiving data". Regarding the setup with a different Hat, probably not, but it really depends the Hat. Genmon does not know anything about RS232 or RS485 so there is nothing to do regarding genmon. The Hat may requires something, but if it has an "auto enable transmitter" switch, just set that. The two test you ran have validated that data is being passed form the pi through the Hat and looped back through the cable. The loopback tests use the same code for serial communication that genmon does. Now, if you set switch one to off and try to communicate with the controller and it does not work, to me this is a strong indication that the controller could be the problem. That with the fact that the 485 LED never comes on is not a good picture for your controller working with RS485. We can still test with the new Hat and the WR630 if you like. |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
I am glad it is working. did you try more than one hat? and you never got the hat working correct? I am going to close this issue but feel free to post to this thread with follow up status or questions. |
Beta Was this translation helpful? Give feedback.
-
Multiple Pihats were tried and configured no success. Also for anyone reading this later the status LED on the generator for the RS485 protocol doesn't light up even once connected and receiving information at least on my unit. |
Beta Was this translation helpful? Give feedback.
That was the most unintuitive device ever.
I don't know how I finally got it working but I did.
This is using the w630.
I tried 3 different hat devices. This worked once I got the server situated. Wow. What a pain.
It claims to have wifi, and 2 ethernet ports. So I'm wondering if I can do what I asked before and have it be on a sepetate network.
Thinking about that.... The pi needs to be on 2 networks I guess not the 630. W630 hardwired into the pi via ethernet. The pi talks to my network via wifi-or via some USB to ethernet to keep everything hardwired?