• 用ARM进行汇编语言编程(7)HelloWorld和gdb调试Arm程序


    简介

    上一篇文章我们在linux里安装了arm环境,不知道怎么安装的可以去看上一篇文章

    HelloWorld

    连接ssh后,然后创建一个文件夹来存放我们写的项目

    mkdir HelloWorld
    cd HelloWorld
    
    • 1
    • 2

    然后用nano工具创建一个文件

    nano HelloWorld.s
    
    • 1

    在这里插入图片描述

    首先创建基本的标签,写入我们想输出的字符串

    .global _start
    _start:
    
    
    .data
    message:
            .asciz "hello world !\n"    //.asciz:ascii集,后面是输出的字符
    len = .-message   //定义字符串的长度
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    然后就要写主程序了,第一件事是我们要把数据或者字符存放到哪里,第二件事是要输出什么,第三件事是我们输出字符的长度是多少

    .global _start
    _start:
    
            MOV R0,#1   //计算机标准输出
            LDR R1,=message   //告诉程序字符串位置在哪里
            LDR R2,=len   //告诉程序要输出的字符串长度
            MOV R7,#4   //当我们与操作系统交互时,r7是一个特殊的寄存器,4意思是输出
    		SWI 0  //中断程序
    
    		MOV R7,#1   //1终止此程序
    		SWI 0   //中断程序
    
    .data   
    message:
            .asciz "hello world !\n"
    len = .-message
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在这里插入图片描述

    ctrl+o保存,然后ctrl+x退出

    在这里插入图片描述

    然后编译程序

    as HelloWorld.s -o helloworld.o
    ld helloworld.o -o hellworld
    
    • 1
    • 2

    在这里插入图片描述

    执行

    ./helloworld
    
    • 1

    在这里插入图片描述

    成功输出

    gdb调试Arm程序

    gdb是linux动态调试工具

    chmod 777 helloworld
    gdb helloworld
    
    • 1
    • 2

    在这里插入图片描述

    然后对程序添加断点,让程序停在我们想要分析的地址上

    b _start   //在_start处添加断点
    disassemble _start  //查看_start的汇编代码
    
    • 1
    • 2

    在这里插入图片描述

    输入run就能停在断点处,现在程序是正在运行中的

    在这里插入图片描述

    输入layout asm 可以获得一个方便观察的界面

    在这里插入图片描述

    可以看到,这里的汇编代码和我们写的差不多,输入info register [小写的寄存器] 可以查看当前寄存器的值,现在没有执行,所以是0

    在这里插入图片描述

    或者输入layout regs,上面就会显示寄存器的界面

    在这里插入图片描述

    可以用键盘上的上下键查看其他地址,输入stepi,执行第一条汇编代码

    在这里插入图片描述

    可以看到,r0寄存器里的值就为1了,使用x/16x $r1 查看r1内存地址里的值

    在这里插入图片描述

    x/10d $r1以十进制显示内存里的数值

    在这里插入图片描述

    x/10c $r1以ascii码新式查看内存里的数据

    在这里插入图片描述

    总结

    这是我学习的笔记,有什么错误和不懂的地方欢迎来私信我,或者加我qq

  • 相关阅读:
    【HDU No. 3567】八数码 II Eight II
    金融知识分享系列之:五日线
    领域自适应的几个子问题
    687 最长同值路径——Leetcode 天天刷(2022.9.2)【DFS】
    41. linux通过yum安装postgresql
    可行性研究报告模板
    太厉害了,阿里内网最新发布的【MySQL面试小册】把MySQL架构+索引原理+性能优化都讲清楚了
    高三高考免费试卷真题押题知识点合集
    多进程编程- POSIX无名信号量
    通过实例学习鸿蒙静态库的创建与使用
  • 原文地址:https://blog.csdn.net/qq_45894840/article/details/126680431