草庐IT

inline-assembly

全部标签

c++ - 'inline' 的正确位置

我应该把inline放在哪里?测试1.h:classtest1{inlinevoidmethod1(){}};测试2.h:classtest2{voidmethod2();};inlinevoidtest2::method2(){}测试3.h:classtest3{inlinevoidmethod3();};inlinevoidtest3::method3(){}测试4.h:classtest4{inlinevoidmethod4();};test4.cpp:voidtest4::method4(){}test5.h:classtest5{inlinevoidmethod5();};t

c++ - Web Assembly (wasm) 会有自己的语法吗?

听说W3正在研究网络的字节码,威尔webassembly(wasm)有自己的语法,比如nasm和masm?例如输入类似的东西,global_mainextern_MessageBoxA@16extern_ExitProcess@4sectioncodeuse32class=code_main:pushdword0;UINTuType=MB_OKpushdwordtitle;LPCSTRlpCaptionpushdwordbanner;LPCSTRlpTextpushdword0;HWNDhWnd=NULLcall_MessageBoxA@16pushdword0;UINTuExitCo

c++ - 我应该在频繁使用的功能上使用 `inline` 吗?

我有一个cnVector类,它表示3维空间中的一个点。它的运算符+-*/被密集使用。他们的实现非常简短:cnVectorcnVector::operator+(constcnVector&v)const{returncnVector(x+v.x,y+v.y,z+v.z);}我的问题是,因为这个函数很短,虽然它被大量使用,但我是否应该内联它?还是在那么使用它时会生成太多代码? 最佳答案 是的,您可能应该这样做。c++中inline关键字的良好用例是:小函数,大量使用。另见http://msdn.microsoft.com/en-us/

c++ - 在 C++ 内联汇编中定义一个变量

假设我们有以下C++代码:intvar1;__asm{movvar1,2;}现在,我想知道的是,如果我不想在__asm指令之外定义var1,我必须做些什么才能将它放入其中。有可能吗?谢谢 最佳答案 为此,您需要使用_declspec(naked)创建一个“裸”方法,并自行编写通常由编译器创建的序言和结尾。序言的目的是:设置EBP和ESP为局部变量保留堆栈空间将需要修改的寄存器保存在函数体中结语必须:恢复保存的寄存器值清理局部变量的保留空间这是一个标准的序言pushebp;Saveebpmovebp,esp;Setstackframe

c++ - 如何在 C++ 中进行内联汇编 (Visual Studio 2010)

我正在编写一个性能关键、数字运算的C++项目,其中70%的时间用于200行核心模块。我想使用内联汇编优化核心,但我对此完全陌生。不过,我知道一些x86汇编语言,包括GCC和NASM使用的语言。我所知道的:我必须将汇编程序指令放在_asm{}我希望它们所在的位置。问题:我不知道从哪里开始。当我的内联汇编发挥作用时,哪个寄存器中有什么? 最佳答案 您可以通过名称访问变量并将它们复制到寄存器中。这是来自MSDN的示例:intpower2(intnum,intpower){__asm{moveax,num;Getfirstargumentm

c++ - 带变量的 GCC 内联 ASM

我正在尝试在我的C++源代码中使用以下ASM内联代码,为VisualStudio提供:__asm{movecx,target}其中target是一个void*指针。我不知道如何将其转换为GCC兼容代码。我知道GCC使用像这样的synthax:asm(".intel_syntaxnoprefix");asm("movecx,target");但显然在这种情况下变量有问题。那么,任何人都可以向我解释如何使用适用于Windows的GCC将指针与内联ASM一起使用吗?感谢您的帮助。 最佳答案 试试这个程序集,这可能会有帮助....至少它对我

c++ - GCC 内联汇编错误 : Cannot take the address of 'this' , 这是一个右值表达式

我仍在与GCC作斗争-编译以下内联汇编代码(使用-fasm-blocks,启用Intel风格汇编syntax)给我一个奇怪的错误Cannottaketheaddressof'this',whichisanrvalueexpression...MyClass::MyFunction(){_asm{//...movebx,this//error:Cannottaketheaddressof'this',whichisanrvalueexpression//...moveax,this//error:Cannottaketheaddressof'this',whichisanrvalueex

c++ - 如果将 "+m"用作输出约束,gcc 能否正常工作?

根据gccdocs在扩展汇编器上:只有当操作数的约束[...]允许寄存器时,您才应该使用读写操作数。这似乎非常明确:您不能将+m用于输出。但是,我已经看到它被执行了很多次。事实上,LinusTorvalds是onrecord如说gcc文档是次要的。它们没有更新,它们不正确,它们不反射(reflect)现实,它们无关紧要。对于这样的事情,唯一正确的用法是“+m”如果编译器最终会搞砸我的代码,我不想使用+m。甚至检查输出asm看它是否工作并不意味着明天当我更改一些看似无关的东西时它仍然可以工作。或者当我获得gcc的下一个更新时它仍然可以工作。如果文档是正确的并且我不能依赖它正常工作,我想知

c++ - 内联汇编程序调用子程序

我对内联汇编程序有疑问。可以在同一个函数中从内联汇编程序调用另一个汇编程序子例程吗?例如:voidFindValidPID(unsignedint&Pid){__asm{subesp,20hmoveax,Pidaddeax,eaxcallsub123;anotherassmsubroutinemovPid,eaxaddesp,20h}}我应该在哪里以及如何编写子例程sub123?干杯,托马斯 最佳答案 如果您在汇编中编写整个子例程,您应该考虑使用文件级汇编器而不是内联。 关于c++-内联

c++ - 错误 : operand out of range (64 is not between 0 and 31)

我在PowerPC上遇到GCC内联汇编。该程序使用-g2-O3编译良好,但使用-g3-O0编译失败。问题是,我需要在调试器下观察它,所以我需要没有优化的符号。程序如下:$cattest.cxx#include#undefvectortypedef__vectorunsignedcharuint8x16_p;uint8x16_pVectorFastLoad8(constvoid*p){longoffset=0;uint8x16_pres;__asm("lxvd2x%x0,%1,%2\n\t":"=wa"(res):"g"(p),"g"(offset/4),"Z"(*(constchar(