mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-11 10:31:27 +00:00

This new syntax is built around putting each instruction on its own line in a "mnemonic op, op, op" like syntax. It also uses conventional data section directives like ".byte" and so on rather than requiring everything to be in hierarchical S-expression format. This is a more natural syntax for a ".s" file format from the perspective of LLVM MC and related tools, while remaining easy to translate into other forms as needed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@249364 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
941 B
LLVM
45 lines
941 B
LLVM
; RUN: llc < %s -asm-verbose=false | FileCheck %s
|
|
|
|
; Test that basic functions assemble as expected.
|
|
|
|
target datalayout = "e-p:32:32-i64:64-n32:64-S128"
|
|
target triple = "wasm32-unknown-unknown"
|
|
|
|
; CHECK-LABEL: f0:
|
|
; CHECK: return{{$}}
|
|
; CHECK: .size f0,
|
|
define void @f0() {
|
|
ret void
|
|
}
|
|
|
|
; CHECK-LABEL: f1:
|
|
; CHECK-NEXT: .result i32{{$}}
|
|
; CHECK-NEXT: i32.const 0{{$}}
|
|
; CHECK-NEXT: set_local @0, pop{{$}}
|
|
; CHECK-NEXT: return @0{{$}}
|
|
; CHECK: .size f1,
|
|
define i32 @f1() {
|
|
ret i32 0
|
|
}
|
|
|
|
; CHECK-LABEL: f2:
|
|
; CHECK-NEXT: .param i32{{$}}
|
|
; CHECK-NEXT: .param f32{{$}}
|
|
; CHECK-NEXT: .result i32{{$}}
|
|
; CHECK-NEXT: i32.const 0{{$}}
|
|
; CHECK-NEXT: set_local @2, pop{{$}}
|
|
; CHECK-NEXT: return @2{{$}}
|
|
; CHECK: .size f2,
|
|
define i32 @f2(i32 %p1, float %p2) {
|
|
ret i32 0
|
|
}
|
|
|
|
; CHECK-LABEL: f3:
|
|
; CHECK-NEXT: .param i32{{$}}
|
|
; CHECK-NEXT: .param f32{{$}}
|
|
; CHECK-NEXT: return{{$}}
|
|
; CHECK: .size f3,
|
|
define void @f3(i32 %p1, float %p2) {
|
|
ret void
|
|
}
|