汇编代码调用main和分配内存

本文探讨了如何在汇编语言中调用C语言的main函数,并详细解释了栈指针SP的作用,它指向的内存区域用于数据存储。此外,还介绍了在子程序函数调用中R0到R2寄存器的角色,它们作为参数传递。同时,提到了Makefile在联合编译汇编和C文件中的应用,以及机器码和汇编代码之间的关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C语言的main函数

int main()
{
   unsigned int *pgpofcon = 0x56000050;
   unsigned int *pgpofdat = 0x56000054;

   *pgpofcon = 0x100;
   *pgpofdat =  0;
    

    return 0;
}
.text
.global _start
_start:
/*设置内存:sp栈*/
/*分辨是nor/nand启动
*写0到0地址,在读出来,如果得到0,表示0地址上的内容被修改了,它对应ram,这就是nand启动
*否则就是nor启动
*/
    mov r1,#0
    ldr r0,[r1] /*读出r0的值备份*/
    str r1,[r1] /*将r1的值写入[r1]地址指向的内存中,r1=0就是0地址*/
    ldr r2,[r1]/*将地址[r1]的值赋给r2*/
    cmp r1,r2 /*比较r1 == r2?,如果相等表示nand启动*/
    ldr sp,=0x40000000+4096 /*先假设是nor启动*/
    moveq sp,#4096 /*nand启动*/
    
    streq r0,[r1] /*恢复原来的值*/
               //ldr sp,=4096 /*nand启动*/
               //ldr sp,=0x40000000+4096 /*nor启动*/
    /*调用main*/
    bl main

halt:
    b halt

 

sp指针说明 ,sp指向的内存是栈,就是存储数据的

 

 

 R0是子程序函数调用的一个参数,R1/R2以此类推

Makefile编写汇编和c联合编译文件

all:
    arm-linux-gcc -c -o led.o led.c //编译c程序
    arm-linux-gcc -c -o start.o start.s//编译汇编程序
    arm-linux-ld -Ttext 0 start.o led.o -o led.elf //联合编译
    arm-linux-objcopy -O binary -S led.elf led.bin//生产可执行文件
    arm-linux-objdump -D led.elf > led.dis //生成机器码
clean:
    rm *.bin *.o *.elf *.dis //删除生成的文件

机器码和汇编码

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值