首页 > 系统相关 >linux操作系统实验四-以time/gettimeofday系统调用为例分析ARM64 Linux 5.4.34

linux操作系统实验四-以time/gettimeofday系统调用为例分析ARM64 Linux 5.4.34

时间:2023-04-01 16:23:23浏览次数:44  
标签:调用 为例 make Linux 系统 dev tm linux

一、搭配环境

(1)安装编译工具

sudo apt-get install gcc-aarch64-linux-gnu

sudo apt-get install libncurses5-dev  build-essential git bison flex libssl-dev

(2)制作根文件系统

wget  https://busybox.net/downloads/busybox-1.33.1.tar.bz2

tar -xjf busybox-1.33.1.tar.bz2

cd busybox-1.33.1

 

(3)打开静态库编译选项

make menuconfig

Settings --->

 [*] Build static binary (no shared libs)

 

 

(4)指定编译工具

export ARCH=arm64

export CROSS_COMPILE=aarch64-linux-gnu-

 

(5)编译

make

make install

 

(6)编译内核

make defconfig ARCH=arm64

make menuconfig ARCH=arm64

 

Kernel hacking  --->

    Compile-time checks and compiler options  --->

        [*] Compile the kernel with debug info

        [*]   Provide GDB scripts for kernel debugging

    [*] Kernel debugging

Kernel Features ---->

    [] Randomize the address of the kernel image

 执行编译

 

export ARCH=arm64

export CROSS_COMPILE=aarch64-linux-gnu-

make Image -j$(nproc)

 

(6)下载并配置qemu

apt-get install build-essential zlib1g-dev pkg-config libglib2.0-dev binutils-dev libboost-all-dev autoconf libtool libssl-dev libpixman-1-dev libpython-dev python-pip python-capstone virtualenv

wget https://download.qemu.org/qemu-4.2.1.tar.xz

tar xvJf qemu-4.2.1.tar.xz

cd qemu-4.2.1

./configure --target-list=x86_64-softmmu,x86_64-linux-user,arm-softmmu,arm-linux-user,aarch64-softmmu,aarch64-linux-user --enable-kvm

make

sudo make install

 

(7)启动qumu

qemu-system-aarch64 -m 128M -smp 1 -cpu cortex-a57 -machine virt -kernel linux-5.4.34/arch/arm64/boot/Image -initrd rootfs.cpio.gz -append "rdinit=/init console=ttyAMA0 loglevel=8" -nographic -s

 

 

二、调试分析系统调用

(1)触发 time/gettimeofday 系统调用:在程序中使用内嵌汇编

#include <stdio.h>

#include <time.h>

#include <sys/time.h>

 

int main()

{

      time_t tt;

      struct timeval tv;

      struct tm *t;

#if 0

      gettimeofday(&tv,NULL); // 使用库函数的方式触发系统调用

#else

      asm volatile( // 使用内嵌汇编的方式触发系统调用

          "add   x0, x29, 16\n\t"  //X0寄存器用于传递参数&tv

          "mov   x1, #0x0\n\t"     //X1寄存器用于传递参数NULL

          "mov   x8, #0xa9\n\t"   //使用X8传递系统调用号169

          "svc   #0x0\n\t"            //触发系统调用

      );

#endif

      tt = tv.tv_sec;                    //tv是保存获取时间结果的结构体

      t = localtime(&tt);                //将世纪秒转换成对应的年月日时分秒

      printf("time: %d/%d/%d %d:%d:%d\n",

             t->tm_year + 1900,

             t->tm_mon,

             t->tm_mday,

             t->tm_hour,

             t->tm_min,

             t->tm_sec);

      return 0;

}

 

编译

aarch64-linux-gnu-gcc -o test test.c -static

 

(2)进行调试

1. 配置vscode文件的launch.json和tasks.json文件,与实验三中配置类似

Launch.json

 

Tasks.json

 

2. 添加断点

 

3. 运行调试,可以看到在断点处停了下来

 

 

4. 分析系统调用的执行

此处系统调用由svc 指令触发,用户态程序触发系统调用时:先把系统调用的参数依次放入 X0-X5 寄存器,然后把系统调用号放在 X8 寄存器里,最后执行 svc 指令,CPU 即进入内核态

