blob: d12abd785f80adc0ce8bf5307f55e24fd017bac1 [file] [log] [blame] [edit]
#!/usr/bin/env python3
r"""
PEL functions.
"""
import func_args as fa
import bmc_ssh_utils as bsu
import json
class peltool_exception(Exception):
r"""
Base class for peltool related exceptions.
"""
def __init__(self, message):
self.message = message
super().__init__(self.message)
def peltool(option_string, parse_json=True, **bsu_options):
r"""
Run peltool on the BMC with the caller's option string and return the result.
Example:
${pel_results}= Peltool -l
Rprint Vars pel_results
pel_results:
[0x50000031]:
[CompID]: 0x1000
[PLID]: 0x50000031
[Subsystem]: BMC Firmware
[Message]: An application had an internal failure
[SRC]: BD8D1002
[Commit Time]: 02/25/2020 04:51:31
[Sev]: Unrecoverable Error
[CreatorID]: BMC
Description of argument(s):
option_string A string of options which are to be processed by the peltool command.
parse_json Indicates that the raw JSON data should parsed into a list of
dictionaries.
bsu_options Options to be passed directly to bmc_execute_command. See its prolog for
details.
"""
bsu_options = fa.args_to_objects(bsu_options)
out_buf, stderr, rc = bsu.bmc_execute_command('peltool ' + option_string, **bsu_options)
if parse_json:
try:
return json.loads(out_buf)
except json.JSONDecodeError:
return {}
return out_buf
def fetch_pelId_For_SRC(src_id):
r"""
Fetch PEL ID for the input SRC ID
Description of arguments:
src_id SRC ID (e.g. BC20E504)
"""
src_pel_id = []
try:
pel_data = peltool(" -l")
pel_id_list = pel_data.keys()
for i in pel_id_list:
if pel_data[i]["SRC"] == src_id:
src_pel_id.append(i)
except Exception as e:
raise peltool_exception("Failed to fetch PEL ID for required SRC : " + str(e))
return src_pel_id
def verify_SRC_details(pel_id, attn_type, target_type, signature_desc,
threshold_limit):
r"""
Verify SRC details for the given PEL ID based on the required
target type, attention type, signature description, threshold limit.
Description of arguments:
pel_id PEL ID for the required SRC details to verify
target_type Target type (e.g. TYPE_OMIC)
attn_type Attention type (e.g. RECCOVERABLE)
signature_desc Signature description of the error inject
threshold_limit Threshold limit (e.g. 1, 5, 32)
"""
try:
pel_cmd = " -i " + pel_id
src_data = peltool(pel_cmd)
src_dict = src_data["Primary SRC"]["SRC Details"]
usr_data = src_data["User Data 4"]
if (src_dict["Attention Type"] != attn_type):
raise peltool_exception("Required Attention type " + attn_type + " not found")
if target_type not in src_dict["Target Type"]:
raise peltool_exception("Required Target type " + target_type + " not found")
if signature_desc not in src_dict["Signature"]:
raise peltool_exception("Required Signature " + signature_desc + " not found")
if (int(threshold_limit) != usr_data["Error Threshold"]):
raise peltool_exception("Required Threshold limit " + threshold_limit + " not found")
except Exception as e:
raise peltool_exception("Failed to verify SRC details : " + str(e))
return True
def fetch_All_SRC():
r"""
Fetch all list of SRC IDs from peltool
"""
src_id = []
try:
pel_data = peltool(" -l")
pel_id_list = pel_data.keys()
for i in pel_id_list:
src_id.append(pel_data[i]["SRC"])
except Exception as e:
raise peltool_exception("Failed to fetch all SRCs : " + str(e))
return src_id