Provide correct encodings for the get_lane and set_lane variants of vmov.
[oota-llvm.git] / test / MC / ELF / relocation.s
1 // RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump  --dump-section-data | FileCheck  %s
2
3 // Test that we produce the correct relocation.
4
5 bar:
6         movl    $bar, %edx        # R_X86_64_32
7         movq    $bar, %rdx        # R_X86_64_32S
8         movq    $bar, bar(%rip)   # R_X86_64_32S
9         movl    bar, %edx         # R_X86_64_32S
10         movq    bar, %rdx         # R_X86_64_32S
11 .long bar                         # R_X86_64_32
12         leaq    foo@GOTTPOFF(%rip), %rax # R_X86_64_GOTTPOFF
13         leaq    foo@TLSGD(%rip), %rax    # R_X86_64_TLSGD
14         leaq    foo@TPOFF(%rax), %rax    # R_X86_64_TPOFF32
15
16 // CHECK:  # Section 0x00000001
17 // CHECK: (('sh_name', 0x00000001) # '.text'
18
19 // CHECK:   # Symbol 0x00000002
20 // CHECK: (('st_name', 0x00000000) # ''
21 // CHECK:  ('st_bind', 0x00000000)
22 // CHECK   ('st_type', 0x00000003)
23 // CHECK:  ('st_other', 0x00000000)
24 // CHECK:  ('st_shndx', 0x00000001)
25
26 // CHECK: # Relocation 0x00000000
27 // CHECK-NEXT:  (('r_offset', 0x00000001)
28 // CHECK-NEXT:   ('r_sym', 0x00000002)
29 // CHECK-NEXT:   ('r_type', 0x0000000a)
30 // CHECK-NEXT:   ('r_addend',
31
32 // CHECK: # Relocation 0x00000001
33 // CHECK-NEXT:  (('r_offset', 0x00000008)
34 // CHECK-NEXT:   ('r_sym', 0x00000002)
35 // CHECK-NEXT:   ('r_type', 0x0000000b)
36 // CHECK-NEXT:   ('r_addend',
37
38 // CHECK: # Relocation 0x00000002
39 // CHECK-NEXT:  (('r_offset', 0x00000013)
40 // CHECK-NEXT:   ('r_sym', 0x00000002)
41 // CHECK-NEXT:   ('r_type', 0x0000000b)
42 // CHECK-NEXT:   ('r_addend',
43
44 // CHECK: # Relocation 0x00000003
45 // CHECK-NEXT:  (('r_offset', 0x0000001a)
46 // CHECK-NEXT:   ('r_sym', 0x00000002)
47 // CHECK-NEXT:   ('r_type', 0x0000000b)
48 // CHECK-NEXT:   ('r_addend',
49
50 // CHECK: # Relocation 0x00000004
51 // CHECK-NEXT:  (('r_offset', 0x00000022)
52 // CHECK-NEXT:   ('r_sym', 0x00000002)
53 // CHECK-NEXT:   ('r_type', 0x0000000b)
54 // CHECK-NEXT:   ('r_addend',
55
56 // CHECK: # Relocation 0x00000005
57 // CHECK-NEXT:  (('r_offset', 0x00000026)
58 // CHECK-NEXT:   ('r_sym', 0x00000002)
59 // CHECK-NEXT:   ('r_type', 0x0000000a)
60 // CHECK-NEXT:   ('r_addend',
61
62 // CHECK: # Relocation 0x00000006
63 // CHECK-NEXT:  (('r_offset', 0x0000002d)
64 // CHECK-NEXT:   ('r_sym', 0x00000006)
65 // CHECK-NEXT:   ('r_type', 0x00000016)
66 // CHECK-NEXT:   ('r_addend', 0xfffffffc)
67
68 // CHECK:  # Relocation 0x00000007
69 // CHECK-NEXT:  (('r_offset', 0x00000034)
70 // CHECK-NEXT:   ('r_sym', 0x00000006)
71 // CHECK-NEXT:   ('r_type', 0x00000013)
72 // CHECK-NEXT:   ('r_addend', 0xfffffffc)
73
74 // CHECK:  # Relocation 0x00000008
75 // CHECK-NEXT:  (('r_offset', 0x0000003b)
76 // CHECK-NEXT:   ('r_sym', 0x00000006)
77 // CHECK-NEXT:   ('r_type', 0x00000017)
78 // CHECK-NEXT:   ('r_addend', 0x00000000)