diff --git a/gen/xyz/openbmc_project/Attestation/ComponentIntegrity/meson.build b/gen/xyz/openbmc_project/Attestation/ComponentIntegrity/meson.build
new file mode 100644
index 0000000..6d2696a
--- /dev/null
+++ b/gen/xyz/openbmc_project/Attestation/ComponentIntegrity/meson.build
@@ -0,0 +1,15 @@
+# Generated file; do not modify.
+generated_sources += custom_target(
+    'xyz/openbmc_project/Attestation/ComponentIntegrity__cpp'.underscorify(),
+    input: [ '../../../../../yaml/xyz/openbmc_project/Attestation/ComponentIntegrity.interface.yaml',  ],
+    output: [ 'common.hpp', 'server.cpp', 'server.hpp', 'aserver.hpp', 'client.hpp',  ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'cpp',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../../yaml',
+        'xyz/openbmc_project/Attestation/ComponentIntegrity',
+    ],
+)
+
diff --git a/gen/xyz/openbmc_project/Attestation/IdentityAuthentication/meson.build b/gen/xyz/openbmc_project/Attestation/IdentityAuthentication/meson.build
new file mode 100644
index 0000000..60d1f7c
--- /dev/null
+++ b/gen/xyz/openbmc_project/Attestation/IdentityAuthentication/meson.build
@@ -0,0 +1,15 @@
+# Generated file; do not modify.
+generated_sources += custom_target(
+    'xyz/openbmc_project/Attestation/IdentityAuthentication__cpp'.underscorify(),
+    input: [ '../../../../../yaml/xyz/openbmc_project/Attestation/IdentityAuthentication.interface.yaml',  ],
+    output: [ 'common.hpp', 'server.cpp', 'server.hpp', 'aserver.hpp', 'client.hpp',  ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'cpp',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../../yaml',
+        'xyz/openbmc_project/Attestation/IdentityAuthentication',
+    ],
+)
+
diff --git a/gen/xyz/openbmc_project/Attestation/MeasurementSet/meson.build b/gen/xyz/openbmc_project/Attestation/MeasurementSet/meson.build
new file mode 100644
index 0000000..532a14e
--- /dev/null
+++ b/gen/xyz/openbmc_project/Attestation/MeasurementSet/meson.build
@@ -0,0 +1,15 @@
+# Generated file; do not modify.
+generated_sources += custom_target(
+    'xyz/openbmc_project/Attestation/MeasurementSet__cpp'.underscorify(),
+    input: [ '../../../../../yaml/xyz/openbmc_project/Attestation/MeasurementSet.interface.yaml',  ],
+    output: [ 'common.hpp', 'server.cpp', 'server.hpp', 'aserver.hpp', 'client.hpp',  ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'cpp',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../../yaml',
+        'xyz/openbmc_project/Attestation/MeasurementSet',
+    ],
+)
+
diff --git a/gen/xyz/openbmc_project/Attestation/meson.build b/gen/xyz/openbmc_project/Attestation/meson.build
new file mode 100644
index 0000000..86e0952
--- /dev/null
+++ b/gen/xyz/openbmc_project/Attestation/meson.build
@@ -0,0 +1,46 @@
+# Generated file; do not modify.
+subdir('ComponentIntegrity')
+generated_others += custom_target(
+    'xyz/openbmc_project/Attestation/ComponentIntegrity__markdown'.underscorify(),
+    input: [ '../../../../yaml/xyz/openbmc_project/Attestation/ComponentIntegrity.interface.yaml',  ],
+    output: [ 'ComponentIntegrity.md' ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'markdown',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../yaml',
+        'xyz/openbmc_project/Attestation/ComponentIntegrity',
+    ],
+)
+
+subdir('IdentityAuthentication')
+generated_others += custom_target(
+    'xyz/openbmc_project/Attestation/IdentityAuthentication__markdown'.underscorify(),
+    input: [ '../../../../yaml/xyz/openbmc_project/Attestation/IdentityAuthentication.interface.yaml',  ],
+    output: [ 'IdentityAuthentication.md' ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'markdown',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../yaml',
+        'xyz/openbmc_project/Attestation/IdentityAuthentication',
+    ],
+)
+
+subdir('MeasurementSet')
+generated_others += custom_target(
+    'xyz/openbmc_project/Attestation/MeasurementSet__markdown'.underscorify(),
+    input: [ '../../../../yaml/xyz/openbmc_project/Attestation/MeasurementSet.interface.yaml',  ],
+    output: [ 'MeasurementSet.md' ],
+    depend_files: sdbusplusplus_depfiles,
+    command: [
+        sdbuspp_gen_meson_prog, '--command', 'markdown',
+        '--output', meson.current_build_dir(),
+        '--tool', sdbusplusplus_prog,
+        '--directory', meson.current_source_dir() / '../../../../yaml',
+        'xyz/openbmc_project/Attestation/MeasurementSet',
+    ],
+)
+
diff --git a/gen/xyz/openbmc_project/meson.build b/gen/xyz/openbmc_project/meson.build
index b30b985..72c5026 100644
--- a/gen/xyz/openbmc_project/meson.build
+++ b/gen/xyz/openbmc_project/meson.build
@@ -14,6 +14,7 @@
     ],
 )
 
