|  | description: > | 
|  | Implement to capture various types of dumps from the host or BMC. This | 
|  | interface is for user to request a particular type of dump. | 
|  |  | 
|  | Any OpenBMC implementation should provide one implementation of | 
|  | xyz.openbmc_project.Dump.Create per dump type on | 
|  | /xyz/openbmc_project/dump/<dump type>. On multi-host or on multi-BMC systems | 
|  | the instance number can be added to the path to differentiate, for example | 
|  | /xyz/openbmc_project/dump/<dump type><instance-id>. | 
|  |  | 
|  | methods: | 
|  | - name: CreateDump | 
|  | description: > | 
|  | Method to create a manual Dump. | 
|  | parameters: | 
|  | - name: AdditionalData | 
|  | type: dict[string, variant[string,uint64]] | 
|  | description: > | 
|  | The additional data, if any, for initiating the dump. The key in | 
|  | this case should be an implementation specific enum defined for | 
|  | the specific type of dump either in xyz or in a domain. The | 
|  | values can be either a string or a 64 bit number. The | 
|  | enum-format string is required to come from a parallel class | 
|  | with this specific Enum name. All of the Enum strings should be | 
|  | in the format 'domain.Dump.Create.CreateParameters.ParamName'. | 
|  | e.g.: | 
|  | { | 
|  | "key1": "value1", | 
|  | "key2": "value2" | 
|  | } | 
|  | ends up in AdditionaData like: | 
|  | ["KEY1=value1", "KEY2=value2"] | 
|  | returns: | 
|  | - name: Path | 
|  | type: object_path | 
|  | description: > | 
|  | The object path of the object that implements | 
|  | xyz.openbmc_project.Common.Progress to track the progress of the | 
|  | dump | 
|  | errors: | 
|  | - xyz.openbmc_project.Common.File.Error.Open | 
|  | - xyz.openbmc_project.Common.File.Error.Write | 
|  | - xyz.openbmc_project.Dump.Create.Error.Disabled | 
|  | - xyz.openbmc_project.Dump.Create.Error.QuotaExceeded | 
|  | - xyz.openbmc_project.Common.Error.NotAllowed | 
|  | - xyz.openbmc_project.Common.Error.InvalidArgument | 
|  | - xyz.openbmc_project.Common.Error.Unavailable | 
|  |  | 
|  | enumerations: | 
|  | - name: CreateParameters | 
|  | description: > | 
|  | Additional parameters for creating the dump. | 
|  | values: | 
|  | - name: "OriginatorId" | 
|  | description: > | 
|  | Unique Id of the originator of the respective operation. This | 
|  | property is defined in xyz.openbmc_project.Common.OriginatedBy | 
|  | interface. | 
|  | - name: "OriginatorType" | 
|  | description: > | 
|  | Type of the originator that initiated the respective operation. | 
|  | This property is defined in xyz.openbmc_project. | 
|  | Common.OriginatedBy interface. | 
|  | - name: "DumpType" | 
|  | description: > | 
|  | Type of the BMC dump to be collected | 
|  | - name: "FilePath" | 
|  | description: > | 
|  | The path to a file to create the dump, for example a systemd | 
|  | core-dump. | 
|  | - name: "ErrorType" | 
|  | description: > | 
|  | Specifies the type of the error that triggered the BMC dump | 
|  | collection. This is a string identifier for the error type. The | 
|  | type of the error dictates the kind of debug data collected | 
|  | during the dump process. | 
|  | - name: "EventId" | 
|  | description: > | 
|  | The identifier for an event that triggers the BMC dump. When a | 
|  | BMC dump is initiated as a response to a specific system event, | 
|  | this parameter can be supplied with the unique ID associated | 
|  | with that event. By linking the dump to an event ID, the system | 
|  | can collate additional, relevant diagnostic data or add this | 
|  | into the dump to aid in providing a clearer context. | 
|  |  | 
|  | - name: DumpType | 
|  | description: > | 
|  | Possible types of BMC Dump. | 
|  | values: | 
|  | - name: "ApplicationCored" | 
|  | description: > | 
|  | Dump triggered due to application core. | 
|  | - name: "UserRequested" | 
|  | description: > | 
|  | Dump triggered by the user. | 
|  | - name: "ErrorLog" | 
|  | description: > | 
|  | This type of dump is triggered in response to a specific error | 
|  | commit. The error type needs to be specified in the "ErrorType" | 
|  | field. If no parameters are provided, a default dump will be | 
|  | generated. | 
|  | - name: "Ramoops" | 
|  | description: > | 
|  | Dump triggered due to Ramoops type error commit. | 
|  |  | 
|  | service_names: | 
|  | - default: xyz.openbmc_project.Dump.Manager | 
|  |  | 
|  | paths: | 
|  | - namespace: /xyz/openbmc_project/dump | 
|  | segments: | 
|  | - name: BMC | 
|  | value: bmc | 
|  | - name: System | 
|  | value: system |