Memory#
Operations related to AMD GPU memory access. More...
| Data Structures | |
| struct | amd_dbgapi_address_class_id_t | 
| Opaque source language address class handle.  More... | |
| struct | amd_dbgapi_address_space_id_t | 
| Opaque address space handle.  More... | |
| Macros | |
| #define | AMD_DBGAPI_LANE_NONE ((amd_dbgapi_lane_id_t) (-1)) | 
| The NULL lane handle.  More... | |
| #define | AMD_DBGAPI_ADDRESS_CLASS_NONE AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_class_id_t, 0) | 
| The NULL address class handle.  More... | |
| #define | AMD_DBGAPI_ADDRESS_SPACE_NONE AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_space_id_t, 0) | 
| The NULL address space handle.  More... | |
| #define | AMD_DBGAPI_ADDRESS_SPACE_GLOBAL AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_space_id_t, 1) | 
| The global address space handle.  More... | |
| Typedefs | |
| typedef uint32_t | amd_dbgapi_lane_id_t | 
| A wave lane handle.  More... | |
| typedef uint64_t | amd_dbgapi_segment_address_t | 
| Each address space has its own linear address to access it termed a segment address.  More... | |
Detailed Description
Operations related to AMD GPU memory access.
The AMD GPU supports allocating memory in different address spaces. See User Guide for AMDGPU Backend - LLVM - Address Spaces.
Macro Definition Documentation
◆ AMD_DBGAPI_ADDRESS_CLASS_NONE
| #define AMD_DBGAPI_ADDRESS_CLASS_NONE AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_class_id_t, 0) | 
The NULL address class handle.
◆ AMD_DBGAPI_ADDRESS_SPACE_GLOBAL
| #define AMD_DBGAPI_ADDRESS_SPACE_GLOBAL AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_space_id_t, 1) | 
The global address space handle.
Every architecture supports a global address space that uses the same address space ID.
◆ AMD_DBGAPI_ADDRESS_SPACE_NONE
| #define AMD_DBGAPI_ADDRESS_SPACE_NONE AMD_DBGAPI_HANDLE_LITERAL (amd_dbgapi_address_space_id_t, 0) | 
The NULL address space handle.
◆ AMD_DBGAPI_LANE_NONE
| #define AMD_DBGAPI_LANE_NONE ((amd_dbgapi_lane_id_t) (-1)) | 
The NULL lane handle.
Typedef Documentation
◆ amd_dbgapi_lane_id_t
| typedef uint32_t amd_dbgapi_lane_id_t | 
A wave lane handle.
A wave can have one or more lanes controlled by an execution mask. Vector instructions will be performed for each lane of the wave that the execution mask has enabled. Vector instructions can access registers that are vector registers. A vector register has a separate value for each lane, and vector instructions will access the corresponding component for each lane's evaluation of the instruction.
The number of lanes of a wave can be obtained with the AMD_DBGAPI_WAVE_INFO_LANE_COUNT query. Different waves of the same architecture can have different lane counts.
The AMD GPU compiler may map source language threads of execution to lanes of a wave. The DWARF debug information which maps such source languages to the generated architecture specific code must include information about the lane mapping.
The DW_ASPACE_AMDGPU_private_lane DWARF address space supports memory allocated independently for each lane of a wave.
Lanes are numbered from 0 to AMD_DBGAPI_WAVE_INFO_LANE_COUNT minus 1.
Only unique for a single wave of a single process.
◆ amd_dbgapi_segment_address_t
| typedef uint64_t amd_dbgapi_segment_address_t | 
Each address space has its own linear address to access it termed a segment address.
Different address spaces may have memory locations that alias each other, but the segment address for such memory locations may be different in each address space. Consequently a segment address is specific to an address space.
Some address spaces may access memory that is allocated independently for each workgroup, for each wave, or for each lane of of a wave. Consequently a segment address may be specific to a wave or lane of a wave.
Enumeration Type Documentation
◆ amd_dbgapi_address_class_info_t
Source language address class queries that are supported by amd_dbgapi_address_class_get_info.
Each query specifies the type of data returned in the value argument to amd_dbgapi_address_class_get_info. 
| Enumerator | |
|---|---|
| AMD_DBGAPI_ADDRESS_CLASS_INFO_NAME | Return the source language address class name. The type of this attribute is a pointer to a NUL terminated  | 
| AMD_DBGAPI_ADDRESS_CLASS_INFO_ADDRESS_SPACE | Return the architecture specific address space that is used to implement a pointer or reference to the source language address class. The type of this attribute is amd_dbgapi_address_class_id_t. See User Guide for AMDGPU Backend - Code Object - DWARF - Address Class Mapping. | 
| AMD_DBGAPI_ADDRESS_CLASS_INFO_DWARF | Return the AMD GPU DWARF address class number for the address class' architecture. The type of this attribute is  | 
◆ amd_dbgapi_address_class_state_t
Indication of whether a segment address in an address space is a member of an source language address class.
◆ amd_dbgapi_address_space_access_t
Indication of how the address space is accessed.
◆ amd_dbgapi_address_space_info_t
Address space queries that are supported by amd_dbgapi_address_space_get_info.
Each query specifies the type of data returned in the value argument to amd_dbgapi_address_space_get_info. 
| Enumerator | |
|---|---|
| AMD_DBGAPI_ADDRESS_SPACE_INFO_NAME | Return the address space name. The type of this attribute is a pointer to a NUL terminated  | 
| AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE | Return the byte size of an address in the address space. The type of this attribute is amd_dbgapi_size_t. | 
| AMD_DBGAPI_ADDRESS_SPACE_INFO_NULL_ADDRESS | Return the NULL segment address value in the address space. The type of this attribute is  | 
| AMD_DBGAPI_ADDRESS_SPACE_INFO_ACCESS | Return the address space access. The type of this attribute is  | 
| AMD_DBGAPI_ADDRESS_SPACE_INFO_DWARF | Return the AMD GPU DWARF address space number for the address space's architecture. The type of this attribute is  | 
◆ amd_dbgapi_memory_precision_t
Memory access precision.
The AMD GPU can overlap the execution of memory instructions with other instructions. This can result in a wave stopping due to a memory violation or hardware data watchpoint hit with a program counter beyond the instruction that caused the wave to stop.
Some architectures allow the hardware to be configured to always wait for memory operations to complete before continuing. This will result in the wave stopping at the instruction immediately after the one that caused the stop event. Enabling this mode can make execution of waves significantly slower.
The AMD_DBGAPI_PROCESS_INFO_PRECISE_MEMORY_SUPPORTED query can be used to determine if the architectures of all the agents of a process support controlling precise memory accesses.
◆ amd_dbgapi_segment_address_dependency_t
The dependency when reading or writing a specific segment address of an address space using the amd_dbgapi_read_memory and amd_dbgapi_write_memory operations.
Function Documentation
◆ amd_dbgapi_address_class_get_info()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_address_class_get_info | ( | amd_dbgapi_address_class_id_t | address_class_id, | 
| amd_dbgapi_address_class_info_t | query, | ||
| size_t | value_size, | ||
| void * | value | ||
| ) | 
Query information about a source language address class of an architecture.
amd_dbgapi_address_class_info_t specifies the queries supported and the type returned using the value argument.
- Parameters
- 
  [in] address_class_id The handle of the source language address class being queried. [in] query The query being requested. [in] value_size Size of the memory pointed to by value. Must be equal to the byte size of the query result.[out] value Pointer to memory where the query result is stored. 
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in value.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and valueis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_CLASS_ID address_class_idis invalid.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT valueis NULL orqueryis invalid.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY value_sizedoes not match the size of thequeryresult.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_CLIENT_CALLBACK This will be reported if the amd_dbgapi_callbacks_s::allocate_memory callback used to allocate valuereturns NULL.valueis unaltered.
◆ amd_dbgapi_address_dependency()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_address_dependency | ( | amd_dbgapi_address_space_id_t | address_space_id, | 
| amd_dbgapi_segment_address_t | segment_address, | ||
| amd_dbgapi_segment_address_dependency_t * | segment_address_dependency | ||
| ) | 
Determine the dependency of a segment address value in a particular address space.
This indicates which arguments amd_dbgapi_read_memory and amd_dbgapi_write_memory require when reading and writing memory when given a specific segment address in an address space.
- Parameters
- 
  [in] address_space_id The address space of the segment_address.[in] segment_address The integral value of the segment address. Only the bits corresponding to the address size for the address_space_idrequested are used. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[out] segment_address_dependency The dependency of the segment_addressvalue inaddress_space_id. Will be a value of amd_dbgapi_segment_address_dependency_t other than AMD_DBGAPI_SEGMENT_ADDRESS_DEPENDENCE_NONE.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in segment_address_dependencies.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and segment_address_dependenciesis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and destination_segment_addressandsegment_address_dependenciesis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID address_space_idis invalid.segment_address_dependenciesis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT segment_address_dependenciesis NULL.segment_address_dependenciesis unaltered.
