#define __printflike(_a,_b) \
__attribute__ ((__format__ (__printf__, _a, _b)))
#define __ahdecl __attribute__((regparm(0))) /*告诉gcc编译器该函数不需要通过任何寄存器来传递参数,参数只是通过堆栈来传递。另如regparm(3)的属性声明告诉gcc编译器这个函数可以通过寄存器传递多达3个的参数,这3个寄存器依次为EAX、EDX 和 ECX。更多的参数才通过堆栈传递。这样可以减少一些入栈出栈操作,因此调用比较快*/
extern void PRINTF(u_int dmask, const char* fmt, ...) __printflike(2,3);
void __ahdecl
xx_vprintf(const char* fmt, va_list ap)
{
char buf[1024]; /* XXX */
vsnprintf(buf, sizeof(buf), fmt, ap);
printk(KERN_INFO "%s", buf);
}
void __ahdecl
PRINTF(u_int dmask, const char* fmt, ...)
{
if (hal_debug & dmask){
__va_list ap;
va_start(ap, fmt);
xx_vprintf(fmt, ap);
va_end(ap);
}
}
|