内核makefile里面的如何定义宏

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了内核makefile里面的如何定义宏相关的知识,希望对你有一定的参考价值。

参考技术A 应该在内核的哪个makefile中定义一个宏,使得编译的时候,可以改变这个宏的值,来选择编译在内核
子目录
下的各个.
c文件
,比如说在driver子目录中有个lcd驱动,在这驱动的一个.c文件里面有好几组屏参,通过定义宏来决定编译哪一个。也就是说通过在makefile中定义宏来,这个宏会传递到所以需要编译的.c文件

c语言宏定义函数如何调用(里面含参数可以当函数用吗)

参考技术A

直接调用即可。如下示例: 

#include<stdio.h>#define sum(b,c)int d=0;d=b+c;printf("两者的和:%d\\n",d);int main()    int x=0,y=0;    scanf("%d%d",&x,&y);    sum (x,y);    return 0;

拓展资料

使用宏函数或者宏函数时,注意如下几点:

1.宏函数的参数没有类型,预处理器只负责做形式上的替换,而不做参数类型检查,所以传参时要格外小心。

2.宏函数定义要注意格式,尤其是括号。

如果上面的宏函数写成 #define MAX(a, b) (a>b?a:b),省去内层括号,则宏展开就成了k = (i&0x0f>j&0x0f?i&0x0f:j&0x0f),运算的优先级就错了。同样道理,这个宏定义的外层括号也是不能省的。若函数中是宏替换为 ++MAX(a,b),则宏展开就成了 ++(a)>(b)?(a):(b),运算优先级也是错了。

3.宏函数往往会导致较低的代码执行效率。

若是普通函数,则通过递归,可取的最大值,时间复杂度为O(n)。但若是宏函数,则宏展开为( a[n]>max(n-1)?a[n]:max(n-1) ),其中max(n-1)被调用了两遍,这样依此递归下去,时间复杂度会很高。

以上是关于内核makefile里面的如何定义宏的主要内容,如果未能解决你的问题,请参考以下文章

Makefile 是如何工作的?其中的宏定义分别是啥意思?

在 makefile 中为 Visual Studio C++ 构建定义宏

如何调试makefile变量

Makefile,宏修饰符

Makefile中的宏定义必须采用 和 么

makefile变量的四种赋值方式