mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-22 10:33:23 +00:00
x86-32: PUSHF/POPF use/def EFLAGS
Summary: As a side-quest for D6629 jvoung pointed out that I should use -verify-machineinstrs and this found a bug in x86-32's handling of EFLAGS for PUSHF/POPF. This patch fixes the use/def, and adds -verify-machineinstrs to all x86 tests which contain 'EFLAGS'. One exception: this patch leaves inline-asm-fpstack.ll as-is because it fails -verify-machineinstrs in a way unrelated to EFLAGS. This patch also modifies cmpxchg-clobber-flags.ll along the lines of what D6629 already does by also testing i386. Test Plan: ninja check Reviewers: t.p.northover, jvoung Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D6687 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224359 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
192487e379
commit
50b8835451
@ -954,11 +954,6 @@ def POP32rmr: I<0x8F, MRM0r, (outs GR32:$reg), (ins), "pop{l}\t$reg", [],
|
|||||||
IIC_POP_REG>, OpSize32, Requires<[Not64BitMode]>;
|
IIC_POP_REG>, OpSize32, Requires<[Not64BitMode]>;
|
||||||
def POP32rmm: I<0x8F, MRM0m, (outs), (ins i32mem:$dst), "pop{l}\t$dst", [],
|
def POP32rmm: I<0x8F, MRM0m, (outs), (ins i32mem:$dst), "pop{l}\t$dst", [],
|
||||||
IIC_POP_MEM>, OpSize32, Requires<[Not64BitMode]>;
|
IIC_POP_MEM>, OpSize32, Requires<[Not64BitMode]>;
|
||||||
|
|
||||||
def POPF16 : I<0x9D, RawFrm, (outs), (ins), "popf{w}", [], IIC_POP_F>,
|
|
||||||
OpSize16;
|
|
||||||
def POPF32 : I<0x9D, RawFrm, (outs), (ins), "popf{l|d}", [], IIC_POP_FD>,
|
|
||||||
OpSize32, Requires<[Not64BitMode]>;
|
|
||||||
} // mayLoad, SchedRW
|
} // mayLoad, SchedRW
|
||||||
|
|
||||||
let mayStore = 1, SchedRW = [WriteStore] in {
|
let mayStore = 1, SchedRW = [WriteStore] in {
|
||||||
@ -987,13 +982,23 @@ def PUSHi16 : Ii16<0x68, RawFrm, (outs), (ins i16imm:$imm),
|
|||||||
def PUSHi32 : Ii32<0x68, RawFrm, (outs), (ins i32imm:$imm),
|
def PUSHi32 : Ii32<0x68, RawFrm, (outs), (ins i32imm:$imm),
|
||||||
"push{l}\t$imm", [], IIC_PUSH_IMM>, OpSize32,
|
"push{l}\t$imm", [], IIC_PUSH_IMM>, OpSize32,
|
||||||
Requires<[Not64BitMode]>;
|
Requires<[Not64BitMode]>;
|
||||||
|
} // mayStore, SchedRW
|
||||||
|
}
|
||||||
|
|
||||||
|
let Defs = [ESP, EFLAGS], Uses = [ESP], mayLoad = 1, hasSideEffects=0,
|
||||||
|
SchedRW = [WriteLoad] in {
|
||||||
|
def POPF16 : I<0x9D, RawFrm, (outs), (ins), "popf{w}", [], IIC_POP_F>,
|
||||||
|
OpSize16;
|
||||||
|
def POPF32 : I<0x9D, RawFrm, (outs), (ins), "popf{l|d}", [], IIC_POP_FD>,
|
||||||
|
OpSize32, Requires<[Not64BitMode]>;
|
||||||
|
}
|
||||||
|
|
||||||
|
let Defs = [ESP], Uses = [ESP, EFLAGS], mayStore = 1, hasSideEffects=0,
|
||||||
|
SchedRW = [WriteStore] in {
|
||||||
def PUSHF16 : I<0x9C, RawFrm, (outs), (ins), "pushf{w}", [], IIC_PUSH_F>,
|
def PUSHF16 : I<0x9C, RawFrm, (outs), (ins), "pushf{w}", [], IIC_PUSH_F>,
|
||||||
OpSize16;
|
OpSize16;
|
||||||
def PUSHF32 : I<0x9C, RawFrm, (outs), (ins), "pushf{l|d}", [], IIC_PUSH_F>,
|
def PUSHF32 : I<0x9C, RawFrm, (outs), (ins), "pushf{l|d}", [], IIC_PUSH_F>,
|
||||||
OpSize32, Requires<[Not64BitMode]>;
|
OpSize32, Requires<[Not64BitMode]>;
|
||||||
|
|
||||||
} // mayStore, SchedRW
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let Defs = [RSP], Uses = [RSP], hasSideEffects=0 in {
|
let Defs = [RSP], Uses = [RSP], hasSideEffects=0 in {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -mtriple=i686-linux -mattr=-sse | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -mtriple=i686-linux -mattr=-sse | FileCheck %s
|
||||||
; PR11768
|
; PR11768
|
||||||
|
|
||||||
@ptr = external global i8*
|
@ptr = external global i8*
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -mcpu=generic -mtriple=x86_64-linux | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -mcpu=generic -mtriple=x86_64-linux | FileCheck %s
|
||||||
|
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
||||||
target triple = "x86_64-apple-macosx10.7.0"
|
target triple = "x86_64-apple-macosx10.7.0"
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -mtriple=x86_64-apple-darwin10 -disable-cgp-select2branch | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -mtriple=x86_64-apple-darwin10 -disable-cgp-select2branch | FileCheck %s
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
||||||
|
|
||||||
define i32 @test1(i32 %x, i32 %n, i32 %w, i32* %vp) nounwind readnone {
|
define i32 @test1(i32 %x, i32 %n, i32 %w, i32* %vp) nounwind readnone {
|
||||||
|
@ -1,19 +1,21 @@
|
|||||||
; RUN: llc -mtriple=x86_64-linux-gnu %s -o - | FileCheck %s
|
; RUN: llc -verify-machineinstrs -mtriple=i386-linux-gnu %s -o - | FileCheck %s
|
||||||
; RUN: llc -mtriple=x86_64-linux-gnu -pre-RA-sched=fast %s -o - | FileCheck %s
|
; RUN: llc -verify-machineinstrs -mtriple=i386-linux-gnu -pre-RA-sched=fast %s -o - | FileCheck %s
|
||||||
|
; RUN: llc -verify-machineinstrs -mtriple=x86_64-linux-gnu %s -o - | FileCheck %s
|
||||||
|
; RUN: llc -verify-machineinstrs -mtriple=x86_64-linux-gnu -pre-RA-sched=fast %s -o - | FileCheck %s
|
||||||
|
|
||||||
declare i32 @bar()
|
declare i32 @bar()
|
||||||
|
|
||||||
define i64 @test_intervening_call(i64* %foo, i64 %bar, i64 %baz) {
|
define i64 @test_intervening_call(i64* %foo, i64 %bar, i64 %baz) {
|
||||||
; CHECK-LABEL: test_intervening_call:
|
; CHECK-LABEL: test_intervening_call:
|
||||||
; CHECK: cmpxchg
|
; CHECK: cmpxchg
|
||||||
; CHECK: pushfq
|
; CHECK: pushf[[LQ:[lq]]]
|
||||||
; CHECK: popq [[FLAGS:%.*]]
|
; CHECK-NEXT: pop[[LQ]] [[FLAGS:%.*]]
|
||||||
|
|
||||||
; CHECK: callq bar
|
; CHECK-NEXT: call[[LQ]] bar
|
||||||
|
|
||||||
; CHECK: pushq [[FLAGS]]
|
; CHECK-NEXT: push[[LQ]] [[FLAGS]]
|
||||||
; CHECK: popfq
|
; CHECK-NEXT: popf[[LQ]]
|
||||||
; CHECK: jne
|
; CHECK-NEXT: jne
|
||||||
%cx = cmpxchg i64* %foo, i64 %bar, i64 %baz seq_cst seq_cst
|
%cx = cmpxchg i64* %foo, i64 %bar, i64 %baz seq_cst seq_cst
|
||||||
%p = extractvalue { i64, i1 } %cx, 1
|
%p = extractvalue { i64, i1 } %cx, 1
|
||||||
call i32 @bar()
|
call i32 @bar()
|
||||||
@ -68,14 +70,13 @@ define i32 @test_feed_cmov(i32* %addr, i32 %desired, i32 %new) {
|
|||||||
; CHECK-LABEL: test_feed_cmov:
|
; CHECK-LABEL: test_feed_cmov:
|
||||||
|
|
||||||
; CHECK: cmpxchg
|
; CHECK: cmpxchg
|
||||||
; CHECK: pushfq
|
; CHECK: pushf[[LQ:[lq]]]
|
||||||
; CHECK: popq [[FLAGS:%.*]]
|
; CHECK-NEXT: pop[[LQ]] [[FLAGS:%.*]]
|
||||||
|
|
||||||
; CHECK: callq bar
|
; CHECK-NEXT: call[[LQ]] bar
|
||||||
|
|
||||||
; CHECK: pushq [[FLAGS]]
|
|
||||||
; CHECK: popfq
|
|
||||||
|
|
||||||
|
; CHECK-NEXT: push[[LQ]] [[FLAGS]]
|
||||||
|
; CHECK-NEXT: popf[[LQ]]
|
||||||
%res = cmpxchg i32* %addr, i32 %desired, i32 %new seq_cst seq_cst
|
%res = cmpxchg i32* %addr, i32 %desired, i32 %new seq_cst seq_cst
|
||||||
%success = extractvalue { i32, i1 } %res, 1
|
%success = extractvalue { i32, i1 } %res, 1
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -disable-fp-elim -disable-machine-dce -verify-coalescing
|
; RUN: llc < %s -verify-machineinstrs -disable-fp-elim -disable-machine-dce -verify-coalescing
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
||||||
target triple = "x86_64-apple-macosx10.7.0"
|
target triple = "x86_64-apple-macosx10.7.0"
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
; REQUIRES: asserts
|
; REQUIRES: asserts
|
||||||
; RUN: llc < %s -march=x86 -mcpu=core2 -pre-RA-sched=source -enable-misched -verify-misched -debug-only=misched -o - 2>&1 > /dev/null | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -march=x86 -mcpu=core2 -pre-RA-sched=source -enable-misched -verify-misched -debug-only=misched -o - 2>&1 > /dev/null | FileCheck %s
|
||||||
;
|
;
|
||||||
; Test scheduling of copy instructions.
|
; Test scheduling of copy instructions.
|
||||||
;
|
;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -enable-misched -verify-misched
|
; RUN: llc < %s -verify-machineinstrs -enable-misched -verify-misched
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
||||||
target triple = "x86_64-apple-macosx10"
|
target triple = "x86_64-apple-macosx10"
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
; RUN: llc -O0 < %s
|
; RUN: llc -O0 < %s -verify-machineinstrs
|
||||||
; RUN: llc < %s
|
; RUN: llc < %s -verify-machineinstrs
|
||||||
target triple = "x86_64-apple-macosx10.7"
|
target triple = "x86_64-apple-macosx10.7"
|
||||||
|
|
||||||
; This test case extracts a sub_8bit_hi sub-register:
|
; This test case extracts a sub_8bit_hi sub-register:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -march=x86 | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -march=x86 | FileCheck %s
|
||||||
|
|
||||||
; CHECK: testl
|
; CHECK: testl
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -mtriple=i386-apple-darwin -mcpu=corei7 | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -mtriple=i386-apple-darwin -mcpu=corei7 | FileCheck %s
|
||||||
; rdar://5571034
|
; rdar://5571034
|
||||||
|
|
||||||
; This requires physreg joining, %vreg13 is live everywhere:
|
; This requires physreg joining, %vreg13 is live everywhere:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN-disabled: llc < %s -mtriple=x86_64-apple-macosx -pre-RA-sched=ilp -debug-only=pre-RA-sched \
|
; RUN-disabled: llc < %s -verify-machineinstrs -mtriple=x86_64-apple-macosx -pre-RA-sched=ilp -debug-only=pre-RA-sched \
|
||||||
; RUN-disabled: 2>&1 | FileCheck %s
|
; RUN-disabled: 2>&1 | FileCheck %s
|
||||||
; RUN: true
|
; RUN: true
|
||||||
; REQUIRES: asserts
|
; REQUIRES: asserts
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
; REQUIRES: asserts
|
; REQUIRES: asserts
|
||||||
; RUN: llc -mtriple=x86_64-apple-darwin -debug -o /dev/null < %s 2>&1 | FileCheck %s
|
; RUN: llc -verify-machineinstrs -mtriple=x86_64-apple-darwin -debug -o /dev/null < %s 2>&1 | FileCheck %s
|
||||||
|
|
||||||
; We need to make sure that rematerialization into a physical register marks the
|
; We need to make sure that rematerialization into a physical register marks the
|
||||||
; super- or sub-register as dead after this rematerialization since only the
|
; super- or sub-register as dead after this rematerialization since only the
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -march=x86-64 -asm-verbose=false -mtriple=x86_64-unknown-linux-gnu -mcpu=nehalem -post-RA-scheduler=true -schedmodel=false | FileCheck %s
|
; RUN: llc < %s -verify-machineinstrs -march=x86-64 -asm-verbose=false -mtriple=x86_64-unknown-linux-gnu -mcpu=nehalem -post-RA-scheduler=true -schedmodel=false | FileCheck %s
|
||||||
|
|
||||||
; Currently, floating-point selects are lowered to CFG triangles.
|
; Currently, floating-point selects are lowered to CFG triangles.
|
||||||
; This means that one side of the select is always unconditionally
|
; This means that one side of the select is always unconditionally
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc -mcpu=corei7-avx %s -o - | FileCheck %s --check-prefix=CHECK --check-prefix=NO-FLAGS
|
; RUN: llc -verify-machineinstrs -mcpu=corei7-avx %s -o - | FileCheck %s --check-prefix=CHECK --check-prefix=NO-FLAGS
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
||||||
target triple = "x86_64-apple-macosx10.9.0"
|
target triple = "x86_64-apple-macosx10.9.0"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user