xref: /openbmc/phosphor-dbus-interfaces/yaml/xyz/openbmc_project/PLDM/Requester.interface.yaml (revision a1347418307d31a94bd21f22897aa508df938dcf)
1description: >
2    Implement to provide features needed to build a PLDM Request message. This
3    API would be used by PLDM requester apps on the BMC.
4
5    Any OpenBMC implementation must provide exactly one implementation of
6    xyz.openbmc_project.PLDM.Requester on /xyz/openbmc_project/pldm.
7
8    PLDM stands for Platform Level Data Model. More information about PLDM (and
9    MCTP) can be found at https://www.dmtf.org/standards/pmci.
10
11methods:
12    - name: GetInstanceId
13      description: >
14          Obtain a new PLDM instance id, for the input MCTP EID, to be used in a
15          PLDM request message. Instance ids help distinguish PLDM response
16          messages when a PLDM requester sends out multiple request messages,
17          without waiting for a response message. Refer the PLDM specification
18          DSP0240 version 1.0.0. Also refer
19          https://github.com/openbmc/docs/blob/master/designs/pldm-stack.md#Requester.
20
21          The instance id starts at 0 and can go upto 31 (5 bits), for each MCTP
22          EID that a PLDM requester is communicating with. An implementation of
23          this API should track instance ids in terms of whether they're in use
24          (request message with that instance id has been sent out, and the
25          corresponding response message hasn't been received yet) or not, and
26          grant unused ids via this method. An implementation may also
27          optionally implement the instance id expiry, as per the spec DSP0240
28          v1.0.0. The spec recommends implementing the same.
29
30          If there's a call to this method when all 32 ids have already been
31          granted to the input eid, then the
32          xyz.openbmc_project.Common.Error.TooManyResources exception will be
33          thrown. The recommendation for the caller upon receiving this
34          exception is to retry calling this method, at least once, after a time
35          period equal to the maximum instance id expiration interval, which is
36          6 seconds as per DSP0240 v1.0.0. If the exception persists post this
37          interval, the way of handling the same (further retries, report an
38          error, etc) is left to the user.
39      parameters:
40          - name: eid
41            type: byte
42            description: >
43                The MCTP endpoint, specified by 'eid' (endpoint id), for which
44                the new PLDM instance id needs to be generated.
45      returns:
46          - name: instanceid
47            type: byte
48            description: >
49                PLDM instance id.
50      errors:
51          - xyz.openbmc_project.Common.Error.TooManyResources
52