blob: b4f77f5a090127abf51e586dae22c2d49c7cbe1f [file] [log] [blame]
Nico Rieckf89da722013-04-12 04:06:46 +00001// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | llvm-readobj -t | FileCheck %s
Rafael Espindoladb9835d2010-11-15 14:40:36 +00002
Roman Divackyd1491862010-12-20 21:14:39 +00003// Test that we emit the correct value.
4
5.set kernbase,0xffffffff80000000
6
Nico Rieckf89da722013-04-12 04:06:46 +00007// CHECK: Symbol {
Stephen Hinesdce4a402014-05-29 02:49:00 -07008// CHECK: Name: kernbase
Nico Rieckf89da722013-04-12 04:06:46 +00009// CHECK-NEXT: Value: 0xFFFFFFFF80000000
10// CHECK-NEXT: Size: 0
11// CHECK-NEXT: Binding: Local
12// CHECK-NEXT: Type: None
13// CHECK-NEXT: Other: 0
Stephen Hines36b56882014-04-23 16:57:46 -070014// CHECK-NEXT: Section: Absolute (0xFFF1)
Nico Rieckf89da722013-04-12 04:06:46 +000015// CHECK-NEXT: }
Roman Divackyd1491862010-12-20 21:14:39 +000016
Rafael Espindoladb9835d2010-11-15 14:40:36 +000017// Test that we accept .set of a symbol after it has been used in a statement.
18
19 jmp foo
20 .set foo, bar
21
22// or a .quad
23
24 .quad foo2
25 .set foo2,bar2
26
27// Test that there is an undefined reference to bar
Nico Rieckf89da722013-04-12 04:06:46 +000028// CHECK: Symbol {
Stephen Hinesdce4a402014-05-29 02:49:00 -070029// CHECK: Name: bar
Nico Rieckf89da722013-04-12 04:06:46 +000030// CHECK-NEXT: Value: 0x0
31// CHECK-NEXT: Size: 0
32// CHECK-NEXT: Binding: Global
33// CHECK-NEXT: Type: None
34// CHECK-NEXT: Other: 0
Stephen Hines36b56882014-04-23 16:57:46 -070035// CHECK-NEXT: Section: Undefined (0x0)
Nico Rieckf89da722013-04-12 04:06:46 +000036// CHECK-NEXT: }