草庐IT

arm汇编

全部标签

c++ - 为什么简单的内联汇编函数不能在 GCC 中正常工作?

我有一个简单的内联汇编函数,它在MSVC中运行良好,但由于某种原因拒绝在AppleGCC4.2.1下运行(i386arch,强制32位模式)。幸运的是,更复杂的汇编函数可以正常工作,但是我不明白为什么这个函数不起作用...不幸的是,我无法调试它-从外观上看,XCode中没有寄存器窗口4.0.2(它是3.2版本)。我很肯定这个问题与英特尔风格的汇编无关。intConvert(doublevalue){_asm{fldvaluepusheaxfistpdwordptr[esp]popeax}//Thereturnedvalueisinsane} 最佳答案

c++ - getch 相当于汇编语言

我在汇编语言中编程,在C++中使用x86,我需要知道汇编语言中的getch等价物而不是C++语言,因为我不想使用C++编程语言中的任何函数。我在网上找到了代码,但它将给定值保存到一个变量中,并在C++中创建。我只想使用该功能来停止程序,直到按下任何键。我不必在进一步的编程中使用输入的键值。 最佳答案 这是一个特定于操作系统的问题。例如,如果您使用的是Linux,则可以像这样发出read系统调用:;Allocatesomestackbuffer...subesp,256moveax,3;3=__NR_readfrommovebx,0;

c++ - GCC 汇编代码生成错误和解决方法

GCC4.5.2(在Ubuntu11.10x64上,但编译为32位)生成无效的汇编代码,我很好奇是否可以在不更改代码的情况下修复,只需应用选项或类似的东西。请注意,优化已经是-O0。我有两个功能:inlinelongClass::Get(){longv=*(long*)(m_p);m_p+=4;returnv;}inlinevoidClass::Command(){m_p+=Get();}GCC4.5.2生成此汇编代码:9840m_p+=Get();f689eff5:mov0x8(%ebp),%eaxf689eff8:mov0xd4(%eax),%eaxf689effe:mov%eax

c++ - Windows RT on ARM native 代码调用约定是什么?

我找不到任何关于VisualStudioC++使用的WindowsRTonARM调用约定的文档。微软是否使用ARM的AAPCS?如果Microsoft在ARM上使用适用于WindowsRT的AAPCS/EABI,它是否也使用ARM'sC++ABI(源自ItaniumC++ABI)?甚至可能是ARMexceptionhandlingABI?ARM上的WindowsRT使用的调用约定与其他(嵌入式)ARMWindows变体使用的调用约定是否不同?是否有可靠的方法通过预定义的编译器宏检测ARM上的WindowsRT?更新:添加了关于C++ABI的问题。 最佳答案

unity android包(armV7+arm64)启动黑屏崩溃,在splash动画开始前

1、先交代下问题背景。打包一直是用的armV7架构,前段时间老板提到加上arm64。没想到公司其中一台手机居然崩溃,unity的splash动画都没播,但是也没闪退,就是黑屏。看到一串红色崩溃日志。2、解决方式。把原来安装的armV7架构包删掉,再装armV7+arm64架构的包就可以了。参考UnityAndroidbuildcrashwhenusingARM64withIL2CPP-UnityForum,其中有好几种情况,也分别有好几种解决方式,这种方式解决不了,可以看看上边问题的回答。我是参考了里边的“更换签名文件”3、崩溃日志关键字:signal11(SIGSEGV),code1(SEG

CISC&RISC? CPU架构有哪些? x86 & ARM?

编者按:鉴于笔者水平有限,文中难免有不当之处,还请各位读者海涵。是为序我猜,常年混迹CSDN的同学应该不会没听说过CPU吧?但你真的了解CPU吗?那笔者问你CPU有哪些架构呢?如果你对你的答案不是很确定,那刚好,不妨跟随笔者来大致了解一下吧~下面开始正文。CISC/RISC照例,先抛出几个问题,带着问题来阅读本文,效果会更好。目前市面上有哪些CPU厂商呢?他们所采用的CPU架构又是哪些呢?不同的CPU架构下面又有哪些CPU品牌呢?话不多说,让咱们来一一解密。先说说CPU厂商,在PC和服务器领域,Intel和AMD是耳熟能详的,在移动消费领域有基于ARM架构进行设计的TI、ST、NXP等等,它们

c++ - 将 GCC 内联汇编 CMOV 转换为 Visual Studio 汇编器

文章中Linearvs.BinarySearch,有一个使用CMOV指令的二进制搜索的快速实现。我想在VC++中实现它,因为我正在处理的应用程序依赖于二进制搜索的性能。该实现有一些GCC内联汇编器,声明如下:staticintbinary_cmov(constint*arr,intn,intkey){intmin=0,max=n;while(min>1;asm("cmpl%3,%2\n\tcmovg%4,%0\n\tcmovle%5,%1":"+r"(min),"+r"(max):"r"(key),"g"(arr[middle]),"g"(middle+1),"g"(middle));

c++ - 如何通过反汇编从 C++ 函数中获取 "lea"指令?

我正在尝试学习逆向工程,但我被这件小事困住了。我有这样的代码:.text:10003478moveax,HWHandle.text:1000347Dleaecx,[eax+1829B8h]我想知道,它在C或C++中看起来如何?尤其是箭头所指的两条指令。HWHandle是一个变量,它保存从GetModuleHandle()函数返回的值。更有趣的是,在这条指令下面的几行中,dword_1000FCA0被用作一个函数:.text:1000353Cmoveax,dword_1000FCA0.text:10003541movecx,[eax+0A0h].text:10003547pushoffs

c++ - 用于多态调用的 x86-64 汇编器

我有C++代码:intmain(){M*m;O*o=newIO();H*h=newH("A");if(__rdtsc()%5==0){m=newY(o,h);}else{m=newZ(o,h);}m->my_virtual();return1;}虚拟调用由这个asm表示:movrax,qwordptr[x]movrax,qwordptr[rax]movrcx,qwordptr[x]callqwordptr[rax]这比我预期的vtable方法调用多了一行。所有四个ASM行都特定于多态调用吗?上面四行怎么伪读?这是完整的ASM和C++(虚拟调用在最后进行):intmain(){addby

ARM 400系列控制器IP简介

1. GIC-400        GIC-400是一个高性能、区域优化的中断控制器,具有高级微控制器总线架构(AMBA)高级可扩展接口(AXI)接口。它在片上系统(SoC)配置中检测、管理和分配中断。你可以对GIC-400进行配置,以便为你的预期应用提供所需的最佳功能、性能和门数量。通过GIC-400的下列软件可配置设置,提供的中断控制选项如下所示:启用或禁用。分配到两个组中的一个,组0或组1。优先处理。在多处理器实现中向不同的处理器发出信号。可以是电平敏感的,也可以是边沿触发的。GIC-400实现了以下的功能:GIC安全扩展,支持。将0组中断作为安全中断,将1组中断作为非安全中断。可以选择