◆ amd_dbgapi_address_is_in_address_class()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_address_is_in_address_class | ( | amd_dbgapi_wave_id_t | wave_id, | 
| amd_dbgapi_lane_id_t | lane_id, | ||
| amd_dbgapi_address_space_id_t | address_space_id, | ||
| amd_dbgapi_segment_address_t | segment_address, | ||
| amd_dbgapi_address_class_id_t | address_class_id, | ||
| amd_dbgapi_address_class_state_t * | address_class_state | ||
| ) | 
Determine if a segment address in an address space is a member of a source language address class.
The address space and source language address class must both belong to the same architecture.
The address space, source language address class, and wave must all belong to the same architecture.
- Parameters
- 
  [in] wave_id The wave that is using the address. If the address_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL thenwave_idmay be AMD_DBGAPI_WAVE_NONE, as the address space does not depend on the active wave, in which caseprocess_idis used.[in] lane_id The lane of the wave_idthat is using the address. If theaddress_spacedoes not depend on the active lane then this may be AMD_DBGAPI_LANE_NONE. For example, the AMD_DBGAPI_ADDRESS_SPACE_GLOBAL address space does not depend on the lane.[in] address_space_id The address space of the segment_address. If the address space is dependent on: the active lane then thelane_idwith in thewave_idis used; the active workgroup then the workgroup ofwave_idis used; or the active wave then thewave_idis used.[in] segment_address The integral value of the segment address. Only the bits corresponding to the address size for the address_spacerequested are used. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[in] address_class_id The handle of the source language address class. [out] address_class_state AMD_DBGAPI_ADDRESS_CLASS_STATE_NOT_MEMBER if the address is not in the address class. AMD_DBGAPI_ADDRESS_CLASS_STATE_MEMBER if the address is in the address class. 
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in address_class_state.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_WAVE_ID wave_idis invalid, orwave_idis AMD_DBGAPI_WAVE_NONE andaddress_spaceis not AMD_DBGAPI_ADDRESS_SPACE_GLOBAL.address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_LANE_ID wave_idis AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE.wave_idis not AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE and is not valid forwave_id.lane_idis AMD_DBGAPI_LANE_NONE andaddress_space_iddepends on the active lane.address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID address_space_idis invalid.address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_CLASS_ID address_class_idis invalid.address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT address_class_stateis NULL.address_class_stateis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY The architectures of wave_id,address_space_id, andaddress_class_idare not the same.address_class_stateis unaltered.
◆ amd_dbgapi_address_space_get_info()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_address_space_get_info | ( | amd_dbgapi_address_space_id_t | address_space_id, | 
| amd_dbgapi_address_space_info_t | query, | ||
| size_t | value_size, | ||
| void * | value | ||
| ) | 
Query information about an address space.
amd_dbgapi_address_space_info_t specifies the queries supported and the type returned using the value argument.
- Parameters
- 
  [in] address_space_id The address space. [in] query The query being requested. [in] value_size Size of the memory pointed to by value. Must be equal to the byte size of the query result.[out] value Pointer to memory where the query result is stored. 
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in value.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and valueis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID address_space_idis invalid.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT queryis invalid orvalueis NULL.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY value_sizedoes not match the size of thequeryresult.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_CLIENT_CALLBACK This will be reported if the amd_dbgapi_callbacks_s::allocate_memory callback used to allocate valuereturns NULL.valueis unaltered.
◆ amd_dbgapi_architecture_address_class_list()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_architecture_address_class_list | ( | amd_dbgapi_architecture_id_t | architecture_id, | 
| size_t * | address_class_count, | ||
| amd_dbgapi_address_class_id_t ** | address_classes | ||
| ) | 
Report the list of source language address classes supported by the architecture.
The order of the source language address class handles in the list is stable between calls.
- Parameters
- 
  [in] architecture_id The architecture being queried. [out] address_class_count The number of architecture source language address classes. [out] address_classes A pointer to an array of amd_dbgapi_address_class_id_t with address_class_countelements. It is allocated by the amd_dbgapi_callbacks_s::allocate_memory callback and is owned by the client.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in address_class_countandaddress_classes.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized; and address_class_countandaddress_classesare unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized; and address_class_countandaddress_classesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARCHITECTURE_ID architecture_idis invalid.address_class_countandaddress_classesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT address_class_countoraddress_classesare NULL.address_class_countandaddress_classesare unaltered.AMD_DBGAPI_STATUS_ERROR_CLIENT_CALLBACK This will be reported if the amd_dbgapi_callbacks_s::allocate_memory callback used to allocate address_classesreturns NULL.address_class_countandaddress_classesare unaltered.
