diff options
author | Andrew Stubbs <ams@codesourcery.com> | 2023-02-06 12:47:28 +0000 |
---|---|---|
committer | Andrew Stubbs <ams@codesourcery.com> | 2023-02-07 09:55:31 +0000 |
commit | 196b25d7b9b73fa89ffb2f6dc73b851584f81127 (patch) | |
tree | 97fca4a6a8c9be29e66826b03234de77ea28b270 /gcc | |
parent | fea797e012e89463a5f93d6799462e10d1c2a9dd (diff) | |
download | gcc-196b25d7b9b73fa89ffb2f6dc73b851584f81127.zip gcc-196b25d7b9b73fa89ffb2f6dc73b851584f81127.tar.gz gcc-196b25d7b9b73fa89ffb2f6dc73b851584f81127.tar.bz2 |
amdgcn: Pass -mstack-size through to runtime
But only for the offload case.
gcc/ChangeLog:
* config/gcn/mkoffload.cc (gcn_stack_size): New global variable.
(process_asm): Create a constructor for GCN_STACK_SIZE.
(main): Parse the -mstack-size option.
(cherry picked from commit 45e01229af33a3dc3f124dcaec4b4ae11e9d07ce)
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog.omp | 6 | ||||
-rw-r--r-- | gcc/config/gcn/mkoffload.cc | 18 |
2 files changed, 24 insertions, 0 deletions
diff --git a/gcc/ChangeLog.omp b/gcc/ChangeLog.omp index f7d0c43..4205a15 100644 --- a/gcc/ChangeLog.omp +++ b/gcc/ChangeLog.omp @@ -1,5 +1,11 @@ 2023-02-06 Andrew Stubbs <ams@codesourcery.com> + * config/gcn/mkoffload.cc (gcn_stack_size): New global variable. + (process_asm): Create a constructor for GCN_STACK_SIZE. + (main): Parse the -mstack-size option. + +2023-02-06 Andrew Stubbs <ams@codesourcery.com> + * config/gcn/gcn-run.cc: Include libgomp-gcn.h. (struct kernargs): Replace the common content with kernargs_abi. (struct heap): Delete. diff --git a/gcc/config/gcn/mkoffload.cc b/gcc/config/gcn/mkoffload.cc index 14d7eed..3af3f71 100644 --- a/gcc/config/gcn/mkoffload.cc +++ b/gcc/config/gcn/mkoffload.cc @@ -123,6 +123,8 @@ uint32_t elf_arch = EF_AMDGPU_MACH_AMDGCN_GFX803; // Default GPU architecture. uint32_t elf_flags = (EF_AMDGPU_FEATURE_XNACK_ANY_V4 | EF_AMDGPU_FEATURE_SRAMECC_ANY_V4); +static int gcn_stack_size = 0; /* Zero means use default. */ + /* Delete tempfiles. */ void @@ -701,6 +703,18 @@ process_asm (FILE *in, FILE *out, FILE *cfile) ? "val[0] != '1' || val[1] != '\\0'" : "val[0] == '1' && val[1] == '\\0'")); + /* Set the stack size if the user configured a value. */ + if (gcn_stack_size) + fprintf (cfile, + "static __attribute__((constructor))\n" + "void configure_stack_size (void)\n" + "{\n" + " const char *val = getenv (\"GCN_STACK_SIZE\");\n" + " if (!val || val[0] == '\\0')\n" + " setenv (\"GCN_STACK_SIZE\", \"%d\", true);\n" + "}\n\n", + gcn_stack_size); + obstack_free (&fns_os, NULL); for (i = 0; i < dims_count; i++) free (dims[i].name); @@ -961,6 +975,10 @@ main (int argc, char **argv) elf_arch = EF_AMDGPU_MACH_AMDGCN_GFX908; else if (strcmp (argv[i], "-march=gfx90a") == 0) elf_arch = EF_AMDGPU_MACH_AMDGCN_GFX90a; +#define STR "-mstack-size=" + else if (startswith (argv[i], STR)) + gcn_stack_size = atoi (argv[i] + strlen (STR)); +#undef STR } if (!(fopenacc ^ fopenmp)) |