[devices]: Marvell hwsku ET6448M 48x1G+4x10G Arm32 Mgmt switch (#3221)
* [platform/hwsku] Added Marvell Armhf 32 bit ET6448M 52x Board 48x1G and 4x10G Management switch Signed-off-by: Antony Rheneus <arheneus@marvell.com>
This commit is contained in:
parent
be9a63932a
commit
88af7f625a
@ -0,0 +1,45 @@
|
|||||||
|
{%- set default_cable = '300m' %}
|
||||||
|
|
||||||
|
{%- macro generate_port_lists(PORT_ALL) %}
|
||||||
|
{# Generate list of ports #}
|
||||||
|
{% for port_idx in range(0,32) %}
|
||||||
|
{% if PORT_ALL.append("Ethernet%d" % (port_idx * 4)) %}{% endif %}
|
||||||
|
{% endfor %}
|
||||||
|
{%- endmacro %}
|
||||||
|
|
||||||
|
{%- macro generate_buffer_pool_and_profiles() %}
|
||||||
|
"BUFFER_POOL": {
|
||||||
|
"ingress_lossless_pool": {
|
||||||
|
"size": "12766208",
|
||||||
|
"type": "ingress",
|
||||||
|
"mode": "dynamic"
|
||||||
|
},
|
||||||
|
"egress_lossless_pool": {
|
||||||
|
"size": "12766208",
|
||||||
|
"type": "egress",
|
||||||
|
"mode": "static"
|
||||||
|
},
|
||||||
|
"egress_lossy_pool": {
|
||||||
|
"size": "7326924",
|
||||||
|
"type": "egress",
|
||||||
|
"mode": "dynamic"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"BUFFER_PROFILE": {
|
||||||
|
"ingress_lossy_profile": {
|
||||||
|
"pool":"[BUFFER_POOL|ingress_lossless_pool]",
|
||||||
|
"size":"0",
|
||||||
|
"dynamic_th":"3"
|
||||||
|
},
|
||||||
|
"egress_lossless_profile": {
|
||||||
|
"pool":"[BUFFER_POOL|egress_lossless_pool]",
|
||||||
|
"size":"0",
|
||||||
|
"static_th":"12766208"
|
||||||
|
},
|
||||||
|
"egress_lossy_profile": {
|
||||||
|
"pool":"[BUFFER_POOL|egress_lossy_pool]",
|
||||||
|
"size":"1518",
|
||||||
|
"dynamic_th":"3"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{%- endmacro %}
|
@ -0,0 +1,53 @@
|
|||||||
|
# name lanes alias
|
||||||
|
Ethernet0 1 Ethernet0
|
||||||
|
Ethernet1 2 Ethernet1
|
||||||
|
Ethernet2 3 Ethernet2
|
||||||
|
Ethernet3 4 Ethernet3
|
||||||
|
Ethernet4 5 Ethernet4
|
||||||
|
Ethernet5 6 Ethernet5
|
||||||
|
Ethernet6 7 Ethernet6
|
||||||
|
Ethernet7 8 Ethernet7
|
||||||
|
Ethernet8 9 Ethernet8
|
||||||
|
Ethernet9 10 Ethernet9
|
||||||
|
Ethernet10 11 Ethernet10
|
||||||
|
Ethernet11 12 Ethernet11
|
||||||
|
Ethernet12 13 Ethernet12
|
||||||
|
Ethernet13 14 Ethernet13
|
||||||
|
Ethernet14 15 Ethernet14
|
||||||
|
Ethernet15 16 Ethernet15
|
||||||
|
Ethernet16 17 Ethernet16
|
||||||
|
Ethernet17 18 Ethernet17
|
||||||
|
Ethernet18 19 Ethernet18
|
||||||
|
Ethernet19 20 Ethernet19
|
||||||
|
Ethernet20 21 Ethernet20
|
||||||
|
Ethernet21 22 Ethernet21
|
||||||
|
Ethernet22 23 Ethernet22
|
||||||
|
Ethernet23 24 Ethernet23
|
||||||
|
Ethernet24 25 Ethernet24
|
||||||
|
Ethernet25 26 Ethernet25
|
||||||
|
Ethernet26 27 Ethernet26
|
||||||
|
Ethernet27 28 Ethernet27
|
||||||
|
Ethernet28 29 Ethernet28
|
||||||
|
Ethernet29 30 Ethernet29
|
||||||
|
Ethernet30 31 Ethernet30
|
||||||
|
Ethernet31 32 Ethernet31
|
||||||
|
Ethernet32 33 Ethernet32
|
||||||
|
Ethernet33 34 Ethernet33
|
||||||
|
Ethernet34 35 Ethernet34
|
||||||
|
Ethernet35 36 Ethernet35
|
||||||
|
Ethernet36 37 Ethernet36
|
||||||
|
Ethernet37 38 Ethernet37
|
||||||
|
Ethernet38 39 Ethernet38
|
||||||
|
Ethernet39 40 Ethernet39
|
||||||
|
Ethernet40 41 Ethernet40
|
||||||
|
Ethernet41 42 Ethernet41
|
||||||
|
Ethernet42 43 Ethernet42
|
||||||
|
Ethernet43 44 Ethernet43
|
||||||
|
Ethernet44 45 Ethernet44
|
||||||
|
Ethernet45 46 Ethernet45
|
||||||
|
Ethernet46 47 Ethernet46
|
||||||
|
Ethernet47 48 Ethernet47
|
||||||
|
Ethernet48 49 Ethernet48
|
||||||
|
Ethernet49 50 Ethernet49
|
||||||
|
Ethernet50 51 Ethernet50
|
||||||
|
Ethernet51 52 Ethernet51
|
@ -0,0 +1 @@
|
|||||||
|
switchMacAddress=00:50:43:ee:ee:ee
|
@ -0,0 +1,3 @@
|
|||||||
|
mode=1
|
||||||
|
hwId=et6448m
|
||||||
|
SAI_INIT_CONFIG_FILE=/usr/share/sonic/hwsku/profile.ini
|
10
device/marvell/armhf-marvell_et6448m_52x-r0/fancontrol
Executable file
10
device/marvell/armhf-marvell_et6448m_52x-r0/fancontrol
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
INTERVAL=10
|
||||||
|
DEVPATH=hwmon0=devices/platform/soc/soc:internal-regs/f1011000.i2c/i2c-0/0-002e hwmon1=devices/platform/soc/soc:internal-regs/f1011000.i2c/i2c-0/0-004a hwmon2=devices/platform/soc/soc:internal-regs/f1011000.i2c/i2c-0/0-004b
|
||||||
|
DEVNAME=hwmon0=adt7473 hwmon1=lm75a hwmon2=lm75a
|
||||||
|
FCTEMPS=hwmon0/device/pwm2=hwmon2/temp1_input hwmon0/device/pwm1=hwmon1/temp1_input
|
||||||
|
FCFANS=hwmon0/device/pwm2=hwmon0/device/fan2_input hwmon0/device/pwm1=hwmon0/device/fan1_input
|
||||||
|
MINTEMP=hwmon0/device/pwm2=20 hwmon0/device/pwm1=20
|
||||||
|
MAXTEMP=hwmon0/device/pwm2=60 hwmon0/device/pwm1=60
|
||||||
|
MINSTART=hwmon0/device/pwm2=150 hwmon0/device/pwm1=150
|
||||||
|
MINSTOP=hwmon0/device/pwm2=0 hwmon0/device/pwm1=0
|
||||||
|
|
@ -0,0 +1,13 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
try:
|
||||||
|
from sonic_eeprom import eeprom_tlvinfo
|
||||||
|
except ImportError, e:
|
||||||
|
raise ImportError (str(e) + "- required module not found")
|
||||||
|
|
||||||
|
|
||||||
|
class board(eeprom_tlvinfo.TlvInfoDecoder):
|
||||||
|
|
||||||
|
def __init__(self, name, path, cpld_root, ro):
|
||||||
|
self.eeprom_path = "/etc/sonic/eeprom"
|
||||||
|
super(board, self).__init__(self.eeprom_path, 0, '', True)
|
54
device/marvell/armhf-marvell_et6448m_52x-r0/plugins/psuutil.py
Executable file
54
device/marvell/armhf-marvell_et6448m_52x-r0/plugins/psuutil.py
Executable file
@ -0,0 +1,54 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import os.path
|
||||||
|
import subprocess
|
||||||
|
try:
|
||||||
|
from sonic_psu.psu_base import PsuBase
|
||||||
|
except ImportError as e:
|
||||||
|
raise ImportError (str(e) + "- required module not found")
|
||||||
|
|
||||||
|
class PsuUtil(PsuBase):
|
||||||
|
"""Platform-specific PSUutil class"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
PsuBase.__init__(self)
|
||||||
|
MAX_PSUS = 2
|
||||||
|
|
||||||
|
def get_num_psus(self):
|
||||||
|
MAX_PSUS = 2
|
||||||
|
return MAX_PSUS
|
||||||
|
|
||||||
|
def get_psu_status(self, index):
|
||||||
|
if index is None:
|
||||||
|
return False
|
||||||
|
|
||||||
|
cmdstatus, psustatus = subprocess.getstatusoutput('i2cget -y 0 0x41 0xa') #need to verify the cpld register logic
|
||||||
|
psustatus = int(psustatus, 16)
|
||||||
|
if cmdstatus == 0:
|
||||||
|
if index == 1:
|
||||||
|
psustatus = psustatus&4
|
||||||
|
if psustatus == 4 :
|
||||||
|
return True
|
||||||
|
if index == 2:
|
||||||
|
psustatus = psustatus&8
|
||||||
|
if psustatus == 8 :
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
def get_psu_presence(self, index):
|
||||||
|
if index is None:
|
||||||
|
return False
|
||||||
|
|
||||||
|
cmdstatus , psustatus = subprocess.getstatusoutput('i2cget -y 0 0x41 0xa') #need to verify the cpld register logic
|
||||||
|
psustatus = int(psustatus, 16)
|
||||||
|
if cmdstatus == 0:
|
||||||
|
if index == 1:
|
||||||
|
psustatus = psustatus&1
|
||||||
|
if psustatus == 1 :
|
||||||
|
return True
|
||||||
|
if index == 2:
|
||||||
|
psustatus = psustatus&2
|
||||||
|
if psustatus == 2 :
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
245
device/marvell/armhf-marvell_et6448m_52x-r0/plugins/sfputil.py
Executable file
245
device/marvell/armhf-marvell_et6448m_52x-r0/plugins/sfputil.py
Executable file
@ -0,0 +1,245 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
try:
|
||||||
|
import os
|
||||||
|
import time
|
||||||
|
import re
|
||||||
|
from sonic_sfp.sfputilbase import SfpUtilBase
|
||||||
|
except ImportError, e:
|
||||||
|
raise ImportError (str(e) + "- required module not found")
|
||||||
|
|
||||||
|
|
||||||
|
class SfpUtil(SfpUtilBase):
|
||||||
|
"""Platform specific sfputil class"""
|
||||||
|
|
||||||
|
_port_start = 49
|
||||||
|
_port_end = 52
|
||||||
|
ports_in_block = 4
|
||||||
|
|
||||||
|
_port_to_eeprom_mapping = {}
|
||||||
|
port_to_i2c_mapping = {
|
||||||
|
49 : 0,
|
||||||
|
50 : 0,
|
||||||
|
51 : 0,
|
||||||
|
52 : 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_qsfp_ports = range(_port_start, ports_in_block + 1)
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
# Override port_to_eeprom_mapping for class initialization
|
||||||
|
if not os.path.exists("/sys/class/gpio/gpio50/") :
|
||||||
|
os.system("echo 50 > /sys/class/gpio/gpiochip32/subsystem/export")
|
||||||
|
if not os.path.exists("/sys/class/gpio/gpio52/") :
|
||||||
|
os.system("echo 52 > /sys/class/gpio/gpiochip32/subsystem/export")
|
||||||
|
os.system("echo out > /sys/class/gpio/gpio50/direction")
|
||||||
|
os.system("echo out > /sys/class/gpio/gpio52/direction ")
|
||||||
|
|
||||||
|
if not os.path.exists("/sys/bus/i2c/devices/0-0050") :
|
||||||
|
os.system("echo optoe2 0x50 > /sys/bus/i2c/devices/i2c-0/new_device")
|
||||||
|
#os.system("echo optoe 0x50 > /sys/bus/i2c/devices/i2c-0/new_device")
|
||||||
|
|
||||||
|
#enable optic
|
||||||
|
os.system("i2cset -y -m 0x0f 0 0x41 0x5 0x00")
|
||||||
|
eeprom_path = '/sys/bus/i2c/devices/0-0050/eeprom'
|
||||||
|
for x in range(self.port_start, self.port_end + 1):
|
||||||
|
port_eeprom_path = eeprom_path.format(self.port_to_i2c_mapping[x])
|
||||||
|
self.port_to_eeprom_mapping[x] = port_eeprom_path
|
||||||
|
SfpUtilBase.__init__(self)
|
||||||
|
|
||||||
|
def reset(self, port_num):
|
||||||
|
# Check for invalid port_num
|
||||||
|
if port_num < self._port_start or port_num > self._port_end:
|
||||||
|
return False
|
||||||
|
|
||||||
|
path = "/sys/bus/i2c/devices/{0}-0050/sfp_port_reset"
|
||||||
|
port_ps = path.format(self.port_to_i2c_mapping[port_num+1])
|
||||||
|
|
||||||
|
try:
|
||||||
|
reg_file = open(port_ps, 'w')
|
||||||
|
except IOError as e:
|
||||||
|
print "Error: unable to open file: %s" % str(e)
|
||||||
|
return False
|
||||||
|
|
||||||
|
#toggle reset
|
||||||
|
reg_file.seek(0)
|
||||||
|
reg_file.write('1')
|
||||||
|
time.sleep(1)
|
||||||
|
reg_file.seek(0)
|
||||||
|
reg_file.write('0')
|
||||||
|
reg_file.close()
|
||||||
|
return True
|
||||||
|
|
||||||
|
def set_low_power_mode(self, port_nuM, lpmode):
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def get_low_power_mode(self, port_num):
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def get_presence(self, port_num):
|
||||||
|
# Check for invalid port_num
|
||||||
|
if port_num < self._port_start or port_num > self._port_end:
|
||||||
|
return False
|
||||||
|
prt = port_num % 49
|
||||||
|
prt = "{0:02b}".format(prt)
|
||||||
|
p = prt[0]
|
||||||
|
q = prt[1]
|
||||||
|
cmd1 = "echo " + q + " > /sys/class/gpio/gpio50/value"
|
||||||
|
cmd2 = "echo " + p + " > /sys/class/gpio/gpio52/value"
|
||||||
|
os.system(cmd1)
|
||||||
|
os.system(cmd2)
|
||||||
|
|
||||||
|
'''if port_num == 49 :
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio50/value")
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio52/value")
|
||||||
|
if port_num == 50 :
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio50/value")
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio52/value")
|
||||||
|
if port_num == 51 :
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio50/value")
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio52/value")
|
||||||
|
if port_num == 52:
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio50/value")
|
||||||
|
os.system("echo 0 > /sys/class/gpio/gpio52/value")'''
|
||||||
|
path = "/sys/bus/i2c/devices/0-0050/eeprom"
|
||||||
|
#port_ps = path.format(self.port_to_i2c_mapping[port_num+1])
|
||||||
|
|
||||||
|
try:
|
||||||
|
reg_file = open(path)
|
||||||
|
reg_file.seek(01)
|
||||||
|
reg_file.read(02)
|
||||||
|
except IOError as e:
|
||||||
|
#print "Error: unable to open file: %s" % str(e)
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
|
#reg_value = reg_file.readline().rstrip()
|
||||||
|
#if reg_value == '1':
|
||||||
|
# return True
|
||||||
|
|
||||||
|
return True
|
||||||
|
|
||||||
|
def read_porttab_mappings(self, porttabfile):
|
||||||
|
logical = []
|
||||||
|
logical_to_bcm = {}
|
||||||
|
logical_to_physical = {}
|
||||||
|
physical_to_logical = {}
|
||||||
|
last_fp_port_index = 0
|
||||||
|
last_portname = ""
|
||||||
|
first = 1
|
||||||
|
port_pos_in_file = 0
|
||||||
|
parse_fmt_port_config_ini = False
|
||||||
|
|
||||||
|
try:
|
||||||
|
f = open(porttabfile)
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
|
parse_fmt_port_config_ini = (os.path.basename(porttabfile) == "port_config.ini")
|
||||||
|
|
||||||
|
# Read the porttab file and generate dicts
|
||||||
|
# with mapping for future reference.
|
||||||
|
#
|
||||||
|
# TODO: Refactor this to use the portconfig.py module that now
|
||||||
|
# exists as part of the sonic-config-engine package.
|
||||||
|
title = []
|
||||||
|
for line in f:
|
||||||
|
line.strip()
|
||||||
|
if re.search("^#", line) is not None:
|
||||||
|
# The current format is: # name lanes alias index speed
|
||||||
|
# Where the ordering of the columns can vary
|
||||||
|
title = line.split()[1:]
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Parsing logic for 'port_config.ini' file
|
||||||
|
if (parse_fmt_port_config_ini):
|
||||||
|
# bcm_port is not explicitly listed in port_config.ini format
|
||||||
|
# Currently we assume ports are listed in numerical order according to bcm_port
|
||||||
|
# so we use the port's position in the file (zero-based) as bcm_port
|
||||||
|
portname = line.split()[0]
|
||||||
|
|
||||||
|
bcm_port = str(port_pos_in_file)
|
||||||
|
#print("portname " + portname)
|
||||||
|
|
||||||
|
if "index" in title:
|
||||||
|
fp_port_index = int(line.split()[title.index("index")])
|
||||||
|
# Leave the old code for backward compatibility
|
||||||
|
elif len(line.split()) >= 4:
|
||||||
|
fp_port_index = int(line.split()[3])
|
||||||
|
else:
|
||||||
|
fp_port_index = portname.split("Ethernet").pop()
|
||||||
|
fp_port_index = int(fp_port_index.split("s").pop(0))+1
|
||||||
|
#print(fp_port_index)
|
||||||
|
else: # Parsing logic for older 'portmap.ini' file
|
||||||
|
(portname, bcm_port) = line.split("=")[1].split(",")[:2]
|
||||||
|
|
||||||
|
fp_port_index = portname.split("Ethernet").pop()
|
||||||
|
fp_port_index = int(fp_port_index.split("s").pop(0))+1
|
||||||
|
|
||||||
|
if ((len(self.sfp_ports) > 0) and (fp_port_index not in self.sfp_ports)):
|
||||||
|
continue
|
||||||
|
|
||||||
|
if first == 1:
|
||||||
|
# Initialize last_[physical|logical]_port
|
||||||
|
# to the first valid port
|
||||||
|
last_fp_port_index = fp_port_index
|
||||||
|
last_portname = portname
|
||||||
|
first = 0
|
||||||
|
|
||||||
|
logical.append(portname)
|
||||||
|
|
||||||
|
logical_to_bcm[portname] = "xe" + bcm_port
|
||||||
|
logical_to_physical[portname] = [fp_port_index]
|
||||||
|
if physical_to_logical.get(fp_port_index) is None:
|
||||||
|
physical_to_logical[fp_port_index] = [portname]
|
||||||
|
else:
|
||||||
|
physical_to_logical[fp_port_index].append(
|
||||||
|
portname)
|
||||||
|
|
||||||
|
if (fp_port_index - last_fp_port_index) > 1:
|
||||||
|
# last port was a gang port
|
||||||
|
for p in range(last_fp_port_index+1, fp_port_index):
|
||||||
|
logical_to_physical[last_portname].append(p)
|
||||||
|
if physical_to_logical.get(p) is None:
|
||||||
|
physical_to_logical[p] = [last_portname]
|
||||||
|
else:
|
||||||
|
physical_to_logical[p].append(last_portname)
|
||||||
|
|
||||||
|
last_fp_port_index = fp_port_index
|
||||||
|
last_portname = portname
|
||||||
|
|
||||||
|
port_pos_in_file += 1
|
||||||
|
|
||||||
|
self.logical = logical
|
||||||
|
self.logical_to_bcm = logical_to_bcm
|
||||||
|
self.logical_to_physical = logical_to_physical
|
||||||
|
self.physical_to_logical = physical_to_logical
|
||||||
|
|
||||||
|
|
||||||
|
#print(self.logical_to_physical)
|
||||||
|
'''print("logical: " + self.logical)
|
||||||
|
print("logical to bcm: " + self.logical_to_bcm)
|
||||||
|
print("logical to physical: " + self.logical_to_physical)
|
||||||
|
print("physical to logical: " + self.physical_to_logical)'''
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@property
|
||||||
|
def port_start(self):
|
||||||
|
return self._port_start
|
||||||
|
|
||||||
|
@property
|
||||||
|
def port_end(self):
|
||||||
|
return self._port_end
|
||||||
|
|
||||||
|
@property
|
||||||
|
def qsfp_ports(self):
|
||||||
|
return self._qsfp_ports
|
||||||
|
|
||||||
|
@property
|
||||||
|
def port_to_eeprom_mapping(self):
|
||||||
|
return self._port_to_eeprom_mapping
|
||||||
|
|
||||||
|
@property
|
||||||
|
def get_transceiver_change_event(self):
|
||||||
|
raise NotImplementedError
|
18
device/marvell/armhf-marvell_et6448m_52x-r0/sensors.conf
Normal file
18
device/marvell/armhf-marvell_et6448m_52x-r0/sensors.conf
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
chip "adt7473-*"
|
||||||
|
label fan1 "rear fan 1"
|
||||||
|
label fan2 "rear fan 2"
|
||||||
|
ignore fan3
|
||||||
|
ignore fan4
|
||||||
|
ignore in1
|
||||||
|
|
||||||
|
chip "lm75a-i2c-*-4a"
|
||||||
|
label temp1 "MAC temp sensor"
|
||||||
|
set temp1_max 65
|
||||||
|
set temp1_crit 75
|
||||||
|
|
||||||
|
chip "lm75a-i2c-*-4b"
|
||||||
|
label temp1 "Board temp sensor"
|
||||||
|
set temp2_max 65
|
||||||
|
set temp2_crit 75
|
||||||
|
chip "armada_thermal-*"
|
||||||
|
ignore temp1
|
Loading…
Reference in New Issue
Block a user