1; RUN: llc -verify-machineinstrs -mtriple powerpc-ibm-aix-xcoff -mcpu=pwr4 \
2; RUN: -mattr=-altivec -data-sections=false -xcoff-traceback-table=false < %s | FileCheck --check-prefixes=COMMON,BIT32 %s
3
4; RUN: llc -verify-machineinstrs -mtriple powerpc64-ibm-aix-xcoff -mcpu=pwr4 \
5; RUN: -mattr=-altivec -data-sections=false -xcoff-traceback-table=false < %s | FileCheck --check-prefixes=COMMON,BIT64 %s
6
7; RUN: llc -verify-machineinstrs -mtriple powerpc-ibm-aix-xcoff -mcpu=pwr4 \
8; RUN: -mattr=-altivec -data-sections=false -xcoff-traceback-table=false -filetype=obj -o %t.o < %s
9; RUN: llvm-readobj --symbols %t.o | FileCheck --check-prefix=CHECKSYM %s
10
11; RUN: not --crash llc -verify-machineinstrs -mcpu=pwr4 -mtriple powerpc64-ibm-aix-xcoff \
12; RUN: -mattr=-altivec -data-sections=false -xcoff-traceback-table=false -filetype=obj -o %t.o 2>&1 < %s | \
13; RUN:   FileCheck --check-prefix=XCOFF64 %s
14; XCOFF64: LLVM ERROR: 64-bit XCOFF object files are not supported yet.
15
16
17@foo_ext_weak_p = global void (...)* bitcast (void ()* @foo_ext_weak_ref to void (...)*)
18@b_w = extern_weak global i32
19
20declare extern_weak void @foo_ext_weak_ref()
21
22define i32 @main() {
23entry:
24  %0 = load void (...)*, void (...)** @foo_ext_weak_p
25  %callee.knr.cast = bitcast void (...)* %0 to void ()*
26  call void %callee.knr.cast()
27  call void @foo_ext_weak(i32* @b_w)
28  ret i32 0
29}
30
31declare extern_weak void @foo_ext_weak(i32*)
32
33; COMMON:         .globl	main[DS]                # -- Begin function main
34; COMMON-NEXT:    .globl	.main
35; COMMON-NEXT:    .align	4
36; COMMON-NEXT:    .csect main[DS]
37; BIT32-NEXT:     .vbyte	4, .main                   # @main
38; BIT32-NEXT:     .vbyte	4, TOC[TC0]
39; BIT32-NEXT:     .vbyte	4, 0
40; BIT64-NEXT:     .vbyte	8, .main                   # @main
41; BIT64-NEXT:     .vbyte	8, TOC[TC0]
42; BIT64-NEXT:     .vbyte	8, 0
43; COMMON-NEXT:    .csect  .text[PR]
44; COMMON-NEXT:    .main:
45
46; COMMON:         .csect  .data[RW]
47; COMMON:         .globl  foo_ext_weak_p
48; BIT32-NEXT:     .align	2
49; BIT64-NEXT:     .align 	3
50; COMMON-NEXT: foo_ext_weak_p:
51; BIT32-NEXT: 	  .vbyte	4, foo_ext_weak_ref[DS]
52; BIT64-NEXT: 	  .vbyte	8, foo_ext_weak_ref[DS]
53; COMMON-NEXT:    .weak   b_w[UA]
54; COMMON-NEXT:    .weak   .foo_ext_weak_ref[PR]
55; COMMON-NEXT:    .weak   foo_ext_weak_ref[DS]
56; COMMON-NEXT:    .weak   .foo_ext_weak[PR]
57; COMMON-NEXT:    .weak   foo_ext_weak[DS]
58; COMMON-NEXT:    .toc
59; COMMON-NEXT: L..C0:
60; COMMON-NEXT:    .tc foo_ext_weak_p[TC],foo_ext_weak_p
61; COMMON-NEXT: L..C1:
62; COMMON-NEXT:    .tc b_w[TC],b_w[UA]
63
64; CHECKSYM:      Symbols [
65; CHECKSYM-NEXT:   Symbol {
66; CHECKSYM-NEXT:     Index: [[#Index:]]
67; CHECKSYM-NEXT:     Name: .foo_ext_weak
68; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
69; CHECKSYM-NEXT:     Section: N_UNDEF
70; CHECKSYM-NEXT:     Type: 0x0
71; CHECKSYM-NEXT:     StorageClass: C_WEAKEXT (0x6F)
72; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
73; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
74; CHECKSYM-NEXT:       Index: [[#Index+1]]
75; CHECKSYM-NEXT:       SectionLen: 0
76; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
77; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
78; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
79; CHECKSYM-NEXT:       SymbolType: XTY_ER (0x0)
80; CHECKSYM-NEXT:       StorageMappingClass: XMC_PR (0x0)
81; CHECKSYM-NEXT:       StabInfoIndex: 0x0
82; CHECKSYM-NEXT:       StabSectNum: 0x0
83; CHECKSYM-NEXT:     }
84; CHECKSYM-NEXT:   }
85; CHECKSYM-NEXT:   Symbol {
86; CHECKSYM-NEXT:     Index: [[#Index+2]]
87; CHECKSYM-NEXT:     Name: foo_ext_weak_ref
88; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
89; CHECKSYM-NEXT:     Section: N_UNDEF
90; CHECKSYM-NEXT:     Type: 0x0
91; CHECKSYM-NEXT:     StorageClass: C_WEAKEXT (0x6F)
92; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
93; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
94; CHECKSYM-NEXT:       Index: [[#Index+3]]
95; CHECKSYM-NEXT:       SectionLen: 0
96; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
97; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
98; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
99; CHECKSYM-NEXT:       SymbolType: XTY_ER (0x0)
100; CHECKSYM-NEXT:       StorageMappingClass: XMC_DS (0xA)
101; CHECKSYM-NEXT:       StabInfoIndex: 0x0
102; CHECKSYM-NEXT:       StabSectNum: 0x0
103; CHECKSYM-NEXT:     }
104; CHECKSYM-NEXT:   }
105; CHECKSYM-NEXT:   Symbol {
106; CHECKSYM-NEXT:     Index: [[#Index+4]]
107; CHECKSYM-NEXT:     Name: b_w
108; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
109; CHECKSYM-NEXT:     Section: N_UNDEF
110; CHECKSYM-NEXT:     Type: 0x0
111; CHECKSYM-NEXT:     StorageClass: C_WEAKEXT (0x6F)
112; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
113; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
114; CHECKSYM-NEXT:       Index: [[#Index+5]]
115; CHECKSYM-NEXT:       SectionLen: 0
116; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
117; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
118; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
119; CHECKSYM-NEXT:       SymbolType: XTY_ER (0x0)
120; CHECKSYM-NEXT:       StorageMappingClass: XMC_UA (0x4)
121; CHECKSYM-NEXT:       StabInfoIndex: 0x0
122; CHECKSYM-NEXT:       StabSectNum: 0x0
123; CHECKSYM-NEXT:     }
124; CHECKSYM-NEXT:   }
125; CHECKSYM-NEXT:   Symbol {
126; CHECKSYM-NEXT:     Index: [[#Index+6]]
127; CHECKSYM-NEXT:     Name: .foo_ext_weak_ref
128; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
129; CHECKSYM-NEXT:     Section: N_UNDEF
130; CHECKSYM-NEXT:     Type: 0x0
131; CHECKSYM-NEXT:     StorageClass: C_WEAKEXT (0x6F)
132; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
133; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
134; CHECKSYM-NEXT:       Index: [[#Index+7]]
135; CHECKSYM-NEXT:       SectionLen: 0
136; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
137; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
138; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
139; CHECKSYM-NEXT:       SymbolType: XTY_ER (0x0)
140; CHECKSYM-NEXT:       StorageMappingClass: XMC_PR (0x0)
141; CHECKSYM-NEXT:       StabInfoIndex: 0x0
142; CHECKSYM-NEXT:       StabSectNum: 0x0
143; CHECKSYM-NEXT:     }
144; CHECKSYM-NEXT:   }
145; CHECKSYM-NEXT:   Symbol {
146; CHECKSYM-NEXT:     Index: [[#Index+8]]
147; CHECKSYM-NEXT:     Name: foo_ext_weak
148; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
149; CHECKSYM-NEXT:     Section: N_UNDEF
150; CHECKSYM-NEXT:     Type: 0x0
151; CHECKSYM-NEXT:     StorageClass: C_WEAKEXT (0x6F)
152; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
153; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
154; CHECKSYM-NEXT:       Index: [[#Index+9]]
155; CHECKSYM-NEXT:       SectionLen: 0
156; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
157; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
158; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
159; CHECKSYM-NEXT:       SymbolType: XTY_ER (0x0)
160; CHECKSYM-NEXT:       StorageMappingClass: XMC_DS (0xA)
161; CHECKSYM-NEXT:       StabInfoIndex: 0x0
162; CHECKSYM-NEXT:       StabSectNum: 0x0
163; CHECKSYM-NEXT:     }
164; CHECKSYM-NEXT:   }
165; CHECKSYM-NEXT:   Symbol {
166; CHECKSYM-NEXT:     Index: [[#Index+10]]
167; CHECKSYM-NEXT:     Name: .text
168; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
169; CHECKSYM-NEXT:     Section: .text
170; CHECKSYM-NEXT:     Type: 0x0
171; CHECKSYM-NEXT:     StorageClass: C_HIDEXT (0x6B)
172; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
173; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
174; CHECKSYM-NEXT:       Index: [[#Index+11]]
175; CHECKSYM-NEXT:       SectionLen: 80
176; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
177; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
178; CHECKSYM-NEXT:       SymbolAlignmentLog2: 4
179; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
180; CHECKSYM-NEXT:       StorageMappingClass: XMC_PR (0x0)
181; CHECKSYM-NEXT:       StabInfoIndex: 0x0
182; CHECKSYM-NEXT:       StabSectNum: 0x0
183; CHECKSYM-NEXT:     }
184; CHECKSYM-NEXT:   }
185; CHECKSYM-NEXT:   Symbol {
186; CHECKSYM-NEXT:     Index: [[#Index+12]]
187; CHECKSYM-NEXT:     Name: .main
188; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x0
189; CHECKSYM-NEXT:     Section: .text
190; CHECKSYM-NEXT:     Type: 0x0
191; CHECKSYM-NEXT:     StorageClass: C_EXT (0x2)
192; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
193; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
194; CHECKSYM-NEXT:       Index: [[#Index+13]]
195; CHECKSYM-NEXT:       ContainingCsectSymbolIndex: [[#Index+10]]
196; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
197; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
198; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
199; CHECKSYM-NEXT:       SymbolType: XTY_LD (0x2)
200; CHECKSYM-NEXT:       StorageMappingClass: XMC_PR (0x0)
201; CHECKSYM-NEXT:       StabInfoIndex: 0x0
202; CHECKSYM-NEXT:       StabSectNum: 0x0
203; CHECKSYM-NEXT:     }
204; CHECKSYM-NEXT:   }
205; CHECKSYM-NEXT:   Symbol {
206; CHECKSYM-NEXT:     Index: [[#Index+14]]
207; CHECKSYM-NEXT:     Name: .data
208; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x50
209; CHECKSYM-NEXT:     Section: .data
210; CHECKSYM-NEXT:     Type: 0x0
211; CHECKSYM-NEXT:     StorageClass: C_HIDEXT (0x6B)
212; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
213; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
214; CHECKSYM-NEXT:       Index: [[#Index+15]]
215; CHECKSYM-NEXT:       SectionLen: 4
216; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
217; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
218; CHECKSYM-NEXT:       SymbolAlignmentLog2: 2
219; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
220; CHECKSYM-NEXT:       StorageMappingClass: XMC_RW (0x5)
221; CHECKSYM-NEXT:       StabInfoIndex: 0x0
222; CHECKSYM-NEXT:       StabSectNum: 0x0
223; CHECKSYM-NEXT:     }
224; CHECKSYM-NEXT:   }
225; CHECKSYM-NEXT:   Symbol {
226; CHECKSYM-NEXT:     Index: [[#Index+16]]
227; CHECKSYM-NEXT:     Name: foo_ext_weak_p
228; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x50
229; CHECKSYM-NEXT:     Section: .data
230; CHECKSYM-NEXT:     Type: 0x0
231; CHECKSYM-NEXT:     StorageClass: C_EXT (0x2)
232; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
233; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
234; CHECKSYM-NEXT:       Index: [[#Index+17]]
235; CHECKSYM-NEXT:       ContainingCsectSymbolIndex: [[#Index+14]]
236; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
237; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
238; CHECKSYM-NEXT:       SymbolAlignmentLog2: 0
239; CHECKSYM-NEXT:       SymbolType: XTY_LD (0x2)
240; CHECKSYM-NEXT:       StorageMappingClass: XMC_RW (0x5)
241; CHECKSYM-NEXT:       StabInfoIndex: 0x0
242; CHECKSYM-NEXT:       StabSectNum: 0x0
243; CHECKSYM-NEXT:     }
244; CHECKSYM-NEXT:   }
245; CHECKSYM-NEXT:   Symbol {
246; CHECKSYM-NEXT:     Index: [[#Index+18]]
247; CHECKSYM-NEXT:     Name: main
248; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x54
249; CHECKSYM-NEXT:     Section: .data
250; CHECKSYM-NEXT:     Type: 0x0
251; CHECKSYM-NEXT:     StorageClass: C_EXT (0x2)
252; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
253; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
254; CHECKSYM-NEXT:       Index: [[#Index+19]]
255; CHECKSYM-NEXT:       SectionLen: 12
256; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
257; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
258; CHECKSYM-NEXT:       SymbolAlignmentLog2: 2
259; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
260; CHECKSYM-NEXT:       StorageMappingClass: XMC_DS (0xA)
261; CHECKSYM-NEXT:       StabInfoIndex: 0x0
262; CHECKSYM-NEXT:       StabSectNum: 0x0
263; CHECKSYM-NEXT:     }
264; CHECKSYM-NEXT:   }
265; CHECKSYM-NEXT:   Symbol {
266; CHECKSYM-NEXT:     Index: [[#Index+20]]
267; CHECKSYM-NEXT:     Name: TOC
268; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x60
269; CHECKSYM-NEXT:     Section: .data
270; CHECKSYM-NEXT:     Type: 0x0
271; CHECKSYM-NEXT:     StorageClass: C_HIDEXT (0x6B)
272; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
273; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
274; CHECKSYM-NEXT:       Index: [[#Index+21]]
275; CHECKSYM-NEXT:       SectionLen: 0
276; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
277; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
278; CHECKSYM-NEXT:       SymbolAlignmentLog2: 2
279; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
280; CHECKSYM-NEXT:       StorageMappingClass: XMC_TC0 (0xF)
281; CHECKSYM-NEXT:       StabInfoIndex: 0x0
282; CHECKSYM-NEXT:       StabSectNum: 0x0
283; CHECKSYM-NEXT:     }
284; CHECKSYM-NEXT:   }
285; CHECKSYM-NEXT:   Symbol {
286; CHECKSYM-NEXT:     Index: [[#Index+22]]
287; CHECKSYM-NEXT:     Name: foo_ext_weak_p
288; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x60
289; CHECKSYM-NEXT:     Section: .data
290; CHECKSYM-NEXT:     Type: 0x0
291; CHECKSYM-NEXT:     StorageClass: C_HIDEXT (0x6B)
292; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
293; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
294; CHECKSYM-NEXT:       Index: [[#Index+23]]
295; CHECKSYM-NEXT:       SectionLen: 4
296; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
297; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
298; CHECKSYM-NEXT:       SymbolAlignmentLog2: 2
299; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
300; CHECKSYM-NEXT:       StorageMappingClass: XMC_TC (0x3)
301; CHECKSYM-NEXT:       StabInfoIndex: 0x0
302; CHECKSYM-NEXT:       StabSectNum: 0x0
303; CHECKSYM-NEXT:     }
304; CHECKSYM-NEXT:   }
305; CHECKSYM-NEXT:   Symbol {
306; CHECKSYM-NEXT:     Index: [[#Index+24]]
307; CHECKSYM-NEXT:     Name: b_w
308; CHECKSYM-NEXT:     Value (RelocatableAddress): 0x64
309; CHECKSYM-NEXT:     Section: .data
310; CHECKSYM-NEXT:     Type: 0x0
311; CHECKSYM-NEXT:     StorageClass: C_HIDEXT (0x6B)
312; CHECKSYM-NEXT:     NumberOfAuxEntries: 1
313; CHECKSYM-NEXT:     CSECT Auxiliary Entry {
314; CHECKSYM-NEXT:       Index: [[#Index+25]]
315; CHECKSYM-NEXT:       SectionLen: 4
316; CHECKSYM-NEXT:       ParameterHashIndex: 0x0
317; CHECKSYM-NEXT:       TypeChkSectNum: 0x0
318; CHECKSYM-NEXT:       SymbolAlignmentLog2: 2
319; CHECKSYM-NEXT:       SymbolType: XTY_SD (0x1)
320; CHECKSYM-NEXT:       StorageMappingClass: XMC_TC (0x3)
321; CHECKSYM-NEXT:       StabInfoIndex: 0x0
322; CHECKSYM-NEXT:       StabSectNum: 0x0
323; CHECKSYM-NEXT:     }
324; CHECKSYM-NEXT:   }
325; CHECKSYM-NEXT: ]
326