[llvm-dev] X86 Backend - How to push and pop eflags?

Fabio Pagani via llvm-dev llvm-dev at lists.llvm.org
Mon Feb 29 14:06:35 PST 2016


Hello llvm-dev list,

i am implementing an X86 Machine Pass that at some point needs to push/pop
eflags on the stack. This pass is hooked at preRegAlloc and LLVM is 3.7.0.
I got two big problems:
1) I didn't found a way to emit a pushfq instruction in a clean way, i.e.
with   BuildMI(*MBB, MI, DL, TII.get(X86::PUSHF64)). Even if both EFLAGS
and RSP are added to the MBB liveins, the Machine Verifier complains saying:
*** Bad machine code: Using an undefined physical register ***

- function:    main

- basic block: BB#238 for.inc.121.4 (0x43133b0)
- instruction: PUSHF64- operand 2:   %EFLAGS<imp-use,kill>

Anyway right now i'm able to push it via some "dirty" INLINE_ASM.

2) INLINE_ASM works pretty well, except in one randomly generated test case
where the register allocator spills a register in between the pushfq/popfq,
resulting in a crash of the compiled application.

So the question is: is there a recommended way to save and restore the
value of eflags?

Any help is really appreciated!
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160229/48d85701/attachment-0001.html>


More information about the llvm-dev mailing list