◆ amd_dbgapi_architecture_address_space_list()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_architecture_address_space_list | ( | amd_dbgapi_architecture_id_t | architecture_id, | 
| size_t * | address_space_count, | ||
| amd_dbgapi_address_space_id_t ** | address_spaces | ||
| ) | 
Report the list of address spaces supported by the architecture.
The order of the address space handles in the list is stable between calls.
- Parameters
- 
  [in] architecture_id The architecture being queried. [out] address_space_count The number of architecture address spaces. [out] address_spaces A pointer to an array of amd_dbgapi_address_space_id_t with address_space_countelements. It is allocated by the amd_dbgapi_callbacks_s::allocate_memory callback and is owned by the client.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in address_space_countandaddress_spaces.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized; and address_space_countandaddress_spacesare unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized; and address_space_countandaddress_spacesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARCHITECTURE_ID architecture_idis invalid.address_space_countandaddress_spacesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT address_space_countandaddress_spacesare NULL.address_space_countandaddress_spacesare unaltered.AMD_DBGAPI_STATUS_ERROR_CLIENT_CALLBACK This will be reported if the amd_dbgapi_callbacks_s::allocate_memory callback used to allocate address_spacesreturns NULL.address_space_countandaddress_spacesare unaltered.
◆ amd_dbgapi_convert_address_space()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_convert_address_space | ( | amd_dbgapi_wave_id_t | wave_id, | 
| amd_dbgapi_lane_id_t | lane_id, | ||
| amd_dbgapi_address_space_id_t | source_address_space_id, | ||
| amd_dbgapi_segment_address_t | source_segment_address, | ||
| amd_dbgapi_address_space_id_t | destination_address_space_id, | ||
| amd_dbgapi_segment_address_t * | destination_segment_address, | ||
| amd_dbgapi_size_t * | destination_contiguous_bytes | ||
| ) | 
Convert a source segment address in the source address space into a destination segment address in the destination address space.
If the source segment address is the NULL value in the source address space then it is converted to the NULL value in the destination address space. The NULL address is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_NULL_ADDRESS query.
An error is returned if the source segment address has no corresponding segment address in the destination address space.
The source and destination address spaces do not have to have the same linear ordering. For example, for AMD GPU the private_swizzled address space is implemented as global address space memory that interleaves the dwords of the wave's lanes. So converting a private_swizzled address to a global address will result in the corresponding scratch backing memory address. The destination_contiguous_bytes will indicate how many bytes, starting at the destination_segment_address, before the scratch backing memory corresponds to a dword of the adjacent lane. To get the scratch backing memory address of the byte after destination_contiguous_bytes bytes requires amd_dbgapi_convert_address_space to be called again with the address source_segment_address plus destination_contiguous_bytes.
A client can use this operation to help manage caching the bytes of different address spaces. An address in an address space that is being accessed can attempt to be converted to the various address spaces being cached to see if it aliases with bytes being cached under a different address space. For example, an address in the AMD GPU generic address space may alias with an address in the global, private_swizzled, or local address spaces.
- Parameters
- 
  [in] wave_id The wave that is using the address. If the address_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL thenwave_idmay be AMD_DBGAPI_WAVE_NONE, as the address space does not depend on the active wave, in which caseprocess_idis used.[in] lane_id The lane of the wave_idthat is using the address. If theaddress_spacedoes not depend on the active lane then this may be AMD_DBGAPI_LANE_NONE. For example, the AMD_DBGAPI_ADDRESS_SPACE_GLOBAL address space does not depend on the lane.[in] source_address_space_id The address space of the source_segment_address.[in] source_segment_address The integral value of the source segment address. Only the bits corresponding to the address size for the source_address_space_idrequested are used. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[in] destination_address_space_id The address space to which to convert source_segment_addressthat is insource_address_space_id.[out] destination_segment_address The integral value of the segment address in destination_address_space_idthat corresponds tosource_segment_addressinsource_address_space_id. The bits corresponding to the address size for thedestination_address_space_idare updated, and any remaining bits are set to zero. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[out] destination_contiguous_bytes The number of contiguous bytes for which the converted destination_segment_addresscontinues to correspond to thesource_segment_address.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in destination_segment_addressanddestination_contiguous_bytes.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_WAVE_ID wave_idis invalid, orwave_idis AMD_DBGAPI_WAVE_NONE andsource_address_space_idordestination_address_space_iddepends on the active wave.destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_LANE_ID wave_idis AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE.wave_idis not AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE and is not valid forwave_id.lane_idis AMD_DBGAPI_LANE_NONE andsource_address_space_idordestination_address_space_iddepends on the active lane.destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID source_address_space_idordestination_address_space_idare invalid.destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_CONVERSION The source_segment_addressin thesource_address_space_idis not an address that can be represented in thedestination_address_space_id.destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT destination_segment_addressordestination_contiguous_bytesare NULL.destination_segment_addressanddestination_contiguous_bytesare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY source_address_space_idordestination_address_space_idaddress spaces are not supported by the architecture ofwave_id(if not AMD_DBGAPI_WAVE_NONE).destination_segment_addressanddestination_contiguous_bytesare unaltered.
