- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在试图分析通过msp430 gcc生成的简单程序集文件时,我无意中发现了一组指令,我不理解如何处理帧指针和msp430的堆栈指针。
C程序:
#include "msp430g2553.h"
int main()
{
int i;
for(i = 0; i < 3; i++);
}
main:
mov r1, r4 ;Stores address of stack pointer in r4(frame pointer)
add #2, r4 ; ?
sub #2, r1 ; subtract 2 to allocate int i
mov #0, -4(r4) ; assign 0 to i
jmp .L2 ; start loop
.L3:
add #1, -4(r4) ; Adds one to int i
.L2:
cmp #3, -4(r4) ; Compare to #3
jl .L3 ; jump to .L3 if true
add #2, r1 ; deallocate int i
.Lfe1:
.size main,.Lfe1-main
add #2, r4
这一行这里到底发生了什么,为什么
int i
被引用到
-4(r4)
?
最佳答案
通常,在函数中要做的第一件事是:
push r4
push
将自动将堆栈指针减小2,因此在执行此操作时:
mov r1, r4
r4
上的地址将高于刚才推到堆栈上的值(这里是“上面”,意思是堆栈向下增长,实际上是数字内存地址的下面)您将希望帧指针实际指向您刚刚推送到堆栈上的值的下方,因此您将它增加两个值以实现此目的:
add #2, r4
main()
是执行的第一个函数,所以没有保存的现有框架指针,所以你在这里看到的是
mov
和
add
没有的
push
。
push r4
mov r1, r4
add #2, r4
-2(r4)
将引用刚才推送到堆栈上的帧指针的上一个值,并且由于尚未向堆栈指针的值添加两个值,
-2(r4)
也将等于该值。
i
以腾出空间,因此
2
的地址将为
i
。
-4(r4)
,而帧指针包含
0x200
,然后要调用函数从这样的堆栈开始:
r4 --> 0x202 ---------------------
<empty>
r1 --> 0x200 ---------------------
0x202
之后,值
push r4
被推送到内存位置
0x202
(即由
0x200
指向的堆栈顶部),堆栈指针被
r1
递减以腾出空间,因此您可以:
r4 --> 0x202 ---------------------
<empty>
0x200 ---------------------
0x202
r1 --> 0x1FE ---------------------
2
中来开始此操作,然后得到:
0x202 ---------------------
<empty>
0x200 ---------------------
0x202
r1 == r4 --> 0x1FE ---------------------
r4
在此之前指向,而不是在它之后指向为此,将
r4
添加到
2
,您将得到:
0x202 ---------------------
<empty>
r4 --> 0x200 ---------------------
0x202
r1 --> 0x1FE ---------------------
r4
指向堆栈帧的底部,而
r4
指向堆栈帧的顶部,这是您想要的位置此时,当前堆栈帧中唯一实际存在的是在函数开始时推送到它上面的帧指针的上一个值。
r1
以腾出空间给新的局部变量,最后得到:
0x202 ---------------------
<empty>
r4 --> 0x200 ---------------------
0x202
0x1FE ---------------------
<uninitialized i>
r1 --> 0x1FC ---------------------
2
存储在
i
中,即
0x1FC
再次指出,您所处的位置
-4(r4)
指向堆栈帧的底部,
r4
指向堆栈帧的顶部,但现在您在当前堆栈帧中有两个16位值,因此两个指针相距4字节。
r1
来“释放”局部变量
add #2, r1
的内存这将给你:
0x202 ---------------------
<empty>
r4 --> 0x200 ---------------------
0x202
r1 --> 0x1FE ---------------------
i
,它将从堆栈中弹出最后一个值(现在是帧指针的原始值
pop r4
),将其放入
0x202
,并将堆栈指针增加
r4
,以反映该值已从堆栈中删除,这将使您处于:
r4 --> 0x202 ---------------------
<empty>
r1 --> 0x200 ---------------------
关于c - MSP430程序集堆栈指针行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26374287/
C#内部访问修饰符的定义是内部:只能在包含程序集或友元程序集内访问。所以我的问题是什么是 C# 程序集?在包含程序集或 friend 程序集之内是什么意思?它是否意味着在同一个命名空间或项目中? 最佳
任何人都可以回答以下问题。我正在使用 c# 语言。 我可以将程序集调用为 .ddl 或 .exe 文件吗? 我可以将 Assembly Manifest 称为程序集吗? 程序集、元数据和程序集 lis
我正在从 Python 运行一个 .NET COM 程序集,只有当我将程序集 dll 和依赖项复制到我的 Python 根路径 c:\Python27 时才能使它正常工作。 这是不整洁的,所以我想将
作为世界上任何一名程序员,他/她一生中至少有一次,我正在尝试创建我的“革命性”,新的且唯一的操作系统。 :D 好吧,我正在使用虚拟模拟器(Oracle VM Virtual Box),为此我创建了一个
我创建了以下程序来读取 5 个数字,然后 dumpreg查看输入的数字... INCLUDE Irvine32.inc .data count = 5 scor
如何在保护模式下执行 IN 和 OUT 等受限指令? 我发现它需要足够高的特权级别(CPL)才能执行 IO 指令。我怎样才能在内核模式下运行,拥有 IO 权限或任何其他可能对我有帮助的东西? - 我希
目录 C# 程序集、模块和类型概念及关系 概述 程序集 模块 类型 程序集、模块和类型的关系 总结 引用
构建 maven assembly ,我留下了这样的东西: ${project.basedir} / LICENS
我的应用程序由几个核心程序集和几个扩展/插件程序集组成。为了让 MEF 知道插件必须提供的所有部件,即使我永远不会使用它们的任何部件,我也必须加载这些程序集。这使得应用程序需要更多时间来启动(如果我要
我对我们的构建基础结构有一个非常具体的要求,即将另一个 JAR 依赖项的一些内容复制到我的 Web 应用程序的特定子文件夹中。我们正在使用 maven-assembly-plugin,一个自然的方法是
为什么下面的指令会设置符号标志? mov al,0FEh sub al,2 据我了解,AL寄存器可以保存2^8 - 1或255。0FEh = 254(十进制)。减去 2 叶 252。这似乎是正数。 (
我以前使用过 NUnit,但已经有一段时间了,而且从来没有在这台机器上使用过。我在 Program Files 下解压了 2.4.8 版本,并且在尝试加载测试时不断收到此错误。 Could not l
我说的是一个使用 C# 进行游戏编程的小型游戏引擎。所以,我有一个嵌入单声道运行时的 C++ 应用程序(我称之为“启动器”)。我有一个用 C# 编写的程序集,它是我的游戏引擎类库。启动器按照 Embe
我对汇编相当陌生,并尝试从标准输入读取值(从 C 调用 scanf 函数)并将其打印回标准输出(使用 printf)。 .text readstr: .asciz "%d" #strin
谢谢帮助,我的问题是关于从下面的代码中收到的 ax 值? mov al,22h mov cl,0fdh imul cl 真机结果:ff9a 我的预期:00:9a(通过二进制相乘) 第一个数字是 22h
我正在开发一个汇编程序,该程序将整个文本文件读入缓冲区,然后将其显示在控制台中。它立即显示 24 行(每行的最大长度为 80,因为我使用 80 宽 * 25 高的 dossbox )然后等待用户输入,
我正在使用一个简单的程序集片段,使用 BIOS 作为引导加载程序的一部分将字符打印到屏幕上。这是引导加载程序代码。 [org 0x7c00] [bits 16] %include "a20_check
我只是想知道这段代码是什么意思: XOR EAX,EBX XOR EBX,EAX XOR EAX,EBX 最佳答案 那是 xor swapping . 在寄存器上执行它不会遇到常见的难看的失败案例。
我在新电脑上的 XNA 项目开始出现奇怪的错误。我有两个关于解决方案的项目和一个由它们使用的库。其中一个项目,一个 XNA 游戏项目,运行完美。另一个项目是 WindowsForm 和 XNA 的混合
是的,我正在努力实现类似的目标 __asm__(jmp label;); 其中 label 应替换为内存中保存的字符串值(结构体的字段)。 有没有办法做到这一点(或类似的方法可以让我跳转到运行时确定的
我是一名优秀的程序员,十分优秀!