+subdir('Attestation')
 subdir('BIOSConfig')
 subdir('Certs')
 generated_others += custom_target(
diff --git a/yaml/xyz/openbmc_project/Attestation/ComponentIntegrity.interface.yaml b/yaml/xyz/openbmc_project/Attestation/ComponentIntegrity.interface.yaml
new file mode 100644
index 0000000..bc0b6dc
--- /dev/null
+++ b/yaml/xyz/openbmc_project/Attestation/ComponentIntegrity.interface.yaml
@@ -0,0 +1,67 @@
+description: >
+    Implement to represent component integrity information acquired from a
+    secure authentication or measurement of the protected components. A trusted
+    component (e.g., iRoT or TPM) is typically involved to provide the info
+    using a security protocol (e.g., SPDM).
+
+properties:
+    - name: Enabled
+      type: boolean
+      default: false
+      description: >
+          An indication of whether security protocols are enabled for the
+          component.
+
+    - name: Type
+      type: enum[self.SecurityTechnologyType]
+      default: Unknown
+      flags:
+          - readonly
+      description: >
+          The type of security technology for the component.
+
+    - name: TypeVersion
+      type: string
+      flags:
+          - readonly
+      description: >
+          The version of the security technology. Human readable format, e.g.
+          "1.1" for SPDM.
+
+    - name: LastUpdated
+      type: uint64
+      flags:
+          - readonly
+      description: >
+          The date and time when information for the component was last updated.
+          Firmware update, device certificate change or other device state
+          change that leads to component integrity change should update this
+          date. It is represented in milliseconds since the UNIX epoch.
+
+associations:
+    - name: authenticating
+      description: >
+          Objects that implement ComponentIntegrity can implement the
+          "authenticating" association to provide a link to the target component
+          whose integrity this resource authenticates.
+      reverse_name: authenticated_by
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Inventory.Item
+
+enumerations:
+    - name: SecurityTechnologyType
+      description: >
+          The security technology used for the component.
+      values:
+          - name: OEM
+            description: >
+                OEM-specific. If it is neither SPDM nor TPM, tag it OEM.
+          - name: SPDM
+            description: >
+                Security Protocol and Data Model (SPDM) protocol.
+          - name: TPM
+            description: >
+                Trusted Platform Module (TPM).
+          - name: Unknown
+            description: >
+                Security technology not known yet.
diff --git a/yaml/xyz/openbmc_project/Attestation/IdentityAuthentication.interface.yaml b/yaml/xyz/openbmc_project/Attestation/IdentityAuthentication.interface.yaml
new file mode 100644
index 0000000..f469a45
--- /dev/null
+++ b/yaml/xyz/openbmc_project/Attestation/IdentityAuthentication.interface.yaml
@@ -0,0 +1,44 @@
+description: >
+    Implement to represent properties related to Identity Authentication using
+    SPDM protocol.
+
+properties:
+    - name: ResponderVerificationStatus
+      type: enum[self.VerificationStatus]
+      default: Unknown
+      description: >
+          The status of the verification of the identity of the component.
+
+associations:
+    - name: requester_identitified_by
+      description: >
+          Objects that implement IdentityAuthentication can implement the
+          "requester_identified_by" association to provide a link to the target
+          certificate that provides the requester's identity.
+      reverse_name: identifying_requester
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Certs.Certificate
+
+    - name: responder_identitified_by
+      description: >
+          Objects that implement IdentityAuthentication can implement the
+          "responder_identified_by" association to provide a link to the target
+          certificate that provides the responder's identity.
+      reverse_name: identifying_responder
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Certs.Certificate
+
+enumerations:
+    - name: VerificationStatus
+      description: >
+          The possible status of the verification.
+      values:
+          - name: Failed
+            description: >
+                Unsuccessful verification.
+          - name: Success
+            description: >
+                Successful verification.
+          - name: Unknown
+            description: >
+                Status not known yet.
diff --git a/yaml/xyz/openbmc_project/Attestation/MeasurementSet.interface.yaml b/yaml/xyz/openbmc_project/Attestation/MeasurementSet.interface.yaml
new file mode 100644
index 0000000..ccb5312
--- /dev/null
+++ b/yaml/xyz/openbmc_project/Attestation/MeasurementSet.interface.yaml
@@ -0,0 +1,62 @@
+description: >
+    Implement to represent properties related to SPDM Measurements set.
+
+methods:
+    - name: SPDMGetSignedMeasurements
+      description: >
+          This method generates an SPDM cryptographic signed statement over the
+          given nonce and measurements of the SPDM Responder.
+
+      parameters:
+          - name: MeasurementIndices
+            type: array[size]
+            description: >
+                An array of indices that identify the measurement blocks to
+                sign.
+
+          - name: Nonce
+            type: string
+            description: >
+                A 32-byte hex-encoded string to be signed with the measurements.
+                The value should be unique.
+
+          - name: SlotId
+            type: size
+            description: >
+                The slot identifier for the certificate containing the private
+                key to generate the signature over the measurements.
+
+      returns:
+          - name: Certificate
+            type: object_path
+            description: >
+                Certificate corresponding to the SPDM slot identifier that can
+                be used to validate the signature.
+          - name: HashingAlgorithm
+            type: string
+            description: >
+                The hashing algorithm used for generating the cryptographic
+                signed statement.
+          - name: PublicKey
+            type: string
+            description: >
+                A Privacy Enhanced Mail (PEM)-encoded public key that can be
+                used to validate the signature.
+          - name: SignedMeasurements
+            type: string
+            description: >
+                Base64 encoded cryptographic signed statement generated by the
+                signer.
+          - name: SigningAlgorithm
+            type: string
+            description: >
+                The asymmetric signing algorithm used for generating the
+                cryptographic signed statement.
+          - name: Version
+            type: string
+            description: >
+                The SPDM version used by the SPDM Responder to generate the
+                cryptographic signed statement.
+      errors:
+          - xyz.openbmc_project.Common.Error.InvalidArgument
+          - xyz.openbmc_project.Common.Error.InternalFailure
diff --git a/yaml/xyz/openbmc_project/Certs/Certificate.interface.yaml b/yaml/xyz/openbmc_project/Certs/Certificate.interface.yaml
index 799d9da..bd3733c 100644
--- a/yaml/xyz/openbmc_project/Certs/Certificate.interface.yaml
+++ b/yaml/xyz/openbmc_project/Certs/Certificate.interface.yaml
@@ -92,3 +92,24 @@
       description: >
           The certificate validity start date and time, in epoch time, in
           milliseconds.
+
+associations:
+    - name: identifying_requester
+      description: >
+          Objects that implement Certificate can optionally implement the
+          "identifying_requester" association to provide a link to the component
+          integrity object whose requester's identity is identified by this
+          certificate.
+      reverse_name: requester_identified_by
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Attestation.IdentityAuthentication
+
+    - name: identifying_responder
+      description: >
+          Objects that implement Certificate can optionally implement the
+          "identifying_responder" association to provide a link to the component
+          integrity object whose responder's identity is identified by this
+          certificate.
+      reverse_name: responder_identified_by
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Attestation.IdentityAuthentication
diff --git a/yaml/xyz/openbmc_project/Inventory/Item.interface.yaml b/yaml/xyz/openbmc_project/Inventory/Item.interface.yaml
index 4eec2bb..4319b02 100644
--- a/yaml/xyz/openbmc_project/Inventory/Item.interface.yaml
+++ b/yaml/xyz/openbmc_project/Inventory/Item.interface.yaml
@@ -94,6 +94,14 @@
           - inventory
       required_endpoint_interfaces:
           - xyz.openbmc_project.Sensor.Value
+    - name: authenticated_by
+      description: >
+          Objects that implement Item can optionally implement the
+          "authenticated_by" association to provide a link to the component
+          integrity object that authenticates this item.
+      reverse_name: authenticating
+      required_endpoint_interfaces:
+          - xyz.openbmc_project.Attestation.ComponentIntegrity
 
 paths:
     - namespace: /xyz/openbmc_project/inventory
