commit | a20be8ec061ad4053c523adfc44d83f91b38b29c | [log] [tgz] |
---|---|---|
author | SunnySrivastava1984 <sunnsr25@in.ibm.com> | Wed Aug 26 02:00:50 2020 -0500 |
committer | Sunny Srivastava <sunnsr25@in.ibm.com> | Fri Nov 27 04:49:45 2020 +0000 |
tree | 7f9a24f239a543ebcc4b70ec30bfc6ed06d97c29 | |
parent | 9d4f11290013e8204365d6d2a60706326a882756 [diff] |
PEL creation in case of HW/SW failure. Creation of PEL in case the parser process fails to parse and/or publish VPD data. This commit handles both hardware or software failure and creates PEL accordingly. Tested on Simics. Test procedure: Step1 : Copy ibm_read_vpd in /tmp folder on simics Step2 : Run ibm_read_vpd exe with a vpd file path having invalid VPD/ECC or invalid JSON path. In this case we have given path to VPD file with invalid VPD data. command-> ./ibm_read_vpd --file <vpd_file_path> Step3 : After the execution is over, look for PEL logged using command "peltool -a" PEL logged incase of invalid VPD: [ { "Private Header": { "Section Version": "1", "Sub-section type": "0", "Created by": "0x4000", "Created at": "11/27/2020 04:40:00", "Committed at": "11/27/2020 04:40:00", "Creator Subsystem": "BMC", "CSSVER": "", "Platform Log Id": "0x50000002", "Entry Id": "0x50000002", "BMC Event Log Id": "2" }, "User Header": { "Section Version": "1", "Sub-section type": "0", "Log Committed by": "0x2000", "Subsystem": "CEC Hardware: VPD Interface", "Event Scope": "Entire Platform", "Event Severity": "Unrecoverable Error", "Event Type": "Not Applicable", "Action Flags": [ "Service Action Required", "Report Externally", "HMC Call Home" ], "Host Transmission": "Not Sent" }, "Primary SRC": { "Section Version": "1", "Sub-section type": "1", "Created by": "0x4000", "SRC Version": "0x02", "SRC Format": "0x55", "Virtual Progress SRC": "False", "I5/OS Service Event Bit": "False", "Hypervisor Dump Initiated":"False", "Power Control Net Fault": "False", "Backplane CCIN": "2E2D", "Error Details": { "Message": "A VPD data exception occurred." }, "Valid Word Count": "0x09", "Reference Code": "BD554001", "Hex Word 2": "00000055", "Hex Word 3": "2E2D0010", "Hex Word 4": "00000000", "Hex Word 5": "00000000", "Hex Word 6": "00000000", "Hex Word 7": "00000000", "Hex Word 8": "00000000", "Hex Word 9": "00000000", "Callout Section": { "Callout Count": "1", "Callouts": [{ "FRU Type": "Normal Hardware FRU", "Priority": "Mandatory, replace all with this type as a unit", "Location Code": "U78DA.ND1.1234567-P0", "Part Number": "F191014", "CCIN": "2E2D", "Serial Number": "YL2E2D010000" }] } }, "Extended User Header": { "Section Version": "1", "Sub-section type": "0", "Created by": "0x2000", "Reporting Machine Type": "9105-22A", "Reporting Serial Number": "SIMP10R", "FW Released Ver": "", "FW SubSys Version": "fw1020.00-6", "Common Ref Time": "00/00/0000 00:00:00", "Symptom Id Len": "20", "Symptom Id": "BD554001_2E2D0010" }, "Failing MTMS": { "Section Version": "1", "Sub-section type": "0", "Created by": "0x2000", "Machine Type Model": "9105-22A", "Serial Number": "SIMP10R" }, "User Data 0": { "Section Version": "1", "Sub-section type": "1", "Created by": "0x2000", "BMC Version ID": "fw1020.00-6-22-gbbd23f832", "BMCState": "Ready", "ChassisState": "Off", "HostState": "Off", "Process Name": "Unknown" }, "User Data 1": { "Section Version": "1", "Sub-section type": "1", "Created by": "0x2000", "CALLOUT_INVENTORY_PATH": "/xyz/openbmc_project/inventory/system/chassis/motherboard", "DESCRIPTION": "Invalid VPD data" } } ] Signed-off-by: Sunny Srivastava <sunnsr25@in.ibm.com> Change-Id: Ieb434bb45b4051d8b7b6d4c9022984d5471fc855
#Overview This repository hosts code for OpenPower and IBM IPZ format VPD parsers. Both OpenPower VPD and IPZ VPD formats are structured binaries that consist of records and keywords. A record is a collection of multiple keywords. More information about the format can be found here.
The repository consists of two distinct applications, which are:
This is a build-time YAML driven application that parses the OpenPower VPD format and uses the YAML configuration (see extra-properties-example.yaml and writefru.yaml) to determine:
The application instance must be passed in the file path to the VPD (this can, for example, be a sysfs path exposed by the EEPROM device driver) and also the D-Bus object path(s) that EEPROM data needs to be published under.
This parser is can be built by passing in the --enable-ibm-parser
configure option. This parser differs from the OpenPower VPD parser in the following ways:
#
and are > 255 bytes in length).Making the application runtime JSON driven allows us to support multiple systems (with different FRU configurations) to be supported in a single code image as well as making the application more flexible for future improvements.