为什么 genkernel 决定在我的 initramfs 中只包含 4 个模块?

为什么 genkernel 决定在我的 initramfs 中只包含 4 个模块?

/lib/firmwareinitramfs-5.*.img只有 4 个模块:

modules/5.10.12-gentoo/kernel/
├── drivers
│   └── net
│       ├── macvlan.ko.xz
│       └── vxlan.ko.xz
└── net
    ├── ipv4
    │   └── udp_tunnel.ko.xz
    └── ipv6
        └── ip6_udp_tunnel.ko.xz

5 directories, 4 files

/lib/firmwarerootfs 上有 172 个模块:

/lib/modules/5.10.12-gentoo/kernel/                                                                                                                                                                        [162/352]
├── drivers
│   ├── acpi
│   │   └── dptf
│   │       └── dptf_pch_fivr.ko.xz
│   ├── base
│   │   └── regmap
│   │       └── regmap-mmio.ko.xz
│   ├── char
│   │   ├── agp
│   │   │   └── intel-gtt.ko.xz
│   │   └── tpm
│   │       ├── tpm.ko.xz
│   │       ├── tpm_atmel.ko.xz
│   │       ├── tpm_crb.ko.xz
│   │       ├── tpm_i2c_atmel.ko.xz
│   │       ├── tpm_i2c_infineon.ko.xz
│   │       ├── tpm_i2c_nuvoton.ko.xz
│   │       ├── tpm_infineon.ko.xz
│   │       ├── tpm_nsc.ko.xz
│   │       ├── tpm_tis.ko.xz
│   │       └── tpm_tis_core.ko.xz
│   ├── crypto
│   │   └── qat
│   │       ├── qat_c3xxx
│   │       │   └── qat_c3xxx.ko.xz
│   │       ├── qat_c3xxxvf
│   │       │   └── qat_c3xxxvf.ko.xz
│   │       ├── qat_c62x
│   │       │   └── qat_c62x.ko.xz
│   │       ├── qat_c62xvf
│   │       │   └── qat_c62xvf.ko.xz
│   │       ├── qat_common
│   │       │   └── intel_qat.ko.xz
│   │       ├── qat_dh895xcc
│   │       │   └── qat_dh895xcc.ko.xz
│   │       └── qat_dh895xccvf
│   │           └── qat_dh895xccvf.ko.xz
│   ├── gpu
│   │   └── drm
│   │       ├── i915
│   │       │   └── i915.ko.xz
│   │       ├── nouveau
│   │       │   └── nouveau.ko.xz
│   │       └── ttm
│   │           └── ttm.ko.xz
│   ├── hwmon
│   │   ├── coretemp.ko.xz
│   │   ├── drivetemp.ko.xz
│   │   ├── i5500_temp.ko.xz
│   │   ├── max31730.ko.xz
│   │   └── mr75203.ko.xz
│   ├── net
│   │   ├── bareudp.ko.xz
│   │   ├── ipvlan
│   │   │   ├── ipvlan.ko.xz
│   │   │   └── ipvtap.ko.xz
│   │   ├── macvlan.ko.xz
│   │   ├── macvtap.ko.xz
│   │   ├── nlmon.ko.xz                                                                                                                                                                                    [103/352]
│   │   ├── tap.ko.xz
│   │   ├── tun.ko.xz
│   │   ├── veth.ko.xz
│   │   ├── vxlan.ko.xz
│   │   ├── wireguard
│   │   │   └── wireguard.ko.xz
│   │   └── wireless
│   │       └── intel
│   │           └── iwlwifi
│   │               ├── dvm
│   │               │   └── iwldvm.ko.xz
│   │               ├── iwlwifi.ko.xz
│   │               └── mvm
│   │                   └── iwlmvm.ko.xz
│   ├── usb
│   │   └── misc
│   │       └── apple-mfi-fastcharge.ko.xz
│   └── watchdog
│       ├── i6300esb.ko.xz
│       ├── iTCO_vendor_support.ko.xz
│       ├── iTCO_wdt.ko.xz
│       ├── softdog.ko.xz
│       └── watchdog.ko.xz
├── lib
│   ├── ts_bm.ko.xz
│   ├── ts_fsm.ko.xz
│   └── ts_kmp.ko.xz
├── net
│   ├── bpfilter
│   │   └── bpfilter.ko.xz
│   ├── ipv4
│   │   ├── netfilter
│   │   │   ├── arp_tables.ko.xz
│   │   │   ├── arpt_mangle.ko.xz
│   │   │   ├── arptable_filter.ko.xz
│   │   │   ├── ip_tables.ko.xz
│   │   │   ├── ipt_REJECT.ko.xz
│   │   │   ├── ipt_rpfilter.ko.xz
│   │   │   ├── iptable_filter.ko.xz
│   │   │   ├── iptable_mangle.ko.xz
│   │   │   ├── iptable_nat.ko.xz
│   │   │   ├── iptable_raw.ko.xz
│   │   │   ├── nf_defrag_ipv4.ko.xz
│   │   │   ├── nf_dup_ipv4.ko.xz
│   │   │   ├── nf_log_arp.ko.xz
│   │   │   ├── nf_log_ipv4.ko.xz
│   │   │   ├── nf_reject_ipv4.ko.xz
│   │   │   ├── nf_socket_ipv4.ko.xz
│   │   │   ├── nf_tproxy_ipv4.ko.xz
│   │   │   ├── nft_dup_ipv4.ko.xz
│   │   │   ├── nft_fib_ipv4.ko.xz
│   │   │   └── nft_reject_ipv4.ko.xz
│   │   └── udp_tunnel.ko.xz
│   ├── ipv6
│   │   ├── ip6_udp_tunnel.ko.xz
│   │   └── netfilter
│   │       ├── nf_defrag_ipv6.ko.xz
│   │       ├── nf_reject_ipv6.ko.xz
│   │       ├── nf_socket_ipv6.ko.xz                                                                                                                                                                        [44/352]
│   │       ├── nf_tproxy_ipv6.ko.xz
│   │       └── nft_reject_ipv6.ko.xz
│   └── netfilter
│       ├── nf_conntrack.ko.xz
│       ├── nf_conntrack_netlink.ko.xz
│       ├── nf_dup_netdev.ko.xz
│       ├── nf_flow_table.ko.xz
│       ├── nf_flow_table_inet.ko.xz
│       ├── nf_log_common.ko.xz
│       ├── nf_log_netdev.ko.xz
│       ├── nf_nat.ko.xz
│       ├── nf_tables.ko.xz
│       ├── nfnetlink_acct.ko.xz
│       ├── nfnetlink_log.ko.xz
│       ├── nfnetlink_osf.ko.xz
│       ├── nfnetlink_queue.ko.xz
│       ├── nft_chain_nat.ko.xz
│       ├── nft_compat.ko.xz
│       ├── nft_counter.ko.xz
│       ├── nft_ct.ko.xz
│       ├── nft_dup_netdev.ko.xz
│       ├── nft_fib.ko.xz
│       ├── nft_flow_offload.ko.xz
│       ├── nft_fwd_netdev.ko.xz
│       ├── nft_hash.ko.xz
│       ├── nft_log.ko.xz
│       ├── nft_masq.ko.xz
│       ├── nft_nat.ko.xz
│       ├── nft_numgen.ko.xz
│       ├── nft_objref.ko.xz
│       ├── nft_osf.ko.xz
│       ├── nft_queue.ko.xz
│       ├── nft_redir.ko.xz
│       ├── nft_reject.ko.xz
│       ├── nft_reject_inet.ko.xz
│       ├── nft_socket.ko.xz
│       ├── nft_tproxy.ko.xz
│       ├── nft_tunnel.ko.xz
│       ├── x_tables.ko.xz
│       ├── xt_CHECKSUM.ko.xz
│       ├── xt_CLASSIFY.ko.xz
│       ├── xt_CT.ko.xz
│       ├── xt_HL.ko.xz
│       ├── xt_HMARK.ko.xz
│       ├── xt_IDLETIMER.ko.xz
│       ├── xt_LOG.ko.xz
│       ├── xt_MASQUERADE.ko.xz
│       ├── xt_NETMAP.ko.xz
│       ├── xt_NFLOG.ko.xz
│       ├── xt_NFQUEUE.ko.xz
│       ├── xt_REDIRECT.ko.xz
│       ├── xt_TCPMSS.ko.xz
│       ├── xt_TCPOPTSTRIP.ko.xz
│       ├── xt_TEE.ko.xz
│       ├── xt_TPROXY.ko.xz
│       ├── xt_TRACE.ko.xz
│       ├── xt_addrtype.ko.xz
│       ├── xt_bpf.ko.xz
│       ├── xt_cgroup.ko.xz
│       ├── xt_comment.ko.xz
│       ├── xt_connlabel.ko.xz
│       ├── xt_connmark.ko.xz
│       ├── xt_conntrack.ko.xz
│       ├── xt_devgroup.ko.xz
│       ├── xt_hashlimit.ko.xz
│       ├── xt_helper.ko.xz
│       ├── xt_hl.ko.xz
│       ├── xt_iprange.ko.xz
│       ├── xt_length.ko.xz
│       ├── xt_limit.ko.xz
│       ├── xt_mac.ko.xz
│       ├── xt_mark.ko.xz
│       ├── xt_multiport.ko.xz
│       ├── xt_nat.ko.xz
│       ├── xt_nfacct.ko.xz
│       ├── xt_osf.ko.xz
│       ├── xt_owner.ko.xz
│       ├── xt_pkttype.ko.xz
│       ├── xt_recent.ko.xz
│       ├── xt_socket.ko.xz
│       ├── xt_state.ko.xz
│       ├── xt_statistic.ko.xz
│       ├── xt_string.ko.xz
│       ├── xt_tcpudp.ko.xz
│       └── xt_u32.ko.xz
└── sound
    └── pci
        └── hda
            ├── snd-hda-codec-analog.ko.xz
            ├── snd-hda-codec-ca0110.ko.xz
            ├── snd-hda-codec-ca0132.ko.xz
            ├── snd-hda-codec-cirrus.ko.xz
            ├── snd-hda-codec-cmedia.ko.xz
            ├── snd-hda-codec-conexant.ko.xz
            ├── snd-hda-codec-hdmi.ko.xz
            ├── snd-hda-codec-idt.ko.xz
            ├── snd-hda-codec-realtek.ko.xz
            ├── snd-hda-codec-si3054.ko.xz
            └── snd-hda-codec-via.ko.xz

