Commit a6c40b17 authored by Luben Tuikov's avatar Luben Tuikov Committed by Alex Deucher

drm/amdgpu: Show IP discovery in sysfs

Add IP discovery data in sysfs. The format is:
/sys/class/drm/cardX/device/ip_discovery/die/D/B/I/<attrs>
where,
X is the card ID, an integer,
D is the die ID, an integer,
B is the IP HW ID, an integer, aka block type,
I is the IP HW ID instance, an integer.
<attrs> are the attributes of the block instance. At the moment these
include HW ID, instance number, major, minor, revision, number of base
addresses, and the base addresses themselves.

A symbolic link of the acronym HW ID is also created, under D/, if you
prefer to browse by something humanly accessible.

Cc: Alex Deucher <Alexander.Deucher@amd.com>
Cc: Tom StDenis <tom.stdenis@amd.com>
Signed-off-by: default avatarLuben Tuikov <luben.tuikov@amd.com>
Reviewed-by: default avatarAlex Deucher <Alexander.Deucher@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 77608faa
...@@ -771,6 +771,8 @@ struct amd_powerplay { ...@@ -771,6 +771,8 @@ struct amd_powerplay {
const struct amd_pm_funcs *pp_funcs; const struct amd_pm_funcs *pp_funcs;
}; };
struct ip_discovery_top;
/* polaris10 kickers */ /* polaris10 kickers */
#define ASICID_IS_P20(did, rid) (((did == 0x67DF) && \ #define ASICID_IS_P20(did, rid) (((did == 0x67DF) && \
((rid == 0xE3) || \ ((rid == 0xE3) || \
...@@ -1096,6 +1098,8 @@ struct amdgpu_device { ...@@ -1096,6 +1098,8 @@ struct amdgpu_device {
bool ram_is_direct_mapped; bool ram_is_direct_mapped;
struct list_head ras_list; struct list_head ras_list;
struct ip_discovery_top *ip_top;
}; };
static inline struct amdgpu_device *drm_to_adev(struct drm_device *ddev) static inline struct amdgpu_device *drm_to_adev(struct drm_device *ddev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment