| # Copyright 2012 The ChromiumOS Authors |
| # Distributed under the terms of the GNU General Public License v2 |
| # |
| # Shellcheck doesn't understand our CONFIG_FRAMGMENTS expansion. |
| # shellcheck disable=SC2034 |
| |
| # Check for EAPI 7+. |
| case "${EAPI:-0}" in |
| 0|1|2|3|4|5|6) die "Unsupported EAPI=${EAPI:-0} (too old) for ${ECLASS}" ;; |
| 7) ;; |
| esac |
| |
| # Since we use CHROMEOS_KERNEL_CONFIG, CHROMEOS_KERNEL_SPLITCONFIG, and |
| # CHROMEOS_DTBS here, it is not safe to reuse the kernel prebuilts across |
| # different boards. Inherit the cros-board eclass to make sure that doesn't |
| # happen. |
| inherit binutils-funcs cros-board cros-kernel-versions estack toolchain-funcs |
| |
| HOMEPAGE="http://www.chromium.org/" |
| LICENSE="GPL-2" |
| SLOT="0" |
| |
| DEPEND="sys-kernel/linux-firmware |
| factory_netboot_ramfs? ( chromeos-base/chromeos-initramfs[factory_netboot_ramfs] ) |
| factory_shim_ramfs? ( chromeos-base/chromeos-initramfs[factory_shim_ramfs] ) |
| minios_ramfs? ( chromeos-base/chromeos-initramfs[minios_ramfs] ) |
| recovery_ramfs? ( chromeos-base/chromeos-initramfs[recovery_ramfs] ) |
| builtin_fw_mali_g57? ( virtual/opengles ) |
| builtin_fw_t210_bpmp? ( sys-kernel/tegra_bpmp-t210 ) |
| builtin_fw_t210_nouveau? ( sys-kernel/nouveau-firmware ) |
| builtin_fw_x86_adl_ucode? ( sys-firmware/brya-kernel-ucode ) |
| builtin_fw_x86_adln_ucode? ( sys-firmware/adln-ucode-firmware-private ) |
| builtin_fw_x86_amd_ucode? ( sys-kernel/linux-firmware[linux_firmware_amd_ucode] ) |
| builtin_fw_x86_aml_ucode? ( chromeos-base/aml-ucode-firmware-private ) |
| builtin_fw_x86_apl_ucode? ( chromeos-base/apl-ucode-firmware-private ) |
| builtin_fw_x86_bdw_ucode? ( chromeos-base/bdw-ucode-firmware-private ) |
| builtin_fw_x86_bsw_ucode? ( chromeos-base/bsw-ucode-firmware-private ) |
| builtin_fw_x86_byt_ucode? ( chromeos-base/byt-ucode-firmware-private ) |
| builtin_fw_x86_cml_ucode? ( chromeos-base/cml-ucode-firmware-private ) |
| builtin_fw_x86_glk_ucode? ( chromeos-base/glk-ucode-firmware-private ) |
| builtin_fw_x86_intel_ucode? ( sys-firmware/intel-ucode-firmware ) |
| builtin_fw_x86_jsl_ucode? ( chromeos-base/jsl-ucode-firmware-private ) |
| builtin_fw_x86_kbl_ucode? ( chromeos-base/kbl-ucode-firmware-private ) |
| builtin_fw_x86_mtl_ucode? ( sys-firmware/mtl-ucode-firmware-private ) |
| builtin_fw_x86_rpl_ucode? ( sys-firmware/brya-kernel-ucode ) |
| builtin_fw_x86_skl_ucode? ( chromeos-base/skl-ucode-firmware-private ) |
| builtin_fw_x86_tgl_ucode? ( chromeos-base/tgl-ucode-firmware-private ) |
| builtin_fw_x86_whl_ucode? ( chromeos-base/whl-ucode-firmware-private ) |
| " |
| |
| CHROMEOS_KERNEL_FAMILY_VALUES=( |
| arcvm |
| chromeos |
| manatee |
| termina |
| ) |
| |
| CHROMEOS_KERNEL_FAMILY_FLAGS=( |
| "${CHROMEOS_KERNEL_FAMILY_VALUES[@]/#/chromeos_kernel_family_}" |
| ) |
| |
| IUSE=" |
| apply_patches |
| -asan |
| buildtest |
| ${CHROMEOS_KERNEL_FAMILY_FLAGS[*]} |
| +clang |
| -compilation_database |
| -device_tree |
| dt_choose_all |
| +dt_compression |
| +fit_compression_kernel_lz4 |
| fit_compression_kernel_lzma |
| firmware_install |
| frozen_gcc |
| hibernate |
| -kernel_sources |
| kernel_warning_level_1 |
| kernel_warning_level_2 |
| kernel_warning_level_3 |
| +lld |
| +llvm_ias |
| nfc |
| -wifi_testbed_ap |
| -boot_dts_device_tree |
| -nowerror |
| -ppp |
| -binder |
| -selinux_develop |
| -transparent_hugepage |
| tpm2 |
| -kernel_afdo |
| -kernel_afdo_verify |
| -kern_arm_afdo |
| +vdso32 |
| -criu |
| -docker |
| -lxc |
| sparse |
| disable_kernel_fragments |
| " |
| REQUIRED_USE=" |
| ^^ ( ${CHROMEOS_KERNEL_FAMILY_FLAGS[*]} ) |
| compilation_database? ( clang ) |
| ?? ( fit_compression_kernel_lz4 fit_compression_kernel_lzma ) |
| frozen_gcc? ( !clang ) |
| kern_arm_afdo? ( kernel_afdo ) |
| lld? ( clang ) |
| llvm_ias? ( clang ) |
| " |
| STRIP_MASK=" |
| /lib/modules/*/kernel/* |
| /usr/lib/debug/* |
| /usr/src/* |
| " |
| |
| # SRC_URI requires RESTRICT="mirror". We specify AutoFDO profiles in SRC_URI |
| # so that ebuild can fetch it for us. |
| # binchecks is restricted because the kernel does not use all the same build |
| # flags we want for userland (crbug/1061666). |
| RESTRICT="binchecks mirror" |
| SRC_URI="" |
| |
| KERNEL_VERSION="${PN#chromeos-kernel-}" |
| KERNEL_VERSION="${KERNEL_VERSION/_/.}" |
| |
| # Specifying AutoFDO profiles in SRC_URI and let ebuild fetch it for us. |
| # Prefer the frozen version of afdo profiles if set. |
| AFDO_VERSION=${AFDO_FROZEN_PROFILE_VERSION:-${AFDO_PROFILE_VERSION}} |
| ARM_AFDO_VERSION=${ARM_AFDO_FROZEN_PROFILE_VERSION:-${ARM_AFDO_PROFILE_VERSION}} |
| |
| GS_PREFIX="gs://chromeos-prebuilt/afdo-job/cwp/kernel" |
| if [[ -n "${AFDO_VERSION}" ]]; then |
| # Set AFDO_LOCATION if not already set. |
| : "${AFDO_LOCATION:="${GS_PREFIX}/amd64/${KERNEL_VERSION}"}" |
| AFDO_GCOV="${PN}-${AFDO_VERSION}.gcov" |
| AFDO_GCOV_EXTBINARY="${AFDO_GCOV}.extbinary.afdo" |
| SRC_URI+=" kernel_afdo? ( |
| ${AFDO_LOCATION}/${AFDO_VERSION}.gcov.xz -> ${AFDO_GCOV}.xz |
| )" |
| fi |
| if [[ -n "${ARM_AFDO_VERSION}" ]]; then |
| : "${ARM_AFDO_LOCATION:="${GS_PREFIX}/arm/${KERNEL_VERSION}"}" |
| ARM_AFDO_GCOV="${PN}-${ARM_AFDO_VERSION}.gcov" |
| ARM_AFDO_GCOV_EXTBINARY="${ARM_AFDO_GCOV}.extbinary.afdo" |
| SRC_URI+=" kern_arm_afdo? ( |
| ${ARM_AFDO_LOCATION}/${ARM_AFDO_VERSION}.gcov.xz -> ${ARM_AFDO_GCOV}.xz |
| )" |
| fi |
| |
| apply_private_patches() { |
| eshopts_push -s nullglob |
| local patches=( "${FILESDIR}"/*.patch ) |
| eshopts_pop |
| [[ ${#patches[@]} -gt 0 ]] && eapply "${patches[@]}" |
| } |
| |
| # Ignore files under /lib/modules/ as we like to install vdso objects in there. |
| MULTILIB_STRICT_EXEMPT+="|modules" |
| |
| # Build out-of-tree and incremental by default, but allow an ebuild inheriting |
| # this eclass to explicitly build in-tree. |
| : "${CROS_WORKON_OUTOFTREE_BUILD:=1}" |
| : "${CROS_WORKON_INCREMENTAL_BUILD:=1}" |
| |
| # Config fragments selected by USE flags. _config fragments are mandatory, |
| # _config_disable fragments are optional and will be appended to kernel config |
| # if use flag is not set. |
| # ...fragments will have the following variables substitutions |
| # applied later (needs to be done later since these values |
| # aren't reliable when used in a global context like this): |
| # %ROOT% => ${SYSROOT} |
| # |
| # A NOTE about config fragments and when they should be used... |
| # |
| # In general config fragments should be avoided. |
| # - They tend to get crufty and obsolete as the kernel moves forward and |
| # nothing validates that they still make sense. |
| # - It's non-obvious when someone is working with the kernel that extra |
| # configs were turned on with a fragment. |
| # |
| # Fragments should really only be for: |
| # - Debug options that a developer might turn on when building the kernel |
| # themselves. |
| # - Debug options that a builder might turn on for producing a debug build |
| # with extra testing (options that we don't want enabled for production). |
| # - Options enabling risky features that are only enabled for non-production |
| # boards that otherwise share the same kernel as production boards. |
| # - Options needed for building the recovery image kernel. This kernel shares |
| # the same kernel config as the normal kernel but needs a few extra kernel |
| # options that we _don't_ want turned on for the normal kernel. |
| # |
| # If a feature is safe for production it should simply be turned on in the main |
| # kernel config even if only a subset of boards need that feature turned on. |
| |
| CONFIG_FRAGMENTS=( |
| acpi_ac |
| acpi_debug |
| allocator_slab |
| apex |
| aurora |
| binder |
| blkdevram |
| bpf_extras |
| builtin_driver_amdgpu |
| ca0132 |
| criu |
| cros_ec_mec |
| debug |
| debugobjects |
| devdebug |
| diskswap |
| dmadebug |
| dm_snapshot |
| docker |
| drm_dp_aux_chardev |
| dwc2_dual_role |
| dyndebug |
| ec2_guest_net |
| eve_bt_hacks |
| eve_wifi_etsi |
| factory_netboot_ramfs |
| factory_shim_ramfs |
| failslab |
| fbconsole |
| goldfish |
| hibernate |
| highmem |
| hypervisor_guest |
| mellanox_eth |
| i2cdev |
| iioservice |
| irqsoff_tracer |
| iscsi |
| livepatch |
| lockdown |
| lxc |
| kasan |
| kcov |
| kcsan |
| kernel_compress_xz |
| kexec_file |
| kgdb |
| kmemleak |
| kvm |
| kvm_invept_global |
| kvm_host |
| kvm_nested |
| kvm_virt_suspend_time |
| lockdebug |
| lockstat |
| lpss_uart |
| mbim |
| memory_debug |
| minios_ramfs |
| module_sign |
| nfc |
| nfs |
| nowerror |
| pageowner |
| pca954x |
| pcserial |
| pkvm |
| plan9 |
| ppp |
| preempt_tracer |
| pvrdebug |
| qmi |
| realtekpstor |
| recovery_ramfs |
| samsung_serial |
| sched_tracer |
| selinux_develop |
| socketmon |
| systemtap |
| tpm |
| transparent_hugepage |
| ubsan |
| usb_gadget |
| usb_gadget_acm |
| usb_gadget_audio |
| usb_gadget_ncm |
| usbip |
| vfat |
| virtio_balloon |
| vivid |
| vkms |
| vlan |
| vtpm_proxy |
| vmware_guest |
| vtconsole |
| wifi_testbed_ap |
| wifi_diag |
| x32 |
| xen_guest |
| hyperv_guest |
| vpu_driver |
| ) |
| |
| acpi_ac_desc="Enable ACPI AC" |
| acpi_ac_config=" |
| CONFIG_ACPI_AC=y |
| " |
| acpi_ac_config_disable=" |
| # CONFIG_ACPI_AC is not set |
| " |
| acpi_debug_desc="Enable ACPI DEBUG" |
| acpi_debug_config=" |
| CONFIG_ACPI_DEBUG=y |
| " |
| |
| allocator_slab_desc="Turn on SLAB allocator" |
| allocator_slab_config=" |
| CONFIG_SLAB=y |
| # CONFIG_SLUB is not set |
| " |
| |
| apex_desc="Apex chip kernel driver" |
| apex_config=" |
| CONFIG_STAGING_GASKET_FRAMEWORK=m |
| CONFIG_STAGING_APEX_DRIVER=m |
| " |
| |
| aurora_desc="Aurora experiment support" |
| aurora_config=" |
| CONFIG_INTEL_IOMMU_SCALABLE_MODE_DEFAULT_ON=y |
| CONFIG_INTEL_IOMMU_SVM=y |
| CONFIG_IOMMU_DEFAULT_PASSTHROUGH=y |
| CONFIG_IRQ_REMAP=y |
| CONFIG_VFIO=m |
| CONFIG_VFIO_PCI=m |
| CONFIG_VMD=y |
| CONFIG_PCI_IOV=y |
| CONFIG_PCI_PF_STUB=m |
| CONFIG_PCI_STUB=m |
| " |
| |
| binder_desc="binder IPC" |
| binder_config=" |
| CONFIG_ANDROID=y |
| CONFIG_ANDROID_BINDER_IPC=y |
| " |
| |
| blkdevram_desc="ram block device" |
| blkdevram_config=" |
| CONFIG_BLK_DEV_RAM=y |
| CONFIG_BLK_DEV_RAM_COUNT=16 |
| CONFIG_BLK_DEV_RAM_SIZE=16384 |
| " |
| |
| bpf_extras_desc="Enable BPF extras. Relocation information and LSM hooks." |
| bpf_extras_config=" |
| CONFIG_DEBUG_INFO_BTF=y |
| CONFIG_BPF_LSM=y |
| " |
| |
| builtin_driver_amdgpu_desc="DRM driver for AMD GPUs" |
| builtin_driver_amdgpu_config=" |
| CONFIG_DRM_AMDGPU=y |
| " |
| ca0132_desc="CA0132 ALSA codec" |
| ca0132_config=" |
| CONFIG_SND_HDA_CODEC_CA0132=y |
| CONFIG_SND_HDA_DSP_LOADER=y |
| " |
| |
| criu_desc="Flags required if you wish to use the criu python library" |
| criu_config=" |
| CONFIG_CHECKPOINT_RESTORE=y |
| CONFIG_EPOLL=y |
| CONFIG_EVENTFD=y |
| CONFIG_FHANDLE=y |
| CONFIG_IA32_EMULATION=y |
| CONFIG_INET_DIAG=y |
| CONFIG_INET_UDP_DIAG=y |
| CONFIG_INOTIFY_USER=y |
| CONFIG_NAMESPACES=y |
| CONFIG_NETLINK_DIAG=y |
| CONFIG_PACKET_DIAG=y |
| CONFIG_PID_NS=y |
| CONFIG_UNIX_DIAG=y |
| " |
| |
| cros_ec_mec_desc="LPC Support for Microchip Embedded Controller" |
| cros_ec_mec_config=" |
| CONFIG_MFD_CROS_EC_LPC_MEC=y |
| CONFIG_CROS_EC_LPC_MEC=y |
| " |
| |
| debugobjects_desc="Enable kernel debug objects debugging" |
| debugobjects_config=" |
| CONFIG_DEBUG_OBJECTS=y |
| CONFIG_DEBUG_OBJECTS_SELFTEST=y |
| CONFIG_DEBUG_OBJECTS_FREE=y |
| CONFIG_DEBUG_OBJECTS_TIMERS=y |
| CONFIG_DEBUG_OBJECTS_WORK=y |
| CONFIG_DEBUG_OBJECTS_RCU_HEAD=y |
| CONFIG_DEBUG_OBJECTS_PERCPU_COUNTER=y |
| " |
| |
| # devdebug configuration options should impose no or little runtime |
| # overhead while providing useful information for developers. |
| devdebug_desc="Miscellaneous developer debugging options" |
| devdebug_config=" |
| CONFIG_ARM_PTDUMP=y |
| CONFIG_ARM_PTDUMP_DEBUGFS=y |
| CONFIG_ARM64_PTDUMP_DEBUGFS=y |
| CONFIG_PTDUMP_DEBUGFS=y |
| CONFIG_BLK_DEBUG_FS=y |
| CONFIG_DEBUG_DEVRES=y |
| CONFIG_DEBUG_WX=y |
| CONFIG_GENERIC_IRQ_DEBUGFS=y |
| CONFIG_IRQ_DOMAIN_DEBUG=y |
| CONFIG_INIT_STACK_ALL_PATTERN=y |
| " |
| |
| diskswap_desc="Enable swap file" |
| diskswap_config=" |
| CONFIG_CRYPTO_LZO=y |
| CONFIG_DISK_BASED_SWAP=y |
| CONFIG_FRONTSWAP=y |
| CONFIG_LZO_COMPRESS=y |
| CONFIG_Z3FOLD=y |
| CONFIG_ZBUD=y |
| CONFIG_ZPOOL=y |
| CONFIG_ZSWAP=y |
| " |
| |
| dmadebug_desc="Enable DMA debugging" |
| dmadebug_config=" |
| CONFIG_DEBUG_SG=y |
| CONFIG_DMA_API_DEBUG=y |
| " |
| |
| dm_snapshot_desc="Snapshot device mapper target" |
| dm_snapshot_config=" |
| CONFIG_BLK_DEV_DM=y |
| CONFIG_DM_SNAPSHOT=m |
| " |
| |
| drm_dp_aux_chardev_desc="DisplayPort DP AUX driver support" |
| drm_dp_aux_chardev_config=" |
| CONFIG_DRM_DP_AUX_CHARDEV=y |
| " |
| |
| dwc2_dual_role_desc="Dual Role support for DesignWare USB2.0 controller" |
| dwc2_dual_role_config=" |
| CONFIG_USB_DWC2_DUAL_ROLE=y |
| " |
| |
| dyndebug_desc="Enable Dynamic Debug" |
| dyndebug_config=" |
| CONFIG_DYNAMIC_DEBUG=y |
| " |
| |
| ec2_guest_net_desc="Amazon EC2 Enhanced Networking drivers" |
| ec2_guest_net_config=" |
| CONFIG_NET_VENDOR_AMAZON=y |
| CONFIG_ENA_ETHERNET=y |
| CONFIG_NET_VENDOR_INTEL=y |
| CONFIG_IXGBEVF=y |
| " |
| |
| eve_bt_hacks_desc="Enable Bluetooth Hacks for Eve" |
| eve_bt_hacks_config=" |
| CONFIG_BT_EVE_HACKS=y |
| " |
| |
| eve_wifi_etsi_desc="Eve-specific workaround for ETSI" |
| eve_wifi_etsi_config=" |
| CONFIG_EVE_ETSI_WORKAROUND=y |
| " |
| |
| failslab_desc="Enable fault injection" |
| failslab_config=" |
| CONFIG_FAILSLAB=y |
| CONFIG_FAULT_INJECTION=y |
| CONFIG_FAULT_INJECTION_DEBUG_FS=y |
| " |
| |
| fbconsole_desc="framebuffer console" |
| fbconsole_config=" |
| CONFIG_FRAMEBUFFER_CONSOLE=y |
| " |
| fbconsole_config_disable=" |
| # CONFIG_FRAMEBUFFER_CONSOLE is not set |
| " |
| |
| goldfish_dec="Goldfish virtual hardware platform" |
| goldfish_config=" |
| CONFIG_GOLDFISH=y |
| CONFIG_GOLDFISH_BUS=y |
| CONFIG_GOLDFISH_PIPE=y |
| CONFIG_KEYBOARD_GOLDFISH_EVENTS=y |
| " |
| |
| hibernate_desc="Enable hibernation (aka suspend-to-disk)" |
| hibernate_config=" |
| CONFIG_HIBERNATION=y |
| " |
| |
| highmem_desc="highmem" |
| highmem_config=" |
| CONFIG_HIGHMEM64G=y |
| " |
| |
| hypervisor_guest_desc="Support running under a hypervisor" |
| hypervisor_guest_config=" |
| CONFIG_HYPERVISOR_GUEST=y |
| CONFIG_PARAVIRT=y |
| CONFIG_KVM_GUEST=y |
| CONFIG_VIRTIO_VSOCKETS=m |
| CONFIG_VIRTIO_IOMMU=m |
| CONFIG_ACPI_VIOT=y |
| CONFIG_PCI_COIOMMU=y |
| CONFIG_COIOMMU=y |
| CONFIG_IOMMU_BOUNCE_BUFFERS=y |
| " |
| |
| mellanox_eth_desc="Mellanox Ethernet Drivers" |
| mellanox_eth_config=" |
| CONFIG_NET_VENDOR_MELLANOX=y |
| CONFIG_MLX4_EN=m |
| CONFIG_MLX4_CORE=m |
| CONFIG_MLX4_DEBUG=y |
| CONFIG_MLX4_CORE_GEN2=y |
| CONFIG_MLX5_CORE=m |
| CONFIG_MLX5_ACCEL=y |
| CONFIG_MLX5_FPGA=y |
| CONFIG_MLX5_CORE_EN=y |
| CONFIG_MLX5_EN_ARFS=y |
| CONFIG_MLX5_EN_RXNFC=y |
| CONFIG_MLX5_MPFS=y |
| # CONFIG_MLX5_CORE_IPOIB is not set |
| CONFIG_MLX5_FPGA_IPSEC=y |
| CONFIG_MLXSW_CORE=m |
| CONFIG_MLXSW_CORE_THERMAL=y |
| CONFIG_MLXSW_PCI=m |
| CONFIG_MLXFW=m |
| # CONFIG_MLX_WDT is not set |
| CONFIG_MELLANOX_PLATFORM=y |
| " |
| |
| i2cdev_desc="I2C device interface" |
| i2cdev_config=" |
| CONFIG_I2C_CHARDEV=y |
| " |
| |
| iioservice_desc="Enable IIO service" |
| iioservice_config=" |
| # CONFIG_IIO_CROS_EC_SENSORS_RING is not set |
| " |
| |
| irqsoff_tracer_desc="irqsoff tracer" |
| irqsoff_tracer_config=" |
| CONFIG_IRQSOFF_TRACER=y |
| " |
| |
| iscsi_desc="iSCSI initiator and target drivers" |
| iscsi_config=" |
| CONFIG_SCSI_LOWLEVEL=y |
| CONFIG_ISCSI_TCP=m |
| CONFIG_CONFIGFS_FS=m |
| CONFIG_TARGET_CORE=m |
| CONFIG_ISCSI_TARGET=m |
| CONFIG_TCM_IBLOCK=m |
| CONFIG_TCM_FILEIO=m |
| CONFIG_TCM_PSCSI=m |
| " |
| |
| kasan_desc="Enable KASAN" |
| kasan_config=" |
| CONFIG_KASAN=y |
| CONFIG_KASAN_INLINE=y |
| CONFIG_TEST_KASAN=m |
| CONFIG_FRAME_WARN=0 |
| CONFIG_FORTIFY_SOURCE=n |
| CONFIG_LOCALVERSION=\"-kasan\" |
| # CONFIG_KFENCE is not set |
| " |
| |
| kcov_desc="Enable kcov" |
| kcov_config=" |
| CONFIG_KCOV=y |
| CONFIG_KCOV_ENABLE_COMPARISONS=y |
| # CONFIG_RANDOMIZE_BASE is not set |
| " |
| |
| kcsan_desc="Enable KCSAN" |
| # KCSAN reports of unknown origin are too frequent and not very useful for now. |
| kcsan_config=" |
| CONFIG_KCSAN=y |
| CONFIG_KCSAN_REPORT_RACE_UNKNOWN_ORIGIN=n |
| CONFIG_FRAME_WARN=0 |
| " |
| |
| kernel_compress_xz_desc="Compresss kernel image with XZ" |
| kernel_compress_xz_config=" |
| # CONFIG_KERNEL_GZIP is not set |
| # CONFIG_KERNEL_BZIP2 is not set |
| # CONFIG_KERNEL_LZMA is not set |
| # CONFIG_KERNEL_LZO is not set |
| # CONFIG_KERNEL_LZ4 is not set |
| CONFIG_KERNEL_XZ=y |
| " |
| |
| kexec_file_desc="Enable CONFIG_KEXEC_FILE" |
| kexec_file_config=" |
| CONFIG_CRASH_CORE=y |
| CONFIG_KEXEC_CORE=y |
| # CONFIG_KEXEC is not set |
| CONFIG_KEXEC_FILE=y |
| # CONFIG_KEXEC_VERIFY_SIG is not set |
| " |
| |
| kgdb_desc="Enable kgdb" |
| kgdb_config=" |
| CONFIG_DEBUG_KERNEL=y |
| CONFIG_DEBUG_INFO=y |
| CONFIG_FRAME_POINTER=y |
| CONFIG_GDB_SCRIPTS=y |
| CONFIG_KGDB=y |
| CONFIG_KGDB_KDB=y |
| CONFIG_PANIC_TIMEOUT=0 |
| CONFIG_PROC_KCORE=y |
| # CONFIG_RANDOMIZE_BASE is not set |
| # CONFIG_WATCHDOG is not set |
| CONFIG_MAGIC_SYSRQ_DEFAULT_ENABLE=1 |
| """ |
| # kgdb over serial port depends on CONFIG_HW_CONSOLE which depends on CONFIG_VT |
| REQUIRED_USE+=" kgdb? ( vtconsole )" |
| |
| kmemleak_desc="Enable kmemleak" |
| kmemleak_config=" |
| CONFIG_DEBUG_KMEMLEAK=y |
| CONFIG_DEBUG_KMEMLEAK_EARLY_LOG_SIZE=16384 |
| CONFIG_DEBUG_KMEMLEAK_TEST=m |
| " |
| |
| lockstat_desc="Lock usage statistics" |
| lockstat_config=" |
| CONFIG_LOCK_STAT=y |
| " |
| |
| lockdebug_desc="Additional lock debug settings" |
| lockdebug_config=" |
| CONFIG_DEBUG_RT_MUTEXES=y |
| CONFIG_DEBUG_SPINLOCK=y |
| CONFIG_DEBUG_MUTEXES=y |
| CONFIG_PROVE_RCU=y |
| CONFIG_PROVE_LOCKING=y |
| CONFIG_DEBUG_ATOMIC_SLEEP=y |
| CONFIG_LOCALVERSION=\"-lockdep\" |
| ${lockstat_config} |
| " |
| lockdebug_config_disable=" |
| # CONFIG_DEBUG_RT_MUTEXES is not set |
| # CONFIG_DEBUG_SPINLOCK is not set |
| # CONFIG_DEBUG_MUTEXES is not set |
| # CONFIG_PROVE_RCU is not set |
| # CONFIG_PROVE_LOCKING is not set |
| # CONFIG_DEBUG_ATOMIC_SLEEP is not set |
| # CONFIG_LOCALVERSION is not set |
| # CONFIG_LOCK_STAT is not set |
| " |
| |
| lpss_uart_desc="Enable Intel LPSS UART serial ports" |
| lpss_uart_config=" |
| CONFIG_SERIAL_8250=y |
| CONFIG_SERIAL_8250_DMA=y |
| CONFIG_SERIAL_8250_DW=y |
| CONFIG_SERIAL_8250_LPSS=y |
| " |
| |
| nfc_desc="Enable NFC support" |
| nfc_config=" |
| CONFIG_NFC=m |
| CONFIG_NFC_HCI=m |
| CONFIG_NFC_LLCP=y |
| CONFIG_NFC_NCI=m |
| CONFIG_NFC_PN533=m |
| CONFIG_NFC_PN544=m |
| CONFIG_NFC_PN544_I2C=m |
| CONFIG_NFC_SHDLC=y |
| " |
| |
| pageowner_desc="Enable pageowner kernel memory tracking" |
| pageowner_config=" |
| CONFIG_PAGE_OWNER=y |
| CONFIG_DEBUG_KERNEL=y |
| " |
| |
| pvrdebug_desc="PowerVR Rogue debugging" |
| pvrdebug_config=" |
| CONFIG_DRM_POWERVR_ROGUE_DEBUG=y |
| " |
| |
| tpm_desc="TPM support" |
| tpm_config=" |
| CONFIG_TCG_TPM=y |
| CONFIG_TCG_TIS=y |
| " |
| |
| vtpm_proxy_desc="vTPM proxy support" |
| vtpm_proxy_config=" |
| CONFIG_TCG_VTPM_PROXY=y |
| " |
| |
| # initramfs compression is done by the chromeos-initramfs package build |
| # and kernel build can ingest the compressed image as it is. |
| recovery_ramfs_desc="Initramfs for recovery image" |
| recovery_ramfs_config=' |
| CONFIG_INITRAMFS_SOURCE="%ROOT%/var/lib/initramfs/recovery_ramfs.cpio" |
| CONFIG_INITRAMFS_COMPRESSION_NONE=y |
| ' |
| |
| # TODO(b/251448197): remove CONFIG_SECURITY_CHROMIUMOS=n when the long-term |
| # solution is landed. |
| factory_netboot_ramfs_desc="Initramfs for factory netboot installer" |
| factory_netboot_ramfs_config=' |
| CONFIG_INITRAMFS_SOURCE="%ROOT%/var/lib/initramfs/factory_netboot_ramfs.cpio" |
| CONFIG_INITRAMFS_COMPRESSION_NONE=y |
| CONFIG_SECURITY_CHROMIUMOS=n |
| ' |
| |
| # TODO(b/251448197): remove CONFIG_SECURITY_CHROMIUMOS=n when the long-term |
| # solution is landed. |
| factory_shim_ramfs_desc="Initramfs for factory installer shim" |
| factory_shim_ramfs_config=' |
| CONFIG_INITRAMFS_SOURCE="%ROOT%/var/lib/initramfs/factory_shim_ramfs.cpio" |
| CONFIG_INITRAMFS_COMPRESSION_NONE=y |
| CONFIG_SECURITY_CHROMIUMOS=n |
| ' |
| |
| minios_ramfs_desc="Initramfs for minios image" |
| minios_ramfs_config=' |
| CONFIG_INITRAMFS_SOURCE="%ROOT%/var/lib/initramfs/minios_ramfs.cpio" |
| CONFIG_INITRAMFS_COMPRESSION_NONE=y |
| ' |
| |
| vfat_desc="vfat" |
| vfat_config=" |
| CONFIG_NLS_CODEPAGE_437=y |
| CONFIG_NLS_ISO8859_1=y |
| CONFIG_FAT_FS=y |
| CONFIG_VFAT_FS=y |
| " |
| |
| kvm_desc="KVM" |
| kvm_config=" |
| CONFIG_HAVE_KVM=y |
| CONFIG_HAVE_KVM_IRQCHIP=y |
| CONFIG_HAVE_KVM_EVENTFD=y |
| CONFIG_KVM_APIC_ARCHITECTURE=y |
| CONFIG_KVM_MMIO=y |
| CONFIG_KVM_ASYNC_PF=y |
| CONFIG_KVM=m |
| CONFIG_KVM_INTEL=m |
| # CONFIG_KVM_AMD is not set |
| # CONFIG_KVM_MMU_AUDIT is not set |
| CONFIG_VIRTIO=m |
| CONFIG_VIRTIO_BLK=m |
| CONFIG_VIRTIO_NET=m |
| CONFIG_VIRTIO_CONSOLE=m |
| CONFIG_VIRTIO_RING=m |
| CONFIG_VIRTIO_PCI=m |
| CONFIG_VIRTUALIZATION=y |
| " |
| |
| kvm_invept_global_desc="Workaround for b/188008861" |
| kvm_invept_global_config=" |
| CONFIG_KVM_INVEPT_GLOBAL=y |
| " |
| |
| kvm_host_desc="Support running virtual machines with KVM" |
| kvm_host_config=" |
| CONFIG_HAVE_KVM_CPU_RELAX_INTERCEPT=y |
| CONFIG_HAVE_KVM_EVENTFD=y |
| CONFIG_HAVE_KVM_IRQCHIP=y |
| CONFIG_HAVE_KVM_IRQFD=y |
| CONFIG_HAVE_KVM_IRQ_ROUTING=y |
| CONFIG_HAVE_KVM_MSI=y |
| CONFIG_KVM=y |
| # CONFIG_KVM_MMU_AUDIT is not set |
| # CONFIG_KVM_APIC_ARCHITECTURE is not set |
| # CONFIG_KVM_ASYNC_PF is not set |
| CONFIG_KVM_AMD=y |
| CONFIG_KVM_INTEL=y |
| CONFIG_KVM_MMIO=y |
| CONFIG_VSOCKETS=m |
| CONFIG_VHOST_VSOCK=m |
| CONFIG_VIRTUALIZATION=y |
| CONFIG_KVM_ARM_HOST=y |
| CONFIG_KVM_HETEROGENEOUS_RT=y |
| " |
| |
| kvm_nested_desc="Support running nested VMs" |
| kvm_nested_config=" |
| CONFIG_HAVE_KVM_CPU_RELAX_INTERCEPT=y |
| CONFIG_HAVE_KVM_EVENTFD=y |
| CONFIG_HAVE_KVM_IRQCHIP=y |
| CONFIG_HAVE_KVM_IRQFD=y |
| CONFIG_HAVE_KVM_IRQ_ROUTING=y |
| CONFIG_HAVE_KVM_MSI=y |
| CONFIG_KVM=y |
| # CONFIG_KVM_MMU_AUDIT is not set |
| # CONFIG_KVM_APIC_ARCHITECTURE is not set |
| # CONFIG_KVM_ASYNC_PF is not set |
| CONFIG_KVM_AMD=y |
| CONFIG_KVM_INTEL=y |
| CONFIG_KVM_MMIO=y |
| " |
| |
| kvm_virt_suspend_time_desc="Support KVM virtual suspend time injection" |
| kvm_virt_suspend_time_config=" |
| CONFIG_KVM_VIRT_SUSPEND_TIMING=y |
| " |
| |
| # TODO(benchan): Remove the 'mbim' use flag and unconditionally enable the |
| # CDC MBIM driver once Chromium OS fully supports MBIM. |
| mbim_desc="CDC MBIM driver" |
| mbim_config=" |
| CONFIG_USB_NET_CDC_MBIM=m |
| " |
| |
| memory_debug_desc="Memory debugging" |
| memory_debug_config=" |
| CONFIG_DEBUG_MEMORY_INIT=y |
| CONFIG_DEBUG_PAGEALLOC=y |
| CONFIG_DEBUG_PER_CPU_MAPS=y |
| CONFIG_DEBUG_STACKOVERFLOW=y |
| CONFIG_DEBUG_VM=y |
| CONFIG_DEBUG_VM_PGFLAGS=y |
| CONFIG_DEBUG_VM_RB=y |
| CONFIG_DEBUG_VM_VMACACHE=y |
| CONFIG_DEBUG_VIRTUAL=y |
| CONFIG_PAGE_OWNER=y |
| CONFIG_PAGE_POISONING=y |
| " |
| |
| module_sign_desc="Enable kernel module signing and signature verification" |
| module_sign_config=' |
| CONFIG_SYSTEM_DATA_VERIFICATION=y |
| CONFIG_MODULE_SIG=y |
| # CONFIG_MODULE_SIG_FORCE is not set |
| CONFIG_MODULE_SIG_ALL=y |
| # CONFIG_MODULE_SIG_SHA1 is not set |
| # CONFIG_MODULE_SIG_SHA224 is not set |
| CONFIG_MODULE_SIG_SHA256=y |
| # CONFIG_MODULE_SIG_SHA384 is not set |
| # CONFIG_MODULE_SIG_SHA512 is not set |
| CONFIG_MODULE_SIG_HASH="sha256" |
| CONFIG_ASN1=y |
| CONFIG_CRYPTO_AKCIPHER=y |
| CONFIG_CRYPTO_RSA=y |
| CONFIG_ASYMMETRIC_KEY_TYPE=y |
| CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=y |
| CONFIG_X509_CERTIFICATE_PARSER=y |
| CONFIG_PKCS7_MESSAGE_PARSER=y |
| # CONFIG_PKCS7_TEST_KEY is not set |
| # CONFIG_SIGNED_PE_FILE_VERIFICATION is not set |
| CONFIG_MODULE_SIG_KEY="certs/signing_key.pem" |
| CONFIG_SYSTEM_TRUSTED_KEYRING=y |
| CONFIG_SYSTEM_TRUSTED_KEYS="certs/trusted_key.pem" |
| # CONFIG_SYSTEM_EXTRA_CERTIFICATE is not set |
| CONFIG_SECONDARY_TRUSTED_KEYRING=y |
| CONFIG_CLZ_TAB=y |
| CONFIG_MPILIB=y |
| CONFIG_OID_REGISTRY=y |
| ' |
| |
| livepatch_desc="kernel livepatching" |
| livepatch_config=' |
| CONFIG_LIVEPATCH=y |
| CONFIG_KALLSYMS_ALL=y |
| ' |
| |
| lockdown_desc="Enable kernel lockdown module" |
| lockdown_config=' |
| CONFIG_SECURITY_LOCKDOWN_LSM=y |
| # CONFIG_SECURITY_LOCKDOWN_LSM_EARLY is not set |
| CONFIG_LOCK_DOWN_KERNEL_FORCE_NONE=y |
| # CONFIG_LOCK_DOWN_KERNEL_FORCE_INTEGRITY is not set |
| # CONFIG_LOCK_DOWN_KERNEL_FORCE_CONFIDENTIALITY is not set |
| ' |
| |
| nfs_desc="NFS" |
| nfs_config=" |
| CONFIG_USB_NET_AX8817X=y |
| CONFIG_DNOTIFY=y |
| CONFIG_DNS_RESOLVER=y |
| CONFIG_LOCKD=y |
| CONFIG_LOCKD_V4=y |
| CONFIG_NETWORK_FILESYSTEMS=y |
| CONFIG_NFSD=m |
| CONFIG_NFSD_V3=y |
| CONFIG_NFSD_V4=y |
| CONFIG_NFS_COMMON=y |
| CONFIG_NFS_FS=y |
| CONFIG_NFS_USE_KERNEL_DNS=y |
| CONFIG_NFS_V3=y |
| CONFIG_NFS_V4=y |
| CONFIG_ROOT_NFS=y |
| CONFIG_RPCSEC_GSS_KRB5=y |
| CONFIG_SUNRPC=y |
| CONFIG_SUNRPC_GSS=y |
| CONFIG_USB_USBNET=y |
| CONFIG_IP_PNP=y |
| CONFIG_IP_PNP_DHCP=y |
| " |
| |
| pca954x_desc="PCA954x I2C mux" |
| pca954x_config=" |
| CONFIG_I2C_MUX_PCA954x=m |
| " |
| |
| pcserial_desc="PC serial" |
| pcserial_config=" |
| CONFIG_SERIAL_8250=y |
| CONFIG_SERIAL_8250_CONSOLE=y |
| CONFIG_SERIAL_8250_DW=y |
| CONFIG_SERIAL_8250_PCI=y |
| CONFIG_SERIAL_EARLYCON=y |
| CONFIG_PARPORT=y |
| CONFIG_PARPORT_PC=y |
| CONFIG_PARPORT_SERIAL=y |
| " |
| |
| pkvm_desc="pKVM support" |
| pkvm_config=" |
| CONFIG_PKVM_INTEL=y |
| CONFIG_PKVM_INTEL_DEBUG=y |
| CONFIG_PCI_PASID=y |
| CONFIG_IOMMU_DEFAULT_PASSTHROUGH=y |
| " |
| |
| plan9_desc="Plan 9 protocol support" |
| plan9_config=" |
| CONFIG_NET_9P=y |
| CONFIG_NET_9P_VIRTIO=y |
| CONFIG_9P_FS=y |
| CONFIG_9P_FS_POSIX_ACL=y |
| CONFIG_9P_FS_SECURITY=y |
| " |
| |
| # NB: CONFIG_PPP must be built-in, because it provides the /dev/ppp alias |
| # (MODULE_ALIAS_CHARDEV()), which otherwise doesn't play nicely with our udev |
| # rules to change its permissions. See also: b/166388882 and crbug.com/864474. |
| ppp_desc="PPPoE and ppp support" |
| ppp_config=" |
| CONFIG_PPPOE=m |
| CONFIG_PPP=y |
| CONFIG_PPP_BSDCOMP=m |
| CONFIG_PPP_DEFLATE=m |
| CONFIG_PPP_MPPE=m |
| CONFIG_PPP_SYNC_TTY=m |
| " |
| |
| preempt_tracer_desc="preemption off tracer" |
| preempt_tracer_config=" |
| CONFIG_PREEMPT_TRACER=y |
| " |
| |
| qmi_desc="QMI WWAN driver" |
| qmi_config=" |
| CONFIG_USB_NET_QMI_WWAN=m |
| " |
| |
| realtekpstor_desc="Realtek PCI card reader" |
| realtekpstor_config=" |
| CONFIG_RTS_PSTOR=m |
| " |
| |
| samsung_serial_desc="Samsung serialport" |
| samsung_serial_config=" |
| CONFIG_SERIAL_SAMSUNG=y |
| CONFIG_SERIAL_SAMSUNG_CONSOLE=y |
| " |
| |
| sched_tracer_desc="scheduling latency tracer" |
| sched_tracer_config=" |
| CONFIG_SCHED_TRACER=y |
| " |
| |
| selinux_develop_desc="SELinux developer mode" |
| selinux_develop_config=" |
| # CONFIG_SECURITY_SELINUX_PERMISSIVE_DONTAUDIT is not set |
| " |
| |
| socketmon_desc="INET socket monitoring interface (for iproute2 ss)" |
| socketmon_config=" |
| CONFIG_INET_DIAG=y |
| CONFIG_INET_TCP_DIAG=y |
| CONFIG_INET_UDP_DIAG=y |
| " |
| |
| systemtap_desc="systemtap support" |
| systemtap_config=" |
| CONFIG_KPROBES=y |
| CONFIG_DEBUG_INFO=y |
| " |
| |
| ubsan_desc="Enable UBSAN" |
| ubsan_config=" |
| CONFIG_UBSAN=y |
| CONFIG_UBSAN_SANITIZE_ALL=y |
| CONFIG_TEST_UBSAN=m |
| CONFIG_FORTIFY_SOURCE=n |
| " |
| |
| usb_gadget_desc="USB gadget support with ConfigFS/FunctionFS" |
| usb_gadget_config=" |
| CONFIG_USB_CONFIGFS=m |
| CONFIG_USB_CONFIGFS_F_FS=y |
| CONFIG_USB_FUNCTIONFS=m |
| CONFIG_USB_GADGET=y |
| " |
| |
| usb_gadget_acm_desc="USB ACM gadget support" |
| usb_gadget_acm_config=" |
| CONFIG_USB_CONFIGFS_ACM=y |
| " |
| |
| usb_gadget_audio_desc="USB Audio gadget support" |
| usb_gadget_audio_config=" |
| CONFIG_USB_CONFIGFS_F_UAC1=y |
| CONFIG_USB_CONFIGFS_F_UAC2=y |
| " |
| |
| usb_gadget_ncm_desc="USB NCM gadget support" |
| usb_gadget_ncm_config=" |
| CONFIG_USB_CONFIGFS_NCM=y |
| " |
| |
| usbip_desc="Virtual USB support" |
| usbip_config=" |
| CONFIG_USBIP_CORE=m |
| CONFIG_USBIP_HOST=m |
| CONFIG_USBIP_VHCI_HCD=m |
| " |
| |
| virtio_balloon_desc="Balloon driver support kvm guests" |
| virtio_balloon_config=" |
| CONFIG_MEMORY_BALLOON=y |
| CONFIG_BALLOON_COMPACTION=y |
| CONFIG_VIRTIO_BALLOON=m |
| " |
| |
| vivid_desc="Virtual Video Test Driver" |
| vivid_config=" |
| CONFIG_MEDIA_TEST_SUPPORT=y |
| CONFIG_V4L_TEST_DRIVERS=y |
| CONFIG_VIDEO_VIVID=m |
| CONFIG_VIDEO_VIVID_MAX_DEVS=64 |
| " |
| |
| vkms_desc="Virtual KMS (Kernel Mode Setting)" |
| vkms_config=" |
| CONFIG_DRM_VKMS=m |
| " |
| |
| vkms_config_disable=" |
| # CONFIG_DRM_VKMS is not set |
| " |
| |
| vlan_desc="802.1Q VLAN" |
| vlan_config=" |
| CONFIG_VLAN_8021Q=m |
| " |
| |
| vmware_guest_desc="Support running under VMware hypervisor" |
| vmware_guest_config=" |
| CONFIG_VMWARE_BALLOON=y |
| CONFIG_VMWARE_PVSCSI=y |
| CONFIG_VMWARE_VMCI=y |
| CONFIG_VMWARE_VMCI_VSOCKETS=y |
| CONFIG_VMXNET3=y |
| " |
| |
| wifi_testbed_ap_desc="Defer Atheros Wifi EEPROM regulatory" |
| wifi_testbed_ap_warning=" |
| Don't use the wifi_testbed_ap flag unless you know what you are doing! |
| An image built with this flag set must never be run outside a |
| sealed RF chamber! |
| " |
| wifi_testbed_ap_config=" |
| CONFIG_ATH_DEFER_EEPROM_REGULATORY=y |
| CONFIG_BRIDGE=y |
| CONFIG_MAC80211_BEACON_FOOTER=y |
| " |
| |
| wifi_diag_desc="mac80211 WiFi diagnostic support" |
| wifi_diag_config=" |
| CONFIG_MAC80211_WIFI_DIAG=y |
| " |
| |
| x32_desc="x32 ABI support" |
| x32_config=" |
| CONFIG_X86_X32=y |
| " |
| |
| xen_guest_desc="Support running under Xen hypervisor" |
| xen_guest_config=" |
| CONFIG_XEN=y |
| CONFIG_XEN_PV=y |
| CONFIG_XEN_PV_SMP=y |
| CONFIG_XEN_DOM0=y |
| CONFIG_XEN_PVHVM=y |
| CONFIG_XEN_PVHVM_SMP=y |
| CONFIG_XEN_512GB=y |
| CONFIG_XEN_SAVE_RESTORE=y |
| CONFIG_XEN_PVH=y |
| CONFIG_PCI_XEN=y |
| CONFIG_XEN_PCIDEV_FRONTEND=y |
| CONFIG_XEN_BLKDEV_FRONTEND=y |
| CONFIG_XEN_BLKDEV_BACKEND=m |
| CONFIG_XEN_SCSI_FRONTEND=m |
| CONFIG_XEN_NETDEV_FRONTEND=y |
| CONFIG_XEN_NETDEV_BACKEND=m |
| CONFIG_INPUT_XEN_KBDDEV_FRONTEND=y |
| CONFIG_HVC_XEN=y |
| CONFIG_HVC_XEN_FRONTEND=y |
| CONFIG_TCG_XEN=m |
| CONFIG_XEN_DEV_EVTCHN=m |
| CONFIG_XEN_BACKEND=y |
| CONFIG_XENFS=m |
| CONFIG_XEN_COMPAT_XENFS=y |
| CONFIG_XEN_SYS_HYPERVISOR=y |
| CONFIG_XEN_XENBUS_FRONTEND=y |
| CONFIG_XEN_GNTDEV=m |
| CONFIG_XEN_GRANT_DEV_ALLOC=m |
| CONFIG_SWIOTLB_XEN=y |
| CONFIG_XEN_TMEM=m |
| CONFIG_XEN_PCIDEV_BACKEND=m |
| CONFIG_XEN_PRIVCMD=m |
| CONFIG_XEN_HAVE_PVMMU=y |
| CONFIG_XEN_EFI=y |
| CONFIG_XEN_AUTO_XLATE=y |
| CONFIG_XEN_ACPI=y |
| CONFIG_XEN_HAVE_VPMU=y |
| " |
| |
| hyperv_guest_desc="Microsoft Hyper-V guest support" |
| hyperv_guest_config=" |
| CONFIG_HYPERV=y |
| CONFIG_HYPERV_NET=y |
| CONFIG_HYPERV_TSCPAGE=y |
| CONFIG_HYPERV_KEYBOARD=y |
| CONFIG_HYPERV_STORAGE=y |
| CONFIG_HYPERV_BALLOON=y |
| CONFIG_HYPERV_UTILS=y |
| CONFIG_HYPERV_TIMER=y |
| CONFIG_HYPERV_IOMMU=y |
| CONFIG_FB_HYPERV=y |
| CONFIG_PCI_HYPERV=y |
| " |
| |
| ntfs_fs_desc="Microsoft NTFS support" |
| ntfs_fs_config=" |
| CONFIG_NTFS_FS=m |
| " |
| |
| cdrom_desc="CDROM support" |
| cdrom_config=" |
| CONFIG_BLK_DEV_SR=y |
| " |
| |
| vtconsole_desc="VT console" |
| vtconsole_config=" |
| CONFIG_VT=y |
| CONFIG_VT_CONSOLE=y |
| " |
| vtconsole_config_disable=" |
| # CONFIG_VT is not set |
| # CONFIG_VT_CONSOLE is not set |
| " |
| |
| nowerror_desc="Don't build with -Werror (warnings aren't fatal)." |
| nowerror_config=" |
| # CONFIG_ERROR_ON_WARNING is not set |
| # CONFIG_WERROR is not set |
| " |
| |
| docker_desc="Docker Support (Linux Containers)" |
| docker_config=" |
| # Generic flag requirements generated from the |
| # ebuild file. |
| CONFIG_BLK_CGROUP=y |
| CONFIG_BLK_DEV_THROTTLING=y |
| CONFIG_BRIDGE=y |
| CONFIG_BRIDGE_NETFILTER=y |
| CONFIG_CFQ_GROUP_IOSCHED=y |
| CONFIG_CFS_BANDWIDTH=y |
| CONFIG_CGROUPS=y |
| CONFIG_CGROUP_CPUACCT=y |
| CONFIG_CGROUP_DEVICE=y |
| CONFIG_CGROUP_FREEZER=y |
| CONFIG_CGROUP_HUGETLB=y |
| CONFIG_CGROUP_NET_PRIO=y |
| CONFIG_CGROUP_PERF=y |
| CONFIG_CGROUP_PIDS=y |
| CONFIG_CGROUP_SCHED=y |
| CONFIG_CPUSETS=y |
| CONFIG_CRYPTO=y |
| CONFIG_CRYPTO_AEAD=y |
| CONFIG_CRYPTO_GCM=y |
| CONFIG_CRYPTO_GHASH=y |
| CONFIG_CRYPTO_SEQIV=y |
| CONFIG_DUMMY=y |
| CONFIG_EXT4_FS_POSIX_ACL=y |
| CONFIG_EXT4_FS_SECURITY=y |
| CONFIG_FAIR_GROUP_SCHED=y |
| CONFIG_IOSCHED_CFQ=y |
| CONFIG_IPC_NS=y |
| CONFIG_IPVLAN=y |
| CONFIG_IP_NF_FILTER=y |
| CONFIG_IP_NF_NAT=y |
| CONFIG_IP_NF_TARGET_MASQUERADE=y |
| CONFIG_IP_VS=y |
| CONFIG_IP_VS_NFCT=y |
| CONFIG_IP_VS_PROTO_TCP=y |
| CONFIG_IP_VS_PROTO_UDP=y |
| CONFIG_IP_VS_RR=y |
| CONFIG_KEYS=y |
| CONFIG_MACVLAN=y |
| CONFIG_MEMCG=y |
| CONFIG_MEMCG_SWAP=y |
| CONFIG_MEMCG_SWAP_ENABLED=y |
| CONFIG_NAMESPACES=y |
| CONFIG_NETFILTER_XT_MATCH_ADDRTYPE=y |
| CONFIG_NETFILTER_XT_MATCH_CONNTRACK=y |
| CONFIG_NETFILTER_XT_MATCH_IPVS=y |
| CONFIG_NET_CLS_CGROUP=y |
| CONFIG_NET_NS=y |
| CONFIG_NF_NAT=y |
| CONFIG_NF_NAT_IPV4=y |
| CONFIG_NF_NAT_NEEDED=y |
| CONFIG_OVERLAY_FS=y |
| CONFIG_PID_NS=y |
| CONFIG_POSIX_MQUEUE=y |
| CONFIG_RT_GROUP_SCHED=y |
| CONFIG_SECCOMP=y |
| CONFIG_USER_NS=y |
| CONFIG_UTS_NS=y |
| CONFIG_VETH=y |
| CONFIG_VXLAN=y |
| CONFIG_XFRM_ALGO=y |
| CONFIG_XFRM_USER=y |
| CONFIG_CGROUP_HUGETLB=y |
| |
| # These are all required for chromeos |
| # On advice of yuzhao@, crash in __mod_node_page_state |
| CONFIG_KSTALED=n |
| # See crbug.com/1955013 |
| CONFIG_SECURITY_CHROMIUMOS_NO_SYMLINK_MOUNT=n |
| # See crbug.com/1050405 |
| CONFIG_INIT_STACK_ALL=n |
| " |
| |
| lxc_desc="LXC Support (Linux Containers)" |
| lxc_config=" |
| CONFIG_CGROUP_DEVICE=y |
| CONFIG_CPUSETS=y |
| CONFIG_CGROUP_CPUACCT=y |
| CONFIG_RESOURCE_COUNTERS=y |
| CONFIG_DEVPTS_MULTIPLE_INSTANCES=y |
| CONFIG_MACVLAN=y |
| CONFIG_POSIX_MQUEUE=y |
| CONFIG_BRIDGE_NETFILTER=y |
| CONFIG_NETFILTER_XT_TARGET_CHECKSUM=y |
| CONFIG_NETFILTER_XT_MATCH_COMMENT=y |
| " |
| |
| transparent_hugepage_desc="Transparent Hugepage Support" |
| transparent_hugepage_config=" |
| CONFIG_ARM_LPAE=y |
| CONFIG_TRANSPARENT_HUGEPAGE=y |
| CONFIG_TRANSPARENT_HUGEPAGE_MADVISE=y |
| " |
| |
| # We blast in all the debug options we can under this use flag so we can catch |
| # as many kernel bugs as possible in testing. Developers can choose to use |
| # this option too, but they should expect performance to be degraded, unlike |
| # the devdebug use flag. Since the kernel binary in gzip may be too large to |
| # fit into a typical 16MB partition, we also switch to xz compression. |
| debug_desc="All the debug options to catch kernel bugs in testing configurations" |
| debug_config=" |
| ${debugobjects_config} |
| ${devdebug_config} |
| ${dmadebug_config} |
| ${dyndebug_config} |
| ${kasan_config} |
| ${kernel_compress_xz_config} |
| ${lockdebug_config} |
| ${memory_debug_config} |
| CONFIG_DEBUG_LIST=y |
| CONFIG_DEBUG_PREEMPT=y |
| CONFIG_DEBUG_STACK_USAGE=y |
| CONFIG_SCHED_STACK_END_CHECK=y |
| CONFIG_WQ_WATCHDOG=y |
| CONFIG_HARDENED_USERCOPY=y |
| CONFIG_HARDENED_USERCOPY_FALLBACK=y |
| CONFIG_HARDENED_USERCOPY_PAGESPAN=y |
| CONFIG_BUG_ON_DATA_CORRUPTION=y |
| CONFIG_DEBUG_PI_LIST=y |
| CONFIG_REFCOUNT_FULL=y |
| CONFIG_DEBUG_KOBJECT_RELEASE=y |
| " |
| |
| vpu_driver_desc="Driver for Intel VPU" |
| vpu_driver_config=" |
| CONFIG_DRM_ACCEL_IVPU=m |
| " |
| |
| # Firmware binaries selected by USE flags. Selected firmware binaries will |
| # be built into the kernel using CONFIG_EXTRA_FIRMWARE. |
| |
| FIRMWARE_BINARIES=( |
| builtin_fw_amdgpu_carrizo |
| builtin_fw_amdgpu_gc_10_3_7 |
| builtin_fw_amdgpu_gc_11_0_1 |
| builtin_fw_amdgpu_green_sardine |
| builtin_fw_amdgpu_picasso |
| builtin_fw_amdgpu_raven2 |
| builtin_fw_amdgpu_renoir |
| builtin_fw_amdgpu_stoney |
| builtin_fw_amdgpu_yellow_carp |
| builtin_fw_guc_adl |
| builtin_fw_guc_adl_kernelnext |
| builtin_fw_guc_adln |
| builtin_fw_guc_g9 |
| builtin_fw_guc_jsl |
| builtin_fw_guc_tgl |
| builtin_fw_huc_adl |
| builtin_fw_huc_adl_kernelnext |
| builtin_fw_huc_adln |
| builtin_fw_huc_g9 |
| builtin_fw_huc_jsl |
| builtin_fw_huc_tgl |
| builtin_fw_mali_g57 |
| builtin_fw_t124_xusb |
| builtin_fw_t210_bpmp |
| builtin_fw_t210_nouveau |
| builtin_fw_t210_xusb |
| builtin_fw_vega12 |
| builtin_fw_x86_adl_ucode |
| builtin_fw_x86_adln_ucode |
| builtin_fw_x86_amd_ucode |
| builtin_fw_x86_aml_ucode |
| builtin_fw_x86_apl_ucode |
| builtin_fw_x86_bdw_ucode |
| builtin_fw_x86_bsw_ucode |
| builtin_fw_x86_byt_ucode |
| builtin_fw_x86_cml_ucode |
| builtin_fw_x86_glk_ucode |
| builtin_fw_x86_intel_ucode |
| builtin_fw_x86_jsl_ucode |
| builtin_fw_x86_kbl_ucode |
| builtin_fw_x86_mtl_ucode |
| builtin_fw_x86_rpl_ucode |
| builtin_fw_x86_skl_ucode |
| builtin_fw_x86_tgl_ucode |
| builtin_fw_x86_whl_ucode |
| ) |
| |
| builtin_fw_amdgpu_carrizo_desc="Firmware for AMD Carizzo" |
| builtin_fw_amdgpu_carrizo_files=( |
| amdgpu/carrizo_ce.bin |
| amdgpu/carrizo_me.bin |
| amdgpu/carrizo_mec.bin |
| amdgpu/carrizo_mec2.bin |
| amdgpu/carrizo_pfp.bin |
| amdgpu/carrizo_rlc.bin |
| amdgpu/carrizo_sdma.bin |
| amdgpu/carrizo_sdma1.bin |
| amdgpu/carrizo_uvd.bin |
| amdgpu/carrizo_vce.bin |
| ) |
| |
| builtin_fw_amdgpu_gc_10_3_7_desc="Firmware for AMD GC 10.3.7" |
| builtin_fw_amdgpu_gc_10_3_7_files=( |
| amdgpu/dcn_3_1_6_dmcub.bin |
| amdgpu/gc_10_3_7_ce.bin |
| amdgpu/gc_10_3_7_me.bin |
| amdgpu/gc_10_3_7_mec2.bin |
| amdgpu/gc_10_3_7_mec.bin |
| amdgpu/gc_10_3_7_pfp.bin |
| amdgpu/gc_10_3_7_rlc.bin |
| amdgpu/psp_13_0_8_asd.bin |
| amdgpu/psp_13_0_8_ta.bin |
| amdgpu/psp_13_0_8_toc.bin |
| amdgpu/sdma_5_2_7.bin |
| amdgpu/yellow_carp_vcn.bin |
| ) |
| |
| builtin_fw_amdgpu_gc_11_0_1_desc="Firmware for AMD GC 11.0.1" |
| builtin_fw_amdgpu_gc_11_0_1_files=( |
| amdgpu/dcn_3_1_4_dmcub.bin |
| amdgpu/gc_11_0_1_imu.bin |
| amdgpu/gc_11_0_1_me.bin |
| amdgpu/gc_11_0_1_mec.bin |
| amdgpu/gc_11_0_1_mes.bin |
| amdgpu/gc_11_0_1_mes1.bin |
| amdgpu/gc_11_0_1_pfp.bin |
| amdgpu/gc_11_0_1_rlc.bin |
| amdgpu/psp_13_0_4_ta.bin |
| amdgpu/psp_13_0_4_toc.bin |
| amdgpu/sdma_6_0_1.bin |
| amdgpu/vcn_4_0_2.bin |
| ) |
| |
| builtin_fw_amdgpu_green_sardine_desc="Firmware for AMD Green Sardine" |
| builtin_fw_amdgpu_green_sardine_files=( |
| amdgpu/green_sardine_asd.bin |
| amdgpu/green_sardine_ce.bin |
| amdgpu/green_sardine_dmcub.bin |
| amdgpu/green_sardine_me.bin |
| amdgpu/green_sardine_mec2.bin |
| amdgpu/green_sardine_mec.bin |
| amdgpu/green_sardine_pfp.bin |
| amdgpu/green_sardine_rlc.bin |
| amdgpu/green_sardine_sdma.bin |
| amdgpu/green_sardine_ta.bin |
| amdgpu/green_sardine_vcn.bin |
| ) |
| |
| builtin_fw_amdgpu_picasso_desc="Firmware for AMD Picasso" |
| builtin_fw_amdgpu_picasso_files=( |
| amdgpu/picasso_asd.bin |
| amdgpu/picasso_ce.bin |
| amdgpu/picasso_gpu_info.bin |
| amdgpu/picasso_me.bin |
| amdgpu/picasso_mec2.bin |
| amdgpu/picasso_mec.bin |
| amdgpu/picasso_pfp.bin |
| amdgpu/picasso_rlc_am4.bin |
| amdgpu/picasso_rlc.bin |
| amdgpu/picasso_sdma.bin |
| amdgpu/picasso_vcn.bin |
| amdgpu/picasso_ta.bin |
| ) |
| |
| builtin_fw_amdgpu_raven2_desc="Firmware for AMD Raven 2" |
| builtin_fw_amdgpu_raven2_files=( |
| amdgpu/raven_dmcu.bin |
| amdgpu/raven2_asd.bin |
| amdgpu/raven2_ce.bin |
| amdgpu/raven2_gpu_info.bin |
| amdgpu/raven2_me.bin |
| amdgpu/raven2_mec.bin |
| amdgpu/raven2_mec2.bin |
| amdgpu/raven2_pfp.bin |
| amdgpu/raven2_rlc.bin |
| amdgpu/raven2_sdma.bin |
| amdgpu/raven2_vcn.bin |
| amdgpu/raven2_ta.bin |
| ) |
| |
| builtin_fw_amdgpu_renoir_desc="Firmware for AMD Renoir" |
| builtin_fw_amdgpu_renoir_files=( |
| amdgpu/renoir_asd.bin |
| amdgpu/renoir_ce.bin |
| amdgpu/renoir_dmcub.bin |
| amdgpu/renoir_gpu_info.bin |
| amdgpu/renoir_me.bin |
| amdgpu/renoir_mec2.bin |
| amdgpu/renoir_mec.bin |
| amdgpu/renoir_pfp.bin |
| amdgpu/renoir_rlc.bin |
| amdgpu/renoir_sdma.bin |
| amdgpu/renoir_ta.bin |
| amdgpu/renoir_vcn.bin |
| ) |
| |
| builtin_fw_amdgpu_stoney_desc="Firmware for AMD Stoney" |
| builtin_fw_amdgpu_stoney_files=( |
| amdgpu/stoney_ce.bin |
| amdgpu/stoney_me.bin |
| amdgpu/stoney_mec.bin |
| amdgpu/stoney_pfp.bin |
| amdgpu/stoney_rlc.bin |
| amdgpu/stoney_sdma.bin |
| amdgpu/stoney_uvd.bin |
| amdgpu/stoney_vce.bin |
| ) |
| |
| builtin_fw_amdgpu_yellow_carp_desc="Firmware for AMD Yellow Carp" |
| builtin_fw_amdgpu_yellow_carp_files=( |
| amdgpu/yellow_carp_asd.bin |
| amdgpu/yellow_carp_ce.bin |
| amdgpu/yellow_carp_dmcub.bin |
| amdgpu/yellow_carp_me.bin |
| amdgpu/yellow_carp_mec2.bin |
| amdgpu/yellow_carp_mec.bin |
| amdgpu/yellow_carp_pfp.bin |
| amdgpu/yellow_carp_rlc.bin |
| amdgpu/yellow_carp_sdma.bin |
| amdgpu/yellow_carp_ta.bin |
| amdgpu/yellow_carp_toc.bin |
| amdgpu/yellow_carp_vcn.bin |
| ) |
| |
| builtin_fw_guc_adl_desc="GuC Firmware for ADL" |
| builtin_fw_guc_adl_files=( |
| i915/tgl_guc_49.0.1.bin |
| i915/adlp_guc_62.0.3.bin |
| i915/adlp_guc_69.0.3.bin |
| ) |
| |
| builtin_fw_guc_adl_kernelnext_desc="GuC Firmware for ADL Kernelnext" |
| builtin_fw_guc_adl_kernelnext_files=( |
| i915/adlp_guc_69.0.3.bin |
| i915/adlp_guc_70.1.1.bin |
| ) |
| |
| builtin_fw_guc_adln_desc="GuC Firmware for ADL-N" |
| builtin_fw_guc_adln_files=( |
| i915/tgl_guc_70.bin |
| ) |
| |
| builtin_fw_guc_g9_desc="GuC Firmware for Gen9" |
| builtin_fw_guc_g9_files=( |
| i915/kbl_guc_ver9_39.bin |
| ) |
| |
| builtin_fw_guc_jsl_desc="GuC Firmware for JSL" |
| builtin_fw_guc_jsl_files=( |
| i915/ehl_guc_49.0.1.bin |
| ) |
| |
| builtin_fw_guc_tgl_desc="GuC Firmware for TGL" |
| builtin_fw_guc_tgl_files=( |
| i915/tgl_guc_49.0.1.bin |
| ) |
| |
| builtin_fw_huc_adl_desc="HuC Firmware for ADL" |
| builtin_fw_huc_adl_files=( |
| i915/tgl_huc_7.9.3.bin |
| ) |
| |
| builtin_fw_huc_adl_kernelnext_desc="HuC Firmware for ADL Kernelnext" |
| builtin_fw_huc_adl_kernelnext_files=( |
| i915/tgl_huc_7.9.3.bin |
| ) |
| |
| builtin_fw_huc_adln_desc="HuC Firmware for ADL-N" |
| builtin_fw_huc_adln_files=( |
| i915/tgl_huc_7.9.3.bin |
| ) |
| |
| builtin_fw_huc_g9_desc="HuC Firmware for Gen9" |
| builtin_fw_huc_g9_files=( |
| i915/kbl_huc_ver02_00_1810.bin |
| ) |
| |
| builtin_fw_huc_jsl_desc="HuC Firmware for JSL" |
| builtin_fw_huc_jsl_files=( |
| i915/ehl_huc_9.0.0.bin |
| ) |
| |
| builtin_fw_huc_tgl_desc="HuC Firmware for TGL" |
| builtin_fw_huc_tgl_files=( |
| i915/tgl_huc_7.5.0.bin |
| ) |
| |
| builtin_fw_mali_g57_desc="Workaround Firmware for Mali-G57" |
| builtin_fw_mali_g57_files=( |
| valhall-1691526.wa |
| ) |
| |
| builtin_fw_t124_xusb_desc="Tegra124 XHCI controller" |
| builtin_fw_t124_xusb_files=( |
| nvidia/tegra124/xusb.bin |
| ) |
| |
| builtin_fw_t210_bpmp_desc="Tegra210 BPMP" |
| builtin_fw_t210_bpmp_files=( |
| nvidia/tegra210/bpmp.bin |
| ) |
| |
| builtin_fw_t210_nouveau_desc="Tegra210 Nouveau GPU" |
| builtin_fw_t210_nouveau_files=( |
| nouveau/acr_ucode.bin |
| nouveau/fecs.bin |
| nouveau/fecs_sig.bin |
| nouveau/gpmu_ucode_desc.bin |
| nouveau/gpmu_ucode_image.bin |
| nouveau/nv12b_bundle |
| nouveau/nv12b_fuc409c |
| nouveau/nv12b_fuc409d |
| nouveau/nv12b_fuc41ac |
| nouveau/nv12b_fuc41ad |
| nouveau/nv12b_method |
| nouveau/nv12b_sw_ctx |
| nouveau/nv12b_sw_nonctx |
| nouveau/pmu_bl.bin |
| nouveau/pmu_sig.bin |
| ) |
| |
| builtin_fw_t210_xusb_desc="Tegra210 XHCI controller" |
| builtin_fw_t210_xusb_files=( |
| nvidia/tegra210/xusb.bin |
| ) |
| |
| builtin_fw_vega12_desc="Firmware for AMD VEGA12" |
| builtin_fw_vega12_files=( |
| amdgpu/vega12_asd.bin |
| amdgpu/vega12_ce.bin |
| amdgpu/vega12_gpu_info.bin |
| amdgpu/vega12_me.bin |
| amdgpu/vega12_mec2.bin |
| amdgpu/vega12_mec.bin |
| amdgpu/vega12_pfp.bin |
| amdgpu/vega12_rlc.bin |
| amdgpu/vega12_sdma1.bin |
| amdgpu/vega12_sdma.bin |
| amdgpu/vega12_smc.bin |
| amdgpu/vega12_sos.bin |
| amdgpu/vega12_uvd.bin |
| amdgpu/vega12_vce.bin |
| ) |
| |
| builtin_fw_x86_amd_ucode_desc="AMD ucode for all chips" |
| builtin_fw_x86_amd_ucode_files=( |
| amd-ucode/microcode_amd.bin |
| amd-ucode/microcode_amd_fam15h.bin |
| amd-ucode/microcode_amd_fam16h.bin |
| amd-ucode/microcode_amd_fam17h.bin |
| amd-ucode/microcode_amd_fam19h.bin |
| ) |
| |
| builtin_fw_x86_intel_ucode_desc="Intel ucode for all chips" |
| builtin_fw_x86_intel_ucode_files=( |
| intel-ucode/06-03-02 |
| intel-ucode/06-05-00 |
| intel-ucode/06-05-01 |
| intel-ucode/06-05-02 |
| intel-ucode/06-05-03 |
| intel-ucode/06-06-00 |
| intel-ucode/06-06-05 |
| intel-ucode/06-06-0a |
| intel-ucode/06-06-0d |
| intel-ucode/06-07-01 |
| intel-ucode/06-07-02 |
| intel-ucode/06-07-03 |
| intel-ucode/06-08-01 |
| intel-ucode/06-08-03 |
| intel-ucode/06-08-06 |
| intel-ucode/06-08-0a |
| intel-ucode/06-09-05 |
| intel-ucode/06-0a-00 |
| intel-ucode/06-0a-01 |
| intel-ucode/06-0b-01 |
| intel-ucode/06-0b-04 |
| intel-ucode/06-0d-06 |
| intel-ucode/06-0e-08 |
| intel-ucode/06-0e-0c |
| intel-ucode/06-0f-02 |
| intel-ucode/06-0f-06 |
| intel-ucode/06-0f-07 |
| intel-ucode/06-0f-0a |
| intel-ucode/06-0f-0b |
| intel-ucode/06-0f-0d |
| intel-ucode/06-16-01 |
| intel-ucode/06-17-06 |
| intel-ucode/06-17-07 |
| intel-ucode/06-17-0a |
| intel-ucode/06-1a-04 |
| intel-ucode/06-1a-05 |
| intel-ucode/06-1c-02 |
| intel-ucode/06-1c-0a |
| intel-ucode/06-1d-01 |
| intel-ucode/06-1e-05 |
| intel-ucode/06-25-02 |
| intel-ucode/06-25-05 |
| intel-ucode/06-26-01 |
| intel-ucode/06-2a-07 |
| intel-ucode/06-2c-02 |
| intel-ucode/06-2d-06 |
| intel-ucode/06-2d-07 |
| intel-ucode/06-2e-06 |
| intel-ucode/06-2f-02 |
| intel-ucode/06-37-08 |
| intel-ucode/06-37-09 |
| intel-ucode/06-3a-09 |
| intel-ucode/06-3c-03 |
| intel-ucode/06-3d-04 |
| intel-ucode/06-3e-04 |
| intel-ucode/06-3e-06 |
| intel-ucode/06-3e-07 |
| intel-ucode/06-3f-02 |
| intel-ucode/06-3f-04 |
| intel-ucode/06-45-01 |
| intel-ucode/06-46-01 |
| intel-ucode/06-47-01 |
| intel-ucode/06-4c-03 |
| intel-ucode/06-4c-04 |
| intel-ucode/06-4d-08 |
| intel-ucode/06-4e-03 |
| intel-ucode/06-55-03 |
| intel-ucode/06-55-04 |
| intel-ucode/06-55-05 |
| intel-ucode/06-55-06 |
| intel-ucode/06-55-07 |
| intel-ucode/06-55-0b |
| intel-ucode/06-56-02 |
| intel-ucode/06-56-03 |
| intel-ucode/06-56-04 |
| intel-ucode/06-56-05 |
| intel-ucode/06-5c-02 |
| intel-ucode/06-5c-09 |
| intel-ucode/06-5c-0a |
| intel-ucode/06-5e-03 |
| intel-ucode/06-5f-01 |
| intel-ucode/06-66-03 |
| intel-ucode/06-6a-05 |
| intel-ucode/06-6a-06 |
| intel-ucode/06-7a-01 |
| intel-ucode/06-7a-08 |
| intel-ucode/06-7e-05 |
| intel-ucode/06-8a-01 |
| intel-ucode/06-8c-01 |
| intel-ucode/06-8c-02 |
| intel-ucode/06-8d-01 |
| intel-ucode/06-8e-09 |
| intel-ucode/06-8e-0a |
| intel-ucode/06-8e-0b |
| intel-ucode/06-8e-0c |
| intel-ucode/06-96-01 |
| intel-ucode/06-97-02 |
| intel-ucode/06-97-05 |
| intel-ucode/06-9a-03 |
| intel-ucode/06-9a-04 |
| intel-ucode/06-9c-00 |
| intel-ucode/06-9e-09 |
| intel-ucode/06-9e-0a |
| intel-ucode/06-9e-0b |
| intel-ucode/06-9e-0c |
| intel-ucode/06-9e-0d |
| intel-ucode/06-a5-02 |
| intel-ucode/06-a5-03 |
| intel-ucode/06-a5-05 |
| intel-ucode/06-a6-00 |
| intel-ucode/06-a6-01 |
| intel-ucode/06-a7-01 |
| intel-ucode/06-bf-02 |
| intel-ucode/06-bf-05 |
| intel-ucode/0f-00-07 |
| intel-ucode/0f-00-0a |
| intel-ucode/0f-01-02 |
| intel-ucode/0f-02-04 |
| intel-ucode/0f-02-05 |
| intel-ucode/0f-02-06 |
| intel-ucode/0f-02-07 |
| intel-ucode/0f-02-09 |
| intel-ucode/0f-03-02 |
| intel-ucode/0f-03-03 |
| intel-ucode/0f-03-04 |
| intel-ucode/0f-04-01 |
| intel-ucode/0f-04-03 |
| intel-ucode/0f-04-04 |
| intel-ucode/0f-04-07 |
| intel-ucode/0f-04-08 |
| intel-ucode/0f-04-09 |
| intel-ucode/0f-04-0a |
| intel-ucode/0f-06-02 |
| intel-ucode/0f-06-04 |
| intel-ucode/0f-06-05 |
| intel-ucode/0f-06-08 |
| ) |
| |
| builtin_fw_x86_adl_ucode_desc="Intel ucode for ADL" |
| builtin_fw_x86_adl_ucode_files=( |
| intel-ucode/06-9a-03 |
| intel-ucode/06-9a-04 |
| ) |
| |
| builtin_fw_x86_adln_ucode_desc="Intel ucode for ADL-N" |
| builtin_fw_x86_adln_ucode_files=( |
| intel-ucode/06-be-00 |
| ) |
| |
| builtin_fw_x86_aml_ucode_desc="Intel ucode for AML" |
| builtin_fw_x86_aml_ucode_files=( |
| intel-ucode/06-8e-09 |
| intel-ucode/06-8e-0c |
| ) |
| |
| builtin_fw_x86_apl_ucode_desc="Intel ucode for APL" |
| builtin_fw_x86_apl_ucode_files=( |
| intel-ucode/06-5c-09 |
| ) |
| |
| builtin_fw_x86_bdw_ucode_desc="Intel ucode for BDW" |
| builtin_fw_x86_bdw_ucode_files=( |
| intel-ucode/06-3d-04 |
| ) |
| |
| builtin_fw_x86_bsw_ucode_desc="Intel ucode for BSW" |
| builtin_fw_x86_bsw_ucode_files=( |
| intel-ucode/06-4c-03 |
| intel-ucode/06-4c-04 |
| ) |
| |
| builtin_fw_x86_byt_ucode_desc="Intel ucode for BYT" |
| builtin_fw_x86_byt_ucode_files=( |
| intel-ucode/06-37-08 |
| ) |
| |
| builtin_fw_x86_cml_ucode_desc="Intel ucode for CML" |
| builtin_fw_x86_cml_ucode_files=( |
| intel-ucode/06-8e-0c |
| intel-ucode/06-9e-0d |
| intel-ucode/06-a6-00 |
| ) |
| |
| builtin_fw_x86_glk_ucode_desc="Intel ucode for GLK" |
| builtin_fw_x86_glk_ucode_files=( |
| intel-ucode/06-7a-01 |
| intel-ucode/06-7a-08 |
| ) |
| |
| builtin_fw_x86_jsl_ucode_desc="Intel ucode for JSL" |
| builtin_fw_x86_jsl_ucode_files=( |
| intel-ucode/06-9c-00 |
| ) |
| |
| builtin_fw_x86_kbl_ucode_desc="Intel ucode for KBL" |
| builtin_fw_x86_kbl_ucode_files=( |
| intel-ucode/06-8e-09 |
| intel-ucode/06-8e-0a |
| ) |
| |
| builtin_fw_x86_mtl_ucode_desc="Intel ucode for MTL" |
| builtin_fw_x86_mtl_ucode_files=( |
| intel-ucode/06-aa-01 |
| intel-ucode/06-aa-02 |
| ) |
| |
| builtin_fw_x86_rpl_ucode_desc="Intel ucode for RPL" |
| builtin_fw_x86_rpl_ucode_files=( |
| intel-ucode/06-ba-02 |
| intel-ucode/06-ba-03 |
| ) |
| |
| builtin_fw_x86_skl_ucode_desc="Intel ucode for SKL" |
| builtin_fw_x86_skl_ucode_files=( |
| intel-ucode/06-4e-03 |
| ) |
| |
| builtin_fw_x86_tgl_ucode_desc="Intel ucode for TGL" |
| builtin_fw_x86_tgl_ucode_files=( |
| intel-ucode/06-8c-00 |
| intel-ucode/06-8c-01 |
| ) |
| |
| builtin_fw_x86_whl_ucode_desc="Intel ucode for WHL" |
| builtin_fw_x86_whl_ucode_files=( |
| intel-ucode/06-8e-0b |
| intel-ucode/06-8e-0c |
| ) |
| |
| extra_fw_config=" |
| CONFIG_EXTRA_FIRMWARE=\"%FW%\" |
| CONFIG_EXTRA_FIRMWARE_DIR=\"%ROOT%/lib/firmware\" |
| " |
| |
| # Add all config and firmware fragments as off by default |
| IUSE="${IUSE} ${CONFIG_FRAGMENTS[*]} ${FIRMWARE_BINARIES[*]}" |
| REQUIRED_USE+=" |
| ?? ( |
| factory_netboot_ramfs |
| factory_shim_ramfs |
| minios_ramfs |
| recovery_ramfs |
| ) |
| factory_netboot_ramfs? ( i2cdev ) |
| factory_shim_ramfs? ( i2cdev ) |
| recovery_ramfs? ( i2cdev ) |
| factory_netboot_ramfs? ( || ( tpm tpm2 ) ) |
| factory_shim_ramfs? ( || ( tpm tpm2 ) ) |
| recovery_ramfs? ( || ( tpm tpm2 ) ) |
| " |
| |
| # Get the CHROMEOS_KERNEL_FAMILY from the use flags(chromeos_kernel_family_*). |
| _get_kernel_family() { |
| local i |
| for i in "${!CHROMEOS_KERNEL_FAMILY_FLAGS[@]}"; do |
| if use "${CHROMEOS_KERNEL_FAMILY_FLAGS[${i}]}"; then |
| echo "${CHROMEOS_KERNEL_FAMILY_VALUES[${i}]}" |
| return |
| fi |
| done |
| |
| die "chromeos kernel family use flag not defined!" |
| } |
| |
| # If an overlay has eclass overrides, but doesn't actually override this |
| # eclass, we'll have ECLASSDIR pointing to the active overlay's |
| # eclass/ dir, but this eclass is still in the main chromiumos tree. So |
| # add a check to locate the cros-kernel/ regardless of what's going on. |
| ECLASSDIR_LOCAL=${BASH_SOURCE[0]%/*} |
| eclass_dir() { |
| # shellcheck disable=SC2154 |
| local d="${ECLASSDIR}/cros-kernel" |
| if [[ ! -d ${d} ]] ; then |
| d="${ECLASSDIR_LOCAL}/cros-kernel" |
| fi |
| echo "${d}" |
| } |
| |
| # @FUNCTION: kernelrelease |
| # @DESCRIPTION: |
| # Returns the current compiled kernel version. |
| # Note: Only valid after src_configure has finished running. |
| kernelrelease() { |
| # Try to fastpath figure out the kernel release since calling |
| # kmake is slow. The idea here is that if we happen to be |
| # running this function at the end of the install phase then |
| # there will be a binary that was created with the kernel |
| # version as a suffix. We can look at that to figure out the |
| # version. |
| # |
| # NOTE: it's safe to always call this function because ${D} |
| # isn't something that is kept between incremental builds, IOW |
| # it's not like $(cros-workon_get_build_dir). That means that |
| # if ${D}/boot/vmlinuz-* exists it must be the right one. |
| |
| local kernel_bins=("${D}"/boot/vmlinuz-*) |
| local version |
| |
| if [[ ${#kernel_bins[@]} -eq 1 ]]; then |
| version="${kernel_bins[0]##${D}/boot/vmlinuz-}" |
| fi |
| if [[ -z "${version}" || "${version}" == '*' ]]; then |
| version="$(kmake -s --no-print-directory kernelrelease)" |
| fi |
| |
| echo "${version}" |
| } |
| |
| # @FUNCTION: cc_option |
| # @DESCRIPTION: |
| # Return 0 if ${CC} supports all provided options, 1 otherwise. |
| # test-flags-CC tests each flag individually and returns the |
| # supported flags, which is not what we need here. |
| cc_option() { |
| local t="$(test-flags-CC "$@")" |
| [[ "${t}" == "$*" ]] |
| } |
| |
| # @FUNCTION: install_kernel_sources |
| # @DESCRIPTION: |
| # Installs the kernel sources into ${D}/usr/src/${P} and fixes symlinks. |
| # The package must have already installed a directory under ${D}/lib/modules. |
| install_kernel_sources() { |
| local version=$(kernelrelease) |
| local dest_modules_dir=lib/modules/${version} |
| local dest_source_dir=usr/src/${P} |
| local dest_build_dir=${dest_source_dir}/build |
| |
| # Fix symlinks in lib/modules |
| ln -sfvT "../../../${dest_build_dir}" \ |
| "${D}/${dest_modules_dir}/build" || die |
| ln -sfvT "../../../${dest_source_dir}" \ |
| "${D}/${dest_modules_dir}/source" || die |
| |
| einfo "Installing kernel source tree" |
| dodir "${dest_source_dir}" |
| local f |
| for f in "${S}"/*; do |
| [[ "${f}" == "${S}/build" ]] && continue |
| cp -pPR "${f}" "${D}/${dest_source_dir}" || |
| die "Failed to copy kernel source tree" |
| done |
| |
| dosym "${P}" "/usr/src/linux" |
| |
| einfo "Installing kernel build tree" |
| dodir "${dest_build_dir}" |
| cp -pPR "$(cros-workon_get_build_dir)"/. "${D}/${dest_build_dir}" || die |
| |
| # Modify Makefile to use the ROOT environment variable if defined. |
| # This path needs to be absolute so that the build directory will |
| # still work if copied elsewhere. |
| sed -i -e "s@${S}@\$(ROOT)/${dest_source_dir}@" \ |
| "${D}/${dest_build_dir}/Makefile" || die |
| } |
| |
| get_build_cfg() { |
| echo "$(cros-workon_get_build_dir)/.config" |
| } |
| |
| # Get architecture to be used for |
| # - "<arch>_defconfig" if there is no splitconfig |
| # - "chromiumos-<arch>" if CHROMEOS_KERNEL_SPLITCONFIG is not defined |
| get_build_arch() { |
| if [[ "${ARCH}" == "arm" || "${ARCH}" == "arm64" ]]; then |
| # shellcheck disable=SC2154 |
| case "${CHROMEOS_KERNEL_SPLITCONFIG}" in |
| *exynos*) |
| echo "exynos5" |
| ;; |
| *qualcomm*) |
| echo "qualcomm" |
| ;; |
| *rockchip64*) |
| echo "rockchip64" |
| ;; |
| *rockchip*) |
| echo "rockchip" |
| ;; |
| *tegra*) |
| echo "tegra" |
| ;; |
| *) |
| echo "${ARCH}" |
| ;; |
| esac |
| elif [[ "${ARCH}" == "x86" ]]; then |
| case "${CHROMEOS_KERNEL_SPLITCONFIG}" in |
| *i386*) |
| echo "i386" |
| ;; |
| *x86_64*) |
| echo "x86_64" |
| ;; |
| *) |
| echo "x86" |
| ;; |
| esac |
| elif [[ "${ARCH}" == "amd64" ]]; then |
| echo "x86_64" |
| elif [[ "${ARCH}" == "mips" ]]; then |
| case "${CHROMEOS_KERNEL_SPLITCONFIG}" in |
| *pistachio*) |
| echo "pistachio" |
| ;; |
| *) |
| echo "maltasmvp" |
| ;; |
| esac |
| else |
| tc-arch-kernel |
| fi |
| } |
| |
| # @FUNCTION: cros_chkconfig_present |
| # @USAGE: <option to check config for> |
| # @DESCRIPTION: |
| # Returns success of the provided option is present in the build config. |
| cros_chkconfig_present() { |
| local config=$1 |
| grep -q "^CONFIG_$1=[ym]$" "$(get_build_cfg)" |
| } |
| |
| cros-kernel2_pkg_setup() { |
| cros-workon_pkg_setup |
| } |
| |
| # @FUNCTION: _cros-kernel2_get_fit_compression |
| # @USAGE: |
| # @DESCRIPTION: |
| # Returns what compression algorithm the kernel uses in the FIT |
| # image. Currently only applicable for arm64 since on all other |
| # kernels we use the zImage which is created/compressed by the kernel |
| # build itself; returns "none" when not applicable. |
| _cros-kernel2_get_fit_compression() { |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| |
| if [[ "${kernel_arch}" != "arm64" ]]; then |
| echo none |
| elif use fit_compression_kernel_lz4; then |
| echo lz4 |
| elif use fit_compression_kernel_lzma; then |
| echo lzma |
| else |
| echo none |
| fi |
| } |
| |
| # @FUNCTION: _cros-kernel2_get_fit_kernel_path |
| # @USAGE: |
| # @DESCRIPTION: |
| # Returns the releative path to the (uncompressed) kernel we'll put in the fit |
| # image. |
| _cros-kernel2_get_fit_kernel_path() { |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| |
| case ${kernel_arch} in |
| arm64) |
| echo "arch/${kernel_arch}/boot/Image" |
| ;; |
| mips) |
| echo "vmlinuz.bin" |
| ;; |
| *) |
| echo "arch/${kernel_arch}/boot/zImage" |
| ;; |
| esac |
| } |
| |
| # @FUNCTION: _cros-kernel2_get_fit_compressed_kernel_path |
| # @USAGE: |
| # @DESCRIPTION: |
| # Returns the releative path to the compressed kernel we'll put in the fit |
| # image; if we're using a compression of "none" this will just return the |
| # path of the uncompressed kernel. |
| _cros-kernel2_get_compressed_path() { |
| local uncompressed_path="$(_cros-kernel2_get_fit_kernel_path)" |
| local compression="$(_cros-kernel2_get_fit_compression)" |
| |
| if [[ "${compression}" == "none" ]]; then |
| echo "${uncompressed_path}" |
| else |
| echo "${uncompressed_path}.${compression}" |
| fi |
| } |
| |
| # @FUNCTION: _cros-kernel2_compress_fit_kernel |
| # @USAGE: <kernel_dir> |
| # @DESCRIPTION: |
| # Compresses the kernel with the algorithm selected by current USE flags. If |
| # no compression algorithm this does nothing. |
| _cros-kernel2_compress_fit_kernel() { |
| local kernel_dir=${1} |
| local kernel_path="${kernel_dir}/$(_cros-kernel2_get_fit_kernel_path)" |
| local compr_path="${kernel_dir}/$(_cros-kernel2_get_compressed_path)" |
| local compression="$(_cros-kernel2_get_fit_compression)" |
| |
| case "${compression}" in |
| lz4) |
| lz4 -20 -z -f "${kernel_path}" "${compr_path}" || die |
| ;; |
| lzma) |
| lzma -9 -z -f -k "${kernel_path}" || die |
| ;; |
| esac |
| } |
| |
| # @FUNCTION: _cros-kernel2_get_compat |
| # @USAGE: <dtb file> |
| # @DESCRIPTION: |
| # Returns the list of compatible strings extracted from a given .dtb file, in |
| # the format required to re-insert it in a new property of an its-script. |
| _cros-kernel2_get_compat() { |
| local dtb="$1" |
| local result="" |
| local s |
| |
| for s in $(fdtget "${dtb}" / compatible); do |
| result+="\"${s}\"," |
| done |
| |
| printf "%s" "${result%,}" |
| } |
| |
| # @FUNCTION: _cros-kernel2_emit_its_script |
| # @USAGE: <output file> <kernel_dir> <device trees> |
| # @DESCRIPTION: |
| # Emits the its script used to build the u-boot fitImage kernel binary |
| # that contains the kernel as well as device trees used when booting |
| # it. |
| _cros-kernel2_emit_its_script() { |
| local compat=() |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| local fit_compression_fdt="none" |
| local fit_compression_kernel |
| local kernel_bin_path |
| local iter=1 |
| local its_out=${1} |
| shift |
| local kernel_dir=${1} |
| shift |
| |
| fit_compression_kernel="$(_cros-kernel2_get_fit_compression)" |
| kernel_bin_path="${kernel_dir}/$(_cros-kernel2_get_compressed_path)" |
| |
| cat > "${its_out}" <<-EOF || die |
| /dts-v1/; |
| |
| / { |
| description = "Chrome OS kernel image with one or more FDT blobs"; |
| #address-cells = <1>; |
| |
| images { |
| kernel@1 { |
| data = /incbin/("${kernel_bin_path}"); |
| type = "kernel_noload"; |
| arch = "${kernel_arch}"; |
| os = "linux"; |
| compression = "${fit_compression_kernel}"; |
| load = <0>; |
| entry = <0>; |
| }; |
| EOF |
| |
| local dtb |
| for dtb in "$@" ; do |
| compat[${iter}]=$(_cros-kernel2_get_compat "${dtb}") |
| if use dt_compression; then |
| # Compress all DTBs in parallel (only needed after this function). |
| lz4 -20 -z -f "${dtb}" "${dtb}.lz4" || die & |
| dtb="${dtb}.lz4" |
| fit_compression_fdt="lz4" |
| fi |
| cat >> "${its_out}" <<-EOF || die |
| fdt@${iter} { |
| description = "$(basename "${dtb}")"; |
| data = /incbin/("${dtb}"); |
| type = "flat_dt"; |
| arch = "${kernel_arch}"; |
| compression = "${fit_compression_fdt}"; |
| hash@1 { |
| algo = "sha1"; |
| }; |
| }; |
| EOF |
| ((++iter)) |
| done |
| |
| cat <<-EOF >>"${its_out}" |
| }; |
| configurations { |
| EOF |
| |
| local i |
| for i in $(seq 1 $((iter-1))) ; do |
| cat >> "${its_out}" <<-EOF || die |
| conf@${i} { |
| kernel = "kernel@1"; |
| fdt = "fdt@${i}"; |
| compatible = ${compat[${i}]}; |
| }; |
| EOF |
| done |
| |
| echo " };" >> "${its_out}" |
| echo "};" >> "${its_out}" |
| |
| # Wait for DTB compression to finish. |
| wait |
| } |
| |
| kmake() { |
| # Allow override of kernel arch. |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| |
| # Support 64bit kernels w/32bit userlands. |
| local cross=${CHOST} |
| local cross_compat |
| local CC_COMPAT |
| local LD_COMPAT |
| case ${ARCH}:${kernel_arch} in |
| x86:x86_64) |
| cross="x86_64-cros-linux-gnu" |
| ;; |
| arm:arm64) |
| cross="aarch64-cros-linux-gnu" |
| ;; |
| esac |
| |
| # Support generating 32-bit VDSO on arm64 kernels |
| if use vdso32 && [[ "${kernel_arch}" == "arm64" ]]; then |
| cross_compat="armv7a-cros-linux-gnueabihf-" |
| CC_COMPAT="armv7a-cros-linux-gnueabihf-clang" |
| LD_COMPAT="ld.lld" |
| fi |
| |
| # Assemble with LLVM's integrated assembler on x86_64 and aarch64 |
| if use llvm_ias; then |
| export LLVM_IAS=1 |
| fi |
| |
| if [[ "${CHOST}" != "${cross}" ]]; then |
| unset CC CXX LD STRIP OBJCOPY NM AR |
| fi |
| |
| tc-export_build_env BUILD_{CC,CXX,LD,PKG_CONFIG} |
| CHOST=${cross} tc-export CC CXX LD STRIP OBJCOPY NM AR |
| if use clang; then |
| STRIP=llvm-strip |
| OBJCOPY=llvm-objcopy |
| NM=llvm-nm |
| AR=llvm-ar |
| CHOST=${cross} clang-setup-env |
| fi |
| # Use ld.lld instead of ${cross}-ld.lld, ${cross}-ld.lld has userspace |
| # specific options. Linux kernel already specifies the type by "-m <type>". |
| # It also matches upstream (https://github.com/ClangBuiltLinux) and |
| # Android usage. |
| local linker=$(usex lld "ld.lld" "${cross}-ld.bfd") |
| |
| # Linux kernel can't be built with gold linker. Explicitly use bfd linker |
| # when invoked through compiler and LLD is not used. |
| local linker_arg="" |
| if ! use lld; then |
| linker_arg="-fuse-ld=bfd" |
| fi |
| |
| # BUILD_CC, BUILD_CXX come from an eclass that shellcheck won't see. |
| # shellcheck disable=SC2154 |
| set -- \ |
| LD="${linker}" \ |
| LD_COMPAT="${LD_COMPAT}" \ |
| OBJCOPY="${OBJCOPY}" \ |
| REAL_STRIP="${STRIP}" \ |
| STRIP="${STRIP}" \ |
| NM="${NM}" \ |
| AR="${AR}" \ |
| CC="${CC} ${linker_arg}" \ |
| CC_COMPAT="${CC_COMPAT}" \ |
| CXX="${CXX} ${linker_arg}" \ |
| HOSTCC="${BUILD_CC}" \ |
| HOSTCXX="${BUILD_CXX}" \ |
| HOSTPKG_CONFIG="${BUILD_PKG_CONFIG}" \ |
| HOSTLD="${BUILD_LD}" \ |
| "$@" |
| |
| # The kernel Makefile allows this optionally set from the environment, |
| # so we do too. |
| # shellcheck disable=SC2154,SC2153 |
| local kcflags="${KCFLAGS}" |
| local afdo_filename afdo_option |
| if use clang; then |
| afdo_filename="${WORKDIR}/${AFDO_GCOV_EXTBINARY}" |
| afdo_option="profile-sample-use" |
| else |
| afdo_filename="${WORKDIR}/${AFDO_GCOV}" |
| afdo_option="auto-profile" |
| fi |
| use kernel_afdo && kcflags+=" -f${afdo_option}=${afdo_filename}" |
| |
| local indirect_branch_options_v1=( |
| "-mindirect-branch=thunk" |
| "-mindirect-branch-loop=pause" |
| "-fno-jump-tables" |
| ) |
| local indirect_branch_options_v2=( |
| "-mindirect-branch=thunk" |
| "-mindirect-branch-register" |
| ) |
| |
| # Indirect branch options only available for Intel GCC and clang. |
| if use x86 || use amd64; then |
| # The kernel will set required compiler options if it supports |
| # the RETPOLINE configuration option and it is enabled. |
| # Otherwise set supported compiler options here to get a basic |
| # level of protection. |
| if ! cros_chkconfig_present RETPOLINE; then |
| if use clang; then |
| kcflags+=" $(test-flags-CC -mretpoline)" |
| else |
| if cc_option "${indirect_branch_options_v1[@]}"; then |
| kcflags+=" ${indirect_branch_options_v1[*]}" |
| elif cc_option "${indirect_branch_options_v2[@]}"; then |
| kcflags+=" ${indirect_branch_options_v2[*]}" |
| fi |
| fi |
| fi |
| fi |
| |
| # LLVM needs this to parse perf.data. |
| # See AutoFDO README for details: https://github.com/google/autofdo |
| use clang && kcflags+=" -fdebug-info-for-profiling " |
| |
| # The kernel doesn't use CFLAGS and doesn't expect it to be passed |
| # in. Let's be explicit that it won't do anything by unsetting CFLAGS. |
| # |
| # In general the kernel manages its own tools flags and doesn't expect |
| # someone external to pass flags in unless those flags have been |
| # very specifically tailored to interact well with the kernel Makefiles. |
| # In that case we pass in flags with KCFLAGS which is documented to be |
| # not a full set of flags but as "additional" flags. In general the |
| # kernel Makefiles carefully adjust their flags in various |
| # sub-directories to get the needed result. The kernel has CONFIG_ |
| # options for adjusting compiler flags and self-adjusts itself |
| # depending on whether it detects clang or not. |
| # |
| # In the same spirit, let's also unset LDFLAGS. While (in some cases) |
| # the kernel will build upon LDFLAGS passed in from the environment it |
| # makes sense to just let the kernel be like we do for the rest of the |
| # flags. |
| unset CFLAGS |
| unset LDFLAGS |
| |
| local kernel_warning_level="" |
| if use kernel_warning_level_1; then |
| kernel_warning_level+=1 |
| fi |
| if use kernel_warning_level_2; then |
| kernel_warning_level+=2 |
| fi |
| if use kernel_warning_level_3; then |
| kernel_warning_level+=3 |
| fi |
| if [[ -n "${kernel_warning_level}" ]]; then |
| kernel_warning_level="W=${kernel_warning_level}" |
| fi |
| |
| local sparse="" |
| if use sparse; then |
| sparse="C=1" |
| fi |
| |
| ARCH=${kernel_arch} \ |
| CROSS_COMPILE="${cross}-" \ |
| CROSS_COMPILE_COMPAT="${cross_compat}" \ |
| KCFLAGS="${kcflags}" \ |
| emake \ |
| V="${VERBOSE:-0}" \ |
| O="$(cros-workon_get_build_dir)" \ |
| ${kernel_warning_level} \ |
| ${sparse} \ |
| "$@" |
| } |
| |
| cros-kernel2_src_unpack() { |
| # Force in-tree builds if private patches may have to be applied. |
| if [[ "${PV}" != "9999" ]] || use apply_patches; then |
| CROS_WORKON_OUTOFTREE_BUILD=0 |
| fi |
| |
| cros-workon_src_unpack |
| if use kern_arm_afdo; then |
| # Use the Arm profile version. |
| AFDO_VERSION="${ARM_AFDO_VERSION}" |
| AFDO_GCOV="${ARM_AFDO_GCOV}" |
| AFDO_GCOV_EXTBINARY="${ARM_AFDO_GCOV_EXTBINARY}" |
| fi |
| if use kernel_afdo && [[ -z "${AFDO_VERSION}" ]]; then |
| if use kern_arm_afdo; then |
| PROF_VER="ARM_AFDO_PROFILE_VERSION" |
| AFDO_FLAG="kern_arm_afdo" |
| else |
| PROF_VER="AFDO_PROFILE_VERSION" |
| AFDO_FLAG="kernel_afdo" |
| fi |
| eerror "${PROF_VER} is required in .ebuild by ${AFDO_FLAG}." |
| die |
| fi |
| |
| pushd "${WORKDIR}" >/dev/null || die |
| if use kernel_afdo; then |
| unpack "${AFDO_GCOV}.xz" |
| |
| # Compressed binary profiles are lazily loaded, so they save a |
| # meaningful amount of CPU and memory per clang invocation. They're |
| # only available with clang. |
| if use clang; then |
| llvm-profdata merge \ |
| -sample \ |
| --extbinary \ |
| -output="${AFDO_GCOV_EXTBINARY}" \ |
| "${AFDO_GCOV}" || die |
| fi |
| fi |
| popd >/dev/null || die |
| } |
| |
| cros-kernel2_src_prepare() { |
| if [[ "${PV}" != "9999" ]] || use apply_patches; then |
| apply_private_patches |
| fi |
| if ! use clang; then |
| if use frozen_gcc; then |
| cros_use_frozen_gcc |
| else |
| cros_use_gcc |
| fi |
| fi |
| |
| # Allow use of GNU tools for configs not using llvm tools. |
| if ! use lld || ! use llvm_ias; then |
| cros_allow_gnu_build_tools |
| fi |
| |
| if [[ ${CROS_WORKON_INCREMENTAL_BUILD} != "1" ]]; then |
| mkdir -p "$(cros-workon_get_build_dir)" |
| fi |
| |
| default |
| } |
| |
| cros-kernel2_src_configure() { |
| # The kernel controls its own optimization settings, so this would be a nop |
| # if we were to run it. Leave it here anyway as a grep-friendly marker. |
| # cros_optimize_package_for_speed |
| |
| # Use a single or split kernel config as specified in the board or variant |
| # make.conf overlay. Default to the arch specific split config if an |
| # overlay or variant does not set either CHROMEOS_KERNEL_CONFIG or |
| # CHROMEOS_KERNEL_SPLITCONFIG. CHROMEOS_KERNEL_CONFIG is set relative |
| # to the root of the kernel source tree. |
| local config |
| local cfgarch="$(get_build_arch)" |
| local build_cfg="$(get_build_cfg)" |
| |
| if use frozen_gcc; then |
| unset LD_PRELOAD |
| export SANDBOX_ON=0 |
| fi |
| |
| if use buildtest; then |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| kmake allmodconfig |
| case ${kernel_arch} in |
| arm) |
| # Big endian builds fail with endianness mismatch errors. |
| # See crbug.com/772028 for details. |
| sed -i -e 's/CONFIG_CPU_BIG_ENDIAN=y/# CONFIG_CPU_BIG_ENDIAN is not set/' "${build_cfg}" |
| ;; |
| esac |
| # Disable CONFIG_FORTIFY_SOURCE for buildtest. See b/265129193. |
| sed -i -e 's/CONFIG_FORTIFY_SOURCE=y/# CONFIG_FORTIFY_SOURCE is not set/' "${build_cfg}" |
| kmake olddefconfig |
| return 0 |
| fi |
| |
| if [ -n "${CHROMEOS_KERNEL_CONFIG}" ]; then |
| case ${CHROMEOS_KERNEL_CONFIG} in |
| /*) |
| config="${CHROMEOS_KERNEL_CONFIG}" |
| ;; |
| *) |
| config="${S}/${CHROMEOS_KERNEL_CONFIG}" |
| ;; |
| esac |
| else |
| config=${CHROMEOS_KERNEL_SPLITCONFIG:-"chromiumos-${cfgarch}"} |
| fi |
| |
| elog "Using kernel config: ${config}" |
| |
| if [ -n "${CHROMEOS_KERNEL_CONFIG}" ]; then |
| cp -f "${config}" "${build_cfg}" || die |
| else |
| if [ -e chromeos/scripts/prepareconfig ] ; then |
| local kernel_family=$(_get_kernel_family) |
| einfo "Using family: ${kernel_family}" |
| CHROMEOS_KERNEL_FAMILY="${kernel_family}" chromeos/scripts/prepareconfig \ |
| "${config}" "${build_cfg}" || die |
| else |
| config="$(eclass_dir)/${cfgarch}_defconfig" |
| ewarn "Can't prepareconfig, falling back to default " \ |
| "${config}" |
| cp "${config}" "${build_cfg}" || die |
| # Allow usage of GNU binutils in this case. It mostly happens in a |
| # developer local build where they are using the ebuild to build |
| # kernel with any upstream kernel hash. |
| cros_allow_gnu_build_tools |
| fi |
| fi |
| |
| if ! use disable_kernel_fragments; then |
| local fragment |
| for fragment in "${CONFIG_FRAGMENTS[@]}"; do |
| local config="${fragment}_config" |
| local status |
| |
| if [[ ${!config+set} != "set" ]]; then |
| die "'${fragment}' listed in CONFIG_FRAGMENTS, but ${config} is not set up" |
| fi |
| |
| if use "${fragment}"; then |
| status="enabling" |
| else |
| config="${fragment}_config_disable" |
| status="disabling" |
| if [[ -z "${!config}" ]]; then |
| continue |
| fi |
| fi |
| |
| local msg="${fragment}_desc" |
| elog " - ${status} ${!msg} config" |
| local warning="${fragment}_warning" |
| local warning_msg="${!warning}" |
| if [[ -n "${warning_msg}" ]] ; then |
| ewarn "${warning_msg}" |
| fi |
| |
| echo "${!config//%ROOT%/${SYSROOT}}" >> "${build_cfg}" || die |
| done |
| fi |
| |
| local -a builtin_fw |
| for fragment in "${FIRMWARE_BINARIES[@]}"; do |
| local files="${fragment}_files[@]" |
| |
| if [[ ${!files+set} != "set" ]]; then |
| die "'${fragment}' listed in FIRMWARE_BINARIES, but ${files} is not set up" |
| fi |
| |
| if use "${fragment}"; then |
| local msg="${fragment}_desc" |
| elog " - Embedding ${!msg} firmware" |
| builtin_fw+=( "${!files}" ) |
| fi |
| done |
| |
| if [[ ${#builtin_fw[@]} -gt 0 ]]; then |
| echo "${extra_fw_config}" | \ |
| sed -e "s|%ROOT%|${SYSROOT}|g" -e "s|%FW%|${builtin_fw[*]}|g" \ |
| >> "${build_cfg}" || die |
| fi |
| |
| # If the old config is unchanged restore it. This allows us to keep |
| # the old timestamp which will avoid regenerating stuff that hasn't |
| # actually changed. Note that we compare against the non-normalized |
| # config to avoid an extra call to "kmake olddefconfig" in the common |
| # case. |
| # |
| # If the old config changed, we'll normalize the new one and stash |
| # both the non-normalized and normalized versions for next time. |
| |
| local old_config="$(cros-workon_get_build_dir)/cros-old-config" |
| local old_defconfig="$(cros-workon_get_build_dir)/cros-old-defconfig" |
| local old_hash="$(cros-workon_get_build_dir)/cros-old-hash" |
| |
| if [[ -e "${old_config}" && -e "${old_defconfig}" && \ |
| -e "${old_hash}" && \ |
| "$(git rev-parse HEAD 2>/dev/null)" == $(<"${old_hash}") ]] && \ |
| cmp -s "${build_cfg}" "${old_config}"; then |
| cp -a "${old_defconfig}" "${build_cfg}" || die |
| else |
| cp -a "${build_cfg}" "${old_config}" || die |
| |
| # Use default for options not explicitly set in splitconfig. |
| kmake olddefconfig |
| |
| cp -a "${build_cfg}" "${old_defconfig}" || die |
| |
| # This is not fatal and happens if source is not a git tree |
| git rev-parse HEAD >"${old_hash}" 2>/dev/null |
| fi |
| } |
| |
| # @FUNCTION: get_dtb_name |
| # @USAGE: <dtb_dir> |
| # @DESCRIPTION: |
| # Get the name(s) of the device tree binary file(s) to include. |
| |
| get_dtb_name() { |
| local dtb_dir=${1} |
| local dtb_glob="*.dtb" |
| local result |
| |
| if ! use dt_choose_all && [[ -n "${CHROMEOS_DTBS}" ]]; then |
| dtb_glob="${CHROMEOS_DTBS}" |
| fi |
| |
| # Add sort to stabilize the dtb ordering. |
| result="$(find "${dtb_dir}" -name "${dtb_glob}" | LC_COLLATE=C sort)" |
| |
| if [[ -z "${result}" ]]; then |
| die "Found no dtb files matching glob ${dtb_glob} in ${dtb_dir}" |
| fi |
| |
| echo "${result}" |
| } |
| |
| gen_compilation_database() { |
| local build_dir="$(cros-workon_get_build_dir)" |
| local src_dir="${build_dir}/source" |
| local db_chroot="${build_dir}/compile_commands_chroot.json" |
| local script="gen_compile_commands.py" |
| |
| # gen_compile_commands.py has been moved into scripts/clang-tools/ |
| # since v5.9 kernel. |
| if [[ -f "${src_dir}/scripts/${script}" ]]; then |
| "${src_dir}/scripts/${script}" \ |
| -d "${build_dir}" -o "${db_chroot}" || die |
| elif [[ -f "${src_dir}/scripts/clang-tools/${script}" ]]; then |
| "${src_dir}/scripts/clang-tools/${script}" \ |
| -d "${build_dir}" -o "${db_chroot}" || die |
| else |
| die "Cannot find ${script}" |
| fi |
| |
| # Make relative include paths absolute. |
| sed -i -e "s:-I\./:-I${build_dir}/:g" "${db_chroot}" || die |
| |
| # shellcheck disable=SC2154 |
| local ext_chroot_path="${EXTERNAL_TRUNK_PATH}/chroot" |
| local in_chroot_path="$(readlink -f "${src_dir}")" |
| local ext_src_path="${EXTERNAL_TRUNK_PATH}/${in_chroot_path#/mnt/host/source/}" |
| |
| # Generate non-chroot version of the DB with the following |
| # changes: |
| # |
| # 1. translate file and directory paths |
| # 2. call clang directly instead of using CrOS wrappers |
| # 3. use standard clang target triples |
| # 4. remove a few compiler options that might not be available |
| # in the potentially older clang version outside the chroot |
| # |
| sed -E -e "s:/mnt/host/source/:${EXTERNAL_TRUNK_PATH}/:g" \ |
| -e "s:\"${src_dir}:\"${ext_src_path}:g" \ |
| -e "s:-I/build/:-I${ext_chroot_path}/build/:g" \ |
| -e "s:\"/build/:\"${ext_chroot_path}/build/:g" \ |
| -e "s:-isystem /:-isystem ${ext_chroot_path}/:g" \ |
| \ |
| -e "s:[a-z0-9_]+-(cros|pc)-linux-gnu([a-z]*)?-clang:clang:g" \ |
| \ |
| -e "s:([a-z0-9_]+)-cros-linux-gnu:\1-linux-gnu:g" \ |
| \ |
| -e "s:-fdebug-info-for-profiling::g" \ |
| -e "s:-mretpoline::g" \ |
| -e "s:-mretpoline-external-thunk::g" \ |
| -e "s:-mfentry::g" \ |
| \ |
| "${db_chroot}" \ |
| > "${build_dir}/compile_commands_no_chroot.json" || or die |
| |
| echo \ |
| "compile_commands_*.json are compilation databases for the Linux kernel. The |
| files can be used by tools that support the commonly used JSON compilation |
| database format. |
| |
| To use the compilation database with an IDE or other tools outside of the |
| chroot create a symlink named 'compile_commands.json' in the kernel source |
| directory (outside of the chroot) to compile_commands_no_chroot.json." \ |
| > "${build_dir}/compile_commands.txt" || die |
| } |
| |
| _cros-kernel2_compile() { |
| local build_targets |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| case ${kernel_arch} in |
| arm) |
| if use device_tree; then |
| build_targets=( "zImage" "dtbs" ) |
| else |
| build_targets=( "uImage" ) |
| fi |
| use boot_dts_device_tree && build_targets+=( "dtbs" ) |
| ;; |
| arm64) |
| build_targets=( |
| "Image" "dtbs" |
| ) |
| ;; |
| mips) |
| build_targets=( |
| vmlinuz.bin |
| ) |
| use device_tree && build_targets+=( "dtbs" ) |
| ;; |
| *) |
| build_targets=( |
| all |
| ) |
| ;; |
| esac |
| |
| cros_chkconfig_present MODULES && build_targets+=( "modules" ) |
| |
| # Some older kernels don't have a scripts_gdb target, so we want this |
| # to be an empty array, not an array with an empty string in it. |
| # shellcheck disable=SC2207 |
| use kgdb && build_targets+=( $(sed -nE 's/^(scripts_gdb):.*$/\1/p' Makefile) ) |
| |
| # If a .dts file is deleted from the source code it won't disappear |
| # from the output in the next incremental build. Nuke all dtbs so we |
| # don't include stale files. We use 'find' to handle old and new |
| # locations (see comments in install below). |
| local arch_dir="$(cros-workon_get_build_dir)/arch" |
| [[ -d "${arch_dir}" ]] && find "${arch_dir}" -name '*.dtb' -delete |
| |
| kmake -k "${build_targets[@]}" |
| |
| if use compilation_database; then |
| gen_compilation_database |
| fi |
| } |
| |
| cros-kernel2_src_compile() { |
| local old_config="$(cros-workon_get_build_dir)/cros-old-config" |
| local old_defconfig="$(cros-workon_get_build_dir)/cros-old-defconfig" |
| local build_cfg="$(get_build_cfg)" |
| # (b/206056057) Disable SANDBOX and LD_PRELOAD for frozen gcc. |
| if use frozen_gcc; then |
| unset LD_PRELOAD |
| export SANDBOX_ON=0 |
| fi |
| |
| # Some users of cros-kernel2 touch the config after |
| # cros-kernel2_src_configure finishes. Detect that and remove |
| # the old configs we were saving to speed up the next |
| # incremental build. These users of cros-kernel2 will be |
| # slower but they will still work OK. |
| if ! cmp -s "${build_cfg}" "${old_defconfig}"; then |
| ewarn "Slowing build speed because ebuild touched config." |
| rm -f "${old_config}" "${old_defconfig}" || die |
| fi |
| |
| _cros-kernel2_compile |
| |
| # If Kconfig files have changed since we last did a compile then the |
| # .config file that we passed in the kernel might not have been in |
| # perfect form. In general we only generate / make defconfig in |
| # cros-kernel2_src_configure() if we see that our config changed (we |
| # don't detect Kconfig changes). |
| # |
| # It's _probably_ fine that we just built the kernel like this because |
| # the kernel detects this case, falls into a slow path, and then |
| # noisily does a defconfig. However, there is a very small chance that |
| # the results here will be unexpected. Specifically if you're jumping |
| # between very different kernels and you're using an underspecified |
| # config (like the fallback config), it's possible the results will be |
| # wrong. AKA if you start with the raw config, then make a defconfig |
| # with kernel A, then use that defconfig w/ kernel B to generate a new |
| # defconfig, you could end up with a different result than if you |
| # sent the raw config straight to kernel B. |
| # |
| # Let's be paranoid and keep things safe. We'll detect if we got |
| # it wrong and in that case compile the kernel a 2nd time. |
| |
| # Check if defconfig is different after the kernel build finished. |
| if [[ -e "${old_defconfig}" ]] && \ |
| ! cmp -s "${build_cfg}" "${old_defconfig}"; then |
| # We'll stash what the kernel came up with as a defconfig. |
| cp -a "${build_cfg}" "${old_defconfig}" || die |
| |
| # Re-create a new defconfig from the stashed raw config. |
| cp -a "${old_config}" "${build_cfg}" || die |
| kmake olddefconfig |
| |
| # If the newly generated defconfig is different from what |
| # the kernel came up with then do a recompile. |
| if ! cmp -s "${build_cfg}" "${old_defconfig}"; then |
| ewarn "Detected Kconfig change; redo with olddefconfig" |
| |
| cp -a "${build_cfg}" "${old_defconfig}" || die |
| _cros-kernel2_compile |
| fi |
| fi |
| } |
| |
| # @FUNCTION: cros-kernel2_src_install |
| # @USAGE: [install_prefix] |
| # @DESCRIPTION: |
| # install the kernel to the system at ${D}${install_prefix}. |
| cros-kernel2_src_install() { |
| if use firmware_install; then |
| die "The firmware_install USE flag is dead." |
| fi |
| |
| if use buildtest ; then |
| ewarn "Skipping install for buildtest" |
| return 0 |
| fi |
| |
| local install_prefix=${1} |
| local install_dir="${D}${install_prefix}" |
| |
| if use kernel_sources && [[ -n "${install_prefix}" ]]; then |
| die "The install_prefix option is not supported with USE kernel_sources flag." |
| fi |
| |
| dodir "${install_prefix}/boot" |
| kmake INSTALL_MOD_PATH="${install_dir}" INSTALL_PATH="${install_dir}/boot" install |
| |
| if use device_tree; then |
| _cros-kernel2_compress_fit_kernel \ |
| "$(cros-workon_get_build_dir)" & |
| fi |
| |
| local version=$(kernelrelease) |
| |
| if cros_chkconfig_present MODULES; then |
| kmake INSTALL_MOD_PATH="${install_dir}" INSTALL_MOD_STRIP="magic" \ |
| STRIP="$(eclass_dir)/strip_splitdebug" \ |
| modules_install |
| dostrip -x "${install_prefix}/lib/modules/${version}/kernel/" \ |
| "${install_prefix}/usr/lib/debug/lib/modules/" |
| fi |
| |
| local kernel_arch=${CHROMEOS_KERNEL_ARCH:-$(tc-arch-kernel)} |
| local kernel_bin="${install_dir}/boot/vmlinuz-${version}" |
| |
| # We might have compressed in background; wait for it now. |
| wait |
| |
| if use arm || use arm64 || use mips; then |
| local kernel_dir="$(cros-workon_get_build_dir)" |
| local boot_dir="${kernel_dir}/arch/${kernel_arch}/boot" |
| local zimage_bin="${install_dir}/boot/zImage-${version}" |
| local image_bin="${install_dir}/boot/Image-${version}" |
| local dtb_dir="${boot_dir}" |
| |
| # Newer kernels (after linux-next 12/3/12) put dtbs in the dts |
| # dir. Use that if we we find no dtbs directly in boot_dir. |
| # Note that we try boot_dir first since the newer kernel will |
| # actually rm ${boot_dir}/*.dtb so we'll have no stale files. |
| if ! ls "${dtb_dir}"/*.dtb &> /dev/null; then |
| dtb_dir="${boot_dir}/dts" |
| fi |
| |
| if use device_tree; then |
| local its_script="${kernel_dir}/its_script" |
| # get_dtb_name() produces a line-separated list, and we *want* to |
| # split on whitespace for _cros-kernel2_emit_its_script(). These |
| # are simple filenames, so this should be OK. |
| # shellcheck disable=SC2046 |
| _cros-kernel2_emit_its_script "${its_script}" \ |
| "${kernel_dir}" $(get_dtb_name "${dtb_dir}") |
| mkimage -D "-I dts -O dtb -p 2048" -f "${its_script}" \ |
| "${kernel_bin}" || die |
| elif [[ "${kernel_arch}" == "arm" ]]; then |
| cp "${boot_dir}/uImage" "${kernel_bin}" || die |
| if use boot_dts_device_tree; then |
| # For boards where the device tree .dtb file is stored |
| # under /boot/dts, loaded into memory, and then |
| # passed on the 'bootm' command line, make sure they're |
| # all installed. |
| # |
| # We install more .dtb files than we need, but it's |
| # less work than a hard-coded list that gets out of |
| # date. |
| # |
| # TODO(jrbarnette): Really, this should use a |
| # FIT image, same as other boards. |
| insinto "${install_prefix}/boot/dts" |
| doins "${dtb_dir}"/*.dtb |
| fi |
| fi |
| case ${kernel_arch} in |
| arm) |
| cp -a "${boot_dir}/zImage" "${zimage_bin}" || die |
| ;; |
| arm64) |
| cp -a "${boot_dir}/Image" "${image_bin}" || die |
| ;; |
| esac |
| fi |
| if use arm || use arm64 || use mips; then |
| pushd "$(dirname "${kernel_bin}")" >/dev/null || die |
| case ${kernel_arch} in |
| arm) |
| ln -sf "$(basename "${zimage_bin}")" zImage || die |
| ;; |
| esac |
| popd >/dev/null || die |
| fi |
| if [ ! -e "${install_dir}/boot/vmlinuz" ]; then |
| ln -sf "vmlinuz-${version}" "${install_dir}/boot/vmlinuz" || die |
| fi |
| |
| # Check the size of kernel image and issue warning when image size is near |
| # the limit. For netboot initramfs, we don't care about kernel |
| # size limit as the image is downloaded over network. |
| local kernel_image_size=$(stat -c '%s' -L "${install_dir}"/boot/vmlinuz) |
| einfo "Kernel image size is ${kernel_image_size} bytes." |
| |
| # Install uncompressed kernel for debugging purposes. |
| insinto "${install_prefix}/usr/lib/debug/boot" |
| newins "$(cros-workon_get_build_dir)/vmlinux" vmlinux.debug |
| dostrip -x "${install_prefix}/usr/lib/debug/boot/vmlinux.debug" \ |
| "${install_prefix}/usr/src/" |
| # Be nice to scripts expecting vmlinux. |
| ln -s vmlinux.debug "${install_dir}/usr/lib/debug/boot/vmlinux" || die |
| |
| if use kgdb && [[ -d "$(cros-workon_get_build_dir)/scripts/gdb" ]]; then |
| insinto "${install_prefix}/usr/lib/debug/boot/" |
| doins "$(readlink -f \ |
| "$(cros-workon_get_build_dir)/vmlinux-gdb.py")" |
| # Match vmlinux symlink to vmlinux.debug. |
| ln -s vmlinux-gdb.py \ |
| "${install_dir}"/usr/lib/debug/boot/vmlinux.debug-gdb.py || die |
| mkdir "${install_dir}"/usr/lib/debug/boot/scripts || die |
| rsync -rKLp --chmod=a+r \ |
| --include='*/' --include='*.py' --exclude='*' \ |
| "$(cros-workon_get_build_dir)/scripts/gdb/" \ |
| "${install_dir}"/usr/lib/debug/boot/scripts/gdb || die |
| fi |
| |
| # Also install the vdso shared ELFs for crash reporting. |
| # We use slightly funky filenames so as to better integrate with |
| # debugging processes (crash reporter/gdb/etc...). The basename |
| # will be the SONAME (what the runtime process sees), but since |
| # that is not unique among all inputs, we also install into a dir |
| # with the original filename. e.g. we will install: |
| # /lib/modules/3.8.11/vdso/vdso32-syscall.so/linux-gate.so |
| if use x86 || use amd64; then |
| local vdso_dir d f soname |
| vdso_dir="$(cros-workon_get_build_dir)/arch/x86/vdso" |
| if [[ ! -d ${vdso_dir} ]]; then |
| # Use new path with newer (>= v4.2-rc1) kernels |
| vdso_dir="$(cros-workon_get_build_dir)/arch/x86/entry/vdso" |
| fi |
| [[ -d ${vdso_dir} ]] || die "could not find x86 vDSO dir" |
| |
| # Use the debug versions (.so.dbg) so portage can run splitdebug on them. |
| for f in "${vdso_dir}"/vdso*.so.dbg; do |
| d="${install_prefix}/lib/modules/${version}/vdso/${f##*/}" |
| |
| exeinto "${d}" |
| newexe "${f}" "linux-gate.so" |
| |
| soname=$(scanelf -qF'%S#f' "${f}") |
| dosym "linux-gate.so" "${d}/${soname}" |
| done |
| elif [[ "${kernel_arch}" == "arm64" ]]; then |
| local vdso_dir d f soname |
| vdso_dir="$(cros-workon_get_build_dir)/arch/arm64/kernel/vdso" |
| [[ -d ${vdso_dir} ]] || die "could not find arm64 vDSO dir" |
| |
| # Use the debug versions (.so.dbg) so portage can run splitdebug on them. |
| for f in "${vdso_dir}"*/vdso*.so.dbg; do |
| d="${install_prefix}/lib/modules/${version}/vdso${f#*vdso}" |
| d="${d%/*}" |
| |
| exeinto "${d}" |
| newexe "${f}" "linux-gate.so" |
| |
| soname=$(scanelf -qF'%S#f' "${f}") |
| dosym "linux-gate.so" "${d}/${soname}" |
| done |
| fi |
| |
| if use kernel_sources; then |
| install_kernel_sources |
| else |
| dosym "$(cros-workon_get_build_dir)" "${install_prefix}/usr/src/linux" |
| fi |
| |
| if use compilation_database; then |
| insinto "${install_prefix}/build/kernel" |
| einfo "Installing kernel compilation databases. |
| To use the compilation database with an IDE or other tools outside of the |
| chroot create a symlink named 'compile_commands.json' in the kernel source |
| directory (outside of the chroot) to compile_commands_no_chroot.json." |
| doins "$(cros-workon_get_build_dir)"/compile_commands_*.json |
| doins "$(cros-workon_get_build_dir)"/compile_commands.txt |
| fi |
| |
| if use kernel_afdo_verify; then |
| # Deliver the profile we just verified. The upload artifacts |
| # step in the builder will collect the (now verified) AFDO |
| # profile from here. |
| insinto "${install_prefix}/usr/lib/debug/boot" |
| doins "${DISTDIR}/${AFDO_GCOV}.xz" |
| fi |
| } |
| |
| EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install |