‘壹’ 什么叫做内核编译,为什么要进行内核编译呢
对开源操作系统(主要是指linux)的内核源代码在本机进行有针对性的编译,就叫做内核编译。
编译内核的目的主要是改变内核的默认选项,比如内核原来不支持某硬件,原因是内核的相应选项默认状态是disactivated,需要改变。
当然,也有人把新版的linux装在旧机子上。这样,许多在内核里activated的硬件,他没有,将来也不需要。那么,就可以在内核里去掉。以及一些服务、特殊的功能等等,如果用不着,比如机子是服务器的话,最好在内核里关掉,"精兵简政"。这是以系统安全和提高效率为目的。
有专门的工具对其进行编译。这个问题不是几句话能说明白的。看你的提问就知道你是刚刚学习这些内容,建议不要好高骛远,先把c语言学好,然后再研究这些东西。
欢迎访问我的论坛:)
http://www.chinesebloger.com
期待您的支持:)
‘贰’ linux内核编译的几点疑惑
(1)编译内核于升级内核没有直接关联。如果编译的内核的版本比现在系统使用的版本新,那么使用编译后的内核可以看成是内核升级。但是有时候是因为需要而编译内核,比如某些模块需要重新编译,打开某些原来内核没打开的选项,这时候可以是同版本内核重新编译,这就不能说是升级内核。
(2)新内核编译好后,还需要安装。也就是make install(把bzimage移动到boot,重命名为vmlinuz) ,make moles install(把模块全部放到/lib/moles/(内核名)文件夹内);然后depmod,在/lib/moles/(内核名)建好新的***.dep文件,这样启动时系统就能通过读取***.dep文件信息来加载模块。还要在boot下新建一个于内核名一样的.img文件,如vmlinuz,那么就是vmlinuz.img,至于系统使用哪个内核,那是在grub.cfg里面写的配置文件决定的。指定哪个就从哪个启动,写两个entry就可以选择启动到哪一个。老内核当然还可以继续使用。
(3)新内核主要是一些新的特性,驱动更改什么的,我不是很清楚,比如2.6.34以上的内核就支持通过echo OFF>/sys/kernel/debug/vgaswitchroo/switch关闭某个显卡,也就是双显卡切换支持,又比如2.6.38中加入了所谓的autogroup在某些情况下提升桌面性能的特性,还有一些对系统某些情况的处理方式的变化等。但是从用户层来说一般感觉不到明显变化。对于程序什么的使用不影响(绝大多数)。
‘叁’ 编译内核模块错误(linux)
在进行内核模块开发时,编译内核模块可能会遇到一些问题。例如,在RedHat Linux 2.6版本中,kernel-devel-2.6.9-5.gz包中并不包含完整的内核源代码,导致编译模块时可能会失败。因此,需要手动安装kernel-source-2.6.9-5.gz包来获取完整的内核源代码。
另外,对于内核模块开发,可以使用rpmbuild -ba --target=i686命令来编译内核模块。但是,编译过程中需要注意修改spec文件中的某些行。例如,将%define buildsource 0行中的0改为1,可以编译出kernel-source包。然后,通过安装kernel-source包来获取完整的内核源代码。
在进行内核模块开发时,还需要注意各rpm包的内容和用途。例如,kernel-2.6.9-5包用于内核开发,kernel-devel-2.6.9-5包用于内核模块开发。此外,qt-devel、gtk2-devel、readline-devel和ncurses-devel等包也非常重要。
对于内核模块开发,需要安装src包来获取内核源代码。如果只需要编译sourcecode和doc包,可以使用rpmbuild -bb --target=i686命令。此外,还可以通过make dep命令来编译内核模块。
在编译内核模块时,还需要注意spec文件中的Requires行。例如,requires X-window行表示需要X-window。因此,在编译内核模块时,可以将requires X-window行注释掉,以避免依赖于X-window。
总之,在进行内核模块开发时,需要明确各rpm包的内容和用途,并正确修改spec文件中的某些行,以确保编译过程顺利进行。
‘肆’ eBPF on android之编译内核与打补丁(解决触摸和WIFI失效问题)
本文为看雪论坛优秀文章
看雪论坛作者ID:seeeseee
一、前言在之前尝试ptach内核时,配置CONFIG_KRETPROBES后遇到了触摸和WIFI失效的问题。后经missking指导,发现修改内核编译选项的操作不正确。正确的步骤如下:
但即便如此,编译出的内核仍然导致触摸和WIFI失效。后续参考多个帖子,解决了触摸问题,但WIFI问题未能解决。
刷自编译内核导致的触摸屏失灵问题、正确的自编译内核操作及解决触摸屏问题的步骤、内核编译问题、单独编译内核的方法、解决触摸屏失灵问题的实践篇、内核编译内文以及相关补丁操作等,均被提及。在一系列操作后,触摸功能得以修复,但WIFI问题仍然悬而未决。
经过进一步探索,发现单独编译内核且包含boot.img的正确方式,这与之前的操作有所区别。对于BUILD_BOOT_IMG的设定和其中的GKI_RAMDISK_PREBUILT_BINARY、VENDOR_RAMDISK_BINARY的理解,以及boot.img解包和生成所需文件的过程,都有了更深入的了解。
通过分析build/build.sh脚本,明确当BOOT_IMAGE_HEADER_VERSION为3时,需指定GKI_RAMDISK_PREBUILT_BINARY和KERNEL_VENDOR_CMDLINE。解包boot.img后,根据文件信息调整BUILD_BOOT_IMG、BASE_ADDRESS、PAGE_SIZE、KERNEL_CMDLINE和KERNEL_BINARY的值,确保正确生成initramfs.cpio和VENDOR_RAMDISK_BINARY。补丁添加bpf_probe_read_user功能,确保内核能正常读取用户空间数据。
进行内核编译配置调整,包括修改内核编译配置选项,确保触摸屏和WIFI功能正常。操作步骤包括进入内核源码目录、生成floral_defconfig、打开内核编译配置界面、保存并退出配置、覆盖floral_defconfig文件、删除.config文件等。最终,通过正确编译命令生成可正常使用的boot.img文件,解决触摸屏和WIFI失效问题。
二、环境搭建环境时,请根据需要添加代理连接。首先,根据官方指南安装所需库和软件,并创建工作目录。选择与手机内核版本对应的分支(如Pixel 4XL对应的android-msm-coral-4.14-android13),同步内核源代码并使用官方说明操作。注意,如果没有设置编译工具,可手动同步代码或使用官方提供的工具。
三、步骤操作步骤包括:
通过解决触摸屏失灵和WIFI失效问题,了解到单独编译内核并生成boot.img的正确方法。在内核编译过程中,明确相关选项和参数的重要性,确保生成的内核能正常运行触摸和WIFI功能。通过实践操作,内核可实现正常启动、触摸和WIFI功能正常,同时支持eBPF设定。
‘伍’ 谁能给个Ubuntu编译内核的详细步骤啊,我的是Ubuntu10.04,想编译一下更高版本的内核,网上方法试过很多了
ubuntu千万别自己搞内核编译,因为ubuntu系统对内核是有修改的,你自己就算编译成功,以后系统也会出现很多问题。