xref: /openbmc/phosphor-dbus-interfaces/yaml/xyz/openbmc_project/Inventory/Item/README.md (revision 8bd711ed214bc06296fb19d71970e7269f47cb56)
1# Representing Inventory Items on DBus
2
3## Overview
4
5Inventory refers to physical objects. Some of the objects can be physically
6accessed, such as a board, a chassis and a drive. Some objects are embedded in
7other objects, such as a BMC embedded in a board, or a core in a CPU. The DBus
8interfaces in this directory describe the DBus representation of those physical
9objects. A graph consisting of Inventory objects as vertexes and Association as
10edges can be constructed that represents the relationship between different
11parts (such as chassis, drive, sensors, etc) of the system.
12
13## Inventory Association
14
15DBus objects with `xyz.opebmc_project.Inventory.Item.${ItemType}` interface
16might be associated with other inventory objects. Such association can be
17translated to Redfish schemas and then indicate the system topology.
18
19Document ObjectMapper association forward and reverse names as follows:
20
21- Item and Item: `{containing, contained_by}`
22- Sensor.Value and Bmc: `{monitoring, monitored_by}`
23- Fan and Item: `{cooling, cooled_by}`
24- Led.Group and Item: `{identifying, identified_by}`
25  `{fault_identifying, fault_identified_by}`
26- PowerSupply and Item: `{powering, powered_by}`
27- FabricAdapter and Connector.Port: `{connecting, connected_to}`
28- Cpu and PCIeSlot: `{connecting, connected_to}`
29- PCIeSwitch and PCIeSlot: `{connecting, connected_to}`
30- Control.Throttle and Item: `{throttling, throttled_by}`
31- Cable and Item: `{connecting, connected_to}`
32