This document gives details about the format of the config file used by log, version and firmware handler. The config file is a .json file.
There are 3 important parameters in this config file
An example config file -
{ "blob": "/flash/adm1266_sink0", "handler": { "type": "file", "path": "/var/run/adm1266/adm1266_sink0.hex" }, "actions": { "preparation": { "type": "skip" }, "verification": { "type": "systemd", "unit": "adm1266-verify@sink0.service" }, "update": { "type": "systemd", "unit": "adm1266-update@sink0.service" } } }
This parameter defines the unique name of the blob. This parameter must be defined for each blob.
A blob must have a handler with a type. Currently only "file" type is supported. With file type, a path of the handler file must be provided.
"actions" define various steps to be performed and are required for each blob. These actions can be triggered from ipmi-blob commands. Currently there are 2 types of actions supported: systemd
to invoke a systemd service, or skip
to not perform any action.
{ "blob": "/log/blackbox_adm1266_sink0", "handler": { "type": "file", "path": "/var/run/adm1266/adm1266_sink0.log" }, "actions": { "open": { "type": "systemd", "unit": "adm1266-read-blackbox-log@sink0.service" }, "delete": { "type": "systemd", "unit": "adm1266-clear-blackbox-data@sink0.service" } } }
In this example the blob handler is the log file that will store the blackbox data from adm1266 and will be returned on BmcBlobRead.
Here log_blob supports 2 actions. These actions are performed on the handler file.
open
: adm1266-read-blackbox-log@sink0.service
gets launched on BmcBlobOpen command. This service should read the blackbox data from adm1266 and place the into blob handler file. This also enables BmcBlobSessionStat command to indicate that the blob is ready to read.
delete
: adm1266-clear-blackbox-data@sink0.service
gets launched on BmcBlobDelete command. This service should delete the cached blackbox data in the handler file and erase the blackbox data from adm1266.