Initial commit

This commit is contained in:
Your Name
2026-04-23 17:07:55 +08:00
commit b7e39e063b
16725 changed files with 1625565 additions and 0 deletions
@@ -0,0 +1,12 @@
[Unit]
Description=Check GPIO State Manager
After=phosphor-gpio-presence@.service
Wants=phosphor-gpio-presence@.service
[Service]
ExecStart=@LIBEXECDIR@/ncplite-inventory-log/inventory-log.sh
SyslogIdentifier=inventory-log
Type=simple
[Install]
WantedBy=multi-user.target
@@ -0,0 +1,54 @@
#!/bin/bash
SERVICE_NAME="xyz.openbmc_project.Inventory.Manager"
INVENTORY_OBJPATH=( \
"/xyz/openbmc_project/inventory/system/chassis/motherboard/ALL_PWR_GOOD_H"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/FAN_STATUS_INT_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/THERMAL_ALERT_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/CPU_CATERR_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/CPU_THERMTEIP_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU0_INT_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU1_INT_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU0_POWER_OK"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU1_POWER_OK"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU0_PRSNT_L"
"/xyz/openbmc_project/inventory/system/chassis/motherboard/PSU1_PRSNT_L"
)
INTERFACE_NAME="xyz.openbmc_project.Inventory.Item"
IPMI_LOG_SERVICE="xyz.openbmc_project.Logging.IPMI"
IPMI_LOG_OBJPATH="/xyz/openbmc_project/Logging/IPMI"
IPMI_LOG_INTERFACE="xyz.openbmc_project.Logging.IPMI"
IPMI_LOG_FUNCT="IpmiSelAdd"
IPMI_LOG_PARA_FORMAT="ssaybq" #5 parameters, s : string, s : string, ay : byte array, b : boolean, q : UINT16
LOG_ERR="Configuration Error(Incorrect_interconnection)"
LOG_EVENT_DATA="3 0x01 0xff 0xff"
LOG_ASSERT_FLAG="true"
LOG_DEASSERT_FLAG="false"
LOG_GENID_FLAG="0x0020"
initial_state=("false" "false" "false" "false" "false" "false" "false" "false" "false" "false" "false" "false")
for i in "${!INVENTORY_OBJPATH[@]}"
do
mapper wait "${INVENTORY_OBJPATH[$i]}"
done
while true; do
for i in "${!INVENTORY_OBJPATH[@]}"
do
current_status="$(busctl get-property $SERVICE_NAME "${INVENTORY_OBJPATH[$i]}" $INTERFACE_NAME Present | awk '{print $2}')"
if [ "$current_status" == "true" ] && [ "${initial_state[$i]}" == "false" ];then
initial_state[i]="true"
busctl call $IPMI_LOG_SERVICE $IPMI_LOG_OBJPATH $IPMI_LOG_INTERFACE $IPMI_LOG_FUNCT $IPMI_LOG_PARA_FORMAT "$LOG_ERR" "${INVENTORY_OBJPATH[$i]}" "$LOG_EVENT_DATA" $LOG_ASSERT_FLAG $LOG_GENID_FLAG
elif [ "$current_status" == "false" ] && [ "${initial_state[$i]}" == "true" ]; then
initial_state[i]="false"
busctl call $IPMI_LOG_SERVICE $IPMI_LOG_OBJPATH $IPMI_LOG_INTERFACE $IPMI_LOG_FUNCT $IPMI_LOG_PARA_FORMAT "$LOG_ERR" "${INVENTORY_OBJPATH[$i]}" "$LOG_EVENT_DATA" $LOG_DEASSERT_FLAG $LOG_GENID_FLAG
fi
done
usleep 100000
done
exit 0