From 1989b2564296a3b8ed9fa44518c92b96b3e16c39 Mon Sep 17 00:00:00 2001 From: Yao Wei Date: Sat, 1 Jun 2024 17:40:54 +0800 Subject: [PATCH] usb_power_delivery: support Revision 3.2 Extended Data --- decoders/usb_power_delivery/pd.py | 107 +++++++++++++++++++++++++----- 1 file changed, 90 insertions(+), 17 deletions(-) diff --git a/decoders/usb_power_delivery/pd.py b/decoders/usb_power_delivery/pd.py index 87ed5546..2eaf85ef 100644 --- a/decoders/usb_power_delivery/pd.py +++ b/decoders/usb_power_delivery/pd.py @@ -40,19 +40,22 @@ 6: 'PS RDY', 7: 'GET SOURCE CAP', 8: 'GET SINK CAP', - 9: 'DR SWAP', - 10: 'PR SWAP', - 11: 'VCONN SWAP', - 12: 'WAIT', - 13: 'SOFT RESET', - 14: 'reserved', - 15: 'reserved', - 16: 'Not Supported', + 9: 'DR_Swap', + 10: 'PR_Swap', + 11: 'VCONN_Swap', + 12: 'Wait', + 13: 'Soft_Reset', + 14: 'Data_Reset', + 15: 'Data_Reset_Complete', + 16: 'Not_Supported', 17: 'Get_Source_Cap_Extended', 18: 'Get_Status', 19: 'FR_Swap', 20: 'Get_PPS_Status', 21: 'Get_Country_Codes', + 22: 'Get_Sink_Cap_Extended', + 23: 'Get_Source_Info', + 24: 'Get_Revision' } # Data message type @@ -64,9 +67,37 @@ 5: 'Battery_Status', 6: 'Alert', 7: 'Get_Country_Info', + 8: 'Enter_USB', + 9: 'EPR_Request', + 10: 'EPR_Mode', + 11: 'Source_Info', + 12: 'Revision', 15: 'VDM' } +# Extended message type +EXT_TYPES = { + 1: 'Source_Capabilities_Extended', + 2: 'Status', + 3: 'Get_Battery_Cap', + 4: 'Get_Battery_Status', + 5: 'Battery_Capabilities', + 6: 'Get_Manufacturer_Info', + 7: 'Manufacturer_Info', + 8: 'Security_Request', + 9: 'Security_Response', + 10: 'Firmware_Update_Request', + 11: 'Firmware_Update_Response', + 12: 'PPS_Status', + 13: 'Country_Info', + 14: 'Country_Codes', + 15: 'Sink_Capabilities_Extended', + 16: 'Extended_Control', + 17: 'EPR_Source_Capabilities', + 18: 'EPR_Sink_Capabilities', + 30: 'Vendor_Defined_Extended' +} + # 4b5b encoding of the symbols DEC4B5B = [ 0x10, # Error 00000 @@ -377,6 +408,10 @@ def get_bist(self, idx, data): return 'mode %s' % (mode_name) if idx == 0 else 'invalid BRO' def putpayload(self, s0, s1, idx): + if self.head_ext() == 1: + # TODO: to decode Extended Message Types + return + t = self.head_type() txt = '['+str(idx+1)+'] ' if t == 2: @@ -396,14 +431,21 @@ def puthead(self): if self.head_data_role() != self.head_power_role(): role += '/DFP' if self.head_data_role() else '/UFP' t = self.head_type() - if self.head_count() == 0: - shortm = CTRL_TYPES[t] + if self.head_ext() == 1: + shortm = EXT_TYPES[t] if t in EXT_TYPES else 'EXT???' + elif self.head_count() == 0: + shortm = CTRL_TYPES[t] if t in CTRL_TYPES else 'CTR???' else: shortm = DATA_TYPES[t] if t in DATA_TYPES else 'DAT???' longm = '(r{:d}) {:s}[{:d}]: {:s}'.format(self.head_rev(), role, self.head_id(), shortm) self.putx(0, -1, [ann_type, [longm, shortm]]) self.text += longm + + def head_ext(self): + if self.head_rev() == 3: + return (self.head >> 15) & 1 + return 0 def head_id(self): return (self.head >> 9) & 7 @@ -418,11 +460,16 @@ def head_rev(self): return ((self.head >> 6) & 3) + 1 def head_type(self): + if self.head_rev() == 3: + return self.head & 0x1F return self.head & 0xF def head_count(self): return (self.head >> 12) & 7 + def exthead_size(self): + return (self.exthead) & 511 + def putx(self, s0, s1, data): self.put(self.edges[s0], self.edges[s1], self.out_ann, data) @@ -430,8 +477,12 @@ def putwarn(self, longm, shortm): self.putx(0, -1, [8, [longm, shortm]]) def compute_crc32(self): - bdata = struct.pack('