当前位置: 技术问答>linux和unix
内核宏, 问题。 大家指教。
来源: 互联网 发布时间:2016-10-16
本文导语: #define SYSCALL_DEFINEx(x, name, ...) asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__)) 系统调用的宏里: __SC_DECL __SC_CAST __SC_LONG 以上这三个东西是干什么的, 在哪可以找到解释? 注意我是想知道__SC_DECL __SC_CAST __SC_LONG三...
#define SYSCALL_DEFINEx(x, name, ...)
asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__))
系统调用的宏里:
__SC_DECL
__SC_CAST
__SC_LONG
以上这三个东西是干什么的, 在哪可以找到解释?
注意我是想知道__SC_DECL __SC_CAST __SC_LONG三个东西, 关于__VA_ARGS__我知道是什么,所以大家帮忙解释下:
__SC_DECL
__SC_CAST
__SC_LONG
谢谢了。
最好给个例子。
asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__))
系统调用的宏里:
__SC_DECL
__SC_CAST
__SC_LONG
以上这三个东西是干什么的, 在哪可以找到解释?
注意我是想知道__SC_DECL __SC_CAST __SC_LONG三个东西, 关于__VA_ARGS__我知道是什么,所以大家帮忙解释下:
__SC_DECL
__SC_CAST
__SC_LONG
谢谢了。
最好给个例子。
|
我参考http://blog.chinaunix.net/u1/51562/showart_1981255.html
看懂了一部分
如果你仅仅问的是
__SC_DECL
__SC_CAST
__SC_LONG ,那还是能解答你的疑问
可以看到这些都是递归宏
以sendto系统调用为例进行分析:
它的定义为:
SYSCALL_DEFINE6(sendto, int, fd, void __user *, buff, size_t, len,
unsigned, flags, struct sockaddr __user *, addr,
int, addr_len)
那么最终
asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__));
的__SC_DECL##x(__VA_ARGS__);就会展开成
int fd, void __user * buff, size_t len,unsigned flags, struct sockaddr __user * addr, int addr_len
完全是函数参数原型
而__SC_CAST##x(__VA_ARGS__)
就会展开成
(int) fd, (void __user *) buff, (size_t) len,(unsigned )flags, (struct sockaddr __user * )addr, (int) addr_len
__SC_LONG##x(__VA_ARGS__)展开成
(long) fd, (long) buff, (long) len,(long)flags, (long )addr, (long) addr_len
看懂了一部分
如果你仅仅问的是
__SC_DECL
__SC_CAST
__SC_LONG ,那还是能解答你的疑问
#define __SC_DECL1(t1, a1) t1 a1
72#define __SC_DECL2(t2, a2, ...) t2 a2, __SC_DECL1(__VA_ARGS__)
73#define __SC_DECL3(t3, a3, ...) t3 a3, __SC_DECL2(__VA_ARGS__)
74#define __SC_DECL4(t4, a4, ...) t4 a4, __SC_DECL3(__VA_ARGS__)
75#define __SC_DECL5(t5, a5, ...) t5 a5, __SC_DECL4(__VA_ARGS__)
76#define __SC_DECL6(t6, a6, ...) t6 a6, __SC_DECL5(__VA_ARGS__)
77
78#define __SC_LONG1(t1, a1) long a1
79#define __SC_LONG2(t2, a2, ...) long a2, __SC_LONG1(__VA_ARGS__)
80#define __SC_LONG3(t3, a3, ...) long a3, __SC_LONG2(__VA_ARGS__)
81#define __SC_LONG4(t4, a4, ...) long a4, __SC_LONG3(__VA_ARGS__)
82#define __SC_LONG5(t5, a5, ...) long a5, __SC_LONG4(__VA_ARGS__)
83#define __SC_LONG6(t6, a6, ...) long a6, __SC_LONG5(__VA_ARGS__)
84
85#define __SC_CAST1(t1, a1) (t1) a1
86#define __SC_CAST2(t2, a2, ...) (t2) a2, __SC_CAST1(__VA_ARGS__)
87#define __SC_CAST3(t3, a3, ...) (t3) a3, __SC_CAST2(__VA_ARGS__)
88#define __SC_CAST4(t4, a4, ...) (t4) a4, __SC_CAST3(__VA_ARGS__)
89#define __SC_CAST5(t5, a5, ...) (t5) a5, __SC_CAST4(__VA_ARGS__)
90#define __SC_CAST6(t6, a6, ...) (t6) a6, __SC_CAST5(__VA_ARGS__)
#define __SYSCALL_DEFINEx(x, name, ...)
181 asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__));
182 static inline long SYSC##name(__SC_DECL##x(__VA_ARGS__));
183 asmlinkage long SyS##name(__SC_LONG##x(__VA_ARGS__))
184 {
185 __SC_TEST##x(__VA_ARGS__);
186 return (long) SYSC##name(__SC_CAST##x(__VA_ARGS__));
187 }
188 SYSCALL_ALIAS(sys##name, SyS##name);
189 static inline long SYSC##name(__SC_DECL##x(__VA_ARGS__))
190
可以看到这些都是递归宏
以sendto系统调用为例进行分析:
它的定义为:
SYSCALL_DEFINE6(sendto, int, fd, void __user *, buff, size_t, len,
unsigned, flags, struct sockaddr __user *, addr,
int, addr_len)
那么最终
asmlinkage long sys##name(__SC_DECL##x(__VA_ARGS__));
的__SC_DECL##x(__VA_ARGS__);就会展开成
int fd, void __user * buff, size_t len,unsigned flags, struct sockaddr __user * addr, int addr_len
完全是函数参数原型
而__SC_CAST##x(__VA_ARGS__)
就会展开成
(int) fd, (void __user *) buff, (size_t) len,(unsigned )flags, (struct sockaddr __user * )addr, (int) addr_len
__SC_LONG##x(__VA_ARGS__)展开成
(long) fd, (long) buff, (long) len,(long)flags, (long )addr, (long) addr_len