热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux默认的include在哪?

#include中的module.h默认是在哪个目录下呢?我在usrincludelinux下并没有找到这个文件。另外想问一下ÿ
#include 中的module.h默认是在哪个目录下呢?我在/usr/include/linux下并没有找到这个文件。


另外想问一下,不同内核版本的linux头文件是不是一样的。比如:我在2.6.20内核的系统上,用2.6.10的头文件会不会有问题。




网友回复:


1


我的 module.h是在 内核编译好了的目录下的,不是在/usr/include/linux下,


2


在2.6.20内核的系统上,用2.6.10的头文件应该会有问题,内核的头文件和 当前系统运行的内核不一致。




网友回复:你引用的是内核下的头文件.


不在/usr/include下.


在: /usr/src/kernels/2.6.18-8.el5-x86_64/include/linux/module.h 下面... 中间的版本号是不一样的...你选你的就行了..




网友回复:请问楼上为什么是在/usr/src/kernels/2.6.18-8.el5-x86_64/include/linux/module.h呢?我查了一下环境变量,没有看到关于头文件的环境变量。gcc是如何知道头文件的位置的?




网友回复:这个问题很好,


你需要看看linux kernel的Makefile文件了。在什么地方找头文件,它说了算。:)




网友回复:你的程序是驱动之类的内核层的吧?


它调用的头文件就应该是内核源码里面的include了。一般的系统都把内核源码放在/usr/src下面,假如是自己编译的内核的话,也可以放在别处的。 至于gcc到哪里去找头文件,就看makefile了,或者直接用gcc命令的话,要加上-I来指定目录。




网友回复:楼上,可是我的makefile里没有指定include呀,gcc是怎么找到头文件的?




网友回复:gcc是怎么找到头文件的?


================================


回答了这个问题,LZ就明白了一切了,GCC找头文件有三种策略:


1.会在默认情况下指定到/usr/include文件夹(更深层次的是一个相对路径,GCC可执行程序的路径是/usr/bin,那么它在实际工作时指定头文件头径是一种相对路径方法,换算成绝对路径就是/usr/include)


2.GCC还使用了-I指定路径的方式,这一点大家都知道


3.还可以使用一个参数来指示GCC不搜索系统默认路径,这个参数我忘了,你搜一下就知道了




在编译驱动模块时,由于非凡的需求必须强制GCC不搜索系统默认路径,也就是不搜索/usr/include,要自己用-I参数来指定内核头文件路径,这个时候必须在Makefile中指定两个参数,一个是内核头文件路径,一个是强制GCC不搜索系统默认路径。在编译内核时,必须使用一个参数(强制GCC不搜索系统默认路径),否则就会引起混乱。




另,在驱动程序下面不是。下面是驱动程序的路径:(注意,这里已经预先定义好了arm平台了,所以才会自动去arm相关的底下找)


驱动程序:
#include 是在linux-2.6.29/include/linux下面寻找源文件。



#include 是在linux-2.6.29/arch/arm/include/asm下面寻找源文件。


#include 是在linux-2.6.29/arch/arm/mach-s3c2410/include/mach下面寻找源文件。






#include   //最基本的文件,支持动态添加和卸载模块。Hello World驱动要这一个文件就可以了


#include   //包含了文件操作相关struct的定义,例如大名鼎鼎的struct file_operations


#include   //包含了对返回值的宏定义,这样用户程序可以用perror输出错误信息。


#include   //对一些特殊类型的定义,例如dev_t, off_t, pid_t.其实这些类型大部分都是unsigned int型通过一连串的typedef变过来的,只是为了方便阅读。


#include   //对字符设备结构cdev以及一系列的操作函数的定义。


#include   //等代队列相关头文件




应用程序:

#include //包含了open()函数的flags,mode参数的宏定义。



驱动程序: 
#include 是在linux-2.6.29/include/linux下面寻找源文件。
#include 是在linux-2.6.29/arch/arm/include/asm下面寻找源文件。
#include 是在linux-2.6.29/arch/arm/mach-s3c2410/include/mach下面寻找源文件。

#include 在linux-2.6.31_TX2440A20100510\linux-2.6.31_TX2440A\arch\arm\plat-s3c\include\plat
#include //最基本的文件,支持动态添加和卸载模块。Hello World驱动要这一个文件就可以了
#include //包含了文件操作相关struct的定义,例如大名鼎鼎的struct file_operations

                                  //包含了struct inode 的定义,MINOR、MAJOR的头文件。
#include //包含了对返回值的宏定义,这样用户程序可以用perror输出错误信息。
#include //对一些特殊类型的定义,例如dev_t, off_t, pid_t.其实这些类型大部分都是unsigned int型通过一连串的typedef变过来的,只是为了方便阅读。
#include //对字符设备结构cdev以及一系列的操作函数的定义。//包含了cdev 结构及相关函数的定义。
#include //等代队列相关头文件//内核等待队列,它包含了自旋锁的头文件

