ARM Linux下添加自定义系统调用

ARM Linux的系统中断采用产生软中断,查找系统调用表,调用系统调用函数的方式实现系统调用。

先讲述,如何去查找gpioctrl函数的实现。

1.       通过查找,找到函数定义。

在Sg2klib.c里,有如下定义:

_syscall3(int,gpioctrl, int, op, int, addr, int, value)

_syscall3是一个宏定义,如下:

#define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3)           \

type name(type1 arg1,type2 arg2,type3 arg3) {                                  \

long __res;                                                                     \

__asm__ __volatile__ (                                                        \

"mov\tr0,%1\n\t"                                                                  \

"mov\tr1,%2\n\t"                                                                  \

"mov\tr2,%3\n\t"                                                                  \

__syscall(name)                                                            \

"mov\t%0,r0"                                                                         \

: "=r" (__res)                                                             \

: "r" ((long)(arg1)),"r" ((long)(arg2)),"r" ((long)(arg3))     \

: "r0","r1","r2","lr");                                                       \

__syscall_return(type,__res);                                                     \

}

这个宏定义,用来定义一个内联汇编的函数。名称为name,传入3个参数arg1、arg2、arg3等3个参数,并返回type类型数据。

说明:

%0:即__res的引用

%1、%2、%3:输入操作数,arg1、arg2、arg3的引用

第一个冒号:输出操作数,“=r”约束操作束,说明操作数是输出操作数。

第二个冒号:输入操作数,“r”指定将操作数存储在寄存器中。

第三个冒号:告诉编译器将在内联汇编中修改"r0","r1","r2","lr"的值,这样 GCC 就不使用该寄存器存储任何其它的值。

通过上述宏定义,即可定义一个函数

int gpioctrl(int op, int addr, int value);

函数功能是产生软中断,调用相应系统调用函数,并传入参数r0、r1、r2,返回值r0。

注意__syscall(name)、__syscall_return也是宏定义,实现一个软中断,和返回函数返回值。

/* unistd.h */

#define __sys2(x) #x

#define __sys1(x) __sys2(x)

#ifndef __syscall

#define __syscall(name) "swi\t" __sys1(__NR_##name) "\n\t"

#endif

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwxdjw.html