3

4

5



Document Identifier: DSP1071

Date: 2017-01-19

Version: 1.0.0

# 6 Multi-type System Memory Profile

7 Supersedes: None

8 **Document Class: Normative** 

9 Document Status: Published

10 **Document Language: en-US** 

11 Copyright Notice

- 12 Copyright © 2017 Distributed Management Task Force, Inc. (DMTF). All rights reserved.
- 13 DMTF is a not-for-profit association of industry members dedicated to promoting enterprise and systems
- 14 management and interoperability. Members and non-members may reproduce DMTF specifications and
- 15 documents, provided that correct attribution is given. As DMTF specifications may be revised from time to
- time, the particular version and release date should always be noted.
- 17 Implementation of certain elements of this standard or proposed standard may be subject to third party
- 18 patent rights, including provisional patent rights (herein "patent rights"). DMTF makes no representations
- 19 to users of the standard as to the existence of such rights, and is not responsible to recognize, disclose,
- 20 or identify any or all such third party patent right, owners or claimants, nor for any incomplete or
- 21 inaccurate identification or disclosure of such rights, owners or claimants. DMTF shall have no liability to
- any party, in any manner or circumstance, under any legal theory whatsoever, for failure to recognize,
- disclose, or identify any such third party patent rights, or for such party's reliance on the standard or
- incorporation thereof in its product, protocols or testing procedures. DMTF shall have no liability to any
- 25 party implementing such standard, whether such implementation is foreseeable or not, nor to any patent
- 26 owner or claimant, and shall have no liability or responsibility for costs or losses incurred if a standard is
- 27 withdrawn or modified after publication, and shall be indemnified and held harmless by any party
- 28 implementing the standard from any and all claims of infringement by a patent owner for such
- 29 implementations.

34

- 30 For information about patents held by third-parties which have notified the DMTF that, in their opinion,
- 31 such patent may relate to or impact implementations of DMTF standards, visit
- 32 http://www.dmtf.org/about/policies/disclosures.php.
- 33 This document's normative language is English. Translation into other languages is permitted.

2 Published Version 1.0.0

# 35 Contents

| 36                   | For   | eword        |                                                                                           | 6  |
|----------------------|-------|--------------|-------------------------------------------------------------------------------------------|----|
| 37                   | Intro | oductio      | on                                                                                        | 7  |
| 38                   | 1     | Scope        |                                                                                           |    |
| 39                   | 2     |              | native references                                                                         |    |
| 40                   | 3     |              | is and definitions                                                                        |    |
| 41                   | 4     |              | pols and abbreviated terms                                                                |    |
| 42                   | 5     | •            | psis                                                                                      |    |
|                      | _     | •            | ription                                                                                   |    |
| 43                   | 6     |              | •                                                                                         |    |
| 44                   | 7     |              | ementation                                                                                |    |
| 45<br>46             |       | 7.1<br>7.2   | Representing raw memory                                                                   |    |
| 46<br>47             |       | 1.2          | Representing visible memory                                                               |    |
| 41<br>48             |       |              | 7.2.2 CIM_VisibleMemory.EnabledState                                                      |    |
| <del>4</del> 0<br>49 |       |              | 7.2.3 Representing memory size                                                            |    |
| <del>-</del> 50      |       |              | 7.2.4 CIM_VisibleMemory.AccessGranularity                                                 |    |
| 51                   |       |              | 7.2.5 CIM_VisibleMemory.Replication                                                       |    |
| 52                   |       | 7.3          | Representing topology                                                                     |    |
| 53                   |       |              | 7.3.1 CIM MemoryController                                                                |    |
| 54                   |       |              | 7.3.2 CIM Processor                                                                       |    |
| 55                   |       |              | 7.3.3 Representing non-uniform memory access configurations                               |    |
| 56                   |       | 7.4          | Representing memory configuration                                                         |    |
| 57                   | 8     | Meth         | ods                                                                                       | 15 |
| 58                   |       | 8.1          | CIM VisibleMemory                                                                         |    |
| 59                   |       | 8.2          | CIM_RawMemory                                                                             |    |
| 60                   |       | 8.3          | CIM_MemoryController                                                                      |    |
| 61                   |       | 8.4          | CIM_Processor                                                                             | 17 |
| 62                   |       | 8.5          | CIM_ConcreteDependency                                                                    | 17 |
| 63                   |       | 8.6          | CIM_AssociatedMemory                                                                      |    |
| 64                   |       | 8.7          | CIM_BasedOn                                                                               | 18 |
| 65                   | 9     | Use          | cases                                                                                     | 18 |
| 66                   |       | 9.1          | Advertising profile conformance                                                           |    |
| 67                   |       | 9.2          | Single visible memory extent                                                              |    |
| 68                   |       | 9.3          | Two visible memory extents                                                                |    |
| 69                   |       | 9.4          | Uniform memory access extents                                                             |    |
| 70                   |       | 9.5          | Non-Uniform Memory Access (NUMA) extents                                                  |    |
| 71                   |       | 9.6          | Determine persistent memory capacity                                                      |    |
| 72<br>70             |       | 9.7          | Determine total installed memory capacity                                                 |    |
| 73<br>74             |       | 9.8<br>9.9   | Determine capacity by processor affinity  Determine processor affinity for visible memory |    |
|                      | 40    |              | ·                                                                                         |    |
| 75<br>70             | 10    |              | Elements                                                                                  |    |
| 76<br>77             |       | 10.1         | CIM_RegisteredProfile                                                                     |    |
| 77<br>78             |       | 10.2         | ,                                                                                         |    |
| 70<br>79             |       | 10.3<br>10.4 | CIM_MemoryController                                                                      |    |
| 79<br>80             |       | 10.4         |                                                                                           |    |
| 81                   |       | 10.5         |                                                                                           |    |
| 82                   |       | 10.7         |                                                                                           |    |
| 83                   |       | . 5.7        | 10.7.1 Relating CIM_Processor to CIM_ComputerSystem                                       |    |
| 84                   |       |              | 10.7.2 Relating CIM_VisibleMemory to CIM_ComputerSystem                                   |    |
| 85                   |       | 10.8         |                                                                                           |    |
|                      |       |              | ·                                                                                         |    |

# DSP1071

# **Multi-type System Memory Profile**

