Linux 模块编译问题分析

Posted llc_no1

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux 模块编译问题分析相关的知识,希望对你有一定的参考价值。

问题描述:

编译一个Linux module,出现下面的错误:

error: conversion to ‘int’ from ‘unsigned int’ may change the sign of the result [-Werror=sign-conversion]

问题原因是没有显式进行类型转换,代码如下:

extern void bitmap_set(unsigned long *map, unsigned int start, int len);

unsigned int nr;

bitmap_set(fdev->memory->used, pos, nr);

 

问题分析:

从结果和分析看这是一个编译选项配置导致编译error,理论上可以使用修改编译选项的方法来修正问题,但是在Makefile中修改EXTRA_CFLAGS无效。

修改方法:EXTRA_CFLAGS += -Wno-error或者EXTRA_CFLAGS += -Wno-error=sign-conversion

 

继续分析:

1)使用make V=1找到详细的gcc选项,并没有发现-Werror=sign-conversion

2)同样的编译选项编译测试文件,没有错误

 

根本原因:

module代码中使用了#pragma GCC diagnostic error "-Wsign-conversion",定义了文件级别的gcc告警选项,删除即可。

 

编译告警处理介绍:

一、

-w的意思是关闭编译时的警告,也就是编译后不显示任何warning,因为有时在编译之后编译器会显示一些例如数据转换之类的警告,这些警告是我们平时可以忽略的。

-Wall选项意思是编译后显示所有警告。

-W选项类似-Wall,会显示警告,但是只显示编译器认为会出现错误的警告。

-Werror所有告警显示成Error

-Wno-error不讲告警显示成Error

 

二、

各个层次的gcc警告
从上到下覆盖

变量(代码)级:指定某个变量警告

int a __attribute__ ((unused));
指定该变量为"未使用的".即使这个变量没有被使用,编译时也会忽略则个警告输出.


文件级:在源代码文件中诊断(忽略/警告)

语法:
#pragma GCC diagnostic [error|warning|ignored] "-W<警告选项>"
诊断-忽略:(关闭警告)


#pragma  GCC diagnostic ignored  "-Wunused"
#pragma  GCC diagnostic ignored  "-Wunused-parameter"
诊断-警告:(开启警告)

#pragma  GCC diagnostic warning  "-Wunused"
#pragma  GCC diagnostic warning  "-Wunused-parameter"
诊断-错误:(开启警告-升级为错误)

#pragma  GCC diagnostic error  "-Wunused"
#pragma  GCC diagnostic error  "-Wunused-parameter"
用法:
在文件开头处关闭警告,在文件结尾出再开启警告,这样可以忽略该文件中的指定警告.


项目级:命令行/编译参数指定

警告:
gcc main.c -Wall 忽略:
gcc mian.c -Wall -Wno-unused-parameter //开去all警告,但是忽略 -unused-parameter警告

选项格式: -W[no-]<警告选项>
如 : -Wno-unused-parameter # no- 表示诊断时忽略这个警告

 






































以上是关于Linux 模块编译问题分析的主要内容,如果未能解决你的问题,请参考以下文章

Linux驱动模块的Makefile分析

《linux内核设计与分析》内核模块编程

《linux内核设计与分析》内核模块编程

Linux系统移植:U-Boot 顶层 Makefile 分析(上)

分析 Linux 内核模块

从源代码/从头开始编译 linux perf 工具及其依赖的内核模块