What is physical memory in windows

Virtual and Physical Memory

The engine provides a number of methods for reading and writing the virtual and physical memory of a target.

Virtual Memory

When specifying a location in the virtual memory of a target, the target’s virtual address space is used. In user-mode debugging, this is the virtual address space of the current process. In kernel-mode debugging, this is the virtual address space of the implicit process. See Threads and Processes for more information about the current and implicit process.

The virtual memory (of the target) can be read by using ReadVirtual and written using WriteVirtual.

Pointers in the target’s memory can be read and written by using the convenience methods ReadPointersVirtual and WritePointersVirtual. These methods will automatically convert between the 64-bit pointers used by the engine and the native pointers used by the target. These methods are useful when requesting memory that contains pointers that will be used for subsequent requests — for example, a pointer to a string.

The SearchVirtual and SearchVirtual2 methods can be used to search the target’s virtual memory for a pattern of bytes.

The FillVirtual method can be used to copy a pattern of bytes, multiple times, to the target’s virtual memory.

The target’s virtual memory can also be read and written in a way that bypasses the debugger engine’s virtual memory cache using the methods ReadVirtualUncached and WriteVirtualUncached. These uncached versions are useful for reading virtual memory that is inherently volatile, such as memory-mapped device areas, without contaminating or invalidating the cache. Uncached memory access should only be used in situations when it is required, as the performance of uncached access can be significantly lower than cached access.

The engine provides some convenience methods to read strings from the target’s virtual memory. To read a multibyte string from the target, use ReadMultiByteStringVirtual and ReadMultiByteStringVirtualWide. To read a Unicode string from the target, use ReadUnicodeStringVirtual and ReadUnicodeStringVirtualWide.

To find information about a memory location, use GetOffsetInformation. Not all of the virtual address space in the target contains valid memory. To find valid memory within a region, use GetValidRegionVirtual. When manually searching for valid memory in a target, the method GetNextDifferentlyValidOffsetVirtual will find the next location where the validity may change.

Physical Memory

The physical memory can only be directly accessed in kernel-mode debugging.

The FillPhysical method can be used to copy a pattern of bytes, multiple times, to the target’s physical memory.

An address in the target’s virtual address space can be translated to a physical address on the target by using the VirtualToPhysical method. The system’s paging structures used to translate a virtual address to a physical address can be found by using GetVirtualTranslationPhysicalOffsets.

Events

When the virtual or physical memory of the target is changed, the IDebugEventCallbacks::ChangeDebuggeeState callback method is called.

Win32_PhysicalMemory class

The Win32_PhysicalMemory WMI class represents a physical memory device located on a computer system and available to the operating system.

The following syntax is simplified from Managed Object Format (MOF) code and includes all of the inherited properties. Properties are listed in alphabetic order, not MOF order.

Syntax

Members

The Win32_PhysicalMemory class has these types of members:

Properties

The Win32_PhysicalMemory class has these properties.

Attributes

Data type: uint32

Access type: Read-only

SMBIOS — Type 17 — Attributes. Represents the RANK.

This value comes from the Attributes member of the Memory Device structure in the SMBIOS information.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

BankLabel

Data type: string

Читайте также:  Linux как сделать загрузочный iso образ

Access type: Read-only

Physically labeled bank where the memory is located.

Examples: «Bank 0», «Bank A»

This value comes from the Bank Locator member of the Memory Device structure in the SMBIOS information.

Capacity

Data type: uint64

Access type: Read-only

Total capacity of the physical memory—in bytes.

This value comes from the Memory Device structure in the SMBIOS version information. For SMBIOS versions 2.1 thru 2.6 the value comes from the Size member. For SMBIOS version 2.7+ the value comes from the Extended Size member.

For more information about using uint64 values in scripts, see Scripting in WMI.

Caption

Data type: string

Access type: Read-only

Short description of the object—a one-line string.

ConfiguredClockSpeed

Data type: uint32

Access type: Read-only

Qualifiers: MappingStrings («SMBIOS|Type 17|Configured Memory Clock Speed»)

The configured clock speed of the memory device, in megahertz (MHz), or 0, if the speed is unknown.

This value comes from the Configured Memory Clock Speed member of the Memory Device structure in the SMBIOS information.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

ConfiguredVoltage

Data type: uint32

Access type: Read-only

Qualifiers: MappingStrings («SMBIOS|Type 17|Configured voltage»)

Configured voltage for this device, in millivolts, or 0, if the voltage is unknown.