| 86 | 10.9 CIM_Based        | On                                | 27 |
|----|-----------------------|-----------------------------------|----|
| 87 | ANNEX A (informative) | SNIA Memory Configuration Profile | 28 |
| 88 | ANNEX B (informative) | Change log                        | 30 |
| 89 |                       |                                   |    |

| 90       | Figures                                                   |    |
|----------|-----------------------------------------------------------|----|
| 91       | Figure 1 – Multi-type System Memory: Class diagram        | 12 |
| 92       | Figure 2 - Registered Profile object diagram              | 18 |
| 93       | Figure 3 – Single visible memory extent object diagram    | 19 |
| 94       | Figure 4 – Distinct visible memory extents object diagram | 20 |
| 95       | Figure 5 – UMA configuration object diagram               | 21 |
| 96       | Figure 6 – NUMA configuration object diagram              | 22 |
| 97<br>98 | Figure 7 – Memory Configuration Profile                   | 28 |
| 99       | Tables                                                    |    |
| 100      | Table 1 – Related profiles                                | 11 |
| 101      | Table 2 – Operations: CIM_VisibleMemory                   | 15 |
| 102      | Table 3 – Operations: CIM_RawMemory                       | 16 |
| 103      | Table 4 – Operations: CIM_MemoryController                | 16 |
| 104      | Table 5 – Operations: CIM_Processor                       | 17 |
| 105      | Table 6 – Operations: CIM_ConcreteDependency              | 17 |
| 106      | Table 7 – Operations: CIM_AssociatedMemory                |    |
| 107      | Table 8 – Operations: CIM_BasedOn                         | 18 |
| 108      | Table 9 – CIM Elements – Multi-type System Memory Profile | 23 |
| 109      | Table 10 – Class: CIM_RegisteredProfile                   |    |
| 110      | Table 11 – Class: CIM_VisibleMemory                       | 24 |
| 111      | Table 12 – Class: CIM_RawMemory                           |    |
| 112      | Table 13 – Class: CIM_MemoryController                    |    |
| 113      | Table 14 – Class: CIM_Processor                           |    |
| 114      | Table 15 – Class: CIM_ConcreteDependency                  |    |
| 115      | Table 16 – Class: CIM_SystemDevice – use 1                |    |
| 116      | Table 17 – Class: CIM_SystemDevice – use 2                |    |
| 117      | Table 18 – Class: CIM_AssociatedMemory                    |    |
| 118      | Table 19 - Class: CIM_BasedOn                             | 27 |
| 119      |                                                           |    |
|          |                                                           |    |

| 121               | Foreword                                                                                                                                                                                                                                  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 122<br>123<br>124 | The <i>Multi-type System Memory Profile</i> (DSP1071) was prepared by the CIM Profiles for Platforms and Services Working Group.  DMTF is a not-for-profit association of industry members dedicated to promoting enterprise and systems. |
| 125               | management and interoperability.                                                                                                                                                                                                          |
| 126               | Acknowledgments                                                                                                                                                                                                                           |
| 127               | The DMTF acknowledges the following individuals for their contributions to this document:                                                                                                                                                 |
| 128               | Editor:                                                                                                                                                                                                                                   |
| 129               | Scott Kirvan – Intel                                                                                                                                                                                                                      |
| 130               | Contributors:                                                                                                                                                                                                                             |
| 131               | Paul von Behren – Intel                                                                                                                                                                                                                   |
| 132               | Barbara Craig – Hewlett-Packard                                                                                                                                                                                                           |
| 133               | John Leung – Intel                                                                                                                                                                                                                        |
| 134               |                                                                                                                                                                                                                                           |
| 135               |                                                                                                                                                                                                                                           |

| 136                      | Introduction                                                                                                                                                                                                                                                                                                          |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 137<br>138<br>139        | This specification describes a management profile including the CIM model and associated behavior for computer system memory. Specifically, it addresses uni- and multi-processor systems with one or more individually managed memory extents.                                                                       |
| 140<br>141<br>142<br>143 | The information in this specification should be sufficient for a provider or consumer of this data to unambiguously identify the classes, properties, methods, and values that shall be instantiated to subscribe, advertise, produce, or consume an indication using the DMTF Common Information Model (CIM) Schema. |
| 144<br>145               | The target audience for this specification is implementers who are writing CIM-based providers or consumers of management interfaces that represent the components described in this document.                                                                                                                        |

# Multi-type System Memory Profile