el0_sync 处的内核汇编代码首先做的就是保存程序的执行现场,然后根据异常发生的原因跳转到 el0_svc,el0_svc将 X8 寄存器中存放的系统调用号传递给 invoke_syscall 函数。

接着执行 invoke_syscall 函数,将通用寄存器中的内容传入 syscall_fn(),引出系统调用内核处理函数 __arm64_sys_gettimeofday。

系统调用内核处理函数执行完成后,会将系统调用的返回值存放在 X0 寄存器中。

系统调用返回前,需要恢复异常发生时程序的执行现场,最后内核调用异常返回指令 eret,返回用户态继续执行用户态程序。

 

标签:调用,为例,make,Linux,系统,dev,tm,linux
From: https://www.cnblogs.com/lijiang2023/p/17278787.html

相关文章

  • Linux核心命令
    Linux查询命令手册网站:https://wangchujiang.com/linux-command/http://linux.51yip.com/1.线上查询及帮助命令(3个)manlshelpinfo2.文件和目录操作命令(13个)ls$ls   #仅列出当前目录可见文件$ls-l  #列出当前目录可见文件详细信息√$ls-hl #列出详......
  • 关于网络通信中TCP/UDP的端口范围-以及在Linux系统中的使用权限说明
    关于TCP/UDP的端口号的范围都是0~65535 根据IANA定义,可以参考如下链接:https://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xhtmlIANA将这些端口分成了3类,LastUpdated2023-03-30Portnumbersareassignedinvariousways,based......
  • Linux下防火墙操作
    一、什么是防火墙防火墙:防范一些网络攻击。有软件防火墙、硬件防火墙之分。防火墙选择让正常请求通过,从而保证网络安全性。二、firewalld防火墙的概念2.1、区域CentOS6x中防火墙叫做iptables;CentOS7.x中默认使用的防火墙是firewalldfirewalld增加了区域的概念,所谓区域......
  • Linux系统之部署Go语言开发运行环境
    (Linux系统之部署Go语言开发运行环境)一、Go语言介绍1.Go语言简介Go(又称Golang)是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言。2.Go语言的撰写风格每行程序结束后不需要撰写分号。左大括号不能够换行放置。if判断式和for循环不需要以小括号......
  • 单例的各种方式实现,本写法以类A为例,泛型可以使用T
    单例的使用如下:#region单例的各种方式实现,本写法以类A为例,泛型可以使用TpublicclassA{#region单线程----常规,多线程不安全/////<summary>/////私有构造函数,防止初始化/////</summary>//privateA()//{......
  • 备份 Linux 系统神器:rsync
    导读探索rsync在备份方案中的作用。在系统管理员的工作中备份无疑是一个重要的部分。当没有完整备份或者良好规划的备份和实施时,就可能或早或晚不可挽回地丢失重要的数据。所有公司,无论大小,都运营在数据之上。考虑到丢失业务数据造成的经济和业务损失,从最小的个人公司到......
  • Linux系统下进程回收--wait()函数
    进程回收在每个进程退出的时候,内核释放该进程所有资源‘包括打开的文件、占用的内存等。但是仍然会保存一定的信息,这些信息主要是进程控制块PCB的信息(包括进程号、退出状态、运行时间等)。父进程可以调用wait()或waitpid()函数得到它的退出状态,同时彻底清除这个进程。wait()......
  • linux连接终端工具
    linux连接终端工具:electerm:https://github.com/electerm/electermhttps://electerm.github.io/electerm/MobaXterm:https://mobaxterm.mobatek.net/功能十分强大,支持SSH,FTP,串口,VNC,Xserver等功能;支持标签,切换也十分方便;可视化目录直接上传下载:注:不能支持szrz命令,可以......
  • Linux线程同步必知,常用方法揭秘!
    一、为什么要线程同步在Linux多线程编程中,线程同步是一个非常重要的问题。如果线程之间没有正确地同步,就会导致程序出现一些意外的问题,例如:竞态条件(RaceCondition):多个线程同时修改同一个共享变量,可能会导致不可预测的结果,因为线程的执行顺序是不确定的。死锁(Deadlock):当两个......
  • Linux:常用命令有哪些?
    查看文件查看文件属性:file 文件名查看内容全部内容:cat-n(可选,显示行号)文件名分页查看:less文件名文件尾部:tail文件名头部:head文件名新建文件夹mkdir......