public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc/devel/omp/gcc-11] amdgcn: DWARF address spaces
@ 2021-05-13 16:18 Kwok Yeung
0 siblings, 0 replies; only message in thread
From: Kwok Yeung @ 2021-05-13 16:18 UTC (permalink / raw)
To: gcc-cvs
https://gcc.gnu.org/g:889ace07a763a5882bbe1825dfec55f9e55502cd
commit 889ace07a763a5882bbe1825dfec55f9e55502cd
Author: Andrew Stubbs <ams@codesourcery.com>
Date: Wed Oct 7 14:15:22 2020 +0100
amdgcn: DWARF address spaces
Map GCN address spaces to the proposed DWARF address spaces defined by AMD.
gcc/ChangeLog:
* config/gcn/gcn.c: Include dwarf2.h.
(gcn_addr_space_debug): New function.
(TARGET_ADDR_SPACE_DEBUG): New hook.
Diff:
---
gcc/config/gcn/gcn.c | 28 ++++++++++++++++++++++++++++
1 file changed, 28 insertions(+)
diff --git a/gcc/config/gcn/gcn.c b/gcc/config/gcn/gcn.c
index 784bae43419..3d73ca59c31 100644
--- a/gcc/config/gcn/gcn.c
+++ b/gcc/config/gcn/gcn.c
@@ -51,6 +51,7 @@
#include "intl.h"
#include "rtl-iter.h"
#include "gimple.h"
+#include "dwarf2.h"
/* This file should be included last. */
#include "target-def.h"
@@ -1516,6 +1517,31 @@ gcn_addr_space_convert (rtx op, tree from_type, tree to_type)
gcc_unreachable ();
}
+/* Implement TARGET_ADDR_SPACE_DEBUG.
+
+ Return the dwarf address space class for each hardware address space. */
+
+static int
+gcn_addr_space_debug (addr_space_t as)
+{
+ switch (as)
+ {
+ case ADDR_SPACE_DEFAULT:
+ case ADDR_SPACE_FLAT:
+ case ADDR_SPACE_GLOBAL:
+ case ADDR_SPACE_SCALAR_FLAT:
+ case ADDR_SPACE_FLAT_SCRATCH:
+ return DW_ADDR_none;
+ case ADDR_SPACE_LDS:
+ return 3; // DW_ADDR_LLVM_group
+ case ADDR_SPACE_SCRATCH:
+ return 4; // DW_ADDR_LLVM_private
+ case ADDR_SPACE_GDS:
+ return 0x8000; // DW_ADDR_AMDGPU_region
+ }
+ gcc_unreachable ();
+}
+
/* Implement REGNO_MODE_CODE_OK_FOR_BASE_P via gcn.h
@@ -6397,6 +6423,8 @@ gcn_dwarf_register_span (rtx rtl)
#undef TARGET_ADDR_SPACE_ADDRESS_MODE
#define TARGET_ADDR_SPACE_ADDRESS_MODE gcn_addr_space_address_mode
+#undef TARGET_ADDR_SPACE_DEBUG
+#define TARGET_ADDR_SPACE_DEBUG gcn_addr_space_debug
#undef TARGET_ADDR_SPACE_LEGITIMATE_ADDRESS_P
#define TARGET_ADDR_SPACE_LEGITIMATE_ADDRESS_P \
gcn_addr_space_legitimate_address_p
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2021-05-13 16:18 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-05-13 16:18 [gcc/devel/omp/gcc-11] amdgcn: DWARF address spaces Kwok Yeung
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).