SVC指令时AARCH64架构中用于系统调用的命令,命令格式为:
SVC #<imm16>
该指令可以使CPU陷入SYNC异常中,linux中一般是el0t_sync,之后会调用el0t_64_sync_handler函数处理该异常,<imm16>为系统调用号。
cpu的sync异常种类有多种,可以从ESR_ELx寄存器中获取具体的异常类型,通过查阅手册,SVC对应的异常为0x15
其中EC字段表示异常的具体类型,SVC的异常类型如下表所示
这一点从linux源码中也可以看出来
linux执行系统调用的时候,通过x0-x7传参,x8记录着对应的系统调用号,系统调用表应该在linux-arch\arm64\include\asm\unistd32.h中(5.9版本)
找到对应的调用之后如何进行,还待后续探索。。。