Linux内核定制及编译方法精讲
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
5. Processor type and features(CPU类型及特性) 1) Tickless System (Dynamic Ticks) 支持动态时钟。 2) High Resolution Timer Support 支持高解析度时钟。 3) Symmetric multi-processing support 对称多处理器支持,如多个CPU或者使用的是 多核CPU。 4) Subarchitecture Type 处理器的子体系结构类型。
5) Paravirtualization support (EXPERIMENTAL) 支持同时运行双Linux系统。 6) Processor family 处理器系列,按照实际使用的CPU选择。 7) Generic x86 support 通用x86支持。 8) HPET Timer Support HPET是替代8254芯片的新一代定时器。 9) Preemption Model 内核抢占模式。 10) Local APIC support on uniprocessors 支持多处理器APIC。
4. Block layer(块设备层) 1) Support for Large Block Devices 使用大于2TB的块设备时需要选择。 2) Support for tracing block io actions 块队列IO跟踪支持。 3) Support for Large Single Files 使用大于2TB的文件时需要。 4) IO Schedulers IO调度器。
8. Executable file formats(可执行文件格式) 1) Kernel support for ELF binaries ELF是开放平台下最常用的二进制文件格式, 支持动态连接,支持不同的硬件平台。 2) Kernel support for a.out and ECOFF binaries 早期UNIX系统的可执行文件格式。 3) Kernel support for MISC binaries 允许插入二进制的封装层到内核中,使用 Java、.NET、Python、Lisp等语言编写的程 序时需要它。
Linux内核的编译模式: 1、编译到内核:内核启动时可以支持相应
的功能,其优点是方便、速度快,系统启 动即可使用这部分功能;缺点是内核变得 很庞大。同时,系统安全性会降低。
2、编译成模块:内核启动后可以动态加载。
优点是不会使内核过分庞大,缺点是必须 由自己来调用这些模块。(主流)
内核配置界面(#make menuconfig):
2、内存管理模块 Linux的内存管理模块采用先进的虚拟存储机制,实 现对多进程的存储管理。它提供了十分可靠的存 储保护措施,对进程赋予不同的权限,用户不能 直接访问系统的程序和数据,保证了系统的安全 性。同时,为每个用户进程分配一个相互独立的 虚拟地址空间。
1、进程调度模块
3、文件系统模块 Linux 的文件系统模块采用先进的虚拟文件系统(VFS)技术, 屏蔽了各种文件系统的差别,为处理各种不同的文件系 统提供了统一的接口,支持多种不同的物理文件系统达 90多种。同时,Linux把各种硬件设备看作一种特殊的文 件来处理,用管理文件的方法管理设备,非常方便、有 效。 4、 网络接口模块 Linux具有最强大的网络功能。网络接口模块通过套接字 (Socket)机制实现计算机之间的网络通信,并采用网络层 次模型提供对多种网络协议和网络硬件设备的支持。 5、进程间通信模块 进程间通信模块保证了Linux支持多种进程间通信机制,包括 最基本的信息和管道,同时支持信息队列、信号量和共 享内存等。
5) POSIX Message Queues POSIX消息队列。 6) BSD Process Accounting 将进程的统计信息写入文件的用户级系统调用,主要包括进 程的创建时间、创建者、指令名、内存占用情况等信息。 7) Export task/process statistics through netlink(EXPERIMENTAL) 通过netlink接口向用户空间导出任务/进程的统计信息。 8) UTS Namespaces 支持UTS名字空间。 9) Auditing support 审计支持,某些内核模块(例如SELinux)需要它,只有同时选 择其子项才能对系统调用进行审计。
11) Machine Check Exception 让CPU检测到系统故障时通知内核。 12) Toshiba laptop support Toshiba笔记本模块支持。 13) Dell laptop support Dell笔记本模块支持。 14) Enable X86 board specific fixups for reboot 修正某些旧X86主板的bug。 15) /dev/cpu/microcode - Intel IA32 CPU microcode support 支持IA32微代码,仅对Intel的CPU有效。 16) /dev/cpu/*/msr - Model-specific register support 支持MSR (Model-Specific Register)寄存器。 17) /dev/cpu/*/cpuid - CPU information support 支持从/dev/cpu/x/cpuid获得CPU的唯一标识符(CPUID)。
24) MTRR (Memory Type Range Register) support 提升PCI/AGP总线上的显卡2倍以上的速度。 25) Boot from EFI support EFI是一种可代替传统BIOS的技术。 26) Enable seccomp to safely compute untrusted bytecode 允许seccomp (快速计算)安全地运算非信任代码。 27) Timer frequency 内核时钟频率。 28) kexec system call kexec系统调用。 29) kernel crash dumps 产生内核崩溃转储。 30) Build a relocatable kernel(EXPERIMENTAL) 建立内核的重定位信息。 31) Compat VDSO support 对VDSO(Virtual Dynamically-linked Shared Object)提供支持。
9. Networking(网络) 1) Networking options 网络选项。 2) Amateur Radio support 业余无线电支持。 3) IrDA (infrared) subsystem support 红外线支持, 4) Bluetooth subsystem support 支持蓝牙技术 5) Generic IEEE 802.11 Networking Stack 通用无线局域网(IEEE 802.11系列协议)支持。
+ 目的、要求
了解Linux内核主要的模块组成,掌握内核的 定制或配置方法,重点掌握Linux内核的编 译过程及相关命令的使用方法。
Linux 以进程作为系统资源分配的基本单位, 并采用动态优先级的调度算法,保证各个 进程使用处理机的合理性。进程调度模块 主要是对进程使用的处理机进行管理和控 制。
1) Local version - append to kernel release 在内核版本后面加上自定义的版本标识(如直接输入:test)。 2) Automatically append version information to the version string 自动在版本字符串后面添加版本标识信息,编译时需要有 perl以及git仓库支持。 3) Support for paging of anonymous memory (swap) 内核使用交换分区或者交换文件作为虚拟内存。 4) System V IPC 支持System V的进程间通信(IPC),许多程序需要这个功能。
内核配置主要选项及功能:
1. Code maturity level options(代码成熟度) Prompt for development and/or incomplete code/drivers 使用尚在开发中或尚未完成的代码与驱动程 序。
2. General setup(常规设置)
18) Firmware Drivers 固件驱动程序。 19) High Memory Support 支持最高内存。 20) Memory model 内存模式。 21) 64 bit Memory and IO resources (EXPERIMENTAL) 使用64位的内存和IO资源。 22) Allocate 3rd-level pagetables from highmem 对内存大于4GB的机器,将用户空间的页表放到高位内存区, 以节约宝贵的低端内存。 23) Math emulation 数学协处理器仿真。
6. Power management options(电源管理选项)
1) Power Management support 支持电源管理,包括APM和ACPI两种标准。 2) CPU FrequenFra Baidu biblioteky scaling 允许动态改变CPU主频,达到省电和降温的目 的。
7. Bus options (PCI,PCMCIA,EISA,MCA,ISA)( 总线选项) 1) PCI support 支持PCI总线。 2) ISA support 支持ISA总线。 3) MCA support 支持微通道总线。 4) NatSemi SCx200 support AMD Geode处理器的机器功能支持。 5) PCCARD (PCMCIA/CardBus) support PCMCIA卡(主要用于笔记本)支持。 6) PCI Hotplug Support 支持PCI的热插拔。
10) Kernel .config support 把内核的配置信息编译进内核中,以后可以通过 scripts/extract-ikconfig脚本来提取这些信息。 11) Create deprecated sysfs files 创建过时的sysfs文件系统 。 12) Kernel->user space relay support (formerly relayfs) 提供从内核空间向用户空间传递大量数据的接口。 13) Initial RAM filesystem and RAM disk (initramfs/initrd) support 支持内存文件系统(initramfs/initrd) 。 14) Optimize for size (Look out for broken compilers!) 编译时优化内核尺寸。 15) Configure standard kernel features (for small systems) 配置标准的内核特性(面向小型系统)。
3. Loadable module support(可加载模块支持)
1)Enable loadable module support 打开可加载模块支持,如果打开它则必须通过“make modules_install”把内核模块安装在/lib/modules/目录下。 2)Module unloading 允许卸载已经加载的模块。 3)Forced module unloading 允许强制卸载正在使用中的模块。 4)Module versioning support 允许使用其他内核版本的模块。 5)Source checksum for all modules 为所有的模块校验源码。 6)Automatic kernel module loading 允许内核通过运行modprobe来自动加载所需要的模块。