mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-06 20:10:38 +00:00
c8b398cd6b
Before, only Thumb functions were marked as ".code 16". These ".code x" directives are effective until the next directive of its kind is encountered. Therefore, in code with interleaved ARM and Thumb functions, it was possible to declare a function as ARM and end up with a Thumb function after assembly. A test has been added. An existing test has also been fixed to take this change into account. Reviewers: aschwaighofer, t.p.northover, jmolloy, rengolin Subscribers: aemerson, rengolin, llvm-commits Differential Revision: https://reviews.llvm.org/D24337 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@281324 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
1.3 KiB
LLVM
31 lines
1.3 KiB
LLVM
; RUN: llc -mtriple armv7-apple-darwin < %s | FileCheck %s
|
|
|
|
; Test that we don't pollute the start of the file with debug sections.
|
|
; This is particularly important on ARM MachO as a change in section order can
|
|
; cause a change the relaxation of the instructions used.
|
|
|
|
; CHECK: .section __TEXT,__text,regular,pure_instructions
|
|
; CHECK-NEXT: .syntax unified
|
|
; CHECK-NEXT: .globl _f
|
|
; CHECK-NEXT: .p2align 2
|
|
; CHECK-NEXT: .code 32 @ @f
|
|
; CHECK-NEXT: _f:
|
|
|
|
; CHECK: .section __DWARF,__debug_str,regular,debug
|
|
|
|
define void @f() !dbg !4 {
|
|
ret void, !dbg !9
|
|
}
|
|
!llvm.dbg.cu = !{!0}
|
|
!llvm.module.flags = !{!7, !8}
|
|
|
|
!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "foo", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, retainedTypes: !2, globals: !2, imports: !2)
|
|
!1 = !DIFile(filename: "/foo/test.c", directory: "/foo")
|
|
!2 = !{}
|
|
!4 = distinct !DISubprogram(name: "f", scope: !1, file: !1, line: 2, type: !5, isLocal: false, isDefinition: true, scopeLine: 1, flags: DIFlagPrototyped, isOptimized: true, unit: !0, variables: !2)
|
|
!5 = !DISubroutineType(types: !6)
|
|
!6 = !{null}
|
|
!7 = !{i32 2, !"Dwarf Version", i32 4}
|
|
!8 = !{i32 2, !"Debug Info Version", i32 3}
|
|
!9 = !DILocation(line: 1, column: 15, scope: !4)
|