| 147                                    | 1 Scope                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                           |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| 148<br>149<br>150<br>151<br>152<br>153 | The Multi-type System Memory Profile extends the management capabilities of referencing pr adding the ability to detect and monitor individual memory extents in a computer system. Logi extents are modeled in the context of related profiles including those that: 1) model the memo aspects; 2) identify the hosting system; 3) allow for configuration; and 4) define registration inf This profile would generally be used instead of the System Memory Profile (DSP1026) rather conjunction with it. | cal memory<br>ry's physical<br>formation. |
| 154                                    | 2 Normative references                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                           |
| 155<br>156<br>157<br>158               | The following referenced documents are indispensable for the application of this document. For versioned references, only the edition cited (including any corrigenda or DMTF update version For references without a date or version, the latest published edition of the referenced docume (including any corrigenda or DMTF update versions) applies.                                                                                                                                                    | ns) applies.                              |
| 159<br>160                             | DMTF DSP0004, CIM Infrastructure Specification 2.7,<br>http://www.dmtf.org/standards/published_documents/DSP0004_2.7.pdf                                                                                                                                                                                                                                                                                                                                                                                    |                                           |
| 161<br>162                             | DMTF DSP0215, Server Management Managed Element Addressing Specification 1.0, <a href="http://www.dmtf.org/standards/published">http://www.dmtf.org/standards/published</a> documents/DSP0215 1.0.pdf                                                                                                                                                                                                                                                                                                       |                                           |
| 163<br>164                             | DMTF DSP0223, Generic Operations 1.0, <a href="http://www.dmtf.org/standards/published_documents/DSP0223_1.0.pdf">http://www.dmtf.org/standards/published_documents/DSP0223_1.0.pdf</a>                                                                                                                                                                                                                                                                                                                     |                                           |
| 165<br>166                             | DMTF DSP0228, Message Registry XML Schema 1.0,<br>http://schemas.dmtf.org/wbem/messageregistry/1/dsp0228_1.0.1.xsd                                                                                                                                                                                                                                                                                                                                                                                          |                                           |
| 167<br>168                             | DMTF DSP1001, Management Profile Specification Usage Guide 1.1, <a href="http://www.dmtf.org/standards/published_documents/DSP1001_1.1.pdf">http://www.dmtf.org/standards/published_documents/DSP1001_1.1.pdf</a>                                                                                                                                                                                                                                                                                           |                                           |
| 169<br>170                             | DMTF DSP1033, Profile Registration Profile 1.1, <a href="http://dmtf.org/sites/default/files/standards/documents/DSP1033_1.1.0.pdf">http://dmtf.org/sites/default/files/standards/documents/DSP1033_1.1.0.pdf</a>                                                                                                                                                                                                                                                                                           |                                           |
| 171<br>172                             | DMTF DSP1011, Physical Asset Profile <a href="http://dmtf.org/sites/default/files/standards/documents/DSP1011_1.0.2.pdf">http://dmtf.org/sites/default/files/standards/documents/DSP1011_1.0.2.pdf</a>                                                                                                                                                                                                                                                                                                      |                                           |
| 173<br>174                             | DMTF DSP1022, CPU Profile <a href="http://dmtf.org/sites/default/files/standards/documents/DSP1022_1.0.1.pdf">http://dmtf.org/sites/default/files/standards/documents/DSP1022_1.0.1.pdf</a>                                                                                                                                                                                                                                                                                                                 |                                           |
| 175<br>176                             | DMTF DSP8016, WBEM Operations Message Registry 1.0, <a href="http://schemas.dmtf.org/wbem/messageregistry/1/dsp8016_1.0.xml">http://schemas.dmtf.org/wbem/messageregistry/1/dsp8016_1.0.xml</a>                                                                                                                                                                                                                                                                                                             |                                           |
| 177<br>178                             | DMTF DSP8020, Standard Metrics Schema 1.0, <a href="http://schemas.dmtf.org/wbem/metricregistry/1/dsp8020_1.0.xsd">http://schemas.dmtf.org/wbem/metricregistry/1/dsp8020_1.0.xsd</a>                                                                                                                                                                                                                                                                                                                        |                                           |
| 179<br>180                             | IETF RFC5234, ABNF: Augmented BNF for Syntax Specifications, January 2008,<br>http://tools.ietf.org/html/rfc5234                                                                                                                                                                                                                                                                                                                                                                                            |                                           |

| 181 ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standard | 181 | ISO/IEC Directives. | Part 2. | Rules for the | e structure and | l drafting of | f International | Standard |
|------------------------------------------------------------------------------------------------|-----|---------------------|---------|---------------|-----------------|---------------|-----------------|----------|
|------------------------------------------------------------------------------------------------|-----|---------------------|---------|---------------|-----------------|---------------|-----------------|----------|

- http://isotc.iso.org/livelink/livelink.exe?func=ll&objld=4230456&objAction=browse&sort=subtype
- 183 The Open Group, "Regular Expressions" in *The Single UNIX* ® Specification, Version 2,
- http://www.opengroup.org/onlinepubs/7908799/xbd/re.html

#### 3 Terms and definitions

186 **3.1** 

185

- 187 **can**
- 188 used for statements of possibility and capability, whether material, physical, or causal
- 189 **3.2**
- 190 cannot
- 191 used for statements of possibility and capability, whether material, physical, or causal
- 192 **3.3**
- 193 conditional
- 194 used to indicate requirements strictly to be followed, in order to conform to the document when the
- 195 specified conditions are met
- 196 **3.4**
- 197 mandatory
- 198 used to indicate requirements strictly to be followed, in order to conform to the document and from which
- 199 no deviation is permitted
- 200 3.5
- 201 **may**
- 202 used to indicate a course of action permissible within the limits of the document
- 203 3.6
- 204 memory extent
- 205 used generically to indicate a range of memory addresses that can participate in management operations
- 206 3.7
- 207 memory module
- 208 non-technology specific term for a circuit board hosting memory integrated circuits
- 209 3.8
- 210 need not
- 211 used to indicate a course of action permissible within the limits of the document
- 212 **3.9**
- 213 optional
- 214 used to indicate a course of action permissible within the limits of the document
- 215 **3.10**
- 216 persistent memory
- 217 byte addressable memory which retains its contents across system power cycles

| 21         | O  | 2  | 4   | 4 |
|------------|----|----|-----|---|
| <i>/</i> I | ο. | 3. | . 1 |   |

- 219 referencing profile
- 220 indicates a profile that owns the definition of a class used, but not defined, in this document and can be
- 221 included in the "Referenced Profiles" table
- 222 **3.12**
- 223 shall
- 224 used to indicate requirements strictly to be followed, in order to conform to the document and from which
- 225 no deviation is permitted
- 226 **3.13**
- 227 shall not
- 228 used to indicate requirements strictly to be followed, in order to conform to the document and from which
- 229 no deviation is permitted
- 230 3.14
- 231 should
- used to indicate that among several possibilities, one is recommended as particularly suitable, without
- 233 mentioning or excluding others, or that a certain course of action is preferred but not necessarily required
- 234 **3.15**
- 235 should not
- 236 used to indicate that a certain possibility or course of action is deprecated but not prohibited
- 237 **3.16**
- 238 unspecified
- 239 indicates that this profile does not define any constraints for the referenced CIM element or operation

# 240 4 Symbols and abbreviated terms

- 241 **4.1**
- 242 **NUMA**
- 243 Non-Uniform Memory Access
- 244 **4.2**
- 245 **NVM**
- 246 Non-Volatile Memory
- 247 **4.3**
- 248 **PM**
- 249 Persistent Memory
- 250 **4.4**
- 251 **QoS**
- 252 Quality of Service
- 253 **4.5**
- 254 **UMA**
- 255 Uniform Memory Access

# 5 Synopsis

- 257 **Profile Name:** Multi-type System Memory
- 258 **Version:** 1.0.0a
- 259 **Organization:** DMTF
- 260 CIM Schema Version: 2.41
- 261 **Central Class:** CIM VisibleMemory
- 262 Scoping Class: CIM ComputerSystem
- 263 System memory devices have traditional been physical device whose only purpose was a volatile
- memory (e.g., DRAM, SRAM, Cache memory). These memory devices have a fixed size. The
- 265 manageability these types of memory is specified in the DSP1026 (System Memory Profile).
- 266 There also exist system memory devices, whose characteristics can be configured. The characteristics
- include size, affinity, and quality of service. This type of system memory is called multi-type system
- 268 memory.

