binutils/readelf: handle AMDGPU OS ABIs
authorSimon Marchi <simon.marchi@efficios.com>
Wed, 16 Mar 2022 13:01:04 +0000 (09:01 -0400)
committerSimon Marchi <simon.marchi@polymtl.ca>
Wed, 16 Mar 2022 13:01:04 +0000 (09:01 -0400)
When the machine is EM_AMDGPU, handle the various OS ABIs described
here:

  https://llvm.org/docs/AMDGPUUsage.html#header

For a binary with the HSA OS ABI, the change looks like:

-  OS/ABI:                            <unknown: 40>
+  OS/ABI:                            AMD HSA

binutils/ChangeLog:

* readelf.c (get_osabi_name): Handle EM_AMDGPU OS ABIs.

include/ChangeLog:

* elf/common.h (ELFOSABI_AMDGPU_PAL, ELFOSABI_AMDGPU_MESA3D):
New.

Change-Id: I383590c390f7dc2fe0f902f50038735626d71863

binutils/ChangeLog
binutils/readelf.c
include/ChangeLog
include/elf/common.h

index bb71e5ca2885fc3f2f0df9e804f7453170876c3c..694ad49fee55ba155f67b8419f512a4110c19522 100644 (file)
@@ -1,3 +1,7 @@
+2022-03-16  Simon Marchi  <simon.marchi@efficios.com>
+
+       * readelf.c (get_osabi_name): Handle EM_AMDGPU OS ABIs.
+
 2022-03-16  Nick Clifton  <nickc@redhat.com>
 
        * po/sr.po: Updated Serbian translation.
index 8b46052c7ded31d5522c750d9390280b04134803..e8974aacec5e4fc441234f19b352a784b41aad09 100644 (file)
@@ -4284,6 +4284,17 @@ get_osabi_name (Filedata * filedata, unsigned int osabi)
       if (osabi >= 64)
        switch (filedata->file_header.e_machine)
          {
+         case EM_AMDGPU:
+           switch (osabi)
+             {
+             case ELFOSABI_AMDGPU_HSA:    return "AMD HSA";
+             case ELFOSABI_AMDGPU_PAL:    return "AMD PAL";
+             case ELFOSABI_AMDGPU_MESA3D: return "AMD Mesa3D";
+             default:
+               break;
+             }
+           break;
+
          case EM_ARM:
            switch (osabi)
              {
index 26a64f42b79cdaeb56569c44a63e849be57167b8..297dcd69443b31cc47630f013da804254ddbe7f2 100644 (file)
@@ -1,3 +1,8 @@
+2022-03-16  Simon Marchi  <simon.marchi@efficios.com>
+
+       * elf/common.h (ELFOSABI_AMDGPU_PAL, ELFOSABI_AMDGPU_MESA3D):
+       New.
+
 2022-03-16  Simon Marchi  <simon.marchi@efficios.com>
 
        * elf/amdgpu.h: New.
index a1cace406a473582ab106e6f441f06726fa97038..70d63e3299c0cc6973b8e3054ee44fe117ba7579 100644 (file)
@@ -79,7 +79,9 @@
 #define ELFOSABI_C6000_ELFABI 64 /* Bare-metal TMS320C6000 */
 #define ELFOSABI_AMDGPU_HSA  64 /* AMD HSA Runtime */
 #define ELFOSABI_C6000_LINUX 65 /* Linux TMS320C6000 */
+#define ELFOSABI_AMDGPU_PAL  65 /* AMD PAL Runtime */
 #define ELFOSABI_ARM_FDPIC   65 /* ARM FDPIC */
+#define ELFOSABI_AMDGPU_MESA3D 66 /* AMD Mesa3D Runtime */
 #define ELFOSABI_ARM        97 /* ARM */
 #define ELFOSABI_STANDALONE 255        /* Standalone (embedded) application */