#include
#include             

#include               //包含了kcalloc、kzalloc内存分配函数的定义。
#include         //包含了copy_to_user、copy_from_user等内核访问用户进程内存地址的函数定义。
#include            //包含了device、class 等结构的定义
#include                   //包含了ioremap、iowrite等内核访问IO内存等函数的定义。
#include     //包含了miscdevice结构的定义及相关的操作函数。
#include         //使用中断必须的头文件
#include              //使用中断必须的头文件
#include            //包含set_bit等位操作函数,实现Input子系统时可用。
#include    //使用信号量必须的头文件
#include        //自旋锁

#include           //内核等待队列中要使用的TASK_NORMAL、TASK_INTERRUPTIBLE包含在这个头文件
#include              //fifo环形队列
#include            //内核定时器
#include            //中断处理

头文件主目录include

头文件目录中总共有32个.h头文件。其中主目录下有13个,asm子目录中有4个,linux子目录中有10个,sys子目录中有5个。这些头文件各自的功能如下,具体的作用和所包含的信息请参见第14章。

:a.out头文件,定义了a.out执行文件格式和一些宏。
:常数符号头文件,目前仅定义了i节点中i_mode字段的各标志位。
:字符类型头文件,定义了一些有关字符类型判断和转换的宏。
:错误号头文件,包含系统中各种出错号。(Linus从minix中引进的)。
:文件控制头文件,用于文件及其描述符的操作控制常数符号的定义。
:信号头文件,定义信号符号常量,信号结构以及信号操作函数原型。
:标准参数头文件,以宏的形式定义变量参数列表。主要说明了一个类型(va_list)和3个宏(va_start, va_arg和va_end),用于vsprintf、vprintf、vfprintf函数。
:标准定义头文件,定义了NULL, offsetof(TYPE, MEMBER)。
:字符串头文件,主要定义了一些有关字符串操作的嵌入函数。
:终端输入输出函数头文件,主要定义控制异步通信口的终端接口。
:时间类型头文件,主要定义了tm结构和一些有关时间的函数原形。
:Linux标准头文件,定义了各种符号常数和类型,并声明了各种函数。如,定义了__LIBRARY__,则还包括系统调用号和内嵌汇编_syscall0()等。
:用户时间头文件,定义了访问和修改时间结构以及utime()原型。

(1)体系结构相关头文件子目录include/asm

这些头文件主要定义了一些与CPU体系结构密切相关的数据结构、宏函数和变量。共4个文件。

:I/O头文件,以宏的嵌入汇编程序形式定义对I/O端口操作的函数。
:内存拷贝头文件,含有memcpy()嵌入式汇编宏函数。
:段操作头文件,定义了有关段寄存器操作的嵌入式汇编函数。
:系统头文件,定义了设置或修改描述符/中断门等的嵌入式汇编宏。

(2)Linux内核专用头文件子目录include/linux

:内核配置头文件,定义键盘语言和硬盘类型(HD_TYPE)可选项。
:软驱头文件,含有软盘控制器参数的一些定义。
:文件系统头文件,定义文件表结构(file,buffer_head,m_inode等)。
:硬盘参数头文件,定义访问硬盘寄存器端口、状态码和分区表等信息。
:head头文件,定义了段描述符的简单结构,和几个选择符常量。
:内核头文件,含有一些内核常用函数的原形定义。
:内存管理头文件,含有页面大小定义和一些页面释放函数原型。
: 调度程序头文件,定义了任务结构task_struct、初始任务0的数据,
以及一些有关描述符参数设置和获取的嵌入式汇编函数宏语句。
:系统调用头文件,含有72个系统调用C函数处理程序,以"sys_"开头。
:tty头文件,定义了有关tty_io,串行通信方面的参数、常数。

(3)系统专用数据结构子目录include/sys

: 文件状态头文件,含有文件或文件系统状态结构stat{}和常量。
:定义了进程中运行时间结构tms以及times()函数原型。
:类型头文件,定义了基本的系统数据类型。
:系统名称结构头文件。
:等待调用头文件,定义系统调用wait()和waitpid()及相关常数符号。