◆ amd_dbgapi_dwarf_address_class_to_address_class()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_dwarf_address_class_to_address_class | ( | amd_dbgapi_architecture_id_t | architecture_id, | 
| uint64_t | dwarf_address_class, | ||
| amd_dbgapi_address_class_id_t * | address_class_id | ||
| ) | 
Return the architecture source language address class from a DWARF address class number for an architecture.
The AMD GPU DWARF address class number must be valid for the architecture.
See User Guide for AMDGPU Backend - Code Object - DWARF - Address Class Mapping.
- Parameters
- 
  [in] architecture_id The architecture of the source language address class. [in] dwarf_address_class The DWARF source language address class. [out] address_class_id The source language address class that corresponds to the DWARF address class for the architecture. 
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in address_class_id.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and address_class_idis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and address_class_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARCHITECTURE_ID architecture_idis invalid.address_class_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT address_class_idis NULL.address_class_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY dwarf_address_classis not valid for thearchitecture_id.address_class_idis unaltered.
◆ amd_dbgapi_dwarf_address_space_to_address_space()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_dwarf_address_space_to_address_space | ( | amd_dbgapi_architecture_id_t | architecture_id, | 
| uint64_t | dwarf_address_space, | ||
| amd_dbgapi_address_space_id_t * | address_space_id | ||
| ) | 
Return the address space from an AMD GPU DWARF address space number for an architecture.
A DWARF address space describes the architecture specific address spaces. It is used in DWARF location expressions that calculate addresses. See User Guide for AMDGPU Backend - Code Object - DWARF - Address Space Mapping.
The AMD GPU DWARF address space number must be valid for the architecture.
- Parameters
- 
  [in] architecture_id The architecture of the address space. [in] dwarf_address_space The AMD GPU DWARF address space. [out] address_space_id The address space that corresponds to the DWARF address space for the architecture architecture_id.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the result is stored in address_space_id.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized and address_space_idis unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and address_space_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARCHITECTURE_ID architecture_idis invalid.address_space_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT address_space_idis NULL.address_space_idis unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY dwarf_address_spaceis not valid forarchitecture_id.address_class_idis unaltered.
