4037867b7d
* [BFN] Updated platform APIs impl
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* Extended BFN platform SFP APIs implementation
* Update sfp.py
* [BFN] Extended SFP platform plugin implementation
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* [BFN] Extended Fans platform plugin implementation
* [BFN] divided classes Fan and FanDrawer into 2 files
* Signed-off-by: Vadym Yashchenko <vadymx.yashchenko@intel.com>
What I did
Add get_model() function
Add get_low_critical_threshold() function
Change __get(...) function.
How I did it
Differnece from previous implementation of __get(...) function is return real value or -9999.9 if value is not provided by thrift API
* Add get_presence() function and revised __get() function
Signed-off-by: Vadym Yashchenko <vadymx.yashchenko@intel.com>
* [BFN] Updated PSU platform APIs impl
Signed-off-by: Dmytro Lytvynenko <dmytrox.lytvynenko@intel.com>
* Added BFN PSU cache (#9)
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* [BFN] Fans and Fantray platform APIs update (#7)
* [BFN] Updated SFP platform APIs (#10)
Signed-off-by: Volodymyr Boyko <volodymyrx.boiko@intel.com>
* [BFN] Updated platform API for thermal (#8)
* Signed-off-by: Vadym Yashchenko <vadymx.yashchenko@intel.com>
* Revert "[BFN] Fans and Fantray platform APIs update (#7)" (#11)
This reverts commit c62a733443be49cbe4ba2d06047aac7516f0495e.
* Add support health monitor system (#15)
Signed-off-by: Petro Bratash <petrox.bratash@intel.com>
* Update chassis.py
* [BFN] Updated FANs and FAN Tray platform API (#14)
* Fix fix_alignment (#17)
Signed-off-by: Petro Bratash <petrox.bratash@intel.com>
* [BFN] Improvement show environment (#16)
* Added PSU temperature skip into platform.json (#18)
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* Do not skip psud on Newport
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* [BFN] fix fan status from Not OK to Ok (#19)
* [BFN] Updated SFP platform plugin (#13)
Signed-off-by: Volodymyr Boyko <volodymyrx.boiko@intel.com>
* [DPB] Fix typo for Ethernet0 2x200G[100G,40G] breakout mode (#21)
Signed-off-by: Mykola Gerasymenko <mykolax.gerasymenko@intel.com>
* [barefoot] Tmp fix vendor_rev (#22)
Signed-off-by: Volodymyr Boyko <volodymyrx.boiko@intel.com>
* Fixed python issues in sonic_platform/fan_drawer.py
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* Updated fan_drawer.py
* Fixing trailing white spaces in fan_drawer.py
* [BFN] Fix thrift for SFPs API
Signed-off-by: Volodymyr Boyko <volodymyrx.boiko@intel.com>
* In platform.json, replaced 'false' with '0' to workaround ast.literal_eval() issue
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* [Newport] Thermal manager (#23)
* Signed-off-by: Vadym Yashchenko <vadymx.yashchenko@intel.com>
* Revert "In platform.json, replaced 'false' with '0' to workaround ast.literal_eval() issue"
This reverts commit 1e73127830
.
* Removed 'controllable' options from platform.json to fix factory default config generation
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
* Update thermal_manager.py
* Migrated SFP plugin to sonic_xcvr API (#30)
Signed-off-by: Andriy Kokhan <andriyx.kokhan@intel.com>
Co-authored-by: KostiantynYarovyiBf <kostiantynx.yarovyi@intel.com>
Co-authored-by: Vadym Yashchenko <vadymx.yashchenko@intel.com>
Co-authored-by: Dmytro Lytvynenko <dmytrox.lytvynenko@intel.com>
Co-authored-by: Volodymyr Boiko <volodymyrx.boiko@intel.com>
Co-authored-by: Petro Bratash <petrox.bratash@intel.com>
Co-authored-by: Mykola Gerasymenko <mykolax.gerasymenko@intel.com>
155 lines
5.1 KiB
Python
155 lines
5.1 KiB
Python
try:
|
|
import os
|
|
import sys
|
|
import errno
|
|
import datetime
|
|
import logging
|
|
import logging.config
|
|
import yaml
|
|
import re
|
|
|
|
sys.path.append(os.path.dirname(__file__))
|
|
|
|
if sys.version_info.major == 3:
|
|
from io import StringIO
|
|
else:
|
|
from cStringIO import StringIO
|
|
|
|
from sonic_platform_base.sonic_eeprom import eeprom_base
|
|
from sonic_platform_base.sonic_eeprom import eeprom_tlvinfo
|
|
|
|
from platform_thrift_client import thrift_try
|
|
except ImportError as e:
|
|
raise ImportError (str(e) + "- required module not found")
|
|
|
|
|
|
_platform_eeprom_map = {
|
|
"prod_name" : ("Product Name", "0x21", 12),
|
|
"odm_pcba_part_num" : ("Part Number", "0x22", 13),
|
|
"prod_ser_num" : ("Serial Number", "0x23", 12),
|
|
"ext_mac_addr" : ("Extended MAC Address Base", "0x24", 12),
|
|
"sys_mfg_date" : ("System Manufacturing Date", "0x25", 4),
|
|
"prod_ver" : ("Product Version", "0x26", 1),
|
|
"ext_mac_addr_size" : ("Extende MAC Address Size", "0x2A", 2),
|
|
"sys_mfger" : ("Manufacturer", "0x2B", 8)
|
|
}
|
|
|
|
_product_dict = {
|
|
"Montara" : "Wedge100BF-32X-O-AC-F-BF",
|
|
"Lower MAV" : "Wedge100BF-65X-O-AC-F-BF",
|
|
"Upper MAV" : "Wedge100BF-65X-O-AC-F-BF"
|
|
}
|
|
|
|
_EEPROM_SYMLINK = "/var/run/platform/eeprom/syseeprom"
|
|
_EEPROM_STATUS = "/var/run/platform/eeprom/status"
|
|
|
|
class Eeprom(eeprom_tlvinfo.TlvInfoDecoder):
|
|
def __init__(self):
|
|
with open(os.path.dirname(__file__) + "/logging.conf", 'r') as f:
|
|
config_dict = yaml.load(f, yaml.SafeLoader)
|
|
logging.config.dictConfig(config_dict)
|
|
|
|
if not os.path.exists(os.path.dirname(_EEPROM_SYMLINK)):
|
|
try:
|
|
os.makedirs(os.path.dirname(_EEPROM_SYMLINK))
|
|
except OSError as e:
|
|
if e.errno != errno.EEXIST:
|
|
raise
|
|
|
|
open(_EEPROM_SYMLINK, 'a').close()
|
|
with open(_EEPROM_STATUS, 'w') as f:
|
|
f.write("initializing..")
|
|
|
|
self.eeprom_path = _EEPROM_SYMLINK
|
|
super(Eeprom, self).__init__(self.eeprom_path, 0, _EEPROM_STATUS, True)
|
|
|
|
def sys_eeprom_get(client):
|
|
return client.pltfm_mgr.pltfm_mgr_sys_eeprom_get()
|
|
try:
|
|
platform_eeprom = thrift_try(sys_eeprom_get)
|
|
except Exception:
|
|
raise RuntimeError("eeprom.py: Initialization failed")
|
|
|
|
self.__eeprom_init(platform_eeprom)
|
|
|
|
def __eeprom_init(self, platform_eeprom):
|
|
with open(_EEPROM_STATUS, 'w') as f:
|
|
f.write("ok")
|
|
|
|
eeprom_params = ""
|
|
for attr, val in platform_eeprom.__dict__.items():
|
|
if val is None:
|
|
continue
|
|
|
|
elem = _platform_eeprom_map.get(attr)
|
|
if elem is None:
|
|
continue
|
|
|
|
if isinstance(val, str):
|
|
value = val.replace('\0', '')
|
|
else:
|
|
value = str(val)
|
|
|
|
if attr == "sys_mfg_date":
|
|
value = datetime.datetime.strptime(value, '%m-%d-%y').strftime('%m/%d/%Y 00:00:00')
|
|
|
|
product = _product_dict.get(value)
|
|
if product is not None:
|
|
value = product
|
|
if len(eeprom_params) > 0:
|
|
eeprom_params += ","
|
|
eeprom_params += "{0:s}={1:s}".format(elem[1], value)
|
|
|
|
orig_stdout = sys.stdout
|
|
sys.stdout = StringIO()
|
|
try:
|
|
eeprom_data = eeprom_tlvinfo.TlvInfoDecoder.set_eeprom(self, "", [eeprom_params])
|
|
finally:
|
|
decode_output = sys.stdout.getvalue()
|
|
sys.stdout = orig_stdout
|
|
|
|
eeprom_base.EepromDecoder.write_eeprom(self, eeprom_data)
|
|
self.__eeprom_tlv_dict = self.__parse_output(decode_output)
|
|
|
|
def __parse_output(self, decode_output):
|
|
EEPROM_DECODE_HEADLINES = 6
|
|
lines = decode_output.replace('\0', '').split('\n')
|
|
lines = lines[EEPROM_DECODE_HEADLINES:]
|
|
res = dict()
|
|
|
|
for line in lines:
|
|
try:
|
|
# match whitespace-separated tag hex, length and value (value is mathced with its whitespaces)
|
|
match = re.search('(0x[0-9a-fA-F]{2})([\s]+[\S]+[\s]+)([\S]+[\s]*[\S]*)', line)
|
|
if match is not None:
|
|
code = match.group(1)
|
|
value = match.group(3).rstrip('\0')
|
|
res[code] = value
|
|
except Exception:
|
|
pass
|
|
return res
|
|
|
|
def __tlv_get(self, code):
|
|
return self.__eeprom_tlv_dict.get("0x{:X}".format(code), 'N/A')
|
|
|
|
def system_eeprom_info(self):
|
|
return self.__eeprom_tlv_dict
|
|
|
|
def serial_number_str(self):
|
|
return self.__tlv_get(self._TLV_CODE_SERIAL_NUMBER)
|
|
|
|
def serial_str(self):
|
|
return self.serial_number_str()
|
|
|
|
def base_mac_addr(self):
|
|
return self.__tlv_get(self._TLV_CODE_MAC_BASE)
|
|
|
|
def part_number_str(self):
|
|
return self.__tlv_get(self._TLV_CODE_PART_NUMBER)
|
|
|
|
def modelstr(self):
|
|
return self.__tlv_get(self._TLV_CODE_PRODUCT_NAME)
|
|
|
|
def revision_str(self):
|
|
return self.__tlv_get(self._TLV_CODE_LABEL_REVISION)
|