[DellEMC] S52xx fix reboot cause issue (#9603)
Why I did it Reboot cause is not working in S52xx platforms. How I did it Modified platform API's. How to verify it Check "show reboot-cause" to verify the reboot reason
This commit is contained in:
parent
3844ae8290
commit
9dfdb43070
@ -20,23 +20,23 @@ from os import *
|
|||||||
from mmap import *
|
from mmap import *
|
||||||
|
|
||||||
def usage():
|
def usage():
|
||||||
''' This is the Usage Method '''
|
''' This is the Usage Method '''
|
||||||
|
|
||||||
print '\t\t pcisysfs.py --get --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --get --offset <offset> --res <resource>')
|
||||||
print '\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
def pci_mem_read(mm,offset):
|
def pci_mem_read(mm,offset):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
read_data_stream=mm.read(4)
|
read_data_stream=mm.read(4)
|
||||||
print ""
|
print("")
|
||||||
reg_val=struct.unpack('I',read_data_stream)
|
reg_val=struct.unpack('I',read_data_stream)
|
||||||
print "reg_val read:%x"%reg_val
|
print("reg_val read:%x"%reg_val)
|
||||||
return reg_val
|
return reg_val
|
||||||
|
|
||||||
def pci_mem_write(mm,offset,data):
|
def pci_mem_write(mm,offset,data):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
print "data to write:%x"%data
|
print("data to write:%x"%data)
|
||||||
mm.write(struct.pack('I',data))
|
mm.write(struct.pack('I',data))
|
||||||
|
|
||||||
def pci_set_value(resource,val,offset):
|
def pci_set_value(resource,val,offset):
|
||||||
|
@ -303,15 +303,15 @@ class Chassis(ChassisBase):
|
|||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
|
|
||||||
if reboot_cause & 0x1:
|
if reboot_cause & 0x1:
|
||||||
return (self.REBOOT_CAUSE_POWER_LOSS, None)
|
return (self.REBOOT_CAUSE_POWER_LOSS, "Power on reset")
|
||||||
elif reboot_cause & 0x2:
|
elif reboot_cause & 0x2:
|
||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
elif reboot_cause & 0x4:
|
elif reboot_cause & 0x4:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
||||||
elif reboot_cause & 0x8:
|
elif reboot_cause & 0x8:
|
||||||
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, None)
|
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, "Thermal overload")
|
||||||
elif reboot_cause & 0x10:
|
elif reboot_cause & 0x10:
|
||||||
return (self.REBOOT_CAUSE_WATCHDOG, None)
|
return (self.REBOOT_CAUSE_WATCHDOG, "Watchdog reset")
|
||||||
elif reboot_cause & 0x20:
|
elif reboot_cause & 0x20:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
||||||
elif reboot_cause & 0x40:
|
elif reboot_cause & 0x40:
|
||||||
|
@ -22,21 +22,21 @@ from mmap import *
|
|||||||
def usage():
|
def usage():
|
||||||
''' This is the Usage Method '''
|
''' This is the Usage Method '''
|
||||||
|
|
||||||
print '\t\t pcisysfs.py --get --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --get --offset <offset> --res <resource>')
|
||||||
print '\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
def pci_mem_read(mm,offset):
|
def pci_mem_read(mm,offset):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
read_data_stream=mm.read(4)
|
read_data_stream=mm.read(4)
|
||||||
print ""
|
print("")
|
||||||
reg_val=struct.unpack('I',read_data_stream)
|
reg_val=struct.unpack('I',read_data_stream)
|
||||||
print "reg_val read:%x"%reg_val
|
print("reg_val read:%x"%reg_val)
|
||||||
return reg_val
|
return reg_val
|
||||||
|
|
||||||
def pci_mem_write(mm,offset,data):
|
def pci_mem_write(mm,offset,data):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
print "data to write:%x"%data
|
print("data to write:%x"%data)
|
||||||
mm.write(struct.pack('I',data))
|
mm.write(struct.pack('I',data))
|
||||||
|
|
||||||
def pci_set_value(resource,val,offset):
|
def pci_set_value(resource,val,offset):
|
||||||
|
@ -262,6 +262,7 @@ class Chassis(ChassisBase):
|
|||||||
An integer represences the number of SFPs on the chassis.
|
An integer represences the number of SFPs on the chassis.
|
||||||
"""
|
"""
|
||||||
return self._num_sfps
|
return self._num_sfps
|
||||||
|
|
||||||
def get_reboot_cause(self):
|
def get_reboot_cause(self):
|
||||||
"""
|
"""
|
||||||
Retrieves the cause of the previous reboot
|
Retrieves the cause of the previous reboot
|
||||||
@ -279,15 +280,15 @@ class Chassis(ChassisBase):
|
|||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
|
|
||||||
if reboot_cause & 0x1:
|
if reboot_cause & 0x1:
|
||||||
return (self.REBOOT_CAUSE_POWER_LOSS, None)
|
return (self.REBOOT_CAUSE_POWER_LOSS, "Power on reset")
|
||||||
elif reboot_cause & 0x2:
|
elif reboot_cause & 0x2:
|
||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
elif reboot_cause & 0x4:
|
elif reboot_cause & 0x4:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
||||||
elif reboot_cause & 0x8:
|
elif reboot_cause & 0x8:
|
||||||
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, None)
|
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, "Thermal overload")
|
||||||
elif reboot_cause & 0x10:
|
elif reboot_cause & 0x10:
|
||||||
return (self.REBOOT_CAUSE_WATCHDOG, None)
|
return (self.REBOOT_CAUSE_WATCHDOG, "Watchdog reset")
|
||||||
elif reboot_cause & 0x20:
|
elif reboot_cause & 0x20:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
||||||
elif reboot_cause & 0x40:
|
elif reboot_cause & 0x40:
|
||||||
|
@ -39,6 +39,7 @@ class Chassis(ChassisBase):
|
|||||||
|
|
||||||
oir_fd = -1
|
oir_fd = -1
|
||||||
epoll = -1
|
epoll = -1
|
||||||
|
REBOOT_CAUSE_PATH = "/host/reboot-cause/platform/reboot_reason"
|
||||||
pci_res = "/sys/bus/pci/devices/0000:04:00.0/resource0"
|
pci_res = "/sys/bus/pci/devices/0000:04:00.0/resource0"
|
||||||
sysled_offset = 0x0024
|
sysled_offset = 0x0024
|
||||||
SYSLED_COLOR_TO_REG = {
|
SYSLED_COLOR_TO_REG = {
|
||||||
@ -290,15 +291,15 @@ class Chassis(ChassisBase):
|
|||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
|
|
||||||
if reboot_cause & 0x1:
|
if reboot_cause & 0x1:
|
||||||
return (self.REBOOT_CAUSE_POWER_LOSS, None)
|
return (self.REBOOT_CAUSE_POWER_LOSS, "Power on reset")
|
||||||
elif reboot_cause & 0x2:
|
elif reboot_cause & 0x2:
|
||||||
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
return (self.REBOOT_CAUSE_NON_HARDWARE, None)
|
||||||
elif reboot_cause & 0x4:
|
elif reboot_cause & 0x4:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "PSU Shutdown")
|
||||||
elif reboot_cause & 0x8:
|
elif reboot_cause & 0x8:
|
||||||
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, None)
|
return (self.REBOOT_CAUSE_THERMAL_OVERLOAD_CPU, "Thermal overload")
|
||||||
elif reboot_cause & 0x10:
|
elif reboot_cause & 0x10:
|
||||||
return (self.REBOOT_CAUSE_WATCHDOG, None)
|
return (self.REBOOT_CAUSE_WATCHDOG, "Watchdog reset")
|
||||||
elif reboot_cause & 0x20:
|
elif reboot_cause & 0x20:
|
||||||
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
return (self.REBOOT_CAUSE_HARDWARE_OTHER, "BMC Shutdown")
|
||||||
elif reboot_cause & 0x40:
|
elif reboot_cause & 0x40:
|
||||||
|
@ -20,23 +20,23 @@ from os import *
|
|||||||
from mmap import *
|
from mmap import *
|
||||||
|
|
||||||
def usage():
|
def usage():
|
||||||
''' This is the Usage Method '''
|
''' This is the Usage Method '''
|
||||||
|
|
||||||
print '\t\t pcisysfs.py --get --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --get --offset <offset> --res <resource>')
|
||||||
print '\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>'
|
print('\t\t pcisysfs.py --set --val <val> --offset <offset> --res <resource>')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
def pci_mem_read(mm,offset):
|
def pci_mem_read(mm,offset):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
read_data_stream=mm.read(4)
|
read_data_stream=mm.read(4)
|
||||||
print ""
|
print("")
|
||||||
reg_val=struct.unpack('I',read_data_stream)
|
reg_val=struct.unpack('I',read_data_stream)
|
||||||
print "reg_val read:%x"%reg_val
|
print("reg_val read:%x"%reg_val)
|
||||||
return reg_val
|
return reg_val
|
||||||
|
|
||||||
def pci_mem_write(mm,offset,data):
|
def pci_mem_write(mm,offset,data):
|
||||||
mm.seek(offset)
|
mm.seek(offset)
|
||||||
print "data to write:%x"%data
|
print("data to write:%x"%data)
|
||||||
mm.write(struct.pack('I',data))
|
mm.write(struct.pack('I',data))
|
||||||
|
|
||||||
def pci_set_value(resource,val,offset):
|
def pci_set_value(resource,val,offset):
|
||||||
|
Reference in New Issue
Block a user