Skip to content

Commit

Permalink
Parse 'Extended Specification compliance' as independent field (#112)
Browse files Browse the repository at this point in the history
Previously 'Extended Specification compliance' was added as part of "sfp_info_bulk", this will request all the vendors to update the related platform API implementation due to the width change of "sfp_info_bulk".

To avoid this, make it parsed separately, it will not impact vendors who haven't update the platform API implementation.
  • Loading branch information
keboliu authored Aug 11, 2020
1 parent f3f3573 commit 433dd1a
Showing 1 changed file with 11 additions and 5 deletions.
16 changes: 11 additions & 5 deletions sonic_platform_base/sonic_sfp/sff8436.py
Original file line number Diff line number Diff line change
Expand Up @@ -373,11 +373,6 @@ class sff8436InterfaceId(sffbase):
{'offset' : 3,
'type' : 'nested',
'decode' : specification_compliance},
'Extended Specification compliance':
{'offset' : 64,
'size':1,
'type' : 'enum',
'decode' : ext_specification_compliance},
'EncodingCodes':
{'offset':11,
'size':1,
Expand Down Expand Up @@ -456,6 +451,14 @@ class sff8436InterfaceId(sffbase):
'type': 'date'}
}

sfp_ext_specification_compliance = {
'Extended Specification compliance':
{'offset' : 0,
'size':1,
'type' : 'enum',
'decode' : ext_specification_compliance}
}

qsfp_dom_capability = {
'Tx_power_support':
{'offset': 0,
Expand Down Expand Up @@ -509,6 +512,9 @@ def parse_vendor_date(self, sn_raw_data, start_pos):
def parse_vendor_oui(self, sn_raw_data, start_pos):
return sffbase.parse(self, self.vendor_oui, sn_raw_data, start_pos)

def parse_ext_specification_compliance(self, sn_raw_data, start_pos):
return sffbase.parse(self, self.sfp_ext_specification_compliance, sn_raw_data, start_pos)

def parse_qsfp_dom_capability(self, sn_raw_data, start_pos):
return sffbase.parse(self, self.qsfp_dom_capability, sn_raw_data, start_pos)

Expand Down

0 comments on commit 433dd1a

Please sign in to comment.