草庐IT

asm-generic

全部标签

c++ - 如何获取 llvm 内联 asm 操作数类型?

我正在从事一个关于LLVM的内联汇编的项目,但我遇到了一个关于汇编操作数的问题。例如,我有这样的代码:inta;intb;asm("nop":"=r"(a),"r"(b),"g"(30));我可以使用llvm::InlineAssembly::getAsmString()函数获取asm字符串“nop”,我还可以使用llvm::InlineAsm::ParseConstraints函数获取约束“rrimr”信息并迭代返回值。但我的问题是我无法获取asm操作数信息,尤其是asm操作数类型(a是整数类型,b是整数类型,30是常量int)。那么有人知道有什么方法可以获取asm操作数信息吗?

Arm Generic Interrupt Controller v3 and v4(GICv3v4)学习(一)

提示该博客主要为个人学习,通过阅读官网手册整理而来(个人觉得阅读官网的英文文档非常有助于理解各个IP特性)。若有不对之处请参考参考文档,以官网参考文档为准。ArmGenericInterruptControllerv3andv4学习一共分为三章,这是第一章第一章:讲解GIC,主要为基础知识,SPI、PPI与SGI配置第二章:讲解LPI第三章:讲解Virtualization1Background中断是发送给处理器的一个信号,表明已经发生了需要处理的事件。中断通常是由外围设备产生的。小型系统可能只有几个中断源和一个处理器。然而,较大的系统可能有更多潜在的中断源和处理器。GIC执行中断管理、优先级

c++ - 确定 "generic function"的返回类型

假设,我想开发一个通用库,它应该可用于类似数字的类型,包括double类型和用户定义类型。我现在面临的问题是我不知道如何像这样编写函数模板的返回类型:templateautotransmogrify(Tx)->???{usingstd::abs;returnabs(x)+2.0;}using声明使此函数模板的主体适用于原始类型,因为它们没有关联的命名空间(因此没有ADL)。但我希望transmogrify使用专门的abs函数,以防用户定义类型的作者提供他自己的abs函数。我不能简单地使用->decltype(abs(x)+2.0)因为这对double不起作用,因为std::abs不在范

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

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

c++ - 什么是 C++11 原子 API 等同于 `` `__asm__ volatile ("":::: "memory")`` `

一个代码库有一个COMPILER_BARRIER宏定义为__asm__volatile("":::"memory").宏的目的是防止编译器跨屏障重新排序读写。请注意,这显然是编译器屏障,不是处理器级内存屏障。事实上,这是相当可移植的,因为在AssemblerTemplate中没有实际的汇编指令,只有volatile和memory破坏。因此,只要编译器支持GCC的ExtendedAsm语法,它就应该可以正常工作。不过,我很好奇如果可能的话,在C++11原子API中表达这一点的正确方法是什么。以下似乎是正确的想法:atomic_signal_fence(memory_order_acq_r

javascript - 如何检查 Firefox 是否使用 asm.js 代码?

那么我如何检查它是通过Google的V8引擎像普通Javascript一样执行还是使用汇编以接近native的性能执行? 最佳答案 如果你只看控制台,Firefox会告诉你你的asm.js是否通过验证。对于上面粘贴的脚本,我得到:TypeError:asm.jstypeerror:non-expression-statementcallmustbecoercedtest.html:23这表明不是。本例中的第23行是:return+sqrt(square(x)+square(y));如果我用这个替换那行:return+sqrt(+sq

c++ - 使用 XMM0 寄存器和内存提取(C++ 代码)比仅使用 XMM 寄存器的 ASM 快两倍 - 为什么?

我正在尝试实现一些内联汇编程序(在VisualStudio2012C++代码中)以利用SSE。我想将7个数字相加1e9次,所以我将它们从RAM放置到xmm0到CPU的xmm6寄存器。当我使用以下代码在visualstudio2012中使用内联汇编时:C++代码:for(inti=0;i我的ASM代码:intcount=1000000000;doubleresVal=0.0;//placingvaluestoregister__asm{movsdxmm0,val1;placingvar1inxmm0registermovsdxmm1,val2movsdxmm2,val3movsdxmm3

c++ - Visual Studio C++ : Seeing the ASM code?

我想看看VisualStudioC++生成的所有asm,以了解一些有关ASM、编译器等的知识。我知道使用GCC,您可以使用-S参数来实现,但不能在VS中实现。我该怎么做? 最佳答案 最简单的方法是在集成调试器中启动您的程序,然后打开汇编语言View。这显示了与您的原始源代码交错的汇编语言。当我使用VS时,这是Alt+F7或其他东西,但它可能已经改变了。这样做(相对于使用-S等价物)的好处是您可以准确地关注您感兴趣的代码行。 关于c++-VisualStudioC++:SeeingtheA

C++:什么是技术层面的 R 值引用 (ASM)?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Whatisthedifferencebetweenr-valuereferencesandl-valuereferences?(CodeGen)我想知道,谁能从技术层面解释一下R值引用是什么?我的意思是:创建R值引用时在汇编程序级别会发生什么。为了进行小测试以查看内部发生的情况,我编写了以下代码:charc=255;char&c2=c;char&c3=std::move(c);我知道创建对“c”的R值引用是没有意义的,但只是为了测试我还是做了,看看它做了什么。结果如下:unsignedcharc=255;m

【异常】jdk21升级,asm报错Unsupported class file major version 65 springboot2 升级JDK21

【异常】jdk21升级,asm报错Unsupportedclassfilemajorversion65错误信息Causedby:org.springframework.core.NestedIOException:ASMClassReaderfailedtoparseclassfile-probablyduetoanewJavaclassfileversionthatisn'tsupportedyet:file[C:\App.class];nestedexceptionisjava.lang.IllegalArgumentException:Unsupportedclassfilemajorv