-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Edgecore 4630/5835/7326/7816 API2.0 platform support (#10053)
* Initial pass of EdgeCore platform changes. * Remove libevent dependency from lldpd. * Remove python2 dependencies python3.7 force from platform install script. * Include usbmount support changes. * Add missing 4630 install file. * Update a few file permissions. Add umask line to Makefile. Specify python3.9 in install script. * Misc platform updates: - Add missing fan drawer component to sonic_platform - Remove kernel version specification from Makefile - Update to 4630 utility * - Fix file permissions on source files - Fix compile issue with 4630 driver modules (set_fs, get_fs, no longer supported in kernel 5.10) * Fix missing/extra parens in 4630 util script. * Fix indentation in fanutil.py. * Integrate deltas from Edgecore to ec_platform branch. * Installer update from Edgecore to resolve smbus serial console errors. * Update stable_size for warm boot. * Fix SFP dictionary key to match xcvrd. * - Add missing define in event.py files needed for xcvrd - Fix SFP info dict key for 7xxx switches * 5835 platform file updates including installer and 5835 utility. * 5835 fix for DMAR errors on serial console. * Don't skip starting thermalctld in the pmon container. * Revert several changes that were not related to platform. * Run thermalctld in pmon container. * Don't disable thermalctld in the pmon container. * Fix prints/parens in 7816 install utility. * - Incorporate 7816 changes from Edgecore - Fix 7326 driver file using old kernel function * Update kernel modules to use kernel_read(). * Fix compile errors with 7816 and 7326 driver modules. * Fix some indents preventing platform files from loading. * Update 7816 platform sfp dictionary to match field names in xcvrd. * Add missing service and util files for 7816. * Update file names, etc. based on full SKU for 7816. * Delete pddf files not needed. These were causing conflicts with API2.0 implementation. * Remove pddf files suggested by Edgecore that were preventing API2.0 support from starting. * Install API2.0 file instead of pddf. * Update 7326 mac service file to not use pddf. Fix syntax errors in 7326 utility script. * Fix sonic_platform setup file for 7326. * Fix syntax errors in python scripts. * Updates to 7326 platform files. * Fix some tab errors pulled down from master merge. * Remove pddf files that were added from previous merge. * Updates for 5835. * Fix missing command byte for 5835 psu status. * Fix permission bits on 4630 service files. * Update platforms to use new SFP refactoring. * Fix unused var warnings.
- Loading branch information
Showing
99 changed files
with
7,422 additions
and
4,357 deletions.
There are no files selected for viewing
2 changes: 1 addition & 1 deletion
2
.../accton/x86_64-accton_as4630_54pe-r0/Accton-AS4630-54PE/hx5-as4630-48x1G+4x25G+2x100G.bcm
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
stable_size=71303168 | ||
stable_size=76303168 | ||
|
||
#polarity/lanemap is using TH2 style. | ||
core_clock_frequency=893 | ||
|
66 changes: 0 additions & 66 deletions
66
device/accton/x86_64-accton_as4630_54pe-r0/pddf/pd-plugin.json
This file was deleted.
Oops, something went wrong.
Empty file.
2 changes: 2 additions & 0 deletions
2
device/accton/x86_64-accton_as4630_54pe-r0/sonic_platform/__init__.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
__all__ = [ "platform", "chassis", "sfp", "eeprom", "component", "psu", "thermal", "fan", "fan_drawer" ] | ||
from . import platform |
255 changes: 255 additions & 0 deletions
255
device/accton/x86_64-accton_as4630_54pe-r0/sonic_platform/chassis.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,255 @@ | ||
############################################################################# | ||
# Edgecore | ||
# | ||
# Module contains an implementation of SONiC Platform Base API and | ||
# provides the Chassis information which are available in the platform | ||
# | ||
############################################################################# | ||
|
||
import os | ||
import sys | ||
|
||
try: | ||
from sonic_platform_base.chassis_base import ChassisBase | ||
from .helper import APIHelper | ||
from .event import SfpEvent | ||
except ImportError as e: | ||
raise ImportError(str(e) + "- required module not found") | ||
|
||
NUM_FAN_TRAY = 3 | ||
NUM_FAN = 2 | ||
NUM_PSU = 2 | ||
NUM_THERMAL = 3 | ||
PORT_START = 49 | ||
PORT_END = 54 | ||
NUM_COMPONENT = 2 | ||
HOST_REBOOT_CAUSE_PATH = "/host/reboot-cause/" | ||
PMON_REBOOT_CAUSE_PATH = "/usr/share/sonic/platform/api_files/reboot-cause/" | ||
REBOOT_CAUSE_FILE = "reboot-cause.txt" | ||
PREV_REBOOT_CAUSE_FILE = "previous-reboot-cause.txt" | ||
HOST_CHK_CMD = "which systemctl > /dev/null 2>&1" | ||
SYSLED_FNODE = "/sys/class/leds/diag/brightness" | ||
SYSLED_MODES = { | ||
"0" : "STATUS_LED_COLOR_OFF", | ||
"1" : "STATUS_LED_COLOR_GREEN", | ||
"2" : "STATUS_LED_COLOR_AMBER", | ||
"5" : "STATUS_LED_COLOR_GREEN_BLINK" | ||
} | ||
|
||
|
||
class Chassis(ChassisBase): | ||
"""Platform-specific Chassis class""" | ||
|
||
def __init__(self): | ||
ChassisBase.__init__(self) | ||
self._api_helper = APIHelper() | ||
self.is_host = self._api_helper.is_host() | ||
|
||
self.config_data = {} | ||
|
||
self.__initialize_fan() | ||
self.__initialize_psu() | ||
self.__initialize_thermals() | ||
self.__initialize_components() | ||
self.__initialize_sfp() | ||
self.__initialize_eeprom() | ||
|
||
def __initialize_sfp(self): | ||
from sonic_platform.sfp import Sfp | ||
for index in range(0, PORT_END): | ||
sfp = Sfp(index) | ||
self._sfp_list.append(sfp) | ||
self._sfpevent = SfpEvent(self._sfp_list) | ||
self.sfp_module_initialized = True | ||
|
||
def __initialize_fan(self): | ||
from sonic_platform.fan_drawer import FanDrawer | ||
for fant_index in range(NUM_FAN_TRAY): | ||
fandrawer = FanDrawer(fant_index) | ||
self._fan_drawer_list.append(fandrawer) | ||
self._fan_list.extend(fandrawer._fan_list) | ||
|
||
def __initialize_psu(self): | ||
from sonic_platform.psu import Psu | ||
for index in range(0, NUM_PSU): | ||
psu = Psu(index) | ||
self._psu_list.append(psu) | ||
|
||
def __initialize_thermals(self): | ||
from sonic_platform.thermal import Thermal | ||
for index in range(0, NUM_THERMAL): | ||
thermal = Thermal(index) | ||
self._thermal_list.append(thermal) | ||
|
||
def __initialize_eeprom(self): | ||
from sonic_platform.eeprom import Tlv | ||
self._eeprom = Tlv() | ||
|
||
def __initialize_components(self): | ||
from sonic_platform.component import Component | ||
for index in range(0, NUM_COMPONENT): | ||
component = Component(index) | ||
self._component_list.append(component) | ||
|
||
def __initialize_watchdog(self): | ||
from sonic_platform.watchdog import Watchdog | ||
self._watchdog = Watchdog() | ||
|
||
|
||
def __is_host(self): | ||
return os.system(HOST_CHK_CMD) == 0 | ||
|
||
def __read_txt_file(self, file_path): | ||
try: | ||
with open(file_path, 'r') as fd: | ||
data = fd.read() | ||
return data.strip() | ||
except IOError: | ||
pass | ||
return None | ||
|
||
def get_name(self): | ||
""" | ||
Retrieves the name of the device | ||
Returns: | ||
string: The name of the device | ||
""" | ||
|
||
return self._eeprom.get_product_name() | ||
|
||
def get_presence(self): | ||
""" | ||
Retrieves the presence of the Chassis | ||
Returns: | ||
bool: True if Chassis is present, False if not | ||
""" | ||
return True | ||
|
||
def get_status(self): | ||
""" | ||
Retrieves the operational status of the device | ||
Returns: | ||
A boolean value, True if device is operating properly, False if not | ||
""" | ||
return True | ||
|
||
def get_base_mac(self): | ||
""" | ||
Retrieves the base MAC address for the chassis | ||
Returns: | ||
A string containing the MAC address in the format | ||
'XX:XX:XX:XX:XX:XX' | ||
""" | ||
return self._eeprom.get_mac() | ||
|
||
def get_model(self): | ||
""" | ||
Retrieves the model number (or part number) of the device | ||
Returns: | ||
string: Model/part number of device | ||
""" | ||
return self._eeprom.get_pn() | ||
|
||
def get_serial(self): | ||
""" | ||
Retrieves the hardware serial number for the chassis | ||
Returns: | ||
A string containing the hardware serial number for this chassis. | ||
""" | ||
return self._eeprom.get_serial() | ||
|
||
def get_system_eeprom_info(self): | ||
""" | ||
Retrieves the full content of system EEPROM information for the chassis | ||
Returns: | ||
A dictionary where keys are the type code defined in | ||
OCP ONIE TlvInfo EEPROM format and values are their corresponding | ||
values. | ||
""" | ||
return self._eeprom.get_eeprom() | ||
|
||
def get_reboot_cause(self): | ||
""" | ||
Retrieves the cause of the previous reboot | ||
Returns: | ||
A tuple (string, string) where the first element is a string | ||
containing the cause of the previous reboot. This string must be | ||
one of the predefined strings in this class. If the first string | ||
is "REBOOT_CAUSE_HARDWARE_OTHER", the second string can be used | ||
to pass a description of the reboot cause. | ||
""" | ||
|
||
reboot_cause_path = (HOST_REBOOT_CAUSE_PATH + REBOOT_CAUSE_FILE) | ||
sw_reboot_cause = self._api_helper.read_txt_file( | ||
reboot_cause_path) or "Unknown" | ||
|
||
|
||
return ('REBOOT_CAUSE_NON_HARDWARE', sw_reboot_cause) | ||
|
||
def get_change_event(self, timeout=0): | ||
# SFP event | ||
if not self.sfp_module_initialized: | ||
self.__initialize_sfp() | ||
|
||
return self._sfpevent.get_sfp_event(timeout) | ||
|
||
def get_sfp(self, index): | ||
""" | ||
Retrieves sfp represented by (1-based) index <index> | ||
Args: | ||
index: An integer, the index (1-based) of the sfp to retrieve. | ||
The index should be the sequence of a physical port in a chassis, | ||
starting from 1. | ||
For example, 1 for Ethernet0, 2 for Ethernet4 and so on. | ||
Returns: | ||
An object dervied from SfpBase representing the specified sfp | ||
""" | ||
sfp = None | ||
if not self.sfp_module_initialized: | ||
self.__initialize_sfp() | ||
|
||
try: | ||
# The index will start from 1 | ||
sfp = self._sfp_list[index-1] | ||
except IndexError: | ||
sys.stderr.write("SFP index {} out of range (1-{})\n".format( | ||
index, len(self._sfp_list))) | ||
return sfp | ||
|
||
def get_position_in_parent(self): | ||
""" | ||
Retrieves 1-based relative physical position in parent device. If the agent cannot determine the parent-relative position | ||
for some reason, or if the associated value of entPhysicalContainedIn is '0', then the value '-1' is returned | ||
Returns: | ||
integer: The 1-based relative physical position in parent device or -1 if cannot determine the position | ||
""" | ||
return -1 | ||
|
||
def is_replaceable(self): | ||
""" | ||
Indicate whether this device is replaceable. | ||
Returns: | ||
bool: True if it is replaceable. | ||
""" | ||
return False | ||
|
||
|
||
def initizalize_system_led(self): | ||
return True | ||
|
||
def get_status_led(self): | ||
val = self._api_helper.read_txt_file(SYSLED_FNODE) | ||
return SYSLED_MODES[val] if val in SYSLED_MODES else "UNKNOWN" | ||
|
||
def set_status_led(self, color): | ||
mode = None | ||
for key, val in SYSLED_MODES.items(): | ||
if val == color: | ||
mode = key | ||
break | ||
if mode is None: | ||
return False | ||
else: | ||
return self._api_helper.write_txt_file(SYSLED_FNODE, mode) | ||
|
Oops, something went wrong.