45 directories, 172 files

为什么genkernel决定只包含其中 4 个以及为什么选择这 4 个包含在 中initramfs

答案1

我不知道它决定仅使用这些模块的方式。但构建 initramfs 的目标是创建最小尺寸的东西。这样,它可以更快地从磁盘加载,从而减少启动时间。 initramfs 唯一需要的模块是那些可以让它挂载根分区的模块,从那里可以加载任何其他模块。其他任何内容都应该省略。

使 initramfs 尽可能小对于启动时间特别重要,因为整个映像将从磁盘加载。没有像延迟加载的mmap()ed 文件那样的优化 - 引导加载程序/内核只是盲目地加载整个内容。当然,在配备 SSD 的现代系统上,甚至可以快速加载更大的 initramfs 文件。因此,此时就成为浪费内存资源的问题(因为图像用其内容填充文件系统缓存)。我预计,启动成功后,从initramfs加载的文件会被清除,让内存稍后被回收,所以内存只是暂时浪费。

genkernel有很多不同的选项来添加/删除不同的功能。例如,如果您的根目录位于 LVM2 上,则您将需要启用该功能,并且它将包含挂载 LVM2 所需的模块和用户空间实用程序。并且根分区使用的文件系统的任何模块都可能会被检测到并包含在内。

我不确定为什么包含五个模块。我认为在正常环境中它们是不必要的。通常,initramfs 将用于挂载本地设备,根本不需要初始化网络。我查了一下macvlan,看起来它可能会被来宾内核在虚拟化环境中使用——如果您的内核正在启动并执行诸如网络挂载之类的操作来获取其根设备,那么这可能是有意义的。某种网络启动可能是 initramfs 的一个功能,但我希望它是可选的并且能够被禁用。

相关内容