| ; RUN: llc < %s -mtriple=x86_64-- -filetype=obj -o - | llvm-objdump -d - | FileCheck %s |
| |
| ; This test verifies that we assemble code for different architectures |
| ; based on target-cpu and target-features attributes. |
| target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" |
| |
| define void @foo() #0 { |
| entry: |
| call void asm sideeffect "aeskeygenassist $$0x4, %xmm0, %xmm1", "~{dirflag},~{fpsr},~{flags}"() |
| ret void |
| } |
| |
| ; CHECK: foo |
| ; CHECK: aeskeygenassist |
| |
| define void @bar() #2 { |
| entry: |
| call void asm sideeffect "crc32b 4(%rbx), %eax", "~{dirflag},~{fpsr},~{flags}"() |
| ret void |
| } |
| |
| ; CHECK: bar |
| ; CHECK: crc32b |
| |
| attributes #0 = { "target-cpu"="x86-64" "target-features"="+avx2" } |
| attributes #2 = { "target-cpu"="corei7" "target-features"="+sse4.2" } |