; RUN: llc < %s | FileCheck %s --check-prefixes CHECK,ATTRS ; RUN: llc < %s -mattr=+simd128 | FileCheck %s --check-prefixes CHECK,SIMD128 ; RUN: llc < %s -mcpu=bleeding-edge | FileCheck %s --check-prefixes CHECK,BLEEDING-EDGE ; Test that codegen emits target features from the command line or ; function attributes correctly and that features are enabled for the ; entire module if they are enabled for any function in the module. target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128" target triple = "wasm32-unknown-unknown" define void @foo(i32* %p1, float %f2) #0 { %a = atomicrmw min i32* undef, i32 42 seq_cst %v = fptoui float %f2 to i32 store i32 %v, i32* %p1 ret void } define void @bar(i32* %p1, float %f2) #1 { %a = atomicrmw min i32* undef, i32 42 seq_cst %v = fptoui float %f2 to i32 store i32 %v, i32* %p1 ret void } attributes #0 = { "target-features"="+atomics" } attributes #1 = { "target-features"="+nontrapping-fptoint" } ; CHECK-LABEL: foo: ; Expanded atomicrmw min ; ATTRS: loop ; ATTRS: i32.atomic.rmw.cmpxchg ; SIMD128-NOT: i32.atomic.rmw.cmpxchg ; ATTRS: end_loop ; nontrapping fptoint ; ATTRS: i32.trunc_sat_f32_u ; SIMD128-NOT: i32.trunc_sat_f32_u ; ATTRS: i32.store ; `bar` should be the same as `foo` ; CHECK-LABEL: bar: ; Expanded atomicrmw min ; ATTRS: loop ; ATTRS: i32.atomic.rmw.cmpxchg ; SIMD128-NOT: i32.atomic.rmw.cmpxchg ; ATTRS: end_loop ; nontrapping fptoint ; ATTRS: i32.trunc_sat_f32_u ; SIMD128-NOT: i32.trunc_sat_f32_u ; ATTRS: i32.store ; CHECK-LABEL: .custom_section.target_features,"",@ ; +atomics, +nontrapping-fptoint ; ATTRS-NEXT: .int8 2 ; ATTRS-NEXT: .int8 43 ; ATTRS-NEXT: .int8 7 ; ATTRS-NEXT: .ascii "atomics" ; ATTRS-NEXT: .int8 43 ; ATTRS-NEXT: .int8 19 ; ATTRS-NEXT: .ascii "nontrapping-fptoint" ; -atomics, +simd128 ; SIMD128-NEXT: .int8 2 ; SIMD128-NEXT: .int8 45 ; SIMD128-NEXT: .int8 7 ; SIMD128-NEXT: .ascii "atomics" ; SIMD128-NEXT: .int8 43 ; SIMD128-NEXT: .int8 7 ; SIMD128-NEXT: .ascii "simd128" ; +atomics, +nontrapping-fptoint, +sign-ext, +simd128 ; BLEEDING-EDGE-NEXT: .int8 5 ; BLEEDING-EDGE-NEXT: .int8 43 ; BLEEDING-EDGE-NEXT: .int8 7 ; BLEEDING-EDGE-NEXT: .ascii "atomics" ; BLEEDING-EDGE-NEXT: .int8 43 ; BLEEDING-EDGE-NEXT: .int8 15 ; BLEEDING-EDGE-NEXT: .ascii "mutable-globals" ; BLEEDING-EDGE-NEXT: .int8 43 ; BLEEDING-EDGE-NEXT: .int8 19 ; BLEEDING-EDGE-NEXT: .ascii "nontrapping-fptoint" ; BLEEDING-EDGE-NEXT: .int8 43 ; BLEEDING-EDGE-NEXT: .int8 8 ; BLEEDING-EDGE-NEXT: .ascii "sign-ext" ; BLEEDING-EDGE-NEXT: .int8 43 ; BLEEDING-EDGE-NEXT: .int8 7 ; BLEEDING-EDGE-NEXT: .ascii "simd128" ; CHECK-NEXT: .text