mirror of https://github.com/arendst/Tasmota.git
Matter log unknown opcodes (#18379)
This commit is contained in:
parent
4b272083d6
commit
3354e2acbf
|
@ -77,7 +77,11 @@ class Matter_Commisioning_Context
|
||||||
end
|
end
|
||||||
|
|
||||||
tasmota.log("MTR: received message " + matter.inspect(msg), 3)
|
tasmota.log("MTR: received message " + matter.inspect(msg), 3)
|
||||||
if msg.opcode == 0x20
|
if msg.opcode == 0x10
|
||||||
|
return self.parse_MsgCounterSyncReq(msg)
|
||||||
|
elif msg.opcode == 0x11
|
||||||
|
return self.parse_MsgCounterSyncRsp(msg)
|
||||||
|
elif msg.opcode == 0x20
|
||||||
return self.parse_PBKDFParamRequest(msg)
|
return self.parse_PBKDFParamRequest(msg)
|
||||||
elif msg.opcode == 0x22
|
elif msg.opcode == 0x22
|
||||||
return self.parse_Pake1(msg)
|
return self.parse_Pake1(msg)
|
||||||
|
@ -89,6 +93,10 @@ class Matter_Commisioning_Context
|
||||||
return self.parse_Sigma3(msg)
|
return self.parse_Sigma3(msg)
|
||||||
elif msg.opcode == 0x40
|
elif msg.opcode == 0x40
|
||||||
return self.parse_StatusReport(msg)
|
return self.parse_StatusReport(msg)
|
||||||
|
else
|
||||||
|
import string
|
||||||
|
tasmota.log(string.format("MTR: >????????? Unknown OpCode (secure channel) %02X", msg.opcode), 2)
|
||||||
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
return false
|
return false
|
||||||
|
@ -679,9 +687,33 @@ class Matter_Commisioning_Context
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#############################################################
|
||||||
|
# placeholder, nothing to run for now
|
||||||
def parse_StatusReport(msg)
|
def parse_StatusReport(msg)
|
||||||
var session = msg.session
|
var session = msg.session
|
||||||
tasmota.log("MTR: StatusReport = "+msg.raw[msg.app_payload_idx..].tohex(), 2)
|
tasmota.log("MTR: >Status "+msg.raw[msg.app_payload_idx..].tohex(), 2)
|
||||||
|
return false # we don't explicitly ack the message
|
||||||
|
end
|
||||||
|
|
||||||
|
#############################################################
|
||||||
|
# MsgCounterSyncReq
|
||||||
|
#
|
||||||
|
# Not yet implemented
|
||||||
|
def parse_MsgCounterSyncReq(msg)
|
||||||
|
import string
|
||||||
|
var session = msg.session
|
||||||
|
tasmota.log(string.format("MTR: >????????? MsgCounterSyncReq not implemented %s", msg.raw[msg.app_payload_idx..].tohex()), 2)
|
||||||
|
return false # we don't explicitly ack the message
|
||||||
|
end
|
||||||
|
|
||||||
|
#############################################################
|
||||||
|
# MsgCounterSyncRsp
|
||||||
|
#
|
||||||
|
# Not yet implemented
|
||||||
|
def parse_MsgCounterSyncRsp(msg)
|
||||||
|
import string
|
||||||
|
var session = msg.session
|
||||||
|
tasmota.log(string.format("MTR: >????????? MsgCounterSyncRsp not implemented %s", msg.raw[msg.app_payload_idx..].tohex()), 2)
|
||||||
return false # we don't explicitly ack the message
|
return false # we don't explicitly ack the message
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -375,13 +375,19 @@ class Matter_Session : Matter_Expirable
|
||||||
def is_CASE() return self.mode == self._CASE end
|
def is_CASE() return self.mode == self._CASE end
|
||||||
|
|
||||||
#############################################################
|
#############################################################
|
||||||
# Register the frabric as complete (end of commissioning)
|
# Assign a new fabric index
|
||||||
def fabric_completed()
|
def assign_fabric_index()
|
||||||
self._fabric.set_no_expiration()
|
|
||||||
self._fabric.set_persist(true)
|
|
||||||
if (self._fabric.get_fabric_index() == nil)
|
if (self._fabric.get_fabric_index() == nil)
|
||||||
self._fabric.set_fabric_index(self._store.next_fabric_idx())
|
self._fabric.set_fabric_index(self._store.next_fabric_idx())
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
#############################################################
|
||||||
|
# Register the fabric as complete (end of commissioning)
|
||||||
|
def fabric_completed()
|
||||||
|
self._fabric.set_no_expiration()
|
||||||
|
self._fabric.set_persist(true)
|
||||||
|
self.assign_fabric_index()
|
||||||
self._store.add_fabric(self._fabric)
|
self._store.add_fabric(self._fabric)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -389,6 +395,7 @@ class Matter_Session : Matter_Expirable
|
||||||
# Register the frabric as complete (end of commissioning)
|
# Register the frabric as complete (end of commissioning)
|
||||||
def fabric_candidate()
|
def fabric_candidate()
|
||||||
self._fabric.set_expire_in_seconds(120) # expire in 2 minutes
|
self._fabric.set_expire_in_seconds(120) # expire in 2 minutes
|
||||||
|
self.assign_fabric_index()
|
||||||
self._store.add_fabric(self._fabric)
|
self._store.add_fabric(self._fabric)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
|
@ -186,7 +186,7 @@ be_local_closure(Matter_UI_web_sensor, /* name */
|
||||||
/* K12 */ be_nested_str_weak(content_send),
|
/* K12 */ be_nested_str_weak(content_send),
|
||||||
/* K13 */ be_nested_str_weak(format),
|
/* K13 */ be_nested_str_weak(format),
|
||||||
/* K14 */ be_nested_str_weak(_X3Cdiv_X20style_X3D_X27text_X2Dalign_X3Aright_X3Bfont_X2Dsize_X3A11px_X3Bcolor_X3A_X23aaa_X3B_X27_X3E_X25s_X3C_X2Fdiv_X3E),
|
/* K14 */ be_nested_str_weak(_X3Cdiv_X20style_X3D_X27text_X2Dalign_X3Aright_X3Bfont_X2Dsize_X3A11px_X3Bcolor_X3A_X23aaa_X3B_X27_X3E_X25s_X3C_X2Fdiv_X3E),
|
||||||
/* K15 */ be_nested_str_weak(No_X20active_X20associaition),
|
/* K15 */ be_nested_str_weak(No_X20active_X20association),
|
||||||
/* K16 */ be_const_int(1),
|
/* K16 */ be_const_int(1),
|
||||||
/* K17 */ be_nested_str_weak(_X20active_X20association),
|
/* K17 */ be_nested_str_weak(_X20active_X20association),
|
||||||
/* K18 */ be_nested_str_weak(s),
|
/* K18 */ be_nested_str_weak(s),
|
||||||
|
@ -907,7 +907,7 @@ be_local_closure(Matter_UI_show_commissioning_info, /* name */
|
||||||
0, /* has sup protos */
|
0, /* has sup protos */
|
||||||
NULL, /* no sub protos */
|
NULL, /* no sub protos */
|
||||||
1, /* has constants */
|
1, /* has constants */
|
||||||
( &(const bvalue[18]) { /* constants */
|
( &(const bvalue[20]) { /* constants */
|
||||||
/* K0 */ be_nested_str_weak(webserver),
|
/* K0 */ be_nested_str_weak(webserver),
|
||||||
/* K1 */ be_nested_str_weak(string),
|
/* K1 */ be_nested_str_weak(string),
|
||||||
/* K2 */ be_nested_str_weak(device),
|
/* K2 */ be_nested_str_weak(device),
|
||||||
|
@ -917,19 +917,21 @@ be_local_closure(Matter_UI_show_commissioning_info, /* name */
|
||||||
/* K6 */ be_const_int(0),
|
/* K6 */ be_const_int(0),
|
||||||
/* K7 */ be_nested_str_weak(content_send),
|
/* K7 */ be_nested_str_weak(content_send),
|
||||||
/* K8 */ be_nested_str_weak(format),
|
/* K8 */ be_nested_str_weak(format),
|
||||||
/* K9 */ be_nested_str_weak(_X3Cfieldset_X3E_X3Clegend_X3E_X3Cb_X3E_X26nbsp_X3B_X5B_X20Commissioning_X20open_X20for_X20_X25i_X20min_X20_X5D_X26nbsp_X3B_X3C_X2Fb_X3E_X3C_X2Flegend_X3E_X3Cp_X3E_X3C_X2Fp_X3E),
|
/* K9 */ be_nested_str_weak(_X3Cfieldset_X3E_X3Clegend_X3E_X3Cb_X3E_X26nbsp_X3BCommissioning_X20open_X20for_X20_X25i_X20min_X26nbsp_X3B_X3C_X2Fb_X3E_X3C_X2Flegend_X3E_X3Cp_X3E_X3C_X2Fp_X3E),
|
||||||
/* K10 */ be_nested_str_weak(compute_manual_pairing_code),
|
/* K10 */ be_nested_str_weak(compute_manual_pairing_code),
|
||||||
/* K11 */ be_nested_str_weak(_X3Cp_X3EManual_X20pairing_X20code_X3A_X3Cbr_X3E_X3Cb_X3E_X25s_X2D_X25s_X2D_X25s_X3C_X2Fb_X3E_X3C_X2Fp_X3E_X3Chr_X3E),
|
/* K11 */ be_nested_str_weak(_X3Cp_X3EManual_X20pairing_X20code_X3A_X3Cbr_X3E_X3Cb_X3E_X25s_X2D_X25s_X2D_X25s_X3C_X2Fb_X3E_X3C_X2Fp_X3E_X3Chr_X3E),
|
||||||
/* K12 */ be_const_int(3),
|
/* K12 */ be_const_int(3),
|
||||||
/* K13 */ be_const_int(2147483647),
|
/* K13 */ be_const_int(2147483647),
|
||||||
/* K14 */ be_nested_str_weak(compute_qrcode_content),
|
/* K14 */ be_nested_str_weak(_X3Cdiv_X3E_X3Ccenter_X3E),
|
||||||
/* K15 */ be_nested_str_weak(show_qrcode),
|
/* K15 */ be_nested_str_weak(compute_qrcode_content),
|
||||||
/* K16 */ be_nested_str_weak(_X3Cp_X3E_X20_X25s_X3C_X2Fp_X3E),
|
/* K16 */ be_nested_str_weak(show_qrcode),
|
||||||
/* K17 */ be_nested_str_weak(_X3Cp_X3E_X3C_X2Fp_X3E_X3C_X2Ffieldset_X3E_X3Cp_X3E_X3C_X2Fp_X3E),
|
/* K17 */ be_nested_str_weak(_X3Cp_X3E_X20_X25s_X3C_X2Fp_X3E),
|
||||||
|
/* K18 */ be_nested_str_weak(_X3C_X2Fdiv_X3E),
|
||||||
|
/* K19 */ be_nested_str_weak(_X3Cp_X3E_X3C_X2Fp_X3E_X3C_X2Ffieldset_X3E_X3Cp_X3E_X3C_X2Fp_X3E),
|
||||||
}),
|
}),
|
||||||
be_str_weak(show_commissioning_info),
|
be_str_weak(show_commissioning_info),
|
||||||
&be_const_str_solidified,
|
&be_const_str_solidified,
|
||||||
( &(const binstruction[56]) { /* code */
|
( &(const binstruction[66]) { /* code */
|
||||||
0xA4060000, // 0000 IMPORT R1 K0
|
0xA4060000, // 0000 IMPORT R1 K0
|
||||||
0xA40A0200, // 0001 IMPORT R2 K1
|
0xA40A0200, // 0001 IMPORT R2 K1
|
||||||
0x880C0102, // 0002 GETMBR R3 R0 K2
|
0x880C0102, // 0002 GETMBR R3 R0 K2
|
||||||
|
@ -970,22 +972,32 @@ be_local_closure(Matter_UI_show_commissioning_info, /* name */
|
||||||
0x94340A0D, // 0025 GETIDX R13 R5 R13
|
0x94340A0D, // 0025 GETIDX R13 R5 R13
|
||||||
0x7C200A00, // 0026 CALL R8 5
|
0x7C200A00, // 0026 CALL R8 5
|
||||||
0x7C180400, // 0027 CALL R6 2
|
0x7C180400, // 0027 CALL R6 2
|
||||||
0x88180102, // 0028 GETMBR R6 R0 K2
|
0x8C180307, // 0028 GETMET R6 R1 K7
|
||||||
0x8C180D0E, // 0029 GETMET R6 R6 K14
|
0x8C200508, // 0029 GETMET R8 R2 K8
|
||||||
0x7C180200, // 002A CALL R6 1
|
0x5828000E, // 002A LDCONST R10 K14
|
||||||
0x8C1C010F, // 002B GETMET R7 R0 K15
|
0x7C200400, // 002B CALL R8 2
|
||||||
0x5C240C00, // 002C MOVE R9 R6
|
0x7C180400, // 002C CALL R6 2
|
||||||
0x7C1C0400, // 002D CALL R7 2
|
0x88180102, // 002D GETMBR R6 R0 K2
|
||||||
0x8C1C0307, // 002E GETMET R7 R1 K7
|
0x8C180D0F, // 002E GETMET R6 R6 K15
|
||||||
0x8C240508, // 002F GETMET R9 R2 K8
|
0x7C180200, // 002F CALL R6 1
|
||||||
0x582C0010, // 0030 LDCONST R11 K16
|
0x8C1C0110, // 0030 GETMET R7 R0 K16
|
||||||
0x5C300C00, // 0031 MOVE R12 R6
|
0x5C240C00, // 0031 MOVE R9 R6
|
||||||
0x7C240600, // 0032 CALL R9 3
|
0x7C1C0400, // 0032 CALL R7 2
|
||||||
0x7C1C0400, // 0033 CALL R7 2
|
0x8C1C0307, // 0033 GETMET R7 R1 K7
|
||||||
0x8C1C0307, // 0034 GETMET R7 R1 K7
|
0x8C240508, // 0034 GETMET R9 R2 K8
|
||||||
0x58240011, // 0035 LDCONST R9 K17
|
0x582C0011, // 0035 LDCONST R11 K17
|
||||||
0x7C1C0400, // 0036 CALL R7 2
|
0x5C300C00, // 0036 MOVE R12 R6
|
||||||
0x80000000, // 0037 RET 0
|
0x7C240600, // 0037 CALL R9 3
|
||||||
|
0x7C1C0400, // 0038 CALL R7 2
|
||||||
|
0x8C1C0307, // 0039 GETMET R7 R1 K7
|
||||||
|
0x8C240508, // 003A GETMET R9 R2 K8
|
||||||
|
0x582C0012, // 003B LDCONST R11 K18
|
||||||
|
0x7C240400, // 003C CALL R9 2
|
||||||
|
0x7C1C0400, // 003D CALL R7 2
|
||||||
|
0x8C1C0307, // 003E GETMET R7 R1 K7
|
||||||
|
0x58240013, // 003F LDCONST R9 K19
|
||||||
|
0x7C1C0400, // 0040 CALL R7 2
|
||||||
|
0x80000000, // 0041 RET 0
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
|
@ -232,7 +232,9 @@ extern "C" {
|
||||||
int ret = br_ccm_reset(ccm_ctx, nonce, nonce_len, aad_len, data_len, tag_len);
|
int ret = br_ccm_reset(ccm_ctx, nonce, nonce_len, aad_len, data_len, tag_len);
|
||||||
if (ret == 0) { be_raise(vm, "value_error", "br_ccm_reset failed"); }
|
if (ret == 0) { be_raise(vm, "value_error", "br_ccm_reset failed"); }
|
||||||
|
|
||||||
|
if (aad_len > 0) {
|
||||||
br_ccm_aad_inject(ccm_ctx, aad, aad_len);
|
br_ccm_aad_inject(ccm_ctx, aad, aad_len);
|
||||||
|
}
|
||||||
br_ccm_flip(ccm_ctx);
|
br_ccm_flip(ccm_ctx);
|
||||||
|
|
||||||
be_return_nil(vm);
|
be_return_nil(vm);
|
||||||
|
|
Loading…
Reference in New Issue