277

278

- The Multi-type Memory Profile extends the management capabilities of the referencing profiles by adding
- 270 the capability to represent and manage multiple types of memory within a managed system. The profile
- 271 supports systems with one or more memory regions where each region can be individually managed.
- Table 1 identifies profiles on which this profile has a dependency.
- 273 CIM VisibleMemory shall be the Central Class of this profile.
- 274 CIM ComputerSystem shall be the Scoping Class of this profile. The instance of CIM ComputerSystem
- 275 with which the Central Instance is associated through an instance of CIM\_SystemDevice shall be the
- 276 Scoping Instance of this profile.

#### Table 1 – Related profiles

| Profile Name                 | Organization | Version | Relationship |
|------------------------------|--------------|---------|--------------|
| Physical Asset               | DMTF         | 1.0.2   | Mandatory    |
| Profile Registration         | DMTF         | 1.1.0   | Mandatory    |
| CPU                          | DMTF         | 1.0.1   | Conditional  |
| Memory Configuration Profile | SNIA         | 1.0.0a  | Conditional  |

# 6 Description

- The Multi-type System Memory Profile describes the elements which allow multiple types of memory to be represented and managed.
- This profile can be used to manage the following capabilities of memory regions in a system with multiple types of memory.
- A memory region can have specific quality of service (QoS) characteristics, such a persistence, redundancy, block access.
- A memory region can be configured from a pool of raw memory.

- The characteristics of a memory region can be configured.
  - A memory region can be visible to, or have affinity with, specific processors and memory controllers.
  - A memory region can be visible to one or more processors (shared).

Figure 1 shows the Multi-type System Memory Profile class hierarchy. For simplicity, the prefix CIM\_ has been removed from the names of the classes.



Figure 1 - Multi-type System Memory: Class diagram

Each memory region visible to the computer system is modeled by an instance of CIM\_VisibleMemory.

Each physical memory region is associated with its logical counterpart, a raw memory region. Raw memory is not visible to the computer system. Raw memory is modeled by an instance of CIM\_RawMemory and its relationship to the visible memory region is modeled by the CIM\_BasedOn association.

A memory controller configures raw memory to create the visible memory regions. Memory controllers are represented by instances of CIM\_MemoryController and their relationship to the raw memory region is modeled by the CIM\_AssociatedMemory association.

In multi-processor systems, memory extents can have an affinity to a specific processor and memory controller. An affinity relationship between memory and a processor/controller can indicate exclusive or preferential access to the memory by that processor. The Multi-type System Memory Profile models a relationship between raw memory extents and their controller and processor such that a management application can determine memory affinity and the physical memory topology.

The SNIA Memory Configuration Profile may be used to model memory regions. That profile includes the CIM\_MemoryResources and CIM\_MemoryAllocationSetting elements.

| 309 | The CIM_ElementSettingData and CIM_ElementAllocatedFromPool associations are used to model the |
|-----|------------------------------------------------------------------------------------------------|
| 310 | relationship between the elements of these two profiles.                                       |

# 7 Implementation

- 312 This clause details the requirements related to the arrangement of instances and their most important
- 313 properties. Class methods are discussed in clause 8; a comprehensive treatment of properties is left to
- 314 clause 10.

311

#### 315 **7.1 Representing raw memory**

- 316 An instance of CIM\_RawMemory shall represent a memory region which is realized by physical memory,
- 317 but not visible to the computer system. Instances of CIM\_RawMemory shall be associated with an
- instance of CIM\_PhysicalMemory with an instance of CIM\_Realizes.
- There shall be at least one instance of CIM\_RawMemory.
- 320 If SMBIOS structure table models a memory device (Type 17), then CIM RawMemory instance shall
- 321 correspond to a structure in the SMBIOS table. For a corresponding memory device, the values of the
- 322 BlockSize and NumberOfBlocks properties of the CIM\_RawMemory instance shall be equal to the values
- in the corresponding SMBIOS Memory Device (Type 17) structure.

#### 324 7.2 Representing visible memory

- 325 An instance of CIM\_VisibleMemory shall represent a memory region which is visible to the computer
- 326 system. Instances of CIM\_VisibleMemory shall be associated with the instance of CIM\_ComputerSystem
- 327 with an instance of CIM\_SystemDevice.
- 328 There shall be at least one instance of CIM\_VisibileMemory. Additional instances of CIM\_VisibleMemory
- may exist when the system contains more than one memory region with distinct memory characteristics.
- 330 For example, one instance may exist for volatile memory and one for non-volatile memory.
- 331 Each instance of CIM\_VisibleMemory shall be associated with one or more instances of
- 332 CIM RawMemory, using the CIM BasedOn association.

#### 333 7.2.1 CIM VisibleMemory.HealthState

- The CIM\_VisibleMemory.HealthState property may have the values 0 (Unknown), 1 (OK) or 2
- 335 (Degraded).

#### 336 7.2.2 CIM VisibleMemory.EnabledState

- 337 The CIM VisibleMemory.EnabledState property shall have a value of 2 (Enabled) when the visible
- 338 memory that it represents is visible to the computer system to which it's scoped.
- 339 The CIM VisibleMemory. EnabledState property shall have a value of 3 (Disabled) when the visible
- 340 memory, that it represents, is not visible to the computer system to which it's scoped.

#### 341 7.2.3 Representing memory size

- The value of the CIM\_VisibleMemory.BlockSize and the CIM\_VisibleMemory.NumberOfBlocks properties
- shall represent the capacity of the memory region visible to the computer system.
- The capacity, so represented, shall be the visible (or usable) capacity of the underlying memory extent.
- 345 For example, memory controllers may support a mirroring feature which has the effect of cutting in half

- 346 the capacity that is usable by the system. The NumberOfBlocks and BlockSize values shall always take
- into account (i.e., do not include) space utilized for replication, metadata or the like.

#### 348 **7.2.4 CIM\_VisibleMemory.AccessGranularity**

