add Modbus response forwarding

This commit is contained in:
Stefan Allius
2024-05-19 12:23:58 +02:00
parent d25173e591
commit 282a459ef0
3 changed files with 16 additions and 16 deletions

View File

@@ -42,7 +42,6 @@ class Talent(Message):
self.contact_name = b''
self.contact_mail = b''
self.db = InfosG3()
self.forward_modbus_resp = False
self.switch = {
0x00: self.msg_contact_info,
0x13: self.msg_ota_update,
@@ -124,7 +123,6 @@ class Talent(Message):
return
def send_modbus_cb(self, modbus_pdu: bytearray):
self.forward_modbus_resp = False
self.__build_header(0x70, 0x77)
self._send_buffer += b'\x00\x01\xa3\x28' # fixme
self._send_buffer += struct.pack('!B', len(modbus_pdu))
@@ -394,11 +392,11 @@ class Talent(Message):
self.header_len+self.data_len]
if self.ctrl.is_req():
if not self.remoteStream.mb.recv_req(data[hdr_len:]):
if not self.remoteStream.mb.recv_req(data[hdr_len:],
self.msg_forward):
self.inc_counter('Invalid_Msg_Format')
else:
self.inc_counter('Modbus_Command')
self.remoteStream.forward_modbus_resp = True
elif self.ctrl.is_ind():
# logger.debug(f'Modbus Ind MsgLen: {modbus_len}')
self.modbus_elms = 0
@@ -408,14 +406,15 @@ class Talent(Message):
if update:
self.new_data[key] = True
self.modbus_elms += 1 # count for unit tests
if not self.forward_modbus_resp:
return
return
else:
logger.warning('Unknown Ctrl')
self.inc_counter('Unknown_Ctrl')
self.forward(self._recv_buffer, self.header_len+self.data_len)
def msg_forward(self):
self.forward(self._recv_buffer, self.header_len+self.data_len)
def msg_unknown(self):
logger.warning(f"Unknow Msg: ID:{self.msg_id}")
self.inc_counter('Unknown_Msg')

View File

@@ -60,7 +60,6 @@ class SolarmanV5(Message):
self.snr = 0
self.db = InfosG3P()
self.time_ofs = 0
self.forward_modbus_resp = False
self.forward_at_cmd_resp = False
self.switch = {
@@ -303,7 +302,6 @@ class SolarmanV5(Message):
self.__finish_send_msg()
def send_modbus_cb(self, pdu: bytearray):
self.forward_modbus_resp = False
self.__build_header(0x4510)
self._send_buffer += struct.pack('<BHLLL', self.MB_RTU_CMD,
0x2b0, 0, 0, 0)
@@ -432,14 +430,14 @@ class SolarmanV5(Message):
self.inc_counter('AT_Command')
self.forward_at_cmd_resp = True
elif ftype == self.MB_RTU_CMD:
if not self.remoteStream.mb.recv_req(data[15:]):
if not self.remoteStream.mb.recv_req(data[15:],
self.__forward_msg()):
self.inc_counter('Invalid_Msg_Format')
else:
self.inc_counter('Modbus_Command')
self.remoteStream.forward_modbus_resp = True
return
self.__forward_msg()
# self.__send_ack_rsp(0x1510, ftype)
def msg_command_rsp(self):
data = self._recv_buffer[self.header_len:
@@ -467,9 +465,7 @@ class SolarmanV5(Message):
if inv_update:
self.__build_model_name()
if not self.forward_modbus_resp:
return
return
self.__forward_msg()
def msg_hbeat_ind(self):

View File

@@ -71,6 +71,7 @@ class Modbus():
self.__build_crc_tab(CRC_POLY)
self.que = asyncio.Queue(100)
self.snd_handler = snd_handler
self.rsp_handler = None
self.timeout = timeout
self.last_addr = 0
self.last_fcode = 0
@@ -93,7 +94,6 @@ class Modbus():
# logging.debug(f'Modbus stop timer {self}')
if self.tim:
self.tim.cancel()
self.get_next_req()
def timeout_cb(self):
self.req_pend = False
@@ -167,6 +167,7 @@ class Modbus():
return
first_reg = self.last_reg # save last_reg before sending next pdu
self.stop_timer() # stop timer and send next pdu
for i in range(0, elmlen):
addr = first_reg+i
if addr in self.map:
@@ -194,6 +195,10 @@ class Modbus():
else:
self.stop_timer()
if self.rsp_handler:
self.rsp_handler()
self.get_next_req()
def check_crc(self, msg) -> bool:
return 0 == self.__calc_crc(msg)