[LLVMdev] How to Find Instruction Encoding for a MachineInstr
John Criswell
criswell at illinois.edu
Tue Oct 23 17:23:13 PDT 2012
On 10/23/12 7:19 PM, Craig Topper wrote:
> What function provides the encoding length? X86 in particular is so
> difficult to encode that only the old style JIT and the MC Code
> Emitter could possibly know how many bytes something takes.
The getSize() method of MCInstrDesc which can be fetched from a
MachineInstr using the getDesc() method:
http://llvm.org/doxygen/classllvm_1_1MCInstrDesc.html#ae8a17b854d9787d11797d9334a22647d
Does this method not work as advertised in Doxygen?
-- John T.
>
> On Tue, Oct 23, 2012 at 11:58 AM, John Criswell <criswell at illinois.edu
> <mailto:criswell at illinois.edu>> wrote:
>
> Dear All,
>
> I'm enhancing a MachineFunctionPass that enforces control-flow
> integrity. One of the things I want to do is to set the alignment
> of an instruction (by adding NOPs before it in the
> MachineBasicBlock or by emitting an alignment directive to the
> assembler) if it causes a specific sequence of bytes to be
> generated at a specific alignment. The goal is to ensure that
> sequences of bytes used to label valid targets of an indirect
> branch (e.g., a return instruction) do not appear at a given
> alignment anywhere in a program other than for where I inserted
> them explicitly.
>
> It looks like MachineInstr has a method for finding the length of
> the instruction's binary encoding, but I didn't see a method for
> finding the exact bytes that would be emitted from the
> MachineInstr. Is there a way to do this in the
> MachineFunctionPass/MachineInstr infrastructure, or do I need to
> use something like the MC classes?
>
> Thanks in advance for any help provided.
>
> -- John T.
>
> _______________________________________________
> LLVM Developers mailing list
> LLVMdev at cs.uiuc.edu <mailto:LLVMdev at cs.uiuc.edu>
> http://llvm.cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev
>
>
>
>
> --
> ~Craig
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20121023/3c3db393/attachment.html>
More information about the llvm-dev
mailing list