- The CIM VisibleMemory.AccessGranularity property shall have a value of 1 (Block Addressable) when
- the modeled memory region is accessed as a block device. When the memory region is accessed using
- load and store memory operations the value of CIM VisibleMemory.AccessGranularity shall be 2 (Byte
- 352 Addressable). Vendor unique access mechanisms may be represented by values in the vendor reserved
- 353 range of 32768..65535.
- When the access granularity of a memory device modeled by an instance of CIM\_VisibleMemory is not
- known, then CIM VisibleMemory.AccessGranularity shall be set to 0 (Unknown)."

#### 356 7.2.5 CIM\_VisibleMemory.Replication

- 357 The CIM\_VisibleMemory.Replication property shall indicate whether the contents of the memory region
- are replicated. The default value for this property shall be 1 (Not Replicated). If the contents are replicated
- using resources on the local server the value used shall be 2 (Local Replication). If the replicated region
- exists on a different server (e.g., using RDMA or the like) the value shall be 3 (Remote Replication).
- Vendor specific replication mechanisms may be represented by values in the vendor reserved range of
- 362 32768..65535.

363

#### 7.3 Representing topology

- 364 Multi-processor systems are common. Often such systems use a Non-Uniform Memory Access (NUMA)
- configuration in which memory has an "affinity" to a specific processor. In such a system, memory can be
- accessed optimally by a processor to which it has an affinity; it is more costly (often drastically so) to
- 367 access from other processors.
- 368 In addition to optimal and non-optimal access paths, the topology of memory devices within a system can
- 369 limit the system's configuration options. For example a given memory controller may support mirroring
- 370 between memory address ranges of memory modules under its control. In this case it would be important
- 371 to understand which memory modules are associated with specific memory controllers. A second
- example of the importance of topology involves memory interleaving. Memory controllers can enhance
- overall memory performance by interleaving capacity from multiple memory modules. In a NUMA system
- 374 it could be advantageous to restrict interleaving to those memory modules with affinity to a specific
- 375 processor. In this case it would be important to understand the affinity of memory modules for a given
- 376 processor.

380

385

- 377 In a uniprocessor system all memory is accessed by a single processor. Conformant implementations
- 378 include topology information in this degenerate case to minimize special cases for clients attempting to
- 379 discover memory topology.

#### 7.3.1 CIM\_MemoryController

- There may be an instance of CIM\_MemoryContoller.
- When an instance of CIM\_MemoryController exists, it shall be associated to an instance of
- 383 CIM RawMemory, which represents raw memory that the memory controller can make available to the
- 384 computer system, with an instance of CIM\_AssociatedMemory.

#### 7.3.2 CIM Processor

- 386 There may be an instance of CIM\_Processor, which represents a processor with access to managed
- 387 memory regions. CIM\_Processor instances utilized in this way may be those created by an

409

418

- implementation of the CPU Profile. This is the preferred model. Optionally, CIM\_Processor instances may be created specifically for the Multi-type System Memory Profile.
- When an instance of CIM\_Processor exists, it shall be associated to the instance of
- 391 CIM\_ComputerSystem, to which the memory is visible, with an instance of CIM\_SystemDevice.

#### 7.3.3 Representing non-uniform memory access configurations

- The instances of CIM\_Processor shall be associated to one or more instances of CIM\_MemoryController with an instance of CIM\_ConcreteDependency.
- 395 The instances of CIM MemoryController shall be associated to one or more instances of
- 396 CIM\_RawMemory with an instance of CIM\_AssociatedMemory.
- 397 This path from processor to memory controller to raw memory extent describes the NUMA affinity of a
- 398 given memory extent to a given processor.
- 399 Additionally, the CIM\_VisibleMemory.ProcessorAffinity property may optionally be used to indicate a
- 400 preferential relationship between a memory region and a processor. A NUMA relationship is an example
- 401 of such a preferential relationship. When a NUMA relationship exists between a memory region as
- 402 modeled by a CIM\_VisibleMemory instance and a processor given by CIM\_Processor the
- 403 CIM\_VisibleMemory.ProcessorAffinity property is conditionally set to the DeviceID of the processor
- instance. When no affinity exists or this property is not used it shall be set to an empty string.
- When a memory controller has an exclusive or preferential access relationship with a processor this
- 406 relationship may be represented by setting the CIM\_MemoryController.ProcessorAffinity property to the
- DeviceID of the CIM\_Processor instance. When no such relationship exists or the property is not used the
- 408 CIM\_MemoryController.ProcessorAffinity property shall be set to an empty string.

# 7.4 Representing memory configuration

- 410 The Multi-type System Memory Profile models the static configuration of memory within a system. For
- 411 systems that support a configuration process which results in CIM\_VisibleMemory instances this profile
- 412 references the SNIA Memory Configuration Profile, specifically the MemoryAllocationSettings and
- 413 MemoryResources classes and the associations which link them to the Multi-type System Memory Profile.
- 414 See ANNEX A for more information.

## 415 8 Methods

- 416 This clause details the requirements for supporting intrinsic operations for the CIM elements defined by
- 417 this profile. No extrinsic methods are defined by this profile.

#### 8.1 CIM VisibleMemory

- 419 Conformant implementations of this profile shall support the operations listed in Table 2 for
- 420 CIM\_VisibleMemory. Each operation shall be supported as defined in <u>DSP0200</u>.

#### 421 Table 2 – Operations: CIM\_VisibleMemory

| Operation       | Requirement | Messages |
|-----------------|-------------|----------|
| GetInstance     | Mandatory   | None     |
| Associators     | Mandatory   | None     |
| AssociatorNames | Mandatory   | None     |
| References      | Mandatory   | None     |

426

429

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| ReferenceNames         | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

# 422 8.2 CIM\_RawMemory

- 423 Conformant implementations of this profile shall support the operations listed in Table 3 for the
- 424 CIM\_RawMemory class. Each operation shall be supported as defined in <u>DSP0200</u>.

Table 3 - Operations: CIM\_RawMemory

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| Associators            | Mandatory   | None     |
| AssociatorNames        | Mandatory   | None     |
| References             | Mandatory   | None     |
| ReferenceNames         | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

# 8.3 CIM\_MemoryController

- 427 Conformant implementations of this profile shall support the operations listed in Table 4 for the
- 428 CIM\_MemoryController class. Each operation shall be supported as defined in <u>DSP0200</u>.

