llvm/llvm/test/tools/llvm-objdump/ELF/data-vs-code-priority.s

@ REQUIRES: arm-registered-target

// Test that code symbols take priority over data symbols if both are
// defined at the same address during disassembly.
//
// In the past, llvm-objdump would select the alphabetically last
// symbol at each address. To demonstrate that it's now choosing by
// symbol type, we define pairs of code and data symbols at the same
// address in such a way that the code symbol and data symbol each
// have a chance to appear alphabetically last. Also, we test that
// both STT_FUNC and STT_NOTYPE are regarded as code symbols.

@ RUN: llvm-mc -triple armv8a-unknown-linux -filetype=obj %s -o %t.o
@ RUN: llvm-objdump --no-print-imm-hex --triple armv8a -d %t.o | FileCheck %s

// Ensure that all four instructions in the section are disassembled
// rather than dumped as data, and that in each case, the code symbol
// is displayed before the disassembly, and not the data symbol at the
// same address.

@ CHECK:        Disassembly of section .text:
@ CHECK-EMPTY:
@ CHECK-NEXT:   <A1function>:
@ CHECK-NEXT:   movw r0, #1
@ CHECK-EMPTY:
@ CHECK-NEXT:   <B2function>:
@ CHECK-NEXT:   movw r0, #2
@ CHECK-EMPTY:
@ CHECK-NEXT:   <A3notype>:
@ CHECK-NEXT:   movw r0, #3
@ CHECK-EMPTY:
@ CHECK-NEXT:   <B4notype>:
@ CHECK-NEXT:   movw r0, #4

.text

.globl A1function
.globl B2function
.globl A3notype
.globl B4notype
.globl B1object
.globl A2object
.globl B3object
.globl A4object

.type A1function,%function
.type B2function,%function
.type A3notype,%notype
.type B4notype,%notype
.type B1object,%object
.type A2object,%object
.type B3object,%object
.type A4object,%object

A1function:
B1object:
        movw r0, #1
A2object:
B2function:
        movw r0, #2
A3notype:
B3object:
        movw r0, #3
A4object:
B4notype:
        movw r0, #4