◆ amd_dbgapi_read_memory()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_read_memory | ( | amd_dbgapi_process_id_t | process_id, | 
| amd_dbgapi_wave_id_t | wave_id, | ||
| amd_dbgapi_lane_id_t | lane_id, | ||
| amd_dbgapi_address_space_id_t | address_space_id, | ||
| amd_dbgapi_segment_address_t | segment_address, | ||
| amd_dbgapi_size_t * | value_size, | ||
| void * | value | ||
| ) | 
Read memory.
The memory bytes in address_space are read for lane_id of wave_id starting at segment_address sequentially into value until value_size bytes have been read or an invalid memory address is reached. value_size is set to the number of bytes read successfully.
If wave_id is not AMD_DBGAPI_WAVE_NONE then it must be stopped, must belong to process_id, and its architecture must be the same as that of the address space.
The library performs all necessary hardware cache management so that the memory values read are coherent with the wave_id if not AMD_DBGAPI_WAVE_NONE. In order for the memory values read to be coherent with other waves, the waves must be stopped when invoking this operation. Stopping wave creation, stopping all waves, performing this operation, resuming any stopped waves, and then allowing wave creation can achieve this requirement. This requirement also applies if memory is read by other operating system supported means.
- Parameters
- 
  [in] process_id The process to read memory from if wave_idis AMD_DBGAPI_WAVE_NONE theaddress_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL.[in] wave_id The wave that is accessing the memory. If the address_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL thenwave_idmay be AMD_DBGAPI_WAVE_NONE, as the address space does not depend on the active wave, in which caseprocess_idis used.[in] lane_id The lane of wave_idthat is accessing the memory. If theaddress_spacedoes not depend on the active lane then this may be AMD_DBGAPI_LANE_NONE. For example, the AMD_DBGAPI_ADDRESS_SPACE_GLOBAL address space does not depend on the lane.[in] address_space_id The address space of the segment_address. If the address space is dependent on: the active lane then thelane_idwith in thewave_idis used; the active workgroup then the workgroup ofwave_idis used; or the active wave then thewave_idis used.[in] segment_address The integral value of the segment address. Only the bits corresponding to the address size for the address_spacerequested are used. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[in,out] value_size Pass in the number of bytes to read from memory. Return the number of bytes successfully read from memory. [out] value Pointer to memory where the result is stored. Must be an array of at least input value_sizebytes.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS Either the input value_sizewas 0, or the inputvalue_sizewas greater than 0 and one or more bytes have been read successfully. The outputvalue_sizeis set to the number of bytes successfully read, which will be 0 if the inputvalue_sizewas 0. The first outputvalue_sizebytes ofvalueare set to the bytes successfully read, all other bytes invalueare unaltered.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized; and value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized; and value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_PROCESS_ID process_idis invalid.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_WAVE_ID wave_idis invalid, orwave_idis AMD_DBGAPI_WAVE_NONE andaddress_spaceis not AMD_DBGAPI_ADDRESS_SPACE_GLOBAL.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_LANE_ID wave_idis AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE.wave_idis not AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE and is not valid forwave_id.lane_idis AMD_DBGAPI_LANE_NONE andaddress_space_iddepends on the active lane.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID address_space_idis invalid.valueis unaltered.AMD_DBGAPI_STATUS_ERROR_WAVE_NOT_STOPPED wave_idis not stopped.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT valueorvalue_sizeare NULL.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY wave_idin not AMD_DBGAPI_WAVE_NONE and does not belong toprocess_idor have the same the architecture asaddress_space_id.value_sizeandvalueare unaltered.AMD_DBGAPI_STATUS_ERROR_MEMORY_ACCESS The input value_sizewas greater than 0 and no bytes were successfully read. The outputvalue_sizeis set to 0.valueis unaltered.
