<div dir="ltr">Please help. How to resolve above mentioned issues.</div><div class="gmail_extra"><br><div class="gmail_quote">On Sat, Aug 26, 2017 at 2:31 PM, hameeza ahmed <span dir="ltr"><<a href="mailto:hahmed2305@gmail.com" target="_blank">hahmed2305@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div> i want to emit binary code for the following implemented vector assembly instructions.<br></div><div><div>P_256B_LOAD_DWORD<span style="white-space:pre-wrap"> </span>R_0_R2048b_0, pword ptr [rip + b]</div><div>P_256B_LOAD_DWORD<span style="white-space:pre-wrap"> </span>R_0_R2048b_1, pword ptr [rip + c]</div><div>P_256B_VADD<span style="white-space:pre-wrap"> </span>R_0_R2048b_0, R_0_R2048b_1, R_0_R2048b_0 </div><div>P_256B_STORE_DWORD<span style="white-space:pre-wrap"> </span>pword ptr [rip + a], R_0_R2048b_0</div></div><div><br></div><div> I added the following lines in X86MCInstLower.cpp;</div><div> unsigned NewOpc;</div><div> switch (OutMI.getOpcode()) {</div><div> default: llvm_unreachable("Invalid opcode");</div><div> case X86::P_256B_LOAD_DWORD: NewOpc = X86::P_256B_LOAD_DWORD; break;</div><div> case X86::P_256B_STORE_DWORD: NewOpc = X86::P_256B_STORE_DWORD; break;</div><div> case X86::P_256B_VADD: NewOpc = X86::P_256B_VADD; break;</div><div> }</div><div> OutMI.setOpcode(NewOpc);</div><div> break; </div><div><br></div><div><br></div><div>when i used the command:<br></div><div><br></div><div><div>llc -x86-asm-syntax=intel -debug -p-enabled=true -filetype=obj sum-vec03.ll>objpon 2>&1</div></div><div>i am getting the following error:<br></div><div><br></div><div><div>********** COMPUTING STACKMAP LIVENESS: foo **********</div><div>Unknown immediate size</div><div>UNREACHABLE executed at lib/Target/X86/MCTargetDesc/<wbr>X86BaseInfo.h:574!</div><div>#0 0x00000000019d9fec llvm::sys::PrintStackTrace(<wbr>llvm::raw_ostream&) lib/Support/Unix/Signals.inc:<wbr>402:11</div><div>#1 0x00000000019da4d9 PrintStackTraceSignalHandler(<wbr>void*) lib/Support/Unix/Signals.inc:<wbr>466:1</div><div>#2 0x00000000019d8853 llvm::sys::RunSignalHandlers() lib/Support/Signals.cpp:0:5</div><div>#3 0x00000000019da834 SignalHandler(int) lib/Support/Unix/Signals.inc:<wbr>256:1</div><div>#4 0x00007f2f2be14d10 __restore_rt (/lib/x86_64-linux-gnu/<wbr>libpthread.so.0+0x10d10)</div><div>#5 0x00007f2f2adc2267 gsignal (/lib/x86_64-linux-gnu/libc.<wbr>so.6+0x35267)</div><div>#6 0x00007f2f2adc3eca abort (/lib/x86_64-linux-gnu/libc.<wbr>so.6+0x36eca)</div><div>#7 0x000000000195f6c0 LLVMInstallFatalErrorHandler lib/Support/ErrorHandling.cpp:<wbr>133:0</div><div>#8 0x0000000000c08966 llvm::X86II::getSizeOfImm(<wbr>unsigned long) lib/Target/X86/MCTargetDesc/<wbr>X86BaseInfo.h:577:29</div><div>#9 0x0000000000c04c2a (anonymous namespace)::X86MCCodeEmitter::<wbr>encodeInstruction(llvm::MCInst const&, llvm::raw_ostream&, llvm::SmallVectorImpl<llvm::<wbr>MCFixup>&, llvm::MCSubtargetInfo const&) const lib/Target/X86/MCTargetDesc/<wbr>X86MCCodeEmitter.cpp:1512:67</div><div>#10 0x00000000015884b3 llvm::MCELFStreamer::<wbr>EmitInstToData(llvm::MCInst const&, llvm::MCSubtargetInfo const&) lib/MC/MCELFStreamer.cpp:478:<wbr>26</div><div>#11 0x00000000015aadc0 llvm::MCObjectStreamer::<wbr>EmitInstruction(llvm::MCInst const&, llvm::MCSubtargetInfo const&) lib/MC/MCObjectStreamer.cpp:<wbr>245:5</div><div>#12 0x00000000007a036b llvm::X86AsmPrinter::<wbr>EmitAndCountInstruction(llvm::<wbr>MCInst&) lib/Target/X86/X86MCInstLower.<wbr>cpp:106:3</div><div>#13 0x00000000007a32dc llvm::X86AsmPrinter::<wbr>EmitInstruction(llvm::<wbr>MachineInstr const*) lib/Target/X86/X86MCInstLower.<wbr>cpp:1849:1</div><div>#14 0x0000000000dde226 llvm::AsmPrinter::<wbr>EmitFunctionBody() lib/CodeGen/AsmPrinter/<wbr>AsmPrinter.cpp:943:11</div><div>#15 0x0000000000796e81 llvm::X86AsmPrinter::<wbr>runOnMachineFunction(llvm::<wbr>MachineFunction&) lib/Target/X86/X86AsmPrinter.<wbr>cpp:73:3</div><div>#16 0x000000000104d441 llvm::MachineFunctionPass::<wbr>runOnFunction(llvm::Function&) lib/CodeGen/<wbr>MachineFunctionPass.cpp:62:8</div><div>#17 0x00000000014766bf llvm::FPPassManager::<wbr>runOnFunction(llvm::Function&) lib/IR/LegacyPassManager.cpp:<wbr>1513:27</div><div>#18 0x00000000014769d5 llvm::FPPassManager::<wbr>runOnModule(llvm::Module&) lib/IR/LegacyPassManager.cpp:<wbr>1534:16</div><div>#19 0x000000000147716a (anonymous namespace)::MPPassManager::<wbr>runOnModule(llvm::Module&) lib/IR/LegacyPassManager.cpp:<wbr>1590:27</div><div>#20 0x0000000001476c96 llvm::legacy::PassManagerImpl:<wbr>:run(llvm::Module&) lib/IR/LegacyPassManager.cpp:<wbr>1693:16</div><div>#21 0x0000000001477681 llvm::legacy::PassManager::<wbr>run(llvm::Module&) lib/IR/LegacyPassManager.cpp:<wbr>1724:3</div><div>#22 0x000000000076bbde compileModule(char**, llvm::LLVMContext&) tools/llc/llc.cpp:530:42</div><div>#23 0x000000000076a0c9 main tools/llc/llc.cpp:285:13</div><div>#24 0x00007f2f2adada40 __libc_start_main (/lib/x86_64-linux-gnu/libc.<wbr>so.6+0x20a40)</div><div>#25 0x0000000000769b99 _start (/bin/llc+0x769b99)</div><div>Stack dump:</div><div>0.<span style="white-space:pre-wrap"> </span>Program arguments: /bin/llc -x86-asm-syntax=intel -debug -pim-enabled=true -filetype=obj sum-vec03.ll </div><div>1.<span style="white-space:pre-wrap"> </span>Running pass 'Function Pass Manager' on module 'sum-vec03.ll'.</div><div>2.<span style="white-space:pre-wrap"> </span>Running pass 'X86 Assembly Printer' on function '@foo'</div></div><div><br></div><div><br></div><div>what to do now? I am stuck here. Please help.</div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div></div><div><br></div><div>when i used the command: llc -x86-asm-syntax=intel -debug -p-enabled=true -filetype=obj sum-vec03.ll>objpon 2>&1</div><div>i am getting the following error:</div><div><br></div><div><div>********** COMPUTING STACKMAP LIVENESS: foo **********</div><div>Unknown immediate size</div><div>UNREACHABLE executed at /lib/Target/X86/MCTargetDesc/X<wbr>86BaseInfo.h:574!</div><div>#0 0x00000000019d9fec llvm::sys::PrintStackTrace(llv<wbr>m::raw_ostream&) /lib/Support/Unix/Signals.inc:<wbr>402:11</div><div>#1 0x00000000019da4d9 PrintStackTraceSignalHandler(v<wbr>oid*) /lib/Support/Unix/Signals.inc:<wbr>466:1</div><div>#2 0x00000000019d8853 llvm::sys::RunSignalHandlers() /lib/Support/Signals.cpp:0:5</div><div>#3 0x00000000019da834 SignalHandler(int) /lib/Support/Unix/Signals.inc:<wbr>256:1</div><div>#4 0x00007f6d08f79d10 __restore_rt (/lib/x86_64-linux-gnu/libpthr<wbr>ead.so.0+0x10d10)</div><div>#5 0x00007f6d07f27267 gsignal (/lib/x86_64-linux-gnu/libc.so<wbr>.6+0x35267)</div><div>#6 0x00007f6d07f28eca abort (/lib/x86_64-linux-gnu/libc.so<wbr>.6+0x36eca)</div><div>#7 0x000000000195f6c0 LLVMInstallFatalErrorHandler /lib/Support/ErrorHandling.cpp<wbr>:133:0</div><div>#8 0x0000000000c08966 llvm::X86II::getSizeOfImm(unsi<wbr>gned long) /lib/Target/X86/MCTargetDesc/X<wbr>86BaseInfo.h:577:29</div><div>#9 0x0000000000c04c2a (anonymous namespace)::X86MCCodeEmitter::<wbr>encodeInstruction(llvm::MCInst const&, llvm::raw_ostream&, llvm::SmallVectorImpl<llvm::MC<wbr>Fixup>&, llvm::MCSubtargetInfo const&) const /lib/Target/X86/MCTargetDesc/X<wbr>86MCCodeEmitter.cpp:1512:67</div><div>#10 0x00000000015884b3 llvm::MCELFStreamer::EmitInstT<wbr>oData(llvm::MCInst const&, llvm::MCSubtargetInfo const&) /lib/MC/MCELFStreamer.cpp:478:<wbr>26</div><div>#11 0x00000000015aadc0 llvm::MCObjectStreamer::EmitIn<wbr>struction(llvm::MCInst const&, llvm::MCSubtargetInfo const&) /lib/MC/MCObjectStreamer.cpp:2<wbr>45:5</div><div>#12 0x00000000007a036b llvm::X86AsmPrinter::EmitAndCo<wbr>untInstruction(llvm::MCInst&) /lib/Target/X86/X86MCInstLower<wbr>.cpp:106:3</div><div>#13 0x00000000007a32dc llvm::X86AsmPrinter::EmitInstr<wbr>uction(llvm::MachineInstr const*) /lib/Target/X86/X86MCInstLower<wbr>.cpp:1738:1</div><div>#14 0x0000000000dde226 llvm::AsmPrinter::EmitFunction<wbr>Body() /lib/CodeGen/AsmPrinter/AsmPri<wbr>nter.cpp:943:11</div><div>#15 0x0000000000796e81 llvm::X86AsmPrinter::runOnMach<wbr>ineFunction(llvm::MachineFunct<wbr>ion&) /lib/Target/X86/X86AsmPrinter.<wbr>cpp:73:3</div><div>#16 0x000000000104d441 llvm::MachineFunctionPass::run<wbr>OnFunction(llvm::Function&) /lib/CodeGen/MachineFunctionPa<wbr>ss.cpp:62:8</div><div>#17 0x00000000014766bf llvm::FPPassManager::runOnFunc<wbr>tion(llvm::Function&) /lib/IR/LegacyPassManager.cpp:<wbr>1513:27</div><div>#18 0x00000000014769d5 llvm::FPPassManager::runOnModu<wbr>le(llvm::Module&) /lib/IR/LegacyPassManager.cpp:<wbr>1534:16</div><div>#19 0x000000000147716a (anonymous namespace)::MPPassManager::run<wbr>OnModule(llvm::Module&) /lib/IR/LegacyPassManager.cpp:<wbr>1590:27</div><div>#20 0x0000000001476c96 llvm::legacy::PassManagerImpl:<wbr>:run(llvm::Module&) /lib/IR/LegacyPassManager.cpp:<wbr>1693:16</div><div>#21 0x0000000001477681 llvm::legacy::PassManager::run<wbr>(llvm::Module&) /lib/IR/LegacyPassManager.cpp:<wbr>1724:3</div><div>#22 0x000000000076bbde compileModule(char**, llvm::LLVMContext&) /tools/llc/llc.cpp:530:42</div><div>#23 0x000000000076a0c9 main /tools/llc/llc.cpp:285:13</div><div>#24 0x00007f6d07f12a40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so<wbr>.6+0x20a40)</div><div>#25 0x0000000000769b99 _start (/bin/llc+0x769b99)</div><div>Stack dump:</div><div>0.<span style="white-space:pre-wrap"> </span>Program arguments: /bin/llc -x86-asm-syntax=intel -debug -p-enabled=true -filetype=obj sum-vec03.ll </div><div>1.<span style="white-space:pre-wrap"> </span>Running pass 'Function Pass Manager' on module 'sum-vec03.ll'.</div><div>2.<span style="white-space:pre-wrap"> </span>Running pass 'X86 Assembly Printer' on function '@foo'</div></div><div><br></div><div><br></div><div>What should I do? Please help.</div><div><div class="m_6400064344569106734gmail-h5"><div><br></div><div><br></div><div><br></div><div><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Aug 24, 2017 at 1:35 AM, hameeza ahmed <span dir="ltr"><<a href="mailto:hahmed2305@gmail.com" target="_blank">hahmed2305@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Hello,<div><br></div><div>I have implemented some vector instructions ( greater vector width) in LLVM x86 backend. The llc is generating correct assembly. however to execute that on some target machine. i need object file. What changes do i need to do? do i need to put these new instructions and register info in MC framework to generate object code from .s assembly file?</div><div><br></div><div><br></div><div>Please help. I am stuck at this point.</div><div><br></div><div>Thank You</div><div>Regards</div></div>
</blockquote></div><br></div></div></div></div>
</blockquote></div><br></div></div>
</blockquote></div><br></div>