#### Table 4 – Operations: CIM\_MemoryController

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| Associators            | Mandatory   | None     |
| AssociatorNames        | Mandatory   | None     |
| References             | Mandatory   | None     |
| ReferenceNames         | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

#### 430 8.4 CIM\_Processor

Conformant implementations of this profile shall support the operations listed in Table 5 for the CIM\_memoryController class. Each operation shall be supported as defined in DSP0200.

#### 433

Table 5 - Operations: CIM Processor

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| Associators            | Mandatory   | None     |
| AssociatorNames        | Mandatory   | None     |
| References             | Mandatory   | None     |
| ReferenceNames         | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

# 434 8.5 CIM\_ConcreteDependency

Conformant implementations of this profile shall support the operations listed in Table 6 for the

436 CIM\_ConcreteDependency class. Each operation shall be supported as defined in <u>DSP0200</u>.

#### 437

Table 6 - Operations: CIM\_ConcreteDependency

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

#### 438 8.6 CIM\_AssociatedMemory

Conformant implementations of this profile shall support the operations listed in Table 7 for the CIM AssociatedMemory class. Each operation shall be supported as defined in DSP0200.

#### 441 Table 7 – Operations: CIM\_AssociatedMemory

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

#### 442 8.7 CIM\_BasedOn

Conformant implementations of this profile shall support the operations listed in Table 8 for the CIM BasedOn class. Each operation shall be supported as defined in DSP0200.

#### 445 Table 8 – Operations: CIM\_BasedOn

| Operation              | Requirement | Messages |
|------------------------|-------------|----------|
| GetInstance            | Mandatory   | None     |
| EnumerateInstances     | Mandatory   | None     |
| EnumerateInstanceNames | Mandatory   | None     |

#### 446 9 Use cases

This clause contains object diagrams and use cases for the *Multi-type System Memory Profile*.

## 448 9.1 Advertising profile conformance

Figure 2 shows how an instance of CIM\_RegisteredProfile is used to indicate the presence of a conforming implementation of the *Multi-type System Memory Profile* and to identify instances of its central class CIM\_VisibleMemory.



Figure 2 – Registered Profile object diagram

453

#### 9.2 Single visible memory extent

Figure 3 shows the simplest possible configuration with a single memory module (dimm1) contributing its full capacity to a single memory extent (memory1).



Figure 3 - Single visible memory extent object diagram

#### 9.3 Two visible memory extents

Figure 4 models a system configuration in which memory modules and the memory controller support configuring memory address ranges with unique quality of service characteristics. In this example a single memory module has been configured so as to expose two CIM\_VisibleMemory extents to the system. Figure 4 shows 1 extent as volatile and the other persistent; the quality of service between the two extents is sufficiently different that one would likely manage and use the extents separately.

Exposing the relationship between CIM\_RawMemory and CIM\_VisibleMemory extents allows clients to understand reliability and serviceability characteristics of each extent. Clients utilize the CIM\_BasedOn association to determine the memory module(s) which host any given CIM\_VisibleMemory instance. The position of any given memory module within the system is determined by following the CIM\_AssociatedMemory association to the CIM\_MemoryController instance.

Version 1.0.0 Published 19

471

472

473 474

475

476 477



Figure 4 - Distinct visible memory extents object diagram

# 9.4 Uniform memory access extents

Figure 5 shows a system with a two-processor UMA architecture. The ProcessorAffinity attribute of the

CIM\_VisibleMemory instance is set to an empty string indicating no specific affinity. The

CIM\_RawMemory instance is associated to a CIM\_MemoryController which services memory accesses

from both CIM\_Processor instances. The CIM\_MemoryController.ProcessorAffinity attribute is also set to

the empty string indicating no affinity to a specific processor.

479

480

481

482

483

484

485

486



Figure 5 - UMA configuration object diagram

# 9.5 Non-Uniform Memory Access (NUMA) extents

Figure 6 shows the model for a multi-processor system with memory extents organized to support NUMA. The CIM\_VisibleMemory.ProcessorAffinity property is set to indicate affinity consistent with the results that can be achieved via association traversal (i.e., set to the DeviceID of the affiliated processor). The CIM\_MemoryController.ProcessorAffinity is likewise set to the DeviceID of the processor it supports.

In a single processor system (essentially the left or right half of diagram 9-5 in isolation) processor affinity is set to the identity of the only processor.

Version 1.0.0 Published 21



Figure 6 - NUMA configuration object diagram

# 9.6 Determine persistent memory capacity

Determining the capacity of memory with a given QoS is determined by enumerating the CIM\_VisibleMemory instances with that QoS and examining the NumberOfBlocks and BlockSize attributes. In Figure 4 above there are two equally sized instances, one offers volatile memory, the other persistent. Enumerating VisibleMemory instances and summing capacity for those with the Volatile property set to FALSE would give the total memory capacity offering a persistent QoS. Similarly summing the capacity of VisibleMemory instances whose Volatile property is set to TRUE would give the total memory capacity offering a volatile QoS.

#### 9.7 Determine total installed memory capacity

Total installed memory (in bytes) is calculated by enumerating RawMemory instances and summing the product of NumberOfBlocks and BlockSize.

#### 9.8 Determine capacity by processor affinity

Capacity available to a given processor is determined by following the CIM\_ConcreteDependency association to find CIM\_MemoryController instances and then following the AssociatedMemory association to CIM\_RawMemory instances. Summing the NumberOfBlocks property for the CIM\_RawMemory instances, so located, determines the total capacity with an affinity to the selected processor. In Figure 6, the total capacity with an affinity to the processor in socket 2 is determined by summing the capacity of dimm3 and dimm4.

#### 9.9 Determine processor affinity for visible memory

- Determining whether a given CIM\_VisibleMemory instance (assuming the system has a NUMA
- architecture as given in Figure 6) has NUMA performance characteristics is determined by following the
- 510 CIM BasedOn association to the CIM RawMemory instances. From there, the CIM AssociatedMemory
- association is used to verify that each instance of CIM\_RawMemory is controlled by a single processor.
- 512 Alternatively, the ProcessorAffinity property maybe sufficient to determine affinity for implementations that
- 513 utilize it.

507

514

515 516

517

518

519

520

521

522

523 524

525

#### 10 CIM Elements

