Skip to content

Commit

Permalink
[devices]: DellEMC S6000 xcvrd support (sonic-net#2560)
Browse files Browse the repository at this point in the history
* DellEMC S6000, xcvrd support

* sleep 1 second to avoid busy looping

* removal of dead code

* Correct typo error to 1 second

* Introduced 1 second sleep

* Revamped script with blocking call support

* get_transceiver_change_event api definition update

* adding timeout support for get_transceiver_change_event
  • Loading branch information
paavaanan authored and lguohan committed Apr 30, 2019
1 parent 259d51a commit 818bbe8
Showing 1 changed file with 80 additions and 7 deletions.
87 changes: 80 additions & 7 deletions device/dell/x86_64-dell_s6000_s1220-r0/plugins/sfputil.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

try:
import time
import datetime
from sonic_sfp.sfputilbase import SfpUtilBase
except ImportError as e:
raise ImportError("%s - required module not found" % str(e))
Expand All @@ -20,6 +21,7 @@ class SfpUtil(SfpUtilBase):
EEPROM_OFFSET = 20

_port_to_eeprom_mapping = {}
port_dict = {}

@property
def port_start(self):
Expand All @@ -37,12 +39,33 @@ def qsfp_ports(self):
def port_to_eeprom_mapping(self):
return self._port_to_eeprom_mapping

@property
def get_transceiver_status(self):

try:
reg_file = open("/sys/devices/platform/dell-s6000-cpld.0/qsfp_modprs")

except IOError as e:
print "Error: unable to open file: %s" % str(e)
return False

content = reg_file.readline().rstrip()

reg_file.close()

return int(content, 16)


def __init__(self):

eeprom_path = "/sys/class/i2c-adapter/i2c-{0}/{0}-0050/eeprom"

for x in range(0, self.port_end + 1):
self._port_to_eeprom_mapping[x] = eeprom_path.format(x + self.EEPROM_OFFSET)

# Get Transceiver status
self.modprs_register = self.get_transceiver_status

SfpUtilBase.__init__(self)

def get_presence(self, port_num):
Expand Down Expand Up @@ -174,10 +197,60 @@ def reset(self, port_num):

return True

def get_transceiver_change_event(self):
"""
TODO: This function need to be implemented
when decide to support monitoring SFP(Xcvrd)
on this platform.
"""
raise NotImplementedError
def get_transceiver_change_event(self, timeout=0):

start_time = time.time()
port_dict = {}
port = self.port_start
forever = False

if timeout == 0:
forever = True
elif timeout > 0:
timeout = timeout / float(1000) # Convert to secs
else:
print "get_transceiver_change_event:Invalid timeout value", timeout
return False, {}

end_time = start_time + timeout
if start_time > end_time:
print 'get_transceiver_change_event:' \
'time wrap / invalid timeout value', timeout

return False, {} # Time wrap or possibly incorrect timeout

while timeout >= 0:
# Check for OIR events and return updated port_dict
reg_value = self.get_transceiver_status
if reg_value != self.modprs_register:
changed_ports = self.modprs_register ^ reg_value
while port >= self.port_start and port <= self.port_end:

# Mask off the bit corresponding to our port
mask = (1 << port)

if changed_ports & mask:
# ModPrsL is active low
if reg_value & mask == 0:
port_dict[port] = '1'
else:
port_dict[port] = '0'

port += 1

# Update reg value
self.modprs_register = reg_value
return True, port_dict

if forever:
time.sleep(1)
else:
timeout = end_time - time.time()
if timeout >= 1:
time.sleep(1) # We poll at 1 second granularity
else:
if timeout > 0:
time.sleep(timeout)
return True, {}
print "get_transceiver_change_event: Should not reach here."
return False, {}

0 comments on commit 818bbe8

Please sign in to comment.