rstrouse / relayEquipmentManager

A hardware controller for GPIO, I2c, SPI, and generic devices.
GNU General Public License v3.0
38 stars 19 forks source link

Sequent 4rel4in v4 - Feeds for digital input errors #75

Closed brentk7 closed 3 months ago

brentk7 commented 4 months ago

I have a Sequent 4rel4in v4 card and have tried to configure the inputs to toggle service mode in njsPC. As soon as I enable the feed, I start getting errors in the log as shown below. I have tried using both inDigital1.value and plain inDigital1 as I am not sure what the difference is between them - but they both give the same error. image

0|REM        | [28/06/2024, 13:25:50] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:50] info: [13:25:50] 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:50] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:4","typeId":1,"id":1,"params":["4"]}
0|REM        | [28/06/2024, 13:25:52] debug: 14 - Sequent 4rel4in v4 Executed read command 0x03 byte read:0x00
0|REM        | [28/06/2024, 13:25:52] debug: 14 - Sequent 4rel4in v4 Executed read command 0x00 byte read:0x01
0|REM        | [28/06/2024, 13:25:52] error: Error getting Sequent 4rel4in v4 digital input value for inDigital1.value
0|REM        | [28/06/2024, 13:25:52] error: Error getting Sequent 4rel4in v4 digital input value for inDigital2.value
0|REM        | [28/06/2024, 13:25:52] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:1 {"isOn":1,"latch":5000}
0|REM        | [28/06/2024, 13:25:52] info: [13:25:52] 192.168.20.230 PUT /state/device/i2c:1:1:1 {"isOn":1,"latch":5000}
0|REM        | [28/06/2024, 13:25:52] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:1","typeId":1,"id":1,"params":["1"]}
0|REM        | [28/06/2024, 13:25:52] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:2 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: [13:25:52] 192.168.20.230 PUT /state/device/i2c:1:1:2 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:2","typeId":1,"id":1,"params":["2"]}
0|REM        | [28/06/2024, 13:25:52] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:3 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: [13:25:52] 192.168.20.230 PUT /state/device/i2c:1:1:3 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:3","typeId":1,"id":1,"params":["3"]}
0|REM        | [28/06/2024, 13:25:52] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: [13:25:52] 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:52] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:4","typeId":1,"id":1,"params":["4"]}
0|REM        | [28/06/2024, 13:25:54] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:1 {"isOn":1,"latch":5000}
0|REM        | [28/06/2024, 13:25:54] info: [13:25:54] 192.168.20.230 PUT /state/device/i2c:1:1:1 {"isOn":1,"latch":5000}
0|REM        | [28/06/2024, 13:25:54] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:1","typeId":1,"id":1,"params":["1"]}
0|REM        | [28/06/2024, 13:25:54] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:2 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: [13:25:54] 192.168.20.230 PUT /state/device/i2c:1:1:2 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:2","typeId":1,"id":1,"params":["2"]}
0|REM        | [28/06/2024, 13:25:54] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:3 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: [13:25:54] 192.168.20.230 PUT /state/device/i2c:1:1:3 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:3","typeId":1,"id":1,"params":["3"]}
0|REM        | [28/06/2024, 13:25:54] verbose: 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: [13:25:54] 192.168.20.230 PUT /state/device/i2c:1:1:4 {"isOn":0}
0|REM        | [28/06/2024, 13:25:54] info: Setting device state {"type":"i2c","busId":1,"deviceId":1,"binding":"i2c:1:1:4","typeId":1,"id":1,"params":["4"]}
0|REM        | [28/06/2024, 13:25:55] debug: Persisting Configuration data... /home/brent/relayEquipmentManager/data/controllerConfig.json
0|REM        | [28/06/2024, 13:25:55] debug: 14 - Sequent 4rel4in v4 Executed read command 0x03 byte read:0x00
0|REM        | [28/06/2024, 13:25:55] debug: 14 - Sequent 4rel4in v4 Executed read command 0x00 byte read:0x01
0|REM        | [28/06/2024, 13:25:55] error: Error getting Sequent 4rel4in v4 digital input value for inDigital1.value
0|REM        | [28/06/2024, 13:25:55] error: Error getting Sequent 4rel4in v4 digital input value for inDigital2.value
brentk7 commented 4 months ago

Does anybody have any pointers on what I can do to troubleshoot or help fix this issue?

rstrouse commented 4 months ago

I will try to get to it later this week. Unfortunately, I do not have one of these boards so I need to see if Sequent changed the registers for the inputs in their code.

brentk7 commented 4 months ago

Much appreciated - please let me know if you need any info, logs or testing.

rstrouse commented 4 months ago

Update your relayEquipmentManager. I checked all the registers and the registers seem to match the 4rel4in from the Sequent codebase. It should be reading the correct i2c registers.

brentk7 commented 4 months ago

I have just pulled the latest version from github and am still getting the same error

rstrouse commented 3 months ago

Have you installed the cli from sequent to see if it works?

brentk7 commented 3 months ago

Yes - works fine from sequent cli and from sequent Node Red

rstrouse commented 3 months ago

I don't know why I was thinking that it was not able to retrieve the values from the device. As it turns out even your log shows a successful read of the register. However, the caught exception below reflects that it was not able to find the channel value for the input. I realized this last night and let it run all night pulling mock values.

Update your REM and let me know if it is doing its thing with the hardware.

brentk7 commented 3 months ago

Thanks that has fixed it. Just a note that the reaction with this is very slow (I have to hold the button in for at least a second). I assume this is due to some polling delays by REM?