This value comes from the Configured voltage member of the Memory Device structure in the SMBIOS information.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

CreationClassName

Data type: string

Access type: Read-only

Name of the first concrete class that appears in the inheritance chain used in the creation of an instance. When used with the other key properties of the class, the property allows all instances of this class and its subclasses to be identified uniquely.

DataWidth

Data type: uint16

Access type: Read-only

Data width of the physical memory—in bits. A data width of 0 (zero) and a total width of 8 (eight) indicates that the memory is used solely to provide error correction bits.

This value comes from the Data Width member of the Memory Device structure in the SMBIOS information.

Description

Data type: string

Access type: Read-only

Description of an object.

DeviceLocator

Data type: string

Access type: Read-only

Label of the socket or circuit board that holds the memory.

This value comes from the Device Locator member of the Memory Device structure in the SMBIOS information.

FormFactor

Data type: uint16

Access type: Read-only

Implementation form factor for the chip.

This value comes from the Form Factor member of the Memory Device structure in the SMBIOS information.

This property is inherited from CIM_Chip.

HotSwappable

Data type: boolean

Access type: Read-only

If TRUE, this physical media component can be replaced with a physically different but equivalent one while the containing package has the power applied. For example, a fan component may be designed to be hot-swapped. All components that can be hot-swapped are inherently removable and replaceable.

InstallDate

Data type: datetime

Access type: Read-only

Date and time the object is installed. This property does not need a value to indicate that the object is installed.

InterleaveDataDepth

Data type: uint16

Access type: Read-only

Qualifiers: MappingStrings («SMBIOS|Type 20|Interleaved Data Depth»)

Unsigned 16-bit integer maximum number of consecutive rows of data that are accessed in a single interleaved transfer from the memory device. If the value is 0 (zero), the memory is not interleaved.

InterleavePosition

Data type: uint32

Access type: Read-only

Qualifiers: MappingStrings («MIF.DMTF|Memory Device Mapped Addresses|001.7»)

Читайте также:  Как открыть документ линукс

Position of the physical memory in an interleave. For example, in a 2:1 interleave, a value of «1» indicates that the memory is in the «even» position.

Manufacturer

Data type: string

Access type: Read-only

Name of the organization responsible for producing the physical element.

This value comes from the Manufacturer member of the Memory Device structure in the SMBIOS information.

MaxVoltage

Data type: uint32

Access type: Read-only

The maximum operating voltage for this device, in millivolts, or 0, if the voltage is unknown.

This value comes from the Maximum voltage member of the Memory Device structure in the SMBIOS information.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

MemoryType

Data type: uint16

Access type: Read-only

Type of physical memory. This is a CIM value that is mapped to the SMBIOS value. The SMBIOSMemoryType property contains the raw SMBIOS memory type.

This value comes from the Memory Type member of the Memory Device structure in the SMBIOS information.

Unknown (0)

Other (1)

DRAM (2)

Synchronous DRAM (3)

Cache DRAM (4)

EDO (5)

EDRAM (6)

VRAM (7)

SRAM (8)

RAM (9)

ROM (10)

Flash (11)

EEPROM (12)

FEPROM (13)

EPROM (14)

CDRAM (15)

3DRAM (16)

SDRAM (17)

SGRAM (18)

RDRAM (19)

DDR (20)

DDR2 (21)

DDR2—May not be available.

DDR2 FB-DIMM (22)

DDR2—FB-DIMM,May not be available.

DDR3—May not be available.

DDR4 (26)

MinVoltage

Data type: uint32

Access type: Read-only

The minimum operating voltage for this device, in millivolts, or 0, if the voltage is unknown.

This value comes from the Minimum voltage member of the Memory Device structure in the SMBIOS information.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

Model

Data type: string

Access type: Read-only

Name for the physical element.

Name

Data type: string

Access type: Read-only

Label for the object. When subclassed, the property can be overridden to be a key property.

OtherIdentifyingInfo

Data type: string

Access type: Read-only

Additional data, beyond asset tag information, that can be used to identify a physical element. One example is bar code data associated with an element that also has an asset tag. If only bar code data is available and unique or able to be used as an element key, this property is be NULL and the bar code data is used as the class key in the tag property.

PartNumber

Data type: string

Access type: Read-only

Part number assigned by the organization responsible for producing or manufacturing the physical element.

This value comes from the Part Number member of the Memory Device structure in the SMBIOS information.

PositionInRow

Data type: uint32

Access type: Read-only

Qualifiers: MappingStrings («MIF.DMTF|Memory Device Mapped Addresses|001.6»)

