diff options
author | Richard Biener <rguenther@suse.de> | 2024-01-26 12:57:10 +0100 |
---|---|---|
committer | Richard Biener <rguenther@suse.de> | 2024-01-26 15:36:35 +0100 |
commit | c34ab549d88da13ae16edccedd4218807afefb65 (patch) | |
tree | 3b809bf03f9e204a136c688ce06f9618b10fbee8 /libgomp/plugin | |
parent | 209ed06c3acddb25935ecdedf2b31235b71e5c39 (diff) |
Avoid registering unsupported OMP offload devices
The following avoids registering unsupported GCN offload devices
when iterating over available ones. With a Zen4 desktop CPU
you will have an IGPU (unspported) which will otherwise be made
available. This causes testcases like
libgomp.c-c++-common/non-rect-loop-1.c which iterate over all
decives to FAIL.
libgomp/
* plugin/plugin-gcn.c (suitable_hsa_agent_p): Filter out
agents with unsupported ISA.
Diffstat (limited to 'libgomp/plugin')
-rw-r--r-- | libgomp/plugin/plugin-gcn.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/libgomp/plugin/plugin-gcn.c b/libgomp/plugin/plugin-gcn.c index 588358bbbf9..2771123252a 100644 --- a/libgomp/plugin/plugin-gcn.c +++ b/libgomp/plugin/plugin-gcn.c @@ -1427,6 +1427,8 @@ init_hsa_runtime_functions (void) #undef DLSYM_FN } +static gcn_isa isa_code (const char *isa); + /* Return true if the agent is a GPU and can accept of concurrent submissions from different threads. */ @@ -1443,6 +1445,18 @@ suitable_hsa_agent_p (hsa_agent_t agent) switch (device_type) { case HSA_DEVICE_TYPE_GPU: + { + char name[64]; + hsa_status_t status + = hsa_fns.hsa_agent_get_info_fn (agent, HSA_AGENT_INFO_NAME, name); + if (status != HSA_STATUS_SUCCESS + || isa_code (name) == EF_AMDGPU_MACH_UNSUPPORTED) + { + GCN_DEBUG ("Ignoring unsupported agent '%s'\n", + status == HSA_STATUS_SUCCESS ? name : "invalid"); + return false; + } + } break; case HSA_DEVICE_TYPE_CPU: if (!support_cpu_devices) |