Table 9 shows the instances of CIM Elements for this profile. Instances of the following CIM Elements shall be implemented as described in Table 9. Clauses 7 ("Implementation") and 8 ("Methods") may impose additional requirements on these elements.

#### Table 9 - CIM Elements - Multi-type System Memory Profile

| Element Name           | Requirement | Description               |
|------------------------|-------------|---------------------------|
| CIM_RegisteredProfile  | Mandatory   | See subclause 10.1        |
| CIM_VisibleMemory      | Mandatory   | See subclause 10.2, 7.2   |
| CIM_RawMemory          | Mandatory   | See subclause 10.3, 7.1   |
| CIM_MemoryController   | Optional    | See subclause 10.4, 7.3.1 |
| CIM_Processor          | Optional    | See subclause 10.5, 7.3.2 |
| CIM_ConcreteDependency | Mandatory   | See subclause 10.6        |
| CIM_SystemDevice       | Mandatory   | See subclause 10.7        |
| CIM_AssociatedMemory   | Mandatory   | See subclause 10.8        |
| CIM_BasedOn            | Mandatory   | See subclause 10.9        |

#### 10.1 CIM RegisteredProfile

CIM\_RegisteredProfile identifies the *Multi-type System Memory Profile* in order for a client to determine whether an instance of CIM\_VisibleMemory is conformant with this profile. The CIM\_RegisteredProfile class is defined by the *Profile Registration Profile*. With the exception of the mandatory values specified for the properties below, the behavior of the CIM\_RegisteredProfile instance is per the *Profile Registration Profile*. Table 10 contains the requirements for elements of this class.

Table 10 - Class: CIM\_RegisteredProfile

| Elements               | Requirement | Notes                                                           |
|------------------------|-------------|-----------------------------------------------------------------|
| RegisteredName         | Mandatory   | This property shall have a value of "Multi-type System Memory". |
| RegisteredVersion      | Mandatory   | This property shall have a value of "1.0.0".                    |
| RegisteredOrganization | Mandatory   | This property shall have a value of 2 (DMTF).                   |

529

530

533

534

# 10.2 CIM\_VisibleMemory

527 The CIM VisibleMemory class represents memory configured with a given set of QoS attributes. 528

Conformant implementations support attributes as given below.

Table 11 - Class: CIM\_VisibleMemory

| Elements                | Requirement | Notes                                                                 |
|-------------------------|-------------|-----------------------------------------------------------------------|
| CreationClassName       | Mandatory   | Key                                                                   |
| DeviceID                | Mandatory   | Key                                                                   |
| SystemCreationClassName | Mandatory   | Key                                                                   |
| SystemName              | Mandatory   | Key                                                                   |
| Primordial              | Mandatory   | False                                                                 |
| BlockSize               | Mandatory   | Number of bytes per block. See subclause 7.2.3                        |
| NumberOfBlocks          | Mandatory   | Block count; multiply by BlockSize to get bytes. See subclause 7.2.3. |
| OperationalStatus       | Mandatory   | None                                                                  |
| HealthState             | Mandatory   | See subclause 7.2.1                                                   |
| EnabledState            | Mandatory   | See subclause 7.2.2                                                   |
| Volatile                | Optional    | None                                                                  |
| AccessGranularity       | Optional    | Access type. See subclause 7.2.4                                      |
| ProcessorAffinity       | Optional    | Affiliated processor. See subclause 7.3.3                             |
| Replication             | Optional    | Data replication. See subclause 7.2.5                                 |

# 10.3 CIM\_RawMemory

531 The CIM\_RawMemory class represents of the capacity of a given physical memory module. Conformant 532 implementations support attributes as given below.

Table 12 - Class: CIM\_RawMemory

| Elements                | Requirement | Notes                                            |
|-------------------------|-------------|--------------------------------------------------|
| CreationClassName       | Mandatory   | Key                                              |
| DeviceID                | Mandatory   | Key                                              |
| SystemCreationClassName | Mandatory   | Key                                              |
| SystemName              | Mandatory   | Key                                              |
| Primordial              | Mandatory   | True                                             |
| BlockSize               | Mandatory   | Number of bytes per block                        |
| NumberOfBlocks          | Mandatory   | Block count; multiply by BlockSize to get bytes. |
| OperationalStatus       | Mandatory   | None                                             |
| HealthState             | Mandatory   | None                                             |

#### 10.4 CIM\_MemoryController

535 The CIM\_MemoryController class represents the controller for one or more raw memory regions. Memory controller modeling is included in this profile to provide an understanding of the system memory topology. 536 537 Conformant implementations support attributes as given below.

Table 13 - Class: CIM\_MemoryController

| Elements                | Requirement | Notes                                    |
|-------------------------|-------------|------------------------------------------|
| CreationClassName       | Mandatory   | Key                                      |
| DeviceID                | Mandatory   | Key                                      |
| SystemCreationClassName | Mandatory   | Key                                      |
| SystemName              | Mandatory   | Key                                      |
| ProtocolSupported       | Optional    | Identify controller protocol, e.g., DDR3 |
| ProcessorAffinity       | Optional    | Processor affinity. See subclause 7.3.3  |

#### 10.5 CIM\_Processor

The CIM\_Processor class models a processor with access to a visible memory region. This usage of CIM\_Processor includes only those properties useful in identifying a processor instance. When implementing both Multi-type System Memory and the CPU Profiles, Multi-type System Memory profile can refer to instances created in accordance with the CPU Profile. When only the Multi-type System Memory profile is implemented the more limited version given below is used. This class is mandatory to remove any ambiguity as to the NUMA/UMA nature of the memory architecture. Conformant implementations support attributes as given below.

#### 547

548

549

550

539

540

541

542

543 544

545

546

Table 14 - Class: CIM Processor

| Elements                | Requirement | Notes                                                                                                                                                                                              |
|-------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CreationClassName       | Mandatory   | Key                                                                                                                                                                                                |
| DeviceID                | Mandatory   | Key                                                                                                                                                                                                |
| SystemCreationClassName | Mandatory   | Key                                                                                                                                                                                                |
| SystemName              | Mandatory   | Key                                                                                                                                                                                                |
| Family                  | Optional    | This property supported if it can be used to determine processor support for specific memory management features.                                                                                  |
| OtherFamilyDescription  | Conditional | Used if Family value is "1".                                                                                                                                                                       |
| Stepping                | Optional    | This property supported if it can be used to determine processor support for specific memory management features.                                                                                  |
| OtherIdentifyingInfo    | Optional    | This property supported if it can be used to determine processor support for specific memory management features. Recommended values: Processor Type, Processor Model, and Processor Manufacturer. |
| IdentifyingDescriptions | Conditional | If OtherIdentifyingInfo is used.                                                                                                                                                                   |

