diff --git a/PKGBUILD b/PKGBUILD index 3efa3f278c1a..954f13097c1b 100644 --- a/PKGBUILD +++ b/PKGBUILD @@ -1,4 +1,6 @@ -# Maintainer: Peter Jung ptr1337 && Piotr Gorski +# Maintainer: Peter Jung ptr1337 +# Maintainer: Piotr Gorski +# Maintainer: Vasiliy Stelmachenok # Contributor: Jan Alexander Steffens (heftig) # Contributor: Tobias Powalowski # Contributor: Thomas Baechler @@ -10,22 +12,16 @@ _cachy_config=${_cachy_config-y} ### Selecting the CPU scheduler -# ATTENTION - one of six predefined values should be selected! -# 'bmq' - select 'BitMap Queue CPU scheduler' -# 'pds' - select 'Priority and Deadline based Skip list multiple queue CPU scheduler' +# ATTENTION - only one of the following values can be selected: # 'bore' - select 'Burst-Oriented Response Enhancer' -# 'cfs' - select 'Completely Fair Scheduler' -# 'tt' - select 'Task Type Scheduler by Hamad Marri' +# 'bmq' - select 'BMQ Scheduler' # 'hardened' - select 'BORE Scheduler hardened' ## kernel with hardened config and hardening patches with the bore scheduler -# 'cachyos' - select 'EEVDF-BORE Variant Scheduler' EEVDF includes latency nice -# 'eevdf' - select 'EEVDF Scheduler' EEVDF includes latency nice -# 'rt' - select CFS, but includes a series of realtime patches +# 'cachyos' - select 'CachyOS Default Scheduler (BORE)' +# 'eevdf' - select 'EEVDF Scheduler' +# 'rt' - select EEVDF, but includes a series of realtime patches +# 'rt-bore' - select Burst-Oriented Response Enhancer, but includes a series of realtime patches _cpusched=${_cpusched-bmq} -## Apply some suggested sysctl values from the bore developer -## These are adjusted to BORE -_tune_bore=${_tune_bore-} - ### Tweak kernel options prior to a build via nconfig _makenconfig=${_makenconfig-} @@ -41,7 +37,8 @@ _makegconfig=${_makegconfig-} # NUMA is optimized for multi-socket motherboards. # A single multi-core CPU actually runs slower with NUMA enabled. # See, https://bugs.archlinux.org/task/31187 -_NUMAdisable=${_NUMAdisable-y} +# It seems that in 2023 this is not really a huge regression anymore +_NUMAdisable=${_NUMAdisable-} # Compile ONLY used modules to VASTLYreduce the number of modules built # and the build time. @@ -53,6 +50,9 @@ _NUMAdisable=${_NUMAdisable-y} # More at this wiki page ---> https://wiki.archlinux.org/index.php/Modprobed-db _localmodcfg=${_localmodcfg-} +# Path to the list of used modules +_localmodcfg_path=${_localmodcfg_path-"$HOME/.config/modprobed.db"} + # Use the current kernel's .config file # Enabling this option will use the .config of the RUNNING kernel rather than # the ARCH defaults. Useful when the package gets updated and you already went @@ -63,20 +63,13 @@ _use_current=${_use_current-} ### Enable KBUILD_CFLAGS -O3 _cc_harder=${_cc_harder-y} -### Enable KBUILD_CFLAGS -Os -## DO NOT SET, THIS IS FOR INTERNAL CI USE ONLY. -_cc_size=${_cc_size-} - -### Set this to your number of threads you have in your machine otherwise it will default to 128 -_nr_cpus=${_nr_cpus-} - ### Set performance governor as default _per_gov=${_per_gov-} ### Enable TCP_CONG_BBR3 -_tcp_bbr3=${_tcp_bbr3-y} +_tcp_bbr3=${_tcp_bbr3-} -### Running with a 1000HZ, 750Hz, 600 Hz, 500Hz, 300Hz, 250Hz and 100Hz tick rate +### Running with a 1000HZ, 750Hz, 625Hz, 600 Hz, 500Hz, 300Hz, 250Hz and 100Hz tick rate _HZ_ticks=${_HZ_ticks-1000} ## Choose between perodic, idle or full @@ -86,20 +79,6 @@ _tickrate=${_tickrate-full} ## Choose between full(low-latency), voluntary or server _preempt=${_preempt-full} -### Enable multigenerational LRU -# ATTENTION - one of three predefined values should be selected! -# 'standard' - enable multigenerational LRU -# 'stats' - enable multigenerational LRU with stats -# 'none' - disable multigenerational LRU -_lru_config=${_lru_config-standard} - -### Enable per-VMA locking -# ATTENTION - one of three predefined values should be selected! -# 'standard' - enable per-VMA locking -# 'stats' - enable per-VMA locking with stats -# 'none' - disable per-VMA locking -_vma_config=${_vma_config-standard} - ### Transparent Hugepages # ATTENTION - one of two predefined values should be selected! # 'always' - always enable THP @@ -108,28 +87,19 @@ _vma_config=${_vma_config-standard} # https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/performance_tuning_guide/sect-red_hat_enterprise_linux-performance_tuning_guide-configuring_transparent_huge_pages _hugepage=${_hugepage-always} -## Enable DAMON -_damon=${_damon-} - -## Enable Linux Random Number Generator -_lrng_enable=${_lrng_enable-} - # CPU compiler optimizations - Defaults to prompt at kernel config if left empty -# AMD CPUs : "k8" "k8sse3" "k10" "barcelona" "bobcat" "jaguar" "bulldozer" "piledriver" "steamroller" "excavator" "zen" "zen2" "zen3" +# AMD CPUs : "k8" "k8sse3" "k10" "barcelona" "bobcat" "jaguar" "bulldozer" "piledriver" "steamroller" "excavator" "zen" "zen2" "zen3" "zen4" # Intel CPUs : "mpsc"(P4 & older Netburst based Xeon) "atom" "core2" "nehalem" "westmere" "silvermont" "sandybridge" "ivybridge" "haswell" "broadwell" "skylake" "skylakex" "cannonlake" "icelake" "goldmont" "goldmontplus" "cascadelake" "cooperlake" "tigerlake" "sapphirerapids" "rocketlake" "alderlake" # Other options : # - "native_amd" (use compiler autodetection - Selecting your arch manually in the list above is recommended instead of this option) # - "native_intel" (use compiler autodetection and will prompt for P6_NOPS - Selecting your arch manually in the list above is recommended instead of this option) # - "generic" (kernel's default - to share the package between machines with different CPU µarch as long as they are x86-64) # -# Or use the _use_auto_optimization with _use_auto_optimization=y _processor_opt=${_processor_opt-} +# This does automatically detect your supported CPU and optimizes for it _use_auto_optimization=${_use_auto_optimization-y} -# disable debug to lower the size of the kernel -_disable_debug=${_disable_debug-} - # Clang LTO mode, only available with the "llvm" compiler - options are "none", "full" or "thin". # ATTENTION - one of three predefined values should be selected! # "full: uses 1 thread for Linking, slow and uses more memory, theoretically with the highest performance gains." @@ -139,16 +109,20 @@ _use_llvm_lto=${_use_llvm_lto-none} # Use suffix -lto only when requested by the user # Enabled by default. -# If you do not want the suffix -lto remove the "y" sign next to the flag. +# y - enable -lto suffix +# n - disable -lto suffix # https://github.com/CachyOS/linux-cachyos/issues/36 _use_lto_suffix=${_use_lto_suffix-y} +# Use suffix -gcc when requested by the user +# This was added to facilitate https://github.com/CachyOS/linux-cachyos/issues/286 +_use_gcc_suffix=${_use_gcc_suffix-} + # KCFI is a proposed forward-edge control-flow integrity scheme for # Clang, which is more suitable for kernel use than the existing CFI # scheme used by CONFIG_CFI_CLANG. kCFI doesn't require LTO, doesn't # alter function references to point to a jump table, and won't break # function address equality. -# ATTENTION!: kCFI is only available in llvm 16 _use_kcfi=${_use_kcfi-} # Build the zfs module in to the kernel @@ -160,19 +134,31 @@ _build_zfs=${_build_zfs-} # This does replace the requirement of nvidia-dkms _build_nvidia=${_build_nvidia-} -# Enable bcachefs -_bcachefs=${_bcachefs-} +# Builds the open nvidia module and package it into a own base +# This does replace the requirement of nvidia-open-dkms +# Use this only if you have Turing+ GPU +_build_nvidia_open=${_build_nvidia_open-} -if [[ "$_use_llvm_lto" = "thin" || "$_use_llvm_lto" = "full" ]] && [ -n "$_use_lto_suffix" ]; then - pkgsuffix=cachyos-${_cpusched}-lto - pkgbase=linux-$pkgsuffix +# Build a debug package with non-stripped vmlinux +_build_debug=${_build_debug-} +# ATTENTION: Do not modify after this line +_is_lto_kernel() { + [[ "$_use_llvm_lto" = "thin" || "$_use_llvm_lto" = "full" ]] + return $? +} + +if _is_lto_kernel && [ "$_use_lto_suffix" = "y" ]; then + _pkgsuffix="cachyos-${_cpusched}-lto" +elif ! _is_lto_kernel && [ "$_use_gcc_suffix" = "y" ]; then + _pkgsuffix="cachyos-${_cpusched}-gcc" else - pkgsuffix=cachyos-${_cpusched} - pkgbase=linux-$pkgsuffix + _pkgsuffix="cachyos-${_cpusched}" fi -_major=6.5 -_minor=9 + +pkgbase="linux-$_pkgsuffix" +_major=6.12 +_minor=7 #_minorc=$((_minor+1)) #_rcver=rc8 pkgver=${_major}.${_minor} @@ -181,17 +167,41 @@ _stable=${_major}.${_minor} #_stablerc=${_major}-${_rcver} _srcname=linux-${_stable} #_srcname=linux-${_major} -pkgdesc='Linux BMQ scheduler Kernel by CachyOS with other patches and improvements' -pkgrel=2 -_kernver=$pkgver-$pkgrel -arch=('x86_64' 'x86_64_v3') +pkgdesc='Linux BORE + Cachy Sauce scheduler Kernel by CachyOS with other patches and improvements' +pkgrel=1 +_kernver="$pkgver-$pkgrel" +_kernuname="${pkgver}-${_pkgsuffix}" +arch=('x86_64') url="https://github.com/CachyOS/linux-cachyos" -license=('GPL2') -options=('!strip') -makedepends=('bc' 'libelf' 'pahole' 'cpio' 'perl' 'tar' 'xz' 'zstd' 'gcc' 'gcc-libs' 'glibc' 'binutils' 'make' 'patch' 'python') +license=('GPL-2.0-only') +options=('!strip' '!debug' '!lto') +makedepends=( + bc + cpio + gettext + libelf + pahole + perl + python + tar + xz + zstd +) + +_patchsource="https://raw.githubusercontent.com/cachyos/kernel-patches/master/${_major}" +_nv_ver=565.77 +_nv_pkg="NVIDIA-Linux-x86_64-${_nv_ver}" +_nv_open_pkg="open-gpu-kernel-modules-${_nv_ver}" +source=( + "https://cdn.kernel.org/pub/linux/kernel/v${pkgver%%.*}.x/${_srcname}.tar.xz" + "config" + "auto-cpu-optimization.sh" + "${_patchsource}/all/0001-cachyos-base-all.patch") + # LLVM makedepends -if [[ "$_use_llvm_lto" = "thin" || "$_use_llvm_lto" = "full" ]] || [ -n "$_use_kcfi" ]; then +if _is_lto_kernel; then makedepends+=(clang llvm lld) + source+=("${_patchsource}/misc/dkms-clang.patch") BUILD_FLAGS=( CC=clang LD=ld.lld @@ -199,67 +209,55 @@ if [[ "$_use_llvm_lto" = "thin" || "$_use_llvm_lto" = "full" ]] || [ -n "$_use_k LLVM_IAS=1 ) fi -_patchsource="https://raw.githubusercontent.com/cachyos/kernel-patches/master/${_major}" -_nv_ver=545.29.02 -_nv_pkg="NVIDIA-Linux-x86_64-${_nv_ver}" -source=( - "https://cdn.kernel.org/pub/linux/kernel/v${pkgver%%.*}.x/${_srcname}.tar.xz" - "config" - "auto-cpu-optimization.sh" - "${_patchsource}/all/0001-cachyos-base-all.patch") + +# WARNING The ZFS module doesn't build with selected RT sched due to licensing issues. +if [[ "$_cpusched" = "rt" || "$_cpusched" = "rt-bore" ]]; then + unset _build_zfs +fi # ZFS support if [ -n "$_build_zfs" ]; then makedepends+=(git) - source+=("git+https://github.com/cachyos/zfs.git#commit=95785196f26e92d82cf4445654ba84e4a9671c57") + source+=("git+https://github.com/cachyos/zfs.git#commit=e65f69e41f4a276d7d0d1800a2878308a0ba84a6") fi # NVIDIA pre-build module support if [ -n "$_build_nvidia" ]; then - source+=("https://us.download.nvidia.com/XFree86/Linux-x86_64/${_nv_ver}/${_nv_pkg}.run") + source+=("https://us.download.nvidia.com/XFree86/Linux-x86_64/${_nv_ver}/${_nv_pkg}.run" + "${_patchsource}/misc/nvidia/0001-Make-modeset-and-fbdev-default-enabled.patch") fi +if [ -n "$_build_nvidia_open" ]; then + source+=("nvidia-open-${_nv_ver}.tar.gz::https://github.com/NVIDIA/open-gpu-kernel-modules/archive/refs/tags/${_nv_ver}.tar.gz" + "${_patchsource}/misc/nvidia/0001-Make-modeset-and-fbdev-default-enabled.patch" + "${_patchsource}/misc/nvidia/0002-Do-not-error-on-unkown-CPU-Type-and-add-Zen5-support.patch" + "${_patchsource}/misc/nvidia/0003-Add-IBT-Support.patch" + "${_patchsource}/misc/nvidia/0004-silence-event-assert-until-570.patch" + "${_patchsource}/misc/nvidia/0005-nvkms-Sanitize-trim-ELD-product-name-strings.patch") +fi + +## List of CachyOS schedulers case "$_cpusched" in - cachyos) # CachyOS Scheduler (EEVDF + BORE) - source+=("${_patchsource}/sched/0001-EEVDF-cachy.patch" - "${_patchsource}/sched/0001-bore-eevdf.patch");; - eevdf) # EEVDF Scheduler - source+=("${_patchsource}/sched/0001-EEVDF-cachy.patch" - "${_patchsource}/misc/0001-eevdf-Disable-DELAY_DEQUEUE.patch");; - pds|bmq) # BMQ/PDS scheduler - source+=("${_patchsource}/sched/0001-prjc-cachy.patch" - linux-cachyos-prjc.install);; - tt) ## TT Scheduler - source+=("${_patchsource}/sched/0001-tt-cachy.patch");; - bore) ## BORE Scheduler - [ -n "$_tune_bore" ] && source+=("${_patchsource}/misc/0001-bore-tuning-sysctl.patch") - source+=("${_patchsource}/sched/0001-bore-cachy.patch");; - rt) ## CFS with RT patches - source+=("${_patchsource}/misc/0001-rt.patch" - linux-cachyos-rt.install);; - hardened) ## Hardened Patches with BORE Scheduler - source+=("${_patchsource}/sched/0001-bore-cachy.patch" - "${_patchsource}/misc/0001-hardened.patch");; + cachyos|bore|rt-bore|hardened) # CachyOS Scheduler (BORE) + source+=("${_patchsource}/sched/0001-bore-cachy.patch");;& + bmq) ## Project C Scheduler + source+=("${_patchsource}/sched/0001-prjc-cachy.patch");; + hardened) ## Hardened Patches + source+=("${_patchsource}/misc/0001-hardened.patch");; + rt) ## EEVDF with RT patches + source+=("${_patchsource}/misc/0001-rt.patch");; + rt-bore) ## RT with BORE Scheduler + source+=("${_patchsource}/misc/0001-rt.patch");; esac -## bcachefs Support -if [ -n "$_bcachefs" ]; then - source+=("${_patchsource}/misc/0001-bcachefs.patch") -fi -## lrng patchset -if [ -n "$_lrng_enable" ]; then - source+=("${_patchsource}/misc/0001-lrng.patch") -fi - export KBUILD_BUILD_HOST=cachyos -export KBUILD_BUILD_USER=$pkgbase +export KBUILD_BUILD_USER="$pkgbase" export KBUILD_BUILD_TIMESTAMP="$(date -Ru${SOURCE_DATE_EPOCH:+d @$SOURCE_DATE_EPOCH})" -_die() { error "$@" ; exit; } +_die() { error "$@" ; exit 1; } prepare() { - - cd ${srcdir}/$_srcname + cd "$_srcname" echo "Setting version..." echo "-$pkgrel" > localversion.10-pkgrel @@ -268,6 +266,8 @@ prepare() { local src for src in "${source[@]}"; do src="${src%%::*}" + # Skip nvidia patches + [[ "$src" == "${_patchsource}"/misc/nvidia/*.patch ]] && continue src="${src##*/}" src="${src%.zst}" [[ $src = *.patch ]] || continue @@ -281,9 +281,16 @@ prepare() { ### Select CPU optimization if [ -n "$_processor_opt" ]; then MARCH="${_processor_opt^^}" - MARCH2=M${MARCH} - scripts/config -k -d CONFIG_GENERIC_CPU - scripts/config -k -e CONFIG_${MARCH2} + + if [ "$MARCH" != "GENERIC" ]; then + if [[ "$MARCH" =~ GENERIC_V[1-4] ]]; then + X86_64_LEVEL="${MARCH//GENERIC_V}" + scripts/config --set-val X86_64_VERSION "${X86_64_LEVEL}" + else + scripts/config -k -d CONFIG_GENERIC_CPU + scripts/config -k -e "CONFIG_M${MARCH}" + fi + fi fi ### Use autooptimization @@ -291,12 +298,6 @@ prepare() { "${srcdir}"/auto-cpu-optimization.sh fi - ### Prevent ZFS and bcachefs building at the same time - # More infos here: https://github.com/CachyOS/linux-cachyos/issues/152 - if [[ -n "$_bcachefs" && -n "$_build_zfs" ]]; then - _die "ZFS and bcachefs support cannot be built at the same time. " - fi - ### Selecting CachyOS config if [ -n "$_cachy_config" ]; then echo "Enabling CachyOS config..." @@ -307,12 +308,11 @@ prepare() { [ -z "$_cpusched" ] && _die "The value is empty. Choose the correct one again." case "$_cpusched" in - pds) scripts/config -e SCHED_ALT -d SCHED_BMQ -e SCHED_PDS -e PSI_DEFAULT_DISABLED;; - bmq) scripts/config -e SCHED_ALT -e SCHED_BMQ -d SCHED_PDS -e PSI_DEFAULT_DISABLED;; - tt) scripts/config -e TT_SCHED -e TT_ACCOUNTING_STATS;; - bore|hardened|cachyos) scripts/config -e SCHED_BORE;; - cfs|eevdf) ;; - rt) scripts/config -e PREEMPT_COUNT -e PREEMPTION -d PREEMPT_VOLUNTARY -d PREEMPT -d PREEMPT_NONE -e PREEMPT_RT -e PREEMPT_LAZY -d PREEMPT_DYNAMIC -e HAVE_PREEMPT_LAZY -d PREEMPT_BUILD;; + cachyos|bore|hardened) scripts/config -e SCHED_BORE;; + bmq) scripts/config -e SCHED_ALT -e SCHED_BMQ;; + eevdf) ;; + rt) scripts/config -d PREEMPT -d PREEMPT_DYNAMIC -e PREEMPT_RT;; + rt-bore) scripts/config -e SCHED_BORE -d PREEMPT -d PREEMPT_DYNAMIC -e PREEMPT_RT;; *) _die "The value $_cpusched is invalid. Choose the correct one again.";; esac @@ -321,8 +321,7 @@ prepare() { ### Enable KCFI if [ -n "$_use_kcfi" ]; then echo "Enabling kCFI" - scripts/config -e ARCH_SUPPORTS_CFI_CLANG \ - -e CFI_CLANG + scripts/config -e ARCH_SUPPORTS_CFI_CLANG -e CFI_CLANG -e CFI_AUTO_DEFAULT fi ### Select LLVM level @@ -338,10 +337,10 @@ prepare() { echo "Selecting '$_use_llvm_lto' LLVM level..." ### Select tick rate - [ -z $_HZ_ticks ] && _die "The value is empty. Choose the correct one again." + [ -z "$_HZ_ticks" ] && _die "The value is empty. Choose the correct one again." case "$_HZ_ticks" in - 100|250|500|600|750|1000) + 100|250|500|600|625|750|1000) scripts/config -d HZ_300 -e "HZ_${_HZ_ticks}" --set-val HZ "${_HZ_ticks}";; 300) scripts/config -e HZ_300 --set-val HZ 300;; @@ -369,17 +368,6 @@ prepare() { -d NUMA_BALANCING_DEFAULT_ENABLED fi - ### Setting NR_CPUS - if [[ "$_nr_cpus" -ge 2 && "$_nr_cpus" -le 512 ]]; then - echo "Setting custom NR_CPUS..." - scripts/config --set-val NR_CPUS "$_nr_cpus" - elif [ -z "$_nr_cpus" ]; then - echo "Setting default NR_CPUS..." - scripts/config --set-val NR_CPUS 320 - else - _die "The value '$_nr_cpus' is invalid. Please select a numerical value from 2 to 512..." - fi - ### Select performance governor if [ -n "$_per_gov" ]; then echo "Setting performance governor..." @@ -402,7 +390,7 @@ prepare() { ### Select preempt type # We should not set up the PREEMPT for RT kernels - if [ "$_cpusched" != "rt" ]; then + if [[ "$_cpusched" != "rt" || "$_cpusched" != "rt-bore" ]]; then [ -z "$_preempt" ] && _die "The value is empty. Choose the correct one again." case "$_preempt" in @@ -422,11 +410,20 @@ prepare() { -e CC_OPTIMIZE_FOR_PERFORMANCE_O3 fi - ### Enable Os - if [ -n "$_cc_size" ] && [ -z "$_cc_harder" ]; then - echo "Enabling KBUILD_CFLAGS -Os..." + ### CI-only stuff + if [[ -n "$CI" || -n "$GITHUB_RUN_ID" ]]; then + echo "Detected build inside CI" scripts/config -d CC_OPTIMIZE_FOR_PERFORMANCE \ - -e CONFIG_CC_OPTIMIZE_FOR_SIZE + -d CC_OPTIMIZE_FOR_PERFORMANCE_O3 \ + -e CONFIG_CC_OPTIMIZE_FOR_SIZE \ + -d SLUB_DEBUG \ + -d PM_DEBUG \ + -d PM_ADVANCED_DEBUG \ + -d PM_SLEEP_DEBUG \ + -d ACPI_DEBUG \ + -d LATENCYTOP \ + -d SCHED_DEBUG \ + -d DEBUG_PREEMPT fi ### Enable bbr3 @@ -436,41 +433,13 @@ prepare() { -d DEFAULT_CUBIC \ -e TCP_CONG_BBR \ -e DEFAULT_BBR \ - --set-str DEFAULT_TCP_CONG bbr - - # BBR3 doesn't work properly with FQ_CODEL - echo "Disabling fq_codel by default..." - scripts/config -m NET_SCH_FQ_CODEL \ + --set-str DEFAULT_TCP_CONG bbr \ + -m NET_SCH_FQ_CODEL \ -e NET_SCH_FQ \ - -d DEFAULT_FQ_CODEL \ - -e DEFAULT_FQ \ - --set-str DEFAULT_NET_SCH fq + -d CONFIG_DEFAULT_FQ_CODEL \ + -e CONFIG_DEFAULT_FQ fi - ### Select LRU config - [ -z "$_lru_config" ] && _die "The value is empty. Choose the correct one again." - - case "$_lru_config" in - standard) scripts/config -e LRU_GEN -e LRU_GEN_ENABLED -d LRU_GEN_STATS;; - stats) scripts/config -e LRU_GEN -e LRU_GEN_ENABLED -e LRU_GEN_STATS;; - none) scripts/config -d LRU_GEN;; - *) _die "The value '$_lru_config' is invalid. Choose the correct one again.";; - esac - - echo "Selecting '$_lru_config' LRU_GEN config..." - - ### Select VMA config - [ -z "$_vma_config" ] && _die "The value is empty. Choose the correct one again." - - case "$_vma_config" in - standard) scripts/config -e PER_VMA_LOCK -d PER_VMA_LOCK_STATS;; - stats) scripts/config -e PER_VMA_LOCK -e PER_VMA_LOCK_STATS;; - none) scripts/config -d PER_VMA_LOCK;; - *) _die "The value '$_vma_config' is invalid. Choose the correct one again.";; - esac - - echo "Selecting '$_vma_config' PER_VMA_LOCK config..." - ### Select THP [ -z "$_hugepage" ] && _die "The value is empty. Choose the correct one again." @@ -482,110 +451,6 @@ prepare() { echo "Selecting '$_hugepage' TRANSPARENT_HUGEPAGE config..." - ### Enable DAMON - if [ -n "$_damon" ]; then - echo "Enabling DAMON..." - scripts/config -e DAMON \ - -e DAMON_VADDR \ - -e DAMON_DBGFS \ - -e DAMON_SYSFS \ - -e DAMON_PADDR \ - -e DAMON_RECLAIM \ - -e DAMON_LRU_SORT - fi - - ### Enable LRNG - if [ -n "$_lrng_enable" ]; then - echo "Enabling Linux Random Number Generator ..." - scripts/config -d RANDOM_DEFAULT_IMPL \ - -e LRNG \ - -e LRNG_SHA256 \ - -e LRNG_COMMON_DEV_IF \ - -e LRNG_DRNG_ATOMIC \ - -e LRNG_SYSCTL \ - -e LRNG_RANDOM_IF \ - -e LRNG_AIS2031_NTG1_SEEDING_STRATEGY \ - -m LRNG_KCAPI_IF \ - -m LRNG_HWRAND_IF \ - -e LRNG_DEV_IF \ - -e LRNG_RUNTIME_ES_CONFIG \ - -e LRNG_IRQ_DFLT_TIMER_ES \ - -d LRNG_SCHED_DFLT_TIMER_ES \ - -e LRNG_TIMER_COMMON \ - -d LRNG_COLLECTION_SIZE_256 \ - -d LRNG_COLLECTION_SIZE_512 \ - -e LRNG_COLLECTION_SIZE_1024 \ - -d LRNG_COLLECTION_SIZE_2048 \ - -d LRNG_COLLECTION_SIZE_4096 \ - -d LRNG_COLLECTION_SIZE_8192 \ - --set-val LRNG_COLLECTION_SIZE 1024 \ - -e LRNG_HEALTH_TESTS \ - --set-val LRNG_RCT_CUTOFF 31 \ - --set-val LRNG_APT_CUTOFF 325 \ - -e LRNG_IRQ \ - -e LRNG_CONTINUOUS_COMPRESSION_ENABLED \ - -d LRNG_CONTINUOUS_COMPRESSION_DISABLED \ - -e LRNG_ENABLE_CONTINUOUS_COMPRESSION \ - -e LRNG_SWITCHABLE_CONTINUOUS_COMPRESSION \ - --set-val LRNG_IRQ_ENTROPY_RATE 256 \ - -e LRNG_JENT \ - --set-val LRNG_JENT_ENTROPY_RATE 16 \ - -e LRNG_CPU \ - --set-val LRNG_CPU_FULL_ENT_MULTIPLIER 1 \ - --set-val LRNG_CPU_ENTROPY_RATE 8 \ - -e LRNG_SCHED \ - --set-val LRNG_SCHED_ENTROPY_RATE 4294967295 \ - -e LRNG_DRNG_CHACHA20 \ - -m LRNG_DRBG \ - -m LRNG_DRNG_KCAPI \ - -e LRNG_SWITCH \ - -e LRNG_SWITCH_HASH \ - -m LRNG_HASH_KCAPI \ - -e LRNG_SWITCH_DRNG \ - -m LRNG_SWITCH_DRBG \ - -m LRNG_SWITCH_DRNG_KCAPI \ - -e LRNG_DFLT_DRNG_CHACHA20 \ - -d LRNG_DFLT_DRNG_DRBG \ - -d LRNG_DFLT_DRNG_KCAPI \ - -e LRNG_TESTING_MENU \ - -d LRNG_RAW_HIRES_ENTROPY \ - -d LRNG_RAW_JIFFIES_ENTROPY \ - -d LRNG_RAW_IRQ_ENTROPY \ - -d LRNG_RAW_RETIP_ENTROPY \ - -d LRNG_RAW_REGS_ENTROPY \ - -d LRNG_RAW_ARRAY \ - -d LRNG_IRQ_PERF \ - -d LRNG_RAW_SCHED_HIRES_ENTROPY \ - -d LRNG_RAW_SCHED_PID_ENTROPY \ - -d LRNG_RAW_SCHED_START_TIME_ENTROPY \ - -d LRNG_RAW_SCHED_NVCSW_ENTROPY \ - -d LRNG_SCHED_PERF \ - -d LRNG_ACVT_HASH \ - -d LRNG_RUNTIME_MAX_WO_RESEED_CONFIG \ - -d LRNG_TEST_CPU_ES_COMPRESSION \ - -e LRNG_SELFTEST \ - -d LRNG_SELFTEST_PANIC \ - -d LRNG_RUNTIME_FORCE_SEEDING_DISABLE - fi - - ### Disable DEBUG - if [ -n "$_disable_debug" ]; then - scripts/config -d DEBUG_INFO \ - -d DEBUG_INFO_BTF \ - -d DEBUG_INFO_DWARF4 \ - -d DEBUG_INFO_DWARF5 \ - -d PAHOLE_HAS_SPLIT_BTF \ - -d DEBUG_INFO_BTF_MODULES \ - -d SLUB_DEBUG \ - -d PM_DEBUG \ - -d PM_ADVANCED_DEBUG \ - -d PM_SLEEP_DEBUG \ - -d ACPI_DEBUG \ - -d SCHED_DEBUG \ - -d LATENCYTOP \ - -d DEBUG_PREEMPT - fi - echo "Enable USER_NS_UNPRIVILEGED" scripts/config -e USER_NS @@ -608,19 +473,18 @@ prepare() { ### Optionally load needed modules for the make localmodconfig # See https://aur.archlinux.org/packages/modprobed-db if [ -n "$_localmodcfg" ]; then - if [ -e $HOME/.config/modprobed.db ]; then + if [ -e "$_localmodcfg_path" ]; then echo "Running Steven Rostedt's make localmodconfig now" - make ${BUILD_FLAGS[*]} LSMOD=$HOME/.config/modprobed.db localmodconfig + make "${BUILD_FLAGS[@]}" LSMOD="${_localmodcfg_path}" localmodconfig else - echo "No modprobed.db data found" - exit + _die "No modprobed.db data found" fi fi ### Rewrite configuration echo "Rewrite configuration..." - make ${BUILD_FLAGS[*]} prepare - yes "" | make ${BUILD_FLAGS[*]} config >/dev/null + make "${BUILD_FLAGS[@]}" prepare + yes "" | make "${BUILD_FLAGS[@]}" config >/dev/null diff -u ../config .config || : ### Prepared version @@ -628,41 +492,65 @@ prepare() { echo "Prepared $pkgbase version $( "${startdir}/config-${pkgver}-${pkgrel}${pkgbase#linux}" + local basedir="$(dirname "$(readlink "${srcdir}/config")")" + cat .config > "${basedir}/config-${pkgver}-${pkgrel}${pkgbase#linux}" if [ -n "$_build_nvidia" ]; then cd "${srcdir}" sh "${_nv_pkg}.run" --extract-only + + # Use fbdev and modeset as default + patch -Np1 -i "${srcdir}/0001-Make-modeset-and-fbdev-default-enabled.patch" -d "${srcdir}/${_nv_pkg}/kernel" + fi + + if [ -n "$_build_nvidia_open" ]; then + patch -Np1 -i "${srcdir}/0001-Make-modeset-and-fbdev-default-enabled.patch" -d "${srcdir}/${_nv_open_pkg}/kernel-open" + # Fix for Zen5 error print in dmesg + patch -Np1 --no-backup-if-mismatch -i "${srcdir}/0002-Do-not-error-on-unkown-CPU-Type-and-add-Zen5-support.patch" -d "${srcdir}/${_nv_open_pkg}" + # Fix for https://bugs.archlinux.org/task/74886 + patch -Np1 --no-backup-if-mismatch -i "${srcdir}/0003-Add-IBT-Support.patch" -d "${srcdir}/${_nv_open_pkg}" + # Fix for CS2 dmesg spam + patch -Np1 --no-backup-if-mismatch -i "${srcdir}/0004-silence-event-assert-until-570.patch" -d "${srcdir}/${_nv_open_pkg}" + # Fix for HDMI names + patch -Np1 --no-backup-if-mismatch -i "${srcdir}/0005-nvkms-Sanitize-trim-ELD-product-name-strings.patch" -d "${srcdir}/${_nv_open_pkg}" fi } build() { - cd ${srcdir}/${_srcname} - make ${BUILD_FLAGS[*]} -j$(nproc) all + cd "$_srcname" + make "${BUILD_FLAGS[@]}" -j"$(nproc)" all + make -C tools/bpf/bpftool vmlinux.h feature-clang-bpf-co-re=1 + local MODULE_FLAGS=( + KERNEL_UNAME="${_kernuname}" + IGNORE_PREEMPT_RT_PRESENCE=1 + SYSSRC="${srcdir}/${_srcname}" + SYSOUT="${srcdir}/${_srcname}" + ) if [ -n "$_build_nvidia" ]; then + MODULE_FLAGS+=(NV_EXCLUDE_BUILD_MODULES='__EXCLUDE_MODULES') cd "${srcdir}/${_nv_pkg}/kernel" - local MODULE_FLAGS=( - KERNEL_UNAME="${pkgver}-${pkgsuffix}" - IGNORE_PREEMPT_RT_PRESENCE=1 - NV_EXCLUDE_BUILD_MODULES='__EXCLUDE_MODULES' - SYSSRC="${srcdir}/${_srcname}" - SYSOUT="${srcdir}/${_srcname}" - ) - make ${BUILD_FLAGS[*]} ${MODULE_FLAGS[*]} -j$(nproc) modules + make "${BUILD_FLAGS[@]}" "${MODULE_FLAGS[@]}" -j"$(nproc)" modules + + fi + + if [ -n "$_build_nvidia_open" ]; then + cd "${srcdir}/${_nv_open_pkg}" + MODULE_FLAGS+=(IGNORE_CC_MISMATCH=yes) + CFLAGS= CXXFLAGS= LDFLAGS= make "${BUILD_FLAGS[@]}" "${MODULE_FLAGS[@]}" -j"$(nproc)" modules fi if [ -n "$_build_zfs" ]; then @@ -672,13 +560,14 @@ build() { [ "$_use_llvm_lto" != "none" ] && CONFIGURE_FLAGS+=("KERNEL_LLVM=1") ./autogen.sh - sed -i "s|\$(uname -r)|${pkgver}-${pkgsuffix}|g" configure - ./configure ${CONFIGURE_FLAGS[*]} --prefix=/usr --sysconfdir=/etc --sbindir=/usr/bin \ + sed -i "s|\$(uname -r)|${_kernuname}|g" configure + ./configure "${CONFIGURE_FLAGS[@]}" --prefix=/usr --sysconfdir=/etc --sbindir=/usr/bin \ --libdir=/usr/lib --datadir=/usr/share --includedir=/usr/include \ --with-udevdir=/lib/udev --libexecdir=/usr/lib/zfs --with-config=kernel \ - --with-linux=${srcdir}/$_srcname - make ${BUILD_FLAGS[*]} + --with-linux="${srcdir}/$_srcname" + make "${BUILD_FLAGS[@]}" fi + } _package() { @@ -687,10 +576,10 @@ _package() { optdepends=('wireless-regdb: to set the correct wireless channels of your country' 'linux-firmware: firmware images needed for some devices' 'modprobed-db: Keeps track of EVERY kernel module that has ever been probed - useful for those of us who make localmodconfig' - 'uksmd: Userspace KSM helper daemon') - provides=(VIRTUALBOX-GUEST-MODULES WIREGUARD-MODULE KSMBD-MODULE UKSMD-BUILTIN) + 'scx-scheds: to use sched-ext schedulers') + provides=(VIRTUALBOX-GUEST-MODULES WIREGUARD-MODULE KSMBD-MODULE UKSMD-BUILTIN NTSYNC-MODULE) - cd ${srcdir}/$_srcname + cd "$_srcname" local modulesdir="$pkgdir/usr/lib/modules/$( 1) M486SX : Select this for an 486-class CPU without an FPU such as AMD/Cyrix/IBM/Intel SL/SLC/SLC2/SLC3/SX/SX2 and UMC U5S.\n \ - > 2) M486 : Select this for an 486-class CPU such as AMD/Cyrix/IBM/Intel 486DX/DX2/DX4 and UMC U5D.\n \ - > 3) M586 : Select this for an 586 or 686 series processor such as the AMD K5,the Cyrix 5x86, 6x86 and 6x86MX. This choice does not assume the RDTSC (Read Time Stamp Counter) instruction.\n \ - > 4) M586TSC : Select this for a Pentium Classic processor with the RDTSC (Read Time Stamp Counter) instruction for benchmarking.\n \ - > 5) M586MMX : Select this for a Pentium with the MMX graphics/multimedia extended instructions.\n \ - > 6) M686 : Select this for Intel Pentium Pro chips.\n \ - > 7) MPENTIUMII : Select this for Intel chips based on the Pentium-II and pre-Coppermine Celeron core.\n \ - > 8) MPENTIUMIII : Select this for Intel chips based on the Pentium-III and Celeron-Coppermine core.\n \ - > 9) MPENTIUMM : Select this for Intel Pentium M (not Pentium-4 M) notebook chips.\n \ - > 10) MPENTIUM4 : Select this for Intel Pentium 4 chips.\n \ - > 11) MK6 : Select this for an AMD K6-family processor.\n \ - > 12) MK7 : Select this for an AMD Athlon K7-family processor.\n \ - > 13) MK8 : Select this for an AMD Opteron or Athlon64 Hammer-family processor.\n \ - > 14) MK8SSE3 : Select this for improved AMD Opteron or Athlon64 Hammer-family processors.\n \ - > 15) MK10 : Select this for an AMD 61xx Eight-Core Magny-Cours, Athlon X2 7x50,Phenom X3/X4/II, Athlon II X2/X3/X4, or Turion II-family processor.\n \ - > 16) MBARCELONA : Select this for AMD Family 10h Barcelona processors.\n \ - > 17) MBOBCAT : Select this for AMD Family 14h Bobcat processors.\n \ - > 18) MJAGUAR : Select this for AMD Family 16h Jaguar processors.\n \ - > 19) MBULLDOZER : Select this for AMD Family 15h Bulldozer processors.\n \ - > 20) MPILEDRIVER : Select this for AMD Family 15h Piledriver processors.\n \ - > 21) MSTEAMROLLER : Select this for AMD Family 15h Steamroller processors.\n \ - > 22) MEXCAVATOR : Select this for AMD Family 15h Excavator processors.\n \ - > 23) MZEN : Select this for AMD Family 17h Zen processors.\n \ - > 24) MZEN2 : Select this for AMD Family 17h Zen 2 processors.\n \ - > 25) MZEN3 : Select this for AMD Family 19h Zen 3 processors. - GCC 10.3 required\n \ - > 26) MZEN4 : Select this for AMD Family 19h Zen 4 processors. - GCC 13.1 required\n \ - > 27) MCRUSOE : Select this for a Transmeta Crusoe processor.\n \ - > 28) MEFFICEON : Select this for a Transmeta Efficeon processor.\n \ - > 29) MWINCHIPC6 : Select this for an IDT Winchip C6 chip.\n \ - > 30) MWINCHIP3D : Select this for an IDT Winchip-2, 2A or 3.\n \ - > 31) MELAN : Select this for an AMD Elan processor.\n \ - > 32) MGEODEGX1 : Select this for a Geode GX1 (Cyrix MediaGX) chip.\n \ - > 33) MGEODE_LX Select this for AMD Geode GX and LX processors.\n \ - > 34) MCYRIXIII : Select this for a Cyrix III or C3 chip.\n \ - > 35) MVIAC3_2 : Select this for a VIA C3 "Nehemiah".\n \ - > 36) MVIAC7 : Select this for a VIA C7.\n \ - > 37) MPSC : Optimize for Intel Pentium 4, Pentium D and older Nocona/Dempsey Xeon CPUs with Intel 64bit which is compatible with x86-64.\n \ - > 38) MATOM : Select this for the Intel Atom platform.\n \ - > 39) MCORE2 : Select this for Intel Core 2 and newer Core 2 Xeons (Xeon 51xx and 53xx) CPUs.\n \ - > 40) MNEHALEM : Select this for 1st Gen Core processors in the Nehalem family.\n \ - > 41) MWESTMERE : Select this for the Intel Westmere formerly Nehalem-C family.\n \ - > 42) MSILVERMONT Select this for the Intel Silvermont platform.\n \ - > 43) MGOLDMONT : Select this for the Intel Goldmont platform including Apollo Lake and Denverton.\n \ - > 44) MGOLDMONTPLUS : Select this for the Intel Goldmont Plus platform including Gemini Lake.\n \ - > 45) MSANDYBRIDGE : Select this for 2nd Gen Core processors in the Sandy Bridge family.\n \ - > 46) MIVYBRIDGE : Select this for 3rd Gen Core processors in the Ivy Bridge family.\n \ - > 47) MHASWELL : Select this for 4th Gen Core processors in the Haswell family.\n \ - > 48) MBROADWELL : Select this for 5th Gen Core processors in the Broadwell family.\n \ - > 49) MSKYLAKE : Select this for 6th Gen Core processors in the Skylake family.\n \ - > 50) MSKYLAKEX : Select this for 6th Gen Core processors in the Skylake X family.\n \ - > 51) MCANNONLAKE : Select this for 8th Gen Core processors.\n \ - > 52) MICELAKE : Select this for 10th Gen Core processors in the Ice Lake family.\n \ - > 53) MCASCADELAKE : Select this for Xeon processors in the Cascade Lake family.\n \ - > 54) MCOOPERLAKE : Select this for Xeon processors in the Cooper Lake family. - GCC 10.1 required\n \ - > 55) MTIGERLAKE : Select this for third-generation 10 nm process processors in the Tiger Lake family. - GCC 10.1 required\n \ - > 56) MSAPPHIRERAPIDS : Select this for third-generation 10 nm process processors in the Sapphire Rapids family. - GCC 11 required\n \ - > 57) MALDERLAKE : Select this for twelfth-generation processors in the Alder Lake family.- GCC 11 required\n \ - > 58) MRAPTORLAKE : Select this for thirteenth-generation processors in the Raptor Lake family.- GCC 13 required\n \ - > 59) MMETORLAKE : Select this for fourteenth-generation processors in the Meteor Lake family.- GCC 13 required\n \ - > 60) GENERIC_CPU : Generic x86-64 CPU. Run equally well on all x86-64 CPUs.\n \ - > 61) GENERIC_CPU2 : Run equally well on all x86-64 CPUs with min support of x86-64-v2. - GCC 11 required\n \ - > 62) GENERIC_CPU3 : Generic x86-64-v3 CPU with v3 instructions. Run equally well on all x86-64 CPUs with min support of x86-64-v3. - GCC 11 required\n \ - > 63) GENERIC_CPU4 : Generic x86-64 CPU with v4 instructions. Run equally well on all x86-64 CPUs with min support of x86-64-v4. - GCC 11 required\n \ - > 64) MNATIVE_INTEL : Intel-Native optimizations autodetected by GCC.\n \ - > 65) MNATIVE_AMD : AMD-Native optimizations autodetected by GCC.\n \ - > Default (60 : Gneric CPU)\nchoice[0-65]: '`" _microarchitecture - - if [[ "$_microarchitecture" = "1" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M486 - elif [[ "$_microarchitecture" = "2" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M486 - elif [[ "$_microarchitecture" = "3" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M586 - elif [[ "$_microarchitecture" = "4" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M586TSC - elif [[ "$_microarchitecture" = "5" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M586MMX - elif [[ "$_microarchitecture" = "6" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_M686 - elif [[ "$_microarchitecture" = "7" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPENTIUMII - elif [[ "$_microarchitecture" = "8" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPENTIUMIII - elif [[ "$_microarchitecture" = "9" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPENTIUMM - elif [[ "$_microarchitecture" = "10" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPENTIUM4 - elif [[ "$_microarchitecture" = "11" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MK6 - elif [[ "$_microarchitecture" = "12" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MK7 - elif [[ "$_microarchitecture" = "13" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MK8 - elif [[ "$_microarchitecture" = "14" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MK8SSE3 - elif [[ "$_microarchitecture" = "15" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MK10 - elif [[ "$_microarchitecture" = "16" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MBARCELONA - elif [[ "$_microarchitecture" = "17" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MBOBCAT - elif [[ "$_microarchitecture" = "18" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MJAGUAR - elif [[ "$_microarchitecture" = "19" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MBULLDOZER - elif [[ "$_microarchitecture" = "20" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPILEDRIVER - elif [[ "$_microarchitecture" = "21" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSTEAMROLLER - elif [[ "$_microarchitecture" = "22" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MEXCAVATOR - elif [[ "$_microarchitecture" = "23" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MZEN - elif [[ "$_microarchitecture" = "24" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MZEN2 - elif [[ "$_microarchitecture" = "25" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MZEN3 - elif [[ "$_microarchitecture" = "26" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MZEN4 - elif [[ "$_microarchitecture" = "27" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCRUSOE - elif [[ "$_microarchitecture" = "28" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MEFFICEON - elif [[ "$_microarchitecture" = "29" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MWINCHIPC6 - elif [[ "$_microarchitecture" = "30" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MWINCHIP3D - elif [[ "$_microarchitecture" = "31" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MELAN - elif [[ "$_microarchitecture" = "32" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MGEODEGX1 - elif [[ "$_microarchitecture" = "33" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MGEODE_LX - elif [[ "$_microarchitecture" = "34" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCYRIXIII - elif [[ "$_microarchitecture" = "35" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MVIAC3_2 - elif [[ "$_microarchitecture" = "36" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MVIAC7 - elif [[ "$_microarchitecture" = "37" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MPSC - elif [[ "$_microarchitecture" = "38" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MATOM - elif [[ "$_microarchitecture" = "39" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCORE2 - elif [[ "$_microarchitecture" = "40" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MNEHALEM - elif [[ "$_microarchitecture" = "41" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MWESTMERE - elif [[ "$_microarchitecture" = "42" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSILVERMONT - elif [[ "$_microarchitecture" = "43" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MGOLDMONT - elif [[ "$_microarchitecture" = "44" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MGOLDMONTPLUS - elif [[ "$_microarchitecture" = "45" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSANDYBRIDGE - elif [[ "$_microarchitecture" = "46" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --disable CONFIG_AGP_AMD64 - scripts/config --disable CONFIG_MICROCODE_AMD - scripts/config --enable CONFIG_MIVYBRIDGE - elif [[ "$_microarchitecture" = "47" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MHASWELL - elif [[ "$_microarchitecture" = "48" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MBROADWELL - elif [[ "$_microarchitecture" = "49" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSKYLAKE - elif [[ "$_microarchitecture" = "50" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSKYLAKEX - elif [[ "$_microarchitecture" = "51" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCANNONLAKE - elif [[ "$_microarchitecture" = "52" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MICELAKE - elif [[ "$_microarchitecture" = "53" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCASCADELAKE - elif [[ "$_microarchitecture" = "54" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MCOOPERLAKE - elif [[ "$_microarchitecture" = "55" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MTIGERLAKE - elif [[ "$_microarchitecture" = "56" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MSAPPHIRERAPIDS - elif [[ "$_microarchitecture" = "57" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MALDERLAKE - elif [[ "$_microarchitecture" = "58" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MRAPTORLAKE - elif [[ "$_microarchitecture" = "59" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MMETORLAKE - elif [[ "$_microarchitecture" = "60" ]]; then - scripts/config --enable CONFIG_GENERIC_CPU - elif [[ "$_microarchitecture" = "61" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_GENERIC_CPU2 - elif [[ "$_microarchitecture" = "62" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_GENERIC_CPU3 - elif [[ "$_microarchitecture" = "63" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_GENERIC_CPU4 - elif [[ "$_microarchitecture" = "64" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MNATIVE_INTEL - elif [[ "$_microarchitecture" = "65" ]]; then - scripts/config --disable CONFIG_GENERIC_CPU - scripts/config --enable CONFIG_MNATIVE_AMD - else - scripts/config --enable CONFIG_GENERIC_CPU - fi - - plain "" - - sleep 2 -} diff --git a/linux-cachyos-prjc.install b/linux-cachyos-prjc.install deleted file mode 100644 index cd90471eaddf..000000000000 --- a/linux-cachyos-prjc.install +++ /dev/null @@ -1,16 +0,0 @@ -post_install() { - cat << EOF -You install the linux-cachyos kernel variant with the PDS/BMQ scheduler. -Please note that this scheduler can cause various performance and stability -issues (especially on AMD Ryzen CPUs) and we don't provide official -support for fixing them. If you encounter any problems while using the kernel, -please make sure that that it is not a BMQ or PDS specific problem before reporting it -to us, otherwise inform the Project C developer: - -https://gitlab.com/alfredchen/linux-prjc/-/issues -EOF -} - -post_upgrade() { - post_install -} diff --git a/linux-cachyos-rt.install b/linux-cachyos-rt.install deleted file mode 100644 index 5bf59d9cb5eb..000000000000 --- a/linux-cachyos-rt.install +++ /dev/null @@ -1,12 +0,0 @@ -post_install() { - cat << EOF -You install the linux-cachyos kernel variant with RT patches. - -Please make sure that you don't use the ZFS filesystem, as this kernel is not -compatible with it due to licensing issues. -EOF -} - -post_upgrade() { - post_install -}