Position of the physical memory in a row. For example, if it takes two 8-bit memory devices to form a 16-bit row, then a value of 2 (two) means that this memory is the second device—0 (zero) is an invalid value for this property.

PoweredOn

Data type: boolean

Access type: Read-only

If TRUE, the physical element is powered on.

Removable

Data type: boolean

Access type: Read-only

If TRUE, a physical component is removable (if it is designed to be taken in and out of the physical container in which it is normally found, without impairing the function of the overall packaging). A component can still be removable if power must be «off» to perform the removal. If power can be «on» and the component removed, then the element is removable and can be hot-swapped. For example, an upgradable processor chip is removable.

Читайте также:  Шрифт times new roman для линукс

Replaceable

Data type: boolean

Access type: Read-only

If TRUE, this physical media component can be replaced with a physically different one. For example, some computer systems allow the main processor chip to be upgraded to one of a higher clock rating. In this case, the processor is said to be replaceable. All removable components are inherently replaceable.

SerialNumber

Data type: string

Access type: Read-only

Manufacturer-allocated number to identify the physical element.

This value comes from the Serial Number member of the Memory Device structure in the SMBIOS information.

SKU

Data type: string

Access type: Read-only

Stock keeping unit number for the physical element.

SMBIOSMemoryType

Data type: uint32

Access type: Read-only

The raw SMBIOS memory type. The value of the MemoryType property is a CIM value that is mapped to the SMBIOS value.

Windows ServerВ 2012В R2, WindowsВ 8.1, Windows ServerВ 2012, WindowsВ 8, Windows ServerВ 2008В R2, WindowsВ 7, Windows ServerВ 2008 and WindowsВ Vista: This property is not supported before Windows ServerВ 2016 and WindowsВ 10.

Speed

Data type: uint32

Access type: Read-only

Speed of the physical memory—in nanoseconds.

This value comes from the Speed member of the Memory Device structure in the SMBIOS information.

Status

Data type: string

Access type: Read-only

Current status of the object. Various operational and nonoperational statuses can be defined. Operational statuses include: «OK», «Degraded», and «Pred Fail» (an element, such as a SMART-enabled hard disk drive, may be functioning properly but predicting a failure in the near future). Nonoperational statuses include: «Error», «Starting», «Stopping», and «Service». The latter, «Service», could apply during mirror-resilvering of a disk, reload of a user permissions list, or other administrative work. Not all such work is online, yet the managed element is neither «OK» nor in one of the other states.

The possible values are.

OK («OK»)

Error («Error»)

Degraded («Degraded»)

Unknown («Unknown»)

Pred Fail («Pred Fail»)

Starting («Starting»)

Stopping («Stopping»)

Service («Service»)

Stressed («Stressed»)

NonRecover («NonRecover»)

No Contact («No Contact»)

Lost Comm («Lost Comm»)

Tag

Data type: string

Access type: Read-only

Unique identifier for the physical memory device that is represented by an instance of Win32_PhysicalMemory. This property is inherited from CIM_PhysicalElement.

Example: «Physical Memory 1»

TotalWidth

Data type: uint16

Access type: Read-only

Total width, in bits, of the physical memory, including check or error correction bits. If there are no error correction bits, the value in this property should match what is specified for the DataWidth property.

This value comes from the Total Width member of the Memory Device structure in the SMBIOS information.

TypeDetail

Data type: uint16

Access type: Read-only

Type of physical memory represented.

This value comes from the Type Detail member of the Memory Device structure in the SMBIOS information.

Reserved (1)

Other (2)

Unknown (4)

Fast-paged (8)

Static column (16)

Pseudo-static (32)

RAMBUS (64)

Synchronous (128)

CMOS (256)

EDO (512)

Window DRAM (1024)

Cache DRAM (2048)

Non-volatile (4096)

Version

Data type: string

Access type: Read-only

Version of the physical element.

Remarks

The Win32_PhysicalMemory class is derived from CIM_PhysicalMemory.

Examples

The Get-ComputerInfo — Query Computer Info From Local/Remote Computers — (WMI) PowerShell sample on TechNet Gallery uses a number of calls to hardware and software, including Win32_PhysicalMemory, to display information about a local or remote system.

The Server Report PowerShell sample on TechNet gallery uses a number of calls to hardware and software, including Win32_PhysicalMemory, to gather server information and publish in Word document.

The following PowerShell code sample retrieves information regarding the physical memory of the local computer.

Оцените статью