◆ amd_dbgapi_set_memory_precision()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_set_memory_precision | ( | amd_dbgapi_process_id_t | process_id, | 
| amd_dbgapi_memory_precision_t | memory_precision | ||
| ) | 
Control precision of memory access reporting.
A process can be set to AMD_DBGAPI_MEMORY_PRECISION_NONE to disable precise memory reporting. Use the AMD_DBGAPI_PROCESS_INFO_PRECISE_MEMORY_SUPPORTED query to determine if the architectures of all the agents of a process support another memory precision.
The memory precision is set independently for each process, and only affects the waves executing on the agents of that process. The setting may be changed at any time, including when waves are executing, and takes effect immediately.
- Parameters
- 
  [in] process_id The process being configured. [in] memory_precision The memory precision to set. 
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS The function has been executed successfully and the agents of the process have been configured. AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized. AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized and no configuration is changed. AMD_DBGAPI_STATUS_ERROR_INVALID_PROCESS_ID process_idis invalid. No configuration is changed.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT memory_precisionis an invalid value. No configuration is changed.AMD_DBGAPI_STATUS_ERROR_NOT_SUPPORTED The requested memory_precisionis not supported by the architecture of all the agents ofprocess_id. No configuration is changed.
◆ amd_dbgapi_write_memory()
| amd_dbgapi_status_t AMD_DBGAPI amd_dbgapi_write_memory | ( | amd_dbgapi_process_id_t | process_id, | 
| amd_dbgapi_wave_id_t | wave_id, | ||
| amd_dbgapi_lane_id_t | lane_id, | ||
| amd_dbgapi_address_space_id_t | address_space_id, | ||
| amd_dbgapi_segment_address_t | segment_address, | ||
| amd_dbgapi_size_t * | value_size, | ||
| const void * | value | ||
| ) | 
Write memory.
The memory bytes in address_space are written for lane_id of wave_id starting at segment_address sequentially from value until value_size bytes have been written or an invalid memory address is reached. value_size is set to the number of bytes written successfully.
If wave_id is not AMD_DBGAPI_WAVE_NONE then it must be stopped, must belong to process_id, and its architecture must be the same as that of the address space.
The library performs all necessary hardware cache management so that the memory values written are coherent with the wave_id if not AMD_DBGAPI_WAVE_NONE. In order for the memory values written to be coherent with other waves, the waves must be stopped when invoking this operation. Stopping wave creation, stopping all waves, performing this operation, resuming any stopped waves, and then allowing wave creation can achieve this requirement. This requirement also applies if memory is written by other operating system supported means.
- Parameters
- 
  [in] process_id The process to write memory to if wave_idis AMD_DBGAPI_WAVE_NONE theaddress_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL.[in] wave_id The wave that is accessing the memory. If the address_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL thenwave_idmay be AMD_DBGAPI_WAVE_NONE, as the address space does not depend on the active wave, in which caseprocess_idis used.[in] lane_id The lane of wave_idthat is accessing the memory. If theaddress_spacedoes not depend on the active lane then this may be AMD_DBGAPI_LANE_NONE. For example, the AMD_DBGAPI_ADDRESS_SPACE_GLOBAL address space does not depend on the lane.[in] address_space_id The address space of the segment_address. If the address space is dependent on: the active lane then thelane_idwith in thewave_idis used; the active workgroup then the workgroup ofwave_idis used; or the active wave then thewave_idis used.[in] segment_address The integral value of the segment address. Only the bits corresponding to the address size for the address_spacerequested are used. The address size is provided by the AMD_DBGAPI_ADDRESS_SPACE_INFO_ADDRESS_SIZE query.[in,out] value_size Pass in the number of bytes to write to memory. Return the number of bytes successfully written to memory. [in] value The bytes to write to memory. Must point to an array of at least input value_sizebytes.