推荐阅读
  • BZOJ4240 Gym 102082G:贪心算法与树状数组的综合应用
    BZOJ4240 Gym 102082G 题目 "有趣的家庭菜园" 结合了贪心算法和树状数组的应用,旨在解决在有限时间和内存限制下高效处理复杂数据结构的问题。通过巧妙地运用贪心策略和树状数组,该题目能够在 10 秒的时间限制和 256MB 的内存限制内,有效处理大量输入数据,实现高性能的解决方案。提交次数为 756 次,成功解决次数为 349 次,体现了该题目的挑战性和实际应用价值。 ... [详细]
  • 掌握DSP必备的56个核心问题,我已经将其收藏以备不时之需! ... [详细]
  • 对于以压缩包形式发布的软件,其目录中通常包含一个配置脚本 `configure`。该脚本的主要功能是确定编译所需的各项参数,如头文件的位置和链接库的路径,并生成相应的 `Makefile` 以供编译使用。通过运行此脚本,开发者可以确保软件在不同环境下的正确编译与安装。此外,该脚本还能够检测系统依赖项,进一步提高编译过程的可靠性和兼容性。 ... [详细]
  • OpenCV 2.4.9 源码解析:级联分类器的错误率与尺寸分析 ... [详细]
  • 在 CentOS 7 上部署和配置 RabbitMQ 消息队列系统时,首先需要安装 Erlang,因为 RabbitMQ 是基于 Erlang 语言开发的。具体步骤包括:安装必要的依赖项,下载 Erlang 源码包(可能需要一些时间,请耐心等待),解压源码包,解决可能出现的错误,验证安装是否成功,并将 Erlang 添加到环境变量中。接下来,下载 RabbitMQ 的 tar.xz 压缩包,并进行解压和安装。确保每一步都按顺序执行,以保证系统的稳定性和可靠性。 ... [详细]
  • 本文详细介绍了如何在Linux系统中搭建51单片机的开发与编程环境,重点讲解了使用Makefile进行项目管理的方法。首先,文章指导读者安装SDCC(Small Device C Compiler),这是一个专为小型设备设计的C语言编译器,适合用于51单片机的开发。随后,通过具体的实例演示了如何配置Makefile文件,以实现代码的自动化编译与链接过程,从而提高开发效率。此外,还提供了常见问题的解决方案及优化建议,帮助开发者快速上手并解决实际开发中可能遇到的技术难题。 ... [详细]
  • 在 Linux 系统中,`/proc` 目录实现了一种特殊的文件系统,称为 proc 文件系统。与传统的文件系统不同,proc 文件系统主要用于提供内核和进程信息的动态视图,通过文件和目录的形式呈现。这些信息包括系统状态、进程细节以及各种内核参数,为系统管理员和开发者提供了强大的诊断和调试工具。此外,proc 文件系统还支持实时读取和修改某些内核参数,增强了系统的灵活性和可配置性。 ... [详细]
  • 本文深入探讨了 `ExpressionChangedAfterItHasBeenCheckedError` 错误的原因及其解决方案。通过分析 Angular 的变更检测机制,详细解释了该错误的发生条件,并提供了多种有效的应对策略,帮助开发者在实际开发中避免这一常见问题。 ... [详细]
  • 在Android平台上利用FFmpeg的Swscale组件实现YUV与RGB格式互转
    本文探讨了在Android平台上利用FFmpeg的Swscale组件实现YUV与RGB格式互转的技术细节。通过详细分析Swscale的工作原理和实际应用,展示了如何在Android环境中高效地进行图像格式转换。此外,还介绍了FFmpeg的全平台编译过程,包括x264和fdk-aac的集成,并在Ubuntu系统中配置Nginx和Nginx-RTMP-Module以支持直播推流服务。这些技术的结合为音视频处理提供了强大的支持。 ... [详细]
  • 深入解析C语言中的大小端字节序存储机制
    在C语言中,当编译器执行“创建变量”的指令时,会为该变量在内存中分配相应的存储空间。对于整型变量,其值通常以二进制补码形式存储。此外,不同系统采用的大端或小端字节序对数据的实际存储方式有显著影响,理解这些机制有助于开发者更好地控制数据的读写过程。 ... [详细]
  • TQ210UBOOT移植笔记添加自己的单板【学习笔记】
    在uboot的源码的根目录下的readme中有介绍如何在uboot中添加自己的单板:一、在boards.cfg中添加自己的单板的信息,可以模仿smdkc ... [详细]
  • 谷歌工程师:TensorFlow已重获新生;网友:我还是用PyTorch
    乾明发自凹非寺量子位报道|公众号QbitAI道友留步!TensorFlow已重获新生。在“PyTorch真香”的潮流中,有人站出来为TensorFlow说话了。这次来自谷歌的工程师 ... [详细]
  • 如何在Linux环境中高效地创建、编译与运行C语言代码
    本文面向第一次在linux尝试写C语言程序的新人。有经验的请绕行。C语言用法不是本文介绍的关键,本文只是引入如何第一次在linux系统下编写、编译和执行一个简单的c程序。学会后请自行深入 ... [详细]
  • iOS 开发深度解析:探究底层缓存机制 Cache_t 的实现细节与优化策略
    iOS 开发深度解析:探究底层缓存机制 Cache_t 的实现细节与优化策略 ... [详细]
  • 我正在Linux64bit下使用EclipseCDT编写一个简单的C共享库。代码对的rand()函数有一个引用它编译得很好但是在链接时报告来自链接器的以下错误:gcc-shared ... [详细]
author-avatar
用户da7lbtmrer
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有