#### 10.6 CIM\_ConcreteDependency

The CIM\_ConcreteDependency association is used to relate an instance of CIM\_MemoryController to a CIM\_Processor instance. Table 15 contains the requirements for elements of this class.

552

553

554

555

556

557

558

559

560

Table 15 - Class: CIM\_ConcreteDependency

| Elements   | Requirement | Notes                                                                                                                             |
|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Antecedent | Mandatory   | This property shall be a reference to an instance of the CIM_Processor class.  Cardinality is "1*".                               |
| Dependency | Mandatory   | This property shall be a reference to an instance of a concrete subclass of the CIM_MemoryController class.  Cardinality is "1*". |

# 10.7 CIM\_SystemDevice

#### 10.7.1 Relating CIM\_Processor to CIM\_ComputerSystem

CIM\_SystemDevice association is used to relate an instance of CIM\_Processor with an instance of CIM\_ComputerSystem. Table 16 contains the requirements for elements of this class.

#### Table 16 - Class: CIM\_SystemDevice - use 1

| Elements       | Requirement | Notes                                                                                         |
|----------------|-------------|-----------------------------------------------------------------------------------------------|
| GroupComponent | Mandatory   | This property shall be a reference to an instance of CIM_ComputerSystem.  Cardinality is "1". |
| PartComponent  | Mandatory   | This property shall be a reference to an instance of CIM_Processor.  Cardinality is "1*".     |

#### 10.7.2 Relating CIM\_VisibleMemory to CIM\_ComputerSystem

CIM\_SystemDevice association is used to relate an instance of CIM\_VisibleMemory with an instance of CIM\_ComputerSystem. Table 16 contains the requirements for elements of this class.

#### Table 17 - Class: CIM\_SystemDevice - use 2

| Elements       | Requirement | Notes                                                                    |
|----------------|-------------|--------------------------------------------------------------------------|
| GroupComponent | Mandatory   | This property shall be a reference to an instance of CIM_ComputerSystem. |
|                |             | Cardinality is "1".                                                      |
| PartComponent  | Mandatory   | This property shall be a reference to an instance of CIM_VisibleMemory.  |
|                |             | Cardinality is "1*".                                                     |

562

563

564

565

566

567

568

569

# 10.8 CIM\_AssociatedMemory

The CIM\_AssociatedMemory association is used to relate the CIM\_MemoryController instance to the CIM\_RawMemory instance to which it applies. Table 18 contains the requirements for elements of this class.

Table 18 - Class: CIM\_AssociatedMemory

| Elements   | Requirement | Notes                                                                                               |
|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Antecedent | Mandatory   | This property shall be a reference to an instance of the CIM_RawMemory class.  Cardinality is "1*". |
|            |             | Cardinality is 1                                                                                    |
| Dependent  | Mandatory   | This property shall be a reference to an instance of the CIM_MemoryController class.                |
|            |             | Cardinality is "1*".                                                                                |

#### 10.9 CIM\_BasedOn

The CIM\_BasedOn association is used to relate the CIM\_VisibleMemory to the CIM\_RawMemory on which it is hosted. Table 19 contains the requirements for elements of this class.

Table 19 - Class: CIM\_BasedOn

| Elements   | Requirement | Notes                                                                                              |
|------------|-------------|----------------------------------------------------------------------------------------------------|
| Antecedent | Mandatory   | This property shall be a reference to an instance of the CIM_RawMemory class.  Cardinality is "1". |
| Dependent  | Mandatory   | This property shall be a reference to an instance of the CIM_VisibleMemory.  Cardinality is "1".   |

# ANNEX A (informative)

# **SNIA Memory Configuration Profile**

This profile, the Multi-type System Memory Profile is being pursued with the DMTF while a closely related profile tentatively named the *Memory Configuration Profile* is being pursued with SNIA. Since memory management has been the purview of the DMTF it was felt that the static view defined by the Multi-type System Memory Profile was best pursued with the DMTF as a follow-on to the existing System Memory Profile. The management of memory configuration is being pursued with SNIA for similar reasons, its similarity to existing SNIA profiles and the blurring of the typical roles played by memory and storage. Indeed, the primary motivation for updating memory management profiles at this time is the recent introduction of non-volatile memory technologies that use typical memory form factors (e.g., DIMM) and typical memory interconnects (e.g., DDR3) but have features/characteristics usually associated with storage.

The SNIA Memory Configuration Profile is conceived as building upon the Multi-type System Memory Profile. As such its detailed definition is trailing the definition provided in this document. That said, some high-level definition has occurred and may be useful in putting the Multi-type System Memory Profile in context. Figure 7 below identifies key classes in the Memory Configuration Profile focusing on those that associate with Multi-type System Memory Profile classes.



Figure 7 - Memory Configuration Profile

- **ComputerSystem** from the referencing profile
  - **VisibleMemory** the central class of the Multi-type System Memory Profile. A system visible memory resource.
  - RawMemory referenced from the Multi-type System Memory Profile, a primordial memory extent associated with a specific memory module.

28 Published Version 1.0.0

#### **DSP1071**

598

599

600

601

602

603

604

#### Multi-type System Memory Profile

- **MemoryAllocationSettings** the settings provided during the provisioning process that resulted in a given VisibleMemory instance. Also used as input to the provisioning extrinsic method.
  - **MemoryAllocationService** provides extrinsic methods for memory configuration. These methods result in the allocation or return of resources to the MemoryResources pool and the creation or destruction of VisibleMemory instances.
  - **MemoryConfigurationCapabilities** describes the supported extrinsic method support available from the MemoryAllocationService.
  - **MemoryCapabilities** describes the configurable features of the resources aggregated under the MemoryResources pool.

Version 1.0.0 Published 29

605 ANNEX B 606 (informative) 607

608 Change log

| Version | Date       | Description |
|---------|------------|-------------|
| 1.0.0   | 2017-01-19 |             |
|         |            |             |

609