- Return values
- 
  AMD_DBGAPI_STATUS_SUCCESS Either the input value_sizewas 0, or the inputvalue_sizewas greater than 0 and one or more bytes have been written successfully. The outputvalue_sizeis set to the number of bytes successfully written, which will be 0 if the inputvalue_sizewas 0. The first outputvalue_sizebytes of memory starting atsegment_addressare updated, all other memory is unaltered.AMD_DBGAPI_STATUS_FATAL A fatal error occurred. The library is left uninitialized; and the memory and value_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_NOT_INITIALIZED The library is not initialized. The library is left uninitialized; the memory and value_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_PROCESS_ID process_idis invalid. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_WAVE_ID wave_idis invalid, orwave_idis AMD_DBGAPI_WAVE_NONE andaddress_spaceis AMD_DBGAPI_ADDRESS_SPACE_GLOBAL. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_LANE_ID wave_idis AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE.wave_idis not AMD_DBGAPI_WAVE_NONE andlane_idis not AMD_DBGAPI_LANE_NONE and is not valid forwave_id.lane_idis AMD_DBGAPI_LANE_NONE andaddress_space_iddepends on the active lane. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ADDRESS_SPACE_ID address_space_idis invalid. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_WAVE_NOT_STOPPED wave_idis not stopped. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT valueorvalue_sizeare NULL. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_INVALID_ARGUMENT_COMPATIBILITY wave_idin not AMD_DBGAPI_WAVE_NONE and does not belong toprocess_idor have the same the architecture asaddress_space_id. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_MEMORY_ACCESS The input value_sizewas greater than 0 and no bytes were successfully written. The outputvalue_sizeis set to 0. The memory andvalue_sizeare unaltered.AMD_DBGAPI_STATUS_ERROR_PROCESS_FROZEN This operation is not permitted because the process is frozen. The memory and value_sizeare unaltered.