aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJulian Brown <julian@codesourcery.com>2022-10-14 11:06:07 +0000
committerJulian Brown <julian@codesourcery.com>2022-10-14 11:33:09 +0000
commit2bccd60658a168138f49578007cb0508deb4f793 (patch)
tree18df91c215b99e34073afdeca1a03c4a97e07bff /gcc
parent5bcf4e223664de67ca1a17eb7d47501b57cbc21b (diff)
downloadgcc-2bccd60658a168138f49578007cb0508deb4f793.zip
gcc-2bccd60658a168138f49578007cb0508deb4f793.tar.gz
gcc-2bccd60658a168138f49578007cb0508deb4f793.tar.bz2
[og12] amdgcn: Use FLAT addressing for all functions with pointer arguments
The GCN backend uses a heuristic to determine whether to use FLAT or GLOBAL addressing in a particular (offload) function: namely, if a function takes a pointer-to-scalar parameter, it is assumed that the pointer may refer to "flat scratch" space, and thus FLAT addressing must be used instead of GLOBAL. I came up with this heuristic initially whilst working on support for moving OpenACC gang-private variables into local-data share (scratch) memory. The assumption that only scalar variables would be transformed in that way turned out to be wrong. For example, prior to the next patch in the series, Fortran compiler-generated temporary structures were treated as gang private and moved to LDS space, typically overflowing the region allocated for such variables. That will no longer happen after that patch is applied, but there may be other cases of structs moving to LDS space now or in the future that this patch may be needed for. 2022-10-14 Julian Brown <julian@codesourcery.com> gcc/ * config/gcn/gcn.cc (gcn_detect_incoming_pointer_arg): Any pointer argument forces FLAT addressing mode, not just pointer-to-non-aggregate.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog.omp6
-rw-r--r--gcc/config/gcn/gcn.cc15
2 files changed, 15 insertions, 6 deletions
diff --git a/gcc/ChangeLog.omp b/gcc/ChangeLog.omp
index d296eb1..ceed4da 100644
--- a/gcc/ChangeLog.omp
+++ b/gcc/ChangeLog.omp
@@ -1,3 +1,9 @@
+2022-10-14 Julian Brown <julian@codesourcery.com>
+
+ * config/gcn/gcn.cc (gcn_detect_incoming_pointer_arg): Any pointer
+ argument forces FLAT addressing mode, not just
+ pointer-to-non-aggregate.
+
2022-10-12 Andrew Stubbs <ams@codesourcery.com>
* config/gcn/gcn.cc (gcn_expand_builtin_1): Change gcn_full_exec_reg
diff --git a/gcc/config/gcn/gcn.cc b/gcc/config/gcn/gcn.cc
index 1f8d8e1..b01131c 100644
--- a/gcc/config/gcn/gcn.cc
+++ b/gcc/config/gcn/gcn.cc
@@ -2819,10 +2819,14 @@ gcn_arg_partial_bytes (cumulative_args_t cum_v, const function_arg_info &arg)
return (NUM_PARM_REGS - cum_num) * regsize;
}
-/* A normal function which takes a pointer argument (to a scalar) may be
- passed a pointer to LDS space (via a high-bits-set aperture), and that only
- works with FLAT addressing, not GLOBAL. Force FLAT addressing if the
- function has an incoming pointer-to-scalar parameter. */
+/* A normal function which takes a pointer argument may be passed a pointer to
+ LDS space (via a high-bits-set aperture), and that only works with FLAT
+ addressing, not GLOBAL. Force FLAT addressing if the function has an
+ incoming pointer parameter. NOTE: This is a heuristic that works in the
+ offloading case, but in general, a function might read global pointer
+ variables, etc. that may refer to LDS space or other special memory areas
+ not supported by GLOBAL instructions, and then this argument check would not
+ suffice. */
static void
gcn_detect_incoming_pointer_arg (tree fndecl)
@@ -2832,8 +2836,7 @@ gcn_detect_incoming_pointer_arg (tree fndecl)
for (tree arg = TYPE_ARG_TYPES (TREE_TYPE (fndecl));
arg;
arg = TREE_CHAIN (arg))
- if (POINTER_TYPE_P (TREE_VALUE (arg))
- && !AGGREGATE_TYPE_P (TREE_TYPE (TREE_VALUE (arg))))
+ if (POINTER_TYPE_P (TREE_VALUE (arg)))
cfun->machine->use_flat_addressing = true;
}