Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
#!/bin/bash
ver54=72
ver57=19
ver58=16
ver59=1
2020-10-26 15:23:54 -05:00
ver510=rc1
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
_tkg_initscript() {
# Load external configuration file if present. Available variable values will overwrite customization.cfg ones.
if [ -e "$_EXT_CONFIG_PATH" ]; then
source "$_EXT_CONFIG_PATH" && msg2 "External configuration file $_EXT_CONFIG_PATH will be used to override customization.cfg values." && msg2 ""
fi
# create build dir early
if [ "$_distro" = "Void" ]; then
_path="${XBPS_BUILDDIR}/${wrksrc}"
else
_path="${_where}"
fi
if [ -z "$_version" ] && [ ! -e "$_path"/versel ]; then
plain "Which kernel version do you want to install?"
2020-10-26 15:59:27 -05:00
read -rp "`echo $' 1. 5.4 LTS\n 2. 5.7\n 3. 5.8\n > 4. 5.9\n 5. 5.10 RC\nchoice[1-5?]'`" _VERSEL;
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
case $_VERSEL in
2020-10-26 15:23:54 -05:00
"1")
echo "_basever=54" > "$_path"/versel
echo "_basekernel=5.4" >> "$_path"/versel
echo "_sub=${ver54}" >> "$_path"/versel
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
;;
2020-10-26 15:23:54 -05:00
"2")
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "_basever=57" > "$_path"/versel
echo "_basekernel=5.7" >> "$_path"/versel
echo "_sub=${ver57}" >> "$_path"/versel
;;
2020-10-26 15:23:54 -05:00
"3")
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "_basever=58" > "$_path"/versel
echo "_basekernel=5.8" >> "$_path"/versel
echo "_sub=${ver58}" >> "$_path"/versel
;;
2020-10-26 15:23:54 -05:00
"5")
echo "_basever=510" > "$_path"/versel
echo "_basekernel=5.10" >> "$_path"/versel
echo "_sub=${ver510}" >> "$_path"/versel
;;
*)
echo "_basever=59" > "$_path"/versel
echo "_basekernel=5.9" >> "$_path"/versel
echo "_sub=${ver59}" >> "$_path"/versel
;;
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
esac
elif [ -n "$_version" ];then
case "$_version" in
"5.4")
echo "_basever=54" > "$_path"/versel
echo "_basekernel=5.4" >> "$_path"/versel
echo "_sub=${ver54}" >> "$_path"/versel
;;
"5.7")
echo "_basever=57" > "$_path"/versel
echo "_basekernel=5.7" >> "$_path"/versel
echo "_sub=${ver57}" >> "$_path"/versel
;;
"5.8")
echo "_basever=58" > "$_path"/versel
echo "_basekernel=5.8" >> "$_path"/versel
echo "_sub=${ver58}" >> "$_path"/versel
;;
"5.9")
echo "_basever=59" > "$_path"/versel
echo "_basekernel=5.9" >> "$_path"/versel
echo "_sub=${ver59}" >> "$_path"/versel
;;
2020-10-26 15:23:54 -05:00
"5.10")
echo "_basever=510" > "$_path"/versel
echo "_basekernel=5.10" >> "$_path"/versel
echo "_sub=${ver510}" >> "$_path"/versel
;;
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
*)
error "There is something wrong with your kernel version selection, exiting..."
exit 1
esac
fi
# source versel early if present
if [ -e "${_path}"/versel ]; then
source "${_path}"/versel
fi
if [ "$_distro" != "Void" ]; then
cp "$_where"/linux-tkg-patches/${_basekernel}/* "$_where" # copy patches inside the PKGBUILD's dir to preserve makepkg sourcing and md5sum checking
cp "$_where"/linux-tkg-config/${_basekernel}/* "$_where" # copy config files and hooks inside the PKGBUILD's dir to preserve makepkg sourcing and md5sum checking
else
cp "$_where"/linux-tkg-patches/${_basekernel}/* "$_path"
cp "$_where"/linux-tkg-config/${_basekernel}/* "$_path"
fi
if [ -z "$_OPTIPROFILE" ] && [ ! -e "$_path"/cpuschedset ]; then
# Prompt about optimized configurations. Available variable values will overwrite customization.cfg/external config ones.
plain "Do you want to use a predefined optimized profile?"
read -rp "`echo $' > 1.Custom\n 2.Ryzen Desktop (Performance)\n 3.Other Desktop (Performance)\nchoice[1-3?]: '`" _OPTIPROFILE;
fi
if [ "$_OPTIPROFILE" = "2" ]; then
2020-10-26 17:36:18 -05:00
source "$_where"/linux-tkg-config/ryzen-desktop-profile.cfg && msg2 "Ryzen Desktop (Performance) profile will be used." && msg2 ""
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "$_OPTIPROFILE" = "3" ]; then
2020-10-26 17:36:18 -05:00
source "$_where"/linux-tkg-config/generic-desktop-profile.cfg && msg2 "Generic Desktop (Performance) profile will be used." && msg2 ""
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# source cpuschedset early if present
if [ -e "${_path}"/cpuschedset ]; then
source "${_path}"/cpuschedset
fi
# source compilerset early if present
if [ -e "${_path}"/compilerset ]; then
source "${_path}"/compilerset
fi
# CPU SCHED selector
if [ -z "$_cpusched" ] && [ ! -e "${_path}"/cpuschedset ]; then
plain "What CPU sched variant do you want to build/install?"
2020-10-26 16:27:14 -05:00
if [ "$_basever" = "54" ] || [ "$_basever" = "57" ]; then
prompt="`echo $' > 1.PDS\n 2.MuQSS\n 3.BMQ\n 4.CFS\nchoice[1-4?]: '`"
elif [ "$_basever" = "58" ]; then
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
prompt="`echo $' > 1.Undead PDS (TkG)\n 2.Project C / PDS\n 3.Project C / BMQ\n 4.CFS\nchoice[1-4?]: '`"
else
2020-10-26 16:27:14 -05:00
prompt="`echo $' > 1.Project C / PDS\n 2.Project C / BMQ\n 3.MuQSS\n 4.CFS\nchoice[1-4?]: '`"
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
read -rp "$prompt" CONDITION;
if [ "$CONDITION" = "2" ];then
2020-10-26 16:27:14 -05:00
if [ "$_basever" = "54" ] || [ "$_basever" = "57" ]; then
echo "_cpusched=\"MuQSS\"" > "${_path}"/cpuschedset
elif [ "$_basever" = "58" ]; then
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "_cpusched=\"pds\"" > "${_path}"/cpuschedset
2020-10-26 16:46:56 -05:00
else
2020-10-26 16:27:14 -05:00
echo "_cpusched=\"bmq\"" > "${_path}"/cpuschedset
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
elif [ "$CONDITION" = "3" ]; then
2020-10-26 16:27:14 -05:00
if [ "$_basever" = "54" ] || [ "$_basever" = "57" ] || [ "$_basever" = "58" ]; then
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "_cpusched=\"bmq\"" > "${_path}"/cpuschedset
2020-10-26 16:27:14 -05:00
else
echo "_cpusched=\"MuQSS\"" > "${_path}"/cpuschedset
fi
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "$CONDITION" = "4" ]; then
echo "_cpusched=\"cfs\"" > "${_path}"/cpuschedset
else
2020-10-26 16:27:14 -05:00
if [ "$_basever" = "58" ]; then
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "_cpusched=\"upds\"" > "${_path}"/cpuschedset
2020-10-26 16:27:14 -05:00
else
echo "_cpusched=\"pds\"" > "${_path}"/cpuschedset
fi
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
if [ -n "$_custom_pkgbase" ]; then
echo "_custom_pkgbase=\"${_custom_pkgbase}\"" >> "${_path}"/cpuschedset
fi
elif [ "$_cpusched" = "upds" ]; then
echo "_cpusched=\"upds\"" > "${_path}"/cpuschedset
elif [ "$_cpusched" = "pds" ]; then
echo "_cpusched=\"pds\"" > "${_path}"/cpuschedset
elif [ "$_cpusched" = "cfs" ]; then
echo "_cpusched=\"cfs\"" > "${_path}"/cpuschedset
elif [ "$_cpusched" = "bmq" ]; then
echo "_cpusched=\"bmq\"" > "${_path}"/cpuschedset
elif [ "$_cpusched" = "muqss" ] || [ "$_cpusched" = "MuQSS" ]; then
echo "_cpusched=\"MuQSS\"" > "${_path}"/cpuschedset
else
if [ "$_nofallback" != "true" ]; then
warning "Something is wrong with your cpusched selection. Do you want to fallback to CFS (default)?"
read -rp "`echo $' > N/y : '`" _fallback;
fi
if [[ "$_fallback" =~ [yY] ]] || [ "$_nofallback" = "true" ]; then
echo "_cpusched=\"cfs\"" > "${_path}"/cpuschedset
else
error "Exiting..."
exit 1
fi
fi
if [ -n "$_custom_pkgbase" ]; then
echo "_custom_pkgbase=\"${_custom_pkgbase}\"" >> "${_path}"/cpuschedset
fi
case $_compileroptlevel in
"2")
_compileropt="-O3"
;;
"3")
_compileropt="-Os"
;;
*)
_compileropt="-O2"
;;
esac
# Compiler selector
if [ -z "$_compiler" ] && [ ! -e "${_path}"/compilerset ]; then
plain "Which compiler do you want to use?"
read -rp "`echo $' > 1.GCC (recommended)\n 2.Clang/LLVM\nchoice[1-2?]: '`" _CONDITION_CMPLR;
if [ "$_CONDITION_CMPLR" = "2" ];then
echo "_compiler_name=\"-llvm\"" > ${_path}/compilerset
echo "llvm_opt=\"LLVM=1\"" >> ${_path}/compilerset
else
echo "_compiler_name=" >> ${_path}/compilerset
fi
elif [ "$_compiler" = "llvm" ]; then
echo "_compiler_name=\"-llvm\"" > ${_path}/compilerset
echo "llvm_opt=\"LLVM=1\"" >> ${_path}/compilerset
else
echo "_compiler_name=" >> ${_path}/compilerset
if [ "$_nofallback" != "true" ] && [ ! -e "${_path}"/compilerset ] && [ "$_compiler" != "llvm" ]; then
warning "Something is wrong with your compiler selection. Do you want to fallback to GCC (default)?"
read -rp "`echo $' > N/y : '`" _fallback;
fi
if [[ "$_fallback" =~ [yY] ]] || [ "$_nofallback" = "true" ]; then
echo "_compiler_name=" >> "${_path}"/compilerset
fi
if [ ! -e "${_path}"/compilerset ]; then
error "Exiting..."
exit 1
fi
fi
source "${_path}"/cpuschedset
source "${_path}"/compilerset
source "${_path}"/versel
}
user_patcher() {
# To patch the user because all your base are belong to us
local _patches=("$_where"/*."${_userpatch_ext}revert")
if [ ${#_patches[@]} -ge 2 ] || [ -e "${_patches}" ]; then
if [ "$_user_patches_no_confirm" != "true" ]; then
msg2 "Found ${#_patches[@]} 'to revert' userpatches for ${_userpatch_target}:"
printf '%s\n' "${_patches[@]}"
read -rp "Do you want to install it/them? - Be careful with that ;)"$'\n> N/y : ' _CONDITION;
fi
if [[ "$_CONDITION" =~ [yY] ]] || [ "$_user_patches_no_confirm" = "true" ]; then
for _f in "${_patches[@]}"; do
if [ -e "${_f}" ]; then
msg2 "######################################################"
msg2 ""
msg2 "Reverting your own ${_userpatch_target} patch ${_f}"
msg2 ""
msg2 "######################################################"
patch -Np1 -R < "${_f}"
echo "Reverted your own patch ${_f}" >> "$_where"/last_build_config.log
fi
done
fi
fi
_patches=("$_where"/*."${_userpatch_ext}patch")
if [ ${#_patches[@]} -ge 2 ] || [ -e "${_patches}" ]; then
if [ "$_user_patches_no_confirm" != "true" ]; then
msg2 "Found ${#_patches[@]} userpatches for ${_userpatch_target}:"
printf '%s\n' "${_patches[@]}"
read -rp "Do you want to install it/them? - Be careful with that ;)"$'\n> N/y : ' _CONDITION;
fi
if [[ "$_CONDITION" =~ [yY] ]] || [ "$_user_patches_no_confirm" = "true" ]; then
for _f in "${_patches[@]}"; do
if [ -e "${_f}" ]; then
msg2 "######################################################"
msg2 ""
msg2 "Applying your own ${_userpatch_target} patch ${_f}"
msg2 ""
msg2 "######################################################"
patch -Np1 < "${_f}"
echo "Applied your own patch ${_f}" >> "$_where"/last_build_config.log
fi
done
fi
fi
}
2020-10-26 15:23:54 -05:00
_tkg_patcher() {
if [ -e "$tkgpatch" ]; then
patch -Np1 -i "$tkgpatch"
else
msg2 "Patch either not found, not available for this kernel version or not needed. Skipping..."
fi
}
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
_tkg_srcprep() {
if [ "${_distro}" = "Void" ] && [ -e ${srcdir}/sum_failed ]; then
exit 1
fi
if [ "${_distro}" = "Arch" ]; then
msg2 "Setting version..."
scripts/setlocalversion --save-scmversion
2020-10-26 11:32:03 -05:00
echo "-$pkgrel-tkg-${_cpusched}${_compiler_name}" > localversion.10-pkgrel
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "" > localversion.20-pkgname
# add upstream patch
if [ "$_sub" != "0" ]; then
msg2 "Patching from $_basekernel to $pkgver"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/patch-${pkgver}" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# ARCH Patches
if [ "${_configfile}" = "config_hardened_${_basekernel}.x86_64" ] && [ "${_cpusched}" = "cfs" ]; then
msg2 "Using linux hardened patchset"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0012-linux-hardened.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
else
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0001-add-sysctl-to-disallow-unprivileged-CLONE_NEWUSER-by.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
fi
pwd
if [ "$_distro" = "Void" ] && [[ "$_sub" = rc* ]]; then
cd ${wrksrc}/linux-${_rc_kern_ver}
elif [ "$_distro" = "Void" ]; then
cd ${wrksrc}/linux-${_kern_ver}
fi
# graysky's cpu opts - https://github.com/graysky2/kernel_gcc_patch
if [ "$_compiler_name" != "-llvm" ]; then
msg2 "Applying graysky's cpu opts patch"
if [ "${_distro}" = "Arch" ]; then
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/enable_additional_cpu_optimizations_for_gcc_v10.1%2B_kernel_v${opt_ver}.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "${_distro}" = "Void" ]; then
2020-10-26 15:23:54 -05:00
tkgpatch="${wrksrc}/enable_additional_cpu_optimizations_for_gcc_v10.1+_kernel_v${opt_ver}.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
else
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/enable_additional_cpu_optimizations_for_gcc_v10.1+_kernel_v${opt_ver}+.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
fi
# TkG
msg2 "Applying clear linux patches"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0002-clear-patches.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
msg2 "Applying glitched base patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0003-glitched-base.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
if [ -z $_misc_adds ]; then
plain "Enable misc additions ? May contain temporary fixes pending upstream or changes that can break on non-Arch. "
read -rp "`echo $' > [Y]/n : '`" _interactive_misc_adds;
if [ "$_interactive_misc_adds" != "n" ] && [ "$_interactive_misc_adds" != "N" ]; then
_misc_adds="true"
fi
fi
if [ "$_misc_adds" = "true" ] && [ "$_basever" != "54" ]; then
msg2 "Applying misc additions patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0012-misc-additions.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# prjc/bmq patch rev
2020-10-26 15:23:54 -05:00
if [ "$_basever" = "58" ] || [ "$_basever" = "57" ]; then
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
rev=3
2020-10-26 15:35:36 -05:00
elif [ "$_basever" = "59" ]; then
rev=1
2020-10-26 15:23:54 -05:00
else
rev=0
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
if [ "${_cpusched}" = "MuQSS" ]; then
# MuQSS
msg2 "Applying MuQSS base patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0004-${_basekernel}-ck1.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
if [ "${_aggressive_ondemand}" = "true" ]; then
msg2 "Applying MuQSS agressive ondemand governor patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0004-glitched-ondemand-muqss.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
msg2 "Applying Glitched MuQSS patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0004-glitched-muqss.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "${_cpusched}" = "upds" ] || [ "${_cpusched}" = "pds" ]; then
# PDS-mq
msg2 "Applying PDS base patch"
if [ "${_cpusched}" = "upds" ] && [ "$_basever" != "59" ]; then
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0005-v${_basekernel}_undead-pds099o.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "$_basever" != "54" ]; then
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0009-prjc_v${_basekernel}-r${rev}.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# ondemand patches don't exist for 5.4
if [ "$_basever" = "58" ] && [ "${_cpusched}" = "upds" ];then
# is it dead or alive
doa="-undead"
fi
if [ "${_aggressive_ondemand}" = "true" ] && [ "$_basever" != "54" ] && [ "${_cpusched}" = "upds" ]; then
msg2 "Applying PDS agressive ondemand governor patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0005${doa}-glitched-ondemand-pds.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
msg2 "Applying Glitched PDS patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0005${doa}-glitched-pds.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "${_cpusched}" = "bmq" ]; then
# Project C / BMQ
msg2 "Applying Project C / BMQ base patch"
if [ "$_basever" != "54" ]; then
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0009-prjc_v${_basekernel}-r${rev}.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
else
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0009-bmq_v5.4-r2.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
if [ "${_aggressive_ondemand}" = "true" ] && [ "$_basever" != "54" ]; then
msg2 "Applying BMQ agressive ondemand governor patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0009-glitched-ondemand-bmq.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
msg2 "Applying Glitched BMQ patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0009-glitched-bmq.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
elif [ "${_cpusched}" = "cfs" ]; then
msg2 "Applying Glitched CFS patch"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0003-glitched-cfs.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
if [ "$_distro" = "Void" ] && [[ "$_sub" = rc* ]]; then
cd ${wrksrc}/linux-${_rc_kern_ver}
elif [ "$_distro" = "Void" ] && [[ "$_sub" != rc* ]]; then
cd ${wrksrc}/linux-${_kern_ver}
fi
if [ "${_distro}" = "Arch" ] || [ "$_distro" = "Void" ]; then
if [ -z "${_configfile}" ]; then
_configfile="config.x86_64"
fi
cat "${srcdir}/${_configfile}" > ./.config
fi
# Set some -tkg defaults
echo "# CONFIG_DYNAMIC_FAULT is not set" >> ./.config
sed -i -e 's/CONFIG_DEFAULT_FQ_CODEL=y/# CONFIG_DEFAULT_FQ_CODEL is not set/' ./.config
echo "CONFIG_DEFAULT_CAKE=y" >> ./.config
echo "CONFIG_NR_TTY_DEVICES=63" >> ./.config
if [ "$_basever" = "54" ]; then
echo "CONFIG_TP_SMAPI=m" >> ./.config
echo "CONFIG_RAID6_USE_PREFER_GEN=y" >> ./.config
fi
if [ "$_basever" = "54" ] || [ "$_basever" = "59" ]; then
sed -i -e 's/CONFIG_RCU_BOOST_DELAY=500/CONFIG_RCU_BOOST_DELAY=0/' ./.config
fi
echo "# CONFIG_NTP_PPS is not set" >> ./.config
sed -i -e 's/CONFIG_CRYPTO_LZ4=m/CONFIG_CRYPTO_LZ4=y/' ./.config
sed -i -e 's/CONFIG_CRYPTO_LZ4HC=m/CONFIG_CRYPTO_LZ4HC=y/' ./.config
sed -i -e 's/CONFIG_LZ4_COMPRESS=m/CONFIG_LZ4_COMPRESS=y/' ./.config
sed -i -e 's/CONFIG_LZ4HC_COMPRESS=m/CONFIG_LZ4HC_COMPRESS=y/' ./.config
sed -i -e 's/CONFIG_ZSWAP_COMPRESSOR_DEFAULT_LZO=y/# CONFIG_ZSWAP_COMPRESSOR_DEFAULT_LZO is not set/' ./.config
sed -i -e 's/# CONFIG_ZSWAP_COMPRESSOR_DEFAULT_LZ4 is not set/CONFIG_ZSWAP_COMPRESSOR_DEFAULT_LZ4=y/' ./.config
sed -i -e 's/CONFIG_ZSWAP_COMPRESSOR_DEFAULT="lzo"/CONFIG_ZSWAP_COMPRESSOR_DEFAULT="lz4"/' ./.config
sed -i -e 's/# CONFIG_CMDLINE_BOOL is not set/CONFIG_CMDLINE_BOOL=y/' ./.config
echo "CONFIG_CMDLINE=\"${_custom_commandline}\"" >> ./.config
echo "# CONFIG_CMDLINE_OVERRIDE is not set" >> ./.config
echo "# CONFIG_X86_P6_NOP is not set" >> ./.config
# openrgb
echo "CONFIG_I2C_NCT6775=m" >> ./.config
# ccache fix
if [ "$_noccache" != "true" ]; then
if { [ "$_distro" = "Arch" ] && pacman -Qq ccache &> /dev/null; } || { [ "$_distro" = "Ubuntu" ] && dpkg -l ccache > /dev/null; }\
|| { [ "$_distro" = "Void" ] && xbps-query -s ccache > /dev/null; } ; then
sed -i -e 's/CONFIG_GCC_PLUGINS=y/# CONFIG_GCC_PLUGINS is not set/' ./.config
fi
# Void uses LibreSSL
if [ "$_distro" = "Void" ]; then
sed -i -e 's/CONFIG_MODULE_SIG_SHA512=y/# CONFIG_MODULE_SIG_SHA512 is not set/' ./.config
sed -i -e 's/# CONFIG_MODULE_SIG_SHA1 is not set/CONFIG_MODULE_SIG_SHA1=y/' ./.config
sed -i -e 's/CONFIG_MODULE_SIG_HASH="sha512"/CONFIG_MODULE_SIG_HASH="sha1"/' ./.config
fi
fi
# Skip dbg package creation on non-Arch
if [ "$_distro" != "Arch" ]; then
sed -i -e 's/CONFIG_DEBUG_INFO.*/CONFIG_DEBUG_INFO=n/' ./.config
fi
if [ "$_compiler_name" = "-llvm" ]; then
if [ "$_basever" = "59" ]; then
echo 'CONFIG_INIT_STACK_ALL_PATTERN=n' >> ./.config
else
echo 'CONFIG_INIT_STACK_ALL=n' >> ./.config
fi
sed -i -e 's/# CONFIG_INIT_ON_FREE_DEFAULT_ON is not set/CONFIG_INIT_ON_FREE_DEFAULT_ON=y/' ./.config
sed -i -e 's/CONFIG_INIT_STACK_NONE=y/CONFIG_INIT_STACK_NONE=n/' ./.config
echo "CONFIG_INIT_STACK_ALL_ZERO=y" >> ./.config
fi
if [ "$_font_autoselect" != "false" ]; then
sed -i -e 's/CONFIG_FONT_TER16x32=y/# CONFIG_FONT_TER16x32 is not set\nCONFIG_FONT_AUTOSELECT=y/' ./.config
fi
# Inject cpuopts options
if [ "$_compiler_name" != "-llvm" ]; then
echo "# CONFIG_MK8SSE3 is not set" >> ./.config
echo "# CONFIG_MK10 is not set" >> ./.config
echo "# CONFIG_MBARCELONA is not set" >> ./.config
echo "# CONFIG_MBOBCAT is not set" >> ./.config
echo "# CONFIG_MJAGUAR is not set" >> ./.config
echo "# CONFIG_MBULLDOZER is not set" >> ./.config
echo "# CONFIG_MPILEDRIVER is not set" >> ./.config
echo "# CONFIG_MSTEAMROLLER is not set" >> ./.config
echo "# CONFIG_MEXCAVATOR is not set" >> ./.config
echo "# CONFIG_MZEN is not set" >> ./.config
echo "# CONFIG_MZEN2 is not set" >> ./.config
echo "# CONFIG_MATOM is not set" >> ./.config
echo "# CONFIG_MNEHALEM is not set" >> ./.config
echo "# CONFIG_MWESTMERE is not set" >> ./.config
echo "# CONFIG_MSILVERMONT is not set" >> ./.config
echo "# CONFIG_MSANDYBRIDGE is not set" >> ./.config
echo "# CONFIG_MIVYBRIDGE is not set" >> ./.config
echo "# CONFIG_MHASWELL is not set" >> ./.config
echo "# CONFIG_MBROADWELL is not set" >> ./.config
echo "# CONFIG_MSKYLAKE is not set" >> ./.config
echo "# CONFIG_MSKYLAKEX is not set" >> ./.config
echo "# CONFIG_MCANNONLAKE is not set" >> ./.config
echo "# CONFIG_MICELAKE is not set" >> ./.config
echo "# CONFIG_MGOLDMONT is not set" >> ./.config
echo "# CONFIG_MGOLDMONTPLUS is not set" >> ./.config
echo "# CONFIG_MCASCADELAKE is not set" >> ./.config
echo "# CONFIG_MCOOPERLAKE is not set" >> ./.config
echo "# CONFIG_MTIGERLAKE is not set" >> ./.config
fi
# Disable some debugging
if [ "${_debugdisable}" = "true" ]; then
sed -i -e 's/CONFIG_SLUB_DEBUG=y/# CONFIG_SLUB_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_PM_DEBUG=y/# CONFIG_PM_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_PM_ADVANCED_DEBUG=y/# CONFIG_PM_ADVANCED_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_PM_SLEEP_DEBUG=y/# CONFIG_PM_SLEEP_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_ACPI_DEBUG=y/# CONFIG_ACPI_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_SCHED_DEBUG=y/# CONFIG_SCHED_DEBUG is not set/' ./.config
sed -i -e 's/CONFIG_LATENCYTOP=y/# CONFIG_LATENCYTOP is not set/' ./.config
sed -i -e 's/CONFIG_DEBUG_PREEMPT=y/# CONFIG_DEBUG_PREEMPT is not set/' ./.config
fi
if [ "${_cpusched}" = "MuQSS" ]; then
# MuQSS default config
echo "CONFIG_SCHED_MUQSS=y" >> ./.config
elif [ "${_cpusched}" = "pds" ]; then
# PDS default config
echo "CONFIG_SCHED_ALT=y" >> ./.config
echo "CONFIG_SCHED_PDS=y" >> ./.config
echo "# CONFIG_SCHED_BMQ is not set" >> ./.config
elif [ "${_cpusched}" = "upds" ]; then
# PDS default config
echo "CONFIG_SCHED_PDS=y" >> ./.config
elif [ "${_cpusched}" = "bmq" ]; then
# BMQ default config
echo "CONFIG_SCHED_ALT=y" >> ./.config
echo "CONFIG_SCHED_BMQ=y" >> ./.config
echo "# CONFIG_SCHED_PDS is not set" >> ./.config
fi
if [ "${_cpusched}" = "MuQSS" ] || [ "${_cpusched}" = "pds" ] || [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "upds" ]; then
# Disable CFS
sed -i -e 's/CONFIG_FAIR_GROUP_SCHED=y/# CONFIG_FAIR_GROUP_SCHED is not set/' ./.config
sed -i -e 's/CONFIG_CFS_BANDWIDTH=y/# CONFIG_CFS_BANDWIDTH is not set/' ./.config
# sched yield type
if [ -n "$_sched_yield_type" ]; then
CONDITION0="$_sched_yield_type"
# in customization.cfg for linux59-tkg _sched_yield_type is set to 0
elif [ "$_basever" = "59" ]; then
CONDITION0="0"
else
plain ""
plain "CPU sched_yield_type - Choose what sort of yield sched_yield will perform."
plain ""
plain "For PDS and MuQSS:"
plain "0: No yield."
plain "1: Yield only to better priority/deadline tasks."
plain "2: Expire timeslice and recalculate deadline."
plain ""
plain "For BMQ (experimental) - No recommended value yet, so try for yourself x) :"
plain "0: No yield."
plain "1: Deboost and requeue task. (default)"
plain "2: Set rq skip task."
if [ "${_cpusched}" = "MuQSS" ]; then
read -rp "`echo $'\n 0. Supposedly best option for gaming performance - could lead to stability issues on some (AMD) platforms when combined with MuQSS\n > 1. Default and recommended option for MuQSS - could lead to stability issues on some (Intel) platforms\n 2. Can be a good option with low rr_interval on MuQSS\n [0-2?]: '`" CONDITION0;
else
read -rp "`echo $'\n > 0. Recommended option for gaming on PDS - "tkg" default\n 1. Default, but can lead to stability issues on some platforms\n 2. Can be a good option with low rr_interval on MuQSS\n [0-2?]: '`" CONDITION0;
fi
fi
if [ "$_basever" = "54" ] || [ "$_basever" = "57" ] && [ "$_cpusched" != "bmq" ]; then
_sched=${_cpusched}
else
_sched="alt_core"
fi
if [ "$CONDITION0" = "0" ]; then
if [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "pds" ] && [ "$_basever" != "54" ]; then
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 0;/' ./kernel/sched/${_sched}.c
else
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 0;/' ./kernel/sched/"${_cpusched}".c
fi
elif [ "$CONDITION0" = "1" ]; then
msg2 "Using default CPU sched yield type (1)"
elif [ "$CONDITION0" = "2" ]; then
if [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "pds" ] && [ "$_basever" != "54" ]; then
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 2;/' ./kernel/sched/${_sched}.c
elif [ "${_cpusched}" = "upds" ]; then
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 2;/' ./kernel/sched/pds.c
else
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 2;/' ./kernel/sched/"${_cpusched}".c
fi
else
if [ "${_cpusched}" = "MuQSS" ]; then
msg2 "Using default CPU sched yield type (1)"
elif [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "pds" ] && [ "$_basever" != "54" ]; then
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 0;/' ./kernel/sched/${_sched}.c
elif [ "${_cpusched}" = "upds" ]; then
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 0;/' ./kernel/sched/pds.c
else
sed -i -e 's/int sched_yield_type __read_mostly = 1;/int sched_yield_type __read_mostly = 0;/' ./kernel/sched/"${_cpusched}".c
fi
fi
fi
# Round Robin interval
if [ "${_cpusched}" = "MuQSS" ] || [ "${_cpusched}" = "pds" ] || [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "upds" ]; then
if [ -n "$_rr_interval" ]; then
CONDITION1="$_rr_interval"
else
plain ""
plain "Round Robin interval is the longest duration two tasks with the same nice level will"
plain "be delayed for. When CPU time is requested by a task, it receives a time slice equal"
plain "to the rr_interval in addition to a virtual deadline. When using yield_type 2, a low"
plain "value can help offset the disadvantages of rescheduling a process that has yielded."
plain ""
plain "MuQSS default: 6ms"
plain "PDS default: 4ms"
plain "BMQ default: 2ms"
read -rp "`echo $'\n > 0.Keep defaults\n 1.2ms\n 2.4ms\n 3.6ms\n 4.8ms\n [0-4?]: '`" CONDITION1;
fi
if [ "$CONDITION1" = "1" ]; then
msg2 "Using 2ms rr_interval"
_rrvalue="2"
elif [ "$CONDITION1" = "2" ]; then
msg2 "Using 4ms rr_interval"
_rrvalue="4"
elif [ "$CONDITION1" = "3" ]; then
msg2 "Using 6ms rr_interval"
_rrvalue="6"
elif [ "$CONDITION1" = "4" ]; then
msg2 "Using 8ms rr_interval"
_rrvalue="8"
else
msg2 "Using default rr_interval"
_rrvalue="default"
fi
if [ "$_basever" != "54" ]; then
if [ "$_rrvalue" != "default" ]; then
if [ "${_cpusched}" = "MuQSS" ]; then
sed -i -e "s/int rr_interval __read_mostly = 6;/int rr_interval __read_mostly = ${_rrvalue};/" ./kernel/sched/"${_cpusched}".c
elif [ "${_cpusched}" = "upds" ]; then
sed -i -e "s/#define SCHED_DEFAULT_RR (4)/#define SCHED_DEFAULT_RR (${_rrvalue})/" ./kernel/sched/pds.c
elif [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "pds" ]; then
sed -i -e "s/u64 sched_timeslice_ns __read_mostly = (4 * 1000 * 1000);/u64 sched_timeslice_ns __read_mostly = (${_rrvalue} * 1000 * 1000);/" ./kernel/sched/${_sched}.c
fi
if [ "${_cpusched}" == "bmq" ]; then
echo "CONFIG_SCHED_TIMESLICE=2" >> ./.config
fi
else
if [ "${_cpusched}" = "bmq" ] || [ "${_cpusched}" = "pds" ]; then
sed -i -e "s/u64 sched_timeslice_ns __read_mostly = (4 * 1000 * 1000);/u64 sched_timeslice_ns __read_mostly = (2 * 1000 * 1000);/" ./kernel/sched/${_sched}.c
fi
fi
else
if [ "$_rrvalue" != "default" ]; then
if [ "${_cpusched}" == "MuQSS" ]; then
sed -i -e "s/int rr_interval __read_mostly = 6;/int rr_interval __read_mostly = ${_rrvalue};/" ./kernel/sched/"${_cpusched}".c
elif [ "${_cpusched}" == "pds" ]; then
sed -i -e "s/#define SCHED_DEFAULT_RR (4)/#define SCHED_DEFAULT_RR (${_rrvalue})/" ./kernel/sched/"${_cpusched}".c
elif [ "${_cpusched}" == "bmq" ]; then
echo "CONFIG_SCHED_TIMESLICE=${_rrvalue}" >> ./.config
fi
else
if [ "${_cpusched}" == "bmq" ]; then
echo "CONFIG_SCHED_TIMESLICE=2" >> ./.config
fi
fi
fi
fi
# zenify
if [ "$_zenify" = "true" ]; then
echo "CONFIG_ZENIFY=y" >> ./.config
elif [ "$_zenify" = "false" ]; then
echo "# CONFIG_ZENIFY is not set" >> ./.config
fi
# compiler optimization level
if [ "$_compileroptlevel" = "1" ]; then
if [ "$_basever" != "54" ]; then
echo "# CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE_O3 is not set" >> ./.config
else
echo "# CONFIG_CC_OPTIMIZE_HARDER is not set" >> ./.config
fi
elif [ "$_compileroptlevel" = "2" ]; then
sed -i -e 's/CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y/# CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE is not set/' ./.config
if [ "$_basever" != "54" ]; then
echo "CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE_O3=y" >> ./.config
else
echo "CONFIG_CC_OPTIMIZE_HARDER=y" >> ./.config
fi
elif [ "$_compileroptlevel" = "3" ]; then
sed -i -e 's/CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y/# CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE is not set/' ./.config
sed -i -e 's/# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set/CONFIG_CC_OPTIMIZE_FOR_SIZE=y/' ./.config
if [ "$_basever" != "54" ]; then
echo "# CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE_O3 is not set" >> ./.config
else
echo "# CONFIG_CC_OPTIMIZE_HARDER is not set" >> ./.config
fi
fi
# cpu opt
if [ -n "$_processor_opt" ] && [ "$_processor_opt" != "native" ]; then
echo "# CONFIG_MNATIVE is not set" >> ./.config
fi
if [ -n "$_processor_opt" ] && [ "$_processor_opt" != "generic" ]; then
sed -i -e 's/CONFIG_GENERIC_CPU=y/# CONFIG_GENERIC_CPU is not set/' ./.config
fi
if [ "$_processor_opt" = "native" ]; then
echo "CONFIG_MNATIVE=y" >> ./.config
elif [ "$_processor_opt" = "k8" ]; then
sed -i -e 's/# CONFIG_MK8 is not set/CONFIG_MK8=y/' ./.config
elif [ "$_processor_opt" = "k8sse3" ]; then
sed -i -e 's/# CONFIG_MK8SSE3 is not set/CONFIG_MK8SSE3=y/' ./.config
elif [ "$_processor_opt" = "k10" ]; then
sed -i -e 's/# CONFIG_MK10 is not set/CONFIG_MK10=y/' ./.config
elif [ "$_processor_opt" = "barcelona" ]; then
sed -i -e 's/# CONFIG_MBARCELONA is not set/CONFIG_MBARCELONA=y/' ./.config
elif [ "$_processor_opt" = "bobcat" ]; then
sed -i -e 's/# CONFIG_MBOBCAT is not set/CONFIG_MBOBCAT=y/' ./.config
elif [ "$_processor_opt" = "jaguar" ]; then
sed -i -e 's/# CONFIG_MJAGUAR is not set/CONFIG_MJAGUAR=y/' ./.config
elif [ "$_processor_opt" = "bulldozer" ]; then
sed -i -e 's/# CONFIG_MBULLDOZER is not set/CONFIG_MBULLDOZER=y/' ./.config
elif [ "$_processor_opt" = "piledriver" ]; then
sed -i -e 's/# CONFIG_MPILEDRIVER is not set/CONFIG_MPILEDRIVER=y/' ./.config
elif [ "$_processor_opt" = "steamroller" ]; then
sed -i -e 's/# CONFIG_MSTEAMROLLER is not set/CONFIG_MSTEAMROLLER=y/' ./.config
elif [ "$_processor_opt" = "excavator" ]; then
sed -i -e 's/# CONFIG_MEXCAVATOR is not set/CONFIG_MEXCAVATOR=y/' ./.config
elif [ "$_processor_opt" = "zen" ]; then
sed -i -e 's/# CONFIG_MZEN is not set/CONFIG_MZEN=y/' ./.config
elif [ "$_processor_opt" = "zen2" ]; then
sed -i -e 's/# CONFIG_MZEN2 is not set/CONFIG_MZEN2=y/' ./.config
elif [ "$_processor_opt" = "mpsc" ]; then
sed -i -e 's/# CONFIG_MPSC is not set/CONFIG_MPSC=y/' ./.config
elif [ "$_processor_opt" = "atom" ]; then
sed -i -e 's/# CONFIG_MATOM is not set/CONFIG_MATOM=y/' ./.config
elif [ "$_processor_opt" = "core2" ]; then
sed -i -e 's/# CONFIG_MCORE2 is not set/CONFIG_MCORE2=y/' ./.config
elif [ "$_processor_opt" = "nehalem" ]; then
sed -i -e 's/# CONFIG_MNEHALEM is not set/CONFIG_MNEHALEM=y/' ./.config
elif [ "$_processor_opt" = "westmere" ]; then
sed -i -e 's/# CONFIG_MWESTMERE is not set/CONFIG_MWESTMERE=y/' ./.config
elif [ "$_processor_opt" = "silvermont" ]; then
sed -i -e 's/# CONFIG_MSILVERMONT is not set/CONFIG_MSILVERMONT=y/' ./.config
elif [ "$_processor_opt" = "sandybridge" ]; then
sed -i -e 's/# CONFIG_MSANDYBRIDGE is not set/CONFIG_MSANDYBRIDGE=y/' ./.config
elif [ "$_processor_opt" = "ivybridge" ]; then
sed -i -e 's/# CONFIG_MIVYBRIDGE is not set/CONFIG_MIVYBRIDGE=y/' ./.config
elif [ "$_processor_opt" = "haswell" ]; then
sed -i -e 's/# CONFIG_MHASWELL is not set/CONFIG_MHASWELL=y/' ./.config
elif [ "$_processor_opt" = "broadwell" ]; then
sed -i -e 's/# CONFIG_MBROADWELL is not set/CONFIG_MBROADWELL=y/' ./.config
elif [ "$_processor_opt" = "skylake" ]; then
sed -i -e 's/# CONFIG_MSKYLAKE is not set/CONFIG_MSKYLAKE=y/' ./.config
elif [ "$_processor_opt" = "skylakex" ]; then
sed -i -e 's/# CONFIG_MSKYLAKEX is not set/CONFIG_MSKYLAKEX=y/' ./.config
elif [ "$_processor_opt" = "cannonlake" ]; then
sed -i -e 's/# CONFIG_MCANNONLAKE is not set/CONFIG_MCANNONLAKE=y/' ./.config
elif [ "$_processor_opt" = "icelake" ]; then
sed -i -e 's/# CONFIG_MICELAKE is not set/CONFIG_MICELAKE=y/' ./.config
elif [ "$_processor_opt" = "goldmont" ]; then
sed -i -e 's/# CONFIG_MGOLDMONT is not set/CONFIG_MGOLDMONT=y/' ./.config
elif [ "$_processor_opt" = "goldmontplus" ]; then
sed -i -e 's/# CONFIG_MGOLDMONTPLUS is not set/CONFIG_MGOLDMONTPLUS=y/' ./.config
elif [ "$_processor_opt" = "cascadelake" ]; then
sed -i -e 's/# CONFIG_MCASCADELAKE is not set/CONFIG_MCASCADELAKE=y/' ./.config
elif [ "$_processor_opt" = "cooperlake" ]; then
sed -i -e 's/# CONFIG_MCOOPERLAKE is not set/CONFIG_MCOOPERLAKE=y/' ./.config
elif [ "$_processor_opt" = "tigerlake" ]; then
sed -i -e 's/# CONFIG_MTIGERLAKE is not set/CONFIG_MTIGERLAKE=y/' ./.config
fi
# irq threading
if [ "$_irq_threading" = "true" ]; then
echo "CONFIG_FORCE_IRQ_THREADING=y" >> ./.config
elif [ "$_irq_threading" = "false" ]; then
echo "# CONFIG_FORCE_IRQ_THREADING is not set" >> ./.config
fi
# smt nice
if [ "$_smt_nice" = "true" ]; then
echo "CONFIG_SMT_NICE=y" >> ./.config
elif [ "$_smt_nice" = "false" ]; then
echo "# CONFIG_SMT_NICE is not set" >> ./.config
fi
# random trust cpu
if [ "$_random_trust_cpu" = "true" ]; then
sed -i -e 's/# CONFIG_RANDOM_TRUST_CPU is not set/CONFIG_RANDOM_TRUST_CPU=y/' ./.config
fi
# rq sharing
if [ "$_runqueue_sharing" = "none" ]; then
echo -e "CONFIG_RQ_NONE=y\n# CONFIG_RQ_SMT is not set\n# CONFIG_RQ_MC is not set\n# CONFIG_RQ_MC_LLC is not set\n# CONFIG_RQ_SMP is not set\n# CONFIG_RQ_ALL is not set" >> ./.config
elif [ -z "$_runqueue_sharing" ] || [ "$_runqueue_sharing" = "smt" ]; then
echo -e "# CONFIG_RQ_NONE is not set\nCONFIG_RQ_SMT=y\n# CONFIG_RQ_MC is not set\n# CONFIG_RQ_MC_LLC is not set\n# CONFIG_RQ_SMP is not set\n# CONFIG_RQ_ALL is not set" >> ./.config
elif [ "$_runqueue_sharing" = "mc" ]; then
echo -e "# CONFIG_RQ_NONE is not set\n# CONFIG_RQ_SMT is not set\nCONFIG_RQ_MC=y\n# CONFIG_RQ_MC_LLC is not set\n# CONFIG_RQ_SMP is not set\n# CONFIG_RQ_ALL is not set" >> ./.config
elif [ "$_runqueue_sharing" = "smp" ]; then
echo -e "# CONFIG_RQ_NONE is not set\n# CONFIG_RQ_SMT is not set\n# CONFIG_RQ_MC is not set\n# CONFIG_RQ_MC_LLC is not set\nCONFIG_RQ_SMP=y\n# CONFIG_RQ_ALL is not set" >> ./.config
elif [ "$_runqueue_sharing" = "all" ]; then
echo -e "# CONFIG_RQ_NONE is not set\n# CONFIG_RQ_SMT is not set\n# CONFIG_RQ_MC is not set\n# CONFIG_RQ_MC_LLC is not set\n# CONFIG_RQ_SMP is not set\nCONFIG_RQ_ALL=y" >> ./.config
elif [ "$_runqueue_sharing" = "mc-llc" ]; then
echo -e "# CONFIG_RQ_NONE is not set\n# CONFIG_RQ_SMT is not set\n# CONFIG_RQ_MC is not set\nCONFIG_RQ_MC_LLC=y\n# CONFIG_RQ_SMP is not set\n# CONFIG_RQ_ALL is not set" >> ./.config
fi
# timer freq
if [ -n "$_timer_freq" ] && [ "$_timer_freq" != "300" ]; then
sed -i -e 's/CONFIG_HZ_300=y/# CONFIG_HZ_300 is not set/' ./.config
sed -i -e 's/CONFIG_HZ_300_NODEF=y/# CONFIG_HZ_300_NODEF is not set/' ./.config
if [ "$_timer_freq" = "1000" ]; then
sed -i -e 's/# CONFIG_HZ_1000 is not set/CONFIG_HZ_1000=y/' ./.config
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=1000/' ./.config
echo "# CONFIG_HZ_500 is not set" >> ./.config
echo "# CONFIG_HZ_500_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_750 is not set" >> ./.config
echo "# CONFIG_HZ_750_NODEF is not set" >> ./.config
echo "CONFIG_HZ_1000_NODEF=y" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
elif [ "$_timer_freq" = "750" ]; then
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=750/' ./.config
echo "# CONFIG_HZ_500 is not set" >> ./.config
echo "# CONFIG_HZ_500_NODEF is not set" >> ./.config
echo "CONFIG_HZ_750=y" >> ./.config
echo "CONFIG_HZ_750_NODEF=y" >> ./.config
echo "# CONFIG_HZ_1000_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
elif [ "$_timer_freq" = "500" ]; then
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=500/' ./.config
echo "CONFIG_HZ_500=y" >> ./.config
echo "CONFIG_HZ_500_NODEF=y" >> ./.config
echo "# CONFIG_HZ_750 is not set" >> ./.config
echo "# CONFIG_HZ_750_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_1000_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
elif [ "$_timer_freq" = "100" ]; then
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=100/' ./.config
echo "# CONFIG_HZ_500 is not set" >> ./.config
echo "# CONFIG_HZ_750 is not set" >> ./.config
echo "# CONFIG_HZ_1000_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_750_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_500_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
echo "CONFIG_HZ_100=y" >> ./.config
echo "CONFIG_HZ_100_NODEF=y" >> ./.config
fi
elif [ "${_cpusched}" = "MuQSS" ] && [ -z "$_timer_freq" ]; then
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=100/' ./.config
echo "# CONFIG_HZ_500 is not set" >> ./.config
echo "# CONFIG_HZ_750 is not set" >> ./.config
echo "# CONFIG_HZ_1000_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_750_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_500_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
echo "CONFIG_HZ_100=y" >> ./.config
echo "CONFIG_HZ_100_NODEF=y" >> ./.config
else
sed -i -e 's/CONFIG_HZ_300=y/# CONFIG_HZ_300 is not set/' ./.config
sed -i -e 's/CONFIG_HZ_300_NODEF=y/# CONFIG_HZ_300_NODEF is not set/' ./.config
sed -i -e 's/CONFIG_HZ=300/CONFIG_HZ=500/' ./.config
echo "CONFIG_HZ_500=y" >> ./.config
echo "CONFIG_HZ_500_NODEF=y" >> ./.config
echo "# CONFIG_HZ_250_NODEF is not set" >> ./.config
echo "# CONFIG_HZ_300_NODEF is not set" >> ./.config
fi
# default cpu gov
if [ "$_default_cpu_gov" = "performance" ]; then
sed -i -e 's/CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL=y/# CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL is not set/' ./.config
sed -i -e 's/# CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE is not set/CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE=y/' ./.config
elif [ "$_default_cpu_gov" = "ondemand" ]; then
sed -i -e 's/CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL=y/# CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL is not set/' ./.config
sed -i -e 's/# CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set/CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND=y/' ./.config
fi
# ACPI_CPUFREQ disablement
if [ "$_disable_acpi_cpufreq" = "true" ]; then
sed -i -e 's/CONFIG_X86_ACPI_CPUFREQ=m/# CONFIG_X86_ACPI_CPUFREQ is not set/' ./.config
fi
# ftrace
if [ -z "$_ftracedisable" ]; then
plain ""
plain "Disable FUNCTION_TRACER/GRAPH_TRACER? Lowers overhead but limits debugging"
plain "and analyzing of kernel functions."
read -rp "`echo $' > N/y : '`" CONDITION2;
fi
if [[ "$CONDITION2" =~ [yY] ]] || [ "$_ftracedisable" = "true" ]; then
sed -i -e 's/CONFIG_FUNCTION_TRACER=y/# CONFIG_FUNCTION_TRACER is not set/' ./.config
sed -i -e 's/CONFIG_FUNCTION_GRAPH_TRACER=y/# CONFIG_FUNCTION_GRAPH_TRACER is not set/' ./.config
fi
# disable numa
if [ -z "$_numadisable" ]; then
plain ""
plain "Disable NUMA? Lowers overhead, but breaks CUDA/NvEnc on Nvidia if disabled."
plain "https://bbs.archlinux.org/viewtopic.php?id=239174"
read -rp "`echo $' > N/y : '`" CONDITION3;
fi
if [[ "$CONDITION3" =~ [yY] ]] || [ "$_numadisable" = "true" ]; then
# disable NUMA since 99.9% of users do not have multiple CPUs but do have multiple cores in one CPU
sed -i -e 's/CONFIG_NUMA=y/# CONFIG_NUMA is not set/' \
-i -e '/CONFIG_AMD_NUMA=y/d' \
-i -e '/CONFIG_X86_64_ACPI_NUMA=y/d' \
-i -e '/CONFIG_NODES_SPAN_OTHER_NODES=y/d' \
-i -e '/# CONFIG_NUMA_EMU is not set/d' \
-i -e '/CONFIG_NODES_SHIFT=6/d' \
-i -e '/CONFIG_NEED_MULTIPLE_NODES=y/d' \
-i -e '/CONFIG_USE_PERCPU_NUMA_NODE_ID=y/d' \
-i -e '/CONFIG_ACPI_NUMA=y/d' ./.config
fi
# tickless
if [ -z "$_tickless" ]; then
plain ""
plain "Use CattaRappa mode (Tickless/Dynticks) ?"
plain "Can give higher performances in many cases but lower consistency on some hardware."
plain "Just tickless idle can perform better with some platforms (mostly AMD) or CPU schedulers (mostly MuQSS)."
if [ "${_cpusched}" = "MuQSS" ]; then
read -rp "`echo $'\n 0.No, use periodic ticks\n 1.Yes, full tickless baby!\n > 2.Just tickless idle plz\n [0-2?]: '`" CONDITION4;
else
read -rp "`echo $'\n 0.No, use periodic ticks\n > 1.Yes, full tickless baby!\n 2.Just tickless idle plz\n [0-2?]: '`" CONDITION4;
fi
fi
if [ "$CONDITION4" = "0" ] || [ "$_tickless" = "0" ]; then
echo "# CONFIG_NO_HZ_FULL_NODEF is not set" >> ./.config
sed -i -e 's/# CONFIG_HZ_PERIODIC is not set/CONFIG_HZ_PERIODIC=y/' ./.config
sed -i -e 's/CONFIG_NO_HZ_IDLE=y/# CONFIG_NO_HZ_IDLE is not set/' ./.config
sed -i -e 's/CONFIG_NO_HZ_FULL=y/# CONFIG_NO_HZ_FULL is not set/' ./.config
sed -i -e 's/CONFIG_NO_HZ=y/# CONFIG_NO_HZ is not set/' ./.config
sed -i -e 's/CONFIG_NO_HZ_COMMON=y/# CONFIG_NO_HZ_COMMON is not set/' ./.config
elif [ "$CONDITION4" = "2" ] || [ "$_tickless" = "2" ]; then
echo "# CONFIG_NO_HZ_FULL_NODEF is not set" >> ./.config
sed -i -e 's/CONFIG_HZ_PERIODIC=y/# CONFIG_HZ_PERIODIC is not set/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_IDLE is not set/CONFIG_NO_HZ_IDLE=y/' ./.config
sed -i -e 's/CONFIG_NO_HZ_FULL=y/# CONFIG_NO_HZ_FULL is not set/' ./.config
sed -i -e 's/# CONFIG_NO_HZ is not set/CONFIG_NO_HZ=y/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_COMMON is not set/CONFIG_NO_HZ_COMMON=y/' ./.config
else
if [ "${_cpusched}" = "MuQSS" ]; then
echo "# CONFIG_NO_HZ_FULL_NODEF is not set" >> ./.config
sed -i -e 's/CONFIG_HZ_PERIODIC=y/# CONFIG_HZ_PERIODIC is not set/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_IDLE is not set/CONFIG_NO_HZ_IDLE=y/' ./.config
sed -i -e 's/CONFIG_NO_HZ_FULL=y/# CONFIG_NO_HZ_FULL is not set/' ./.config
sed -i -e 's/# CONFIG_NO_HZ is not set/CONFIG_NO_HZ=y/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_COMMON is not set/CONFIG_NO_HZ_COMMON=y/' ./.config
else
echo "CONFIG_NO_HZ_FULL_NODEF=y" >> ./.config
sed -i -e 's/CONFIG_HZ_PERIODIC=y/# CONFIG_HZ_PERIODIC is not set/' ./.config
sed -i -e 's/CONFIG_NO_HZ_IDLE=y/# CONFIG_NO_HZ_IDLE is not set/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_FULL is not set/CONFIG_NO_HZ_FULL=y/' ./.config
sed -i -e 's/# CONFIG_NO_HZ is not set/CONFIG_NO_HZ=y/' ./.config
sed -i -e 's/# CONFIG_NO_HZ_COMMON is not set/CONFIG_NO_HZ_COMMON=y/' ./.config
echo "CONFIG_CONTEXT_TRACKING=y" >> ./.config
echo "# CONFIG_CONTEXT_TRACKING_FORCE is not set" >> ./.config
fi
fi
# voluntary preempt
if [ -z "$_voluntary_preempt" ]; then
plain ""
plain "Use explicit preemption points?"
plain "It can improve latency on PDS (at the cost of throughput)"
plain "and improve throughput on other schedulers (at the cost of latency)"
read -rp "`echo $' > N/y : '`" CONDITION5;
fi
if [[ "$CONDITION5" =~ [yY] ]] || [ "$_voluntary_preempt" = "true" ]; then
sed -i -e 's/CONFIG_PREEMPT=y/# CONFIG_PREEMPT is not set/' ./.config
sed -i -e 's/CONFIG_PREEMPT_LL=y/# CONFIG_PREEMPT_LL is not set/' ./.config
sed -i -e 's/# CONFIG_PREEMPT_VOLUNTARY is not set/CONFIG_PREEMPT_VOLUNTARY=y/' ./.config
fi
# Open Firmware support
if [ -z "$_OFenable" ]; then
plain ""
plain "Enable Device Tree and Open Firmware support?"
read -rp "`echo $' > N/y : '`" CONDITION6;
fi
if [[ "$CONDITION6" =~ [yY] ]] || [ "$_OFenable" = "true" ]; then
sed -i -e 's/# CONFIG_OF is not set/CONFIG_OF=y/' ./.config
fi
# acs override
if [ -z "$_acs_override" ]; then
plain ""
plain "Use ACS override patch?"
plain "https://wiki.archlinux.org/index.php/PCI_passthrough_via_OVMF#Bypassing_the_IOMMU_groups_.28ACS_override_patch.29"
read -rp "`echo $' > N/y : '`" CONDITION7;
fi
if [[ "$CONDITION7" =~ [yY] ]] || [ "$_acs_override" = "true" ]; then
msg2 "Patching ACS override"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0006-add-acs-overrides_iommu.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# bcachefs
if [ -z "$_bcachefs" ] && [ "$_basever" != "54" ]; then
plain ""
plain "Add Bcache filesystem support? You'll have to install bcachefs-tools-git from AUR for utilities."
plain "https://bcachefs.org/"
read -rp "`echo $' > N/y : '`" CONDITION8;
fi
if [[ "$CONDITION8" =~ [yY] ]] || [ "$_bcachefs" = "true" ]; then
msg2 "Patching Bcache filesystem support override"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0008-${_basekernel}-bcachefs.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
echo "CONFIG_BCACHEFS_FS=m" >> ./.config
echo "CONFIG_BCACHEFS_QUOTA=y" >> ./.config
echo "CONFIG_BCACHEFS_POSIX_ACL=y" >> ./.config
echo "# CONFIG_BCACHEFS_DEBUG is not set" >> ./.config
echo "# CONFIG_BCACHEFS_TESTS is not set" >> ./.config
echo "# CONFIG_DEBUG_CLOSURES is not set" >> ./.config
fi
# fsync support
if [ -z "$_fsync" ]; then
plain ""
plain "Enable support for fsync, an experimental replacement for esync in Valve Proton 4.11+"
plain "https://steamcommunity.com/games/221410/announcements/detail/2957094910196249305"
read -rp "`echo $' > N/y : '`" CONDITION9;
fi
if [[ "$CONDITION9" =~ [yY] ]] || [ "$_fsync" = "true" ]; then
msg2 "Patching Fsync support"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0007-v${_basekernel}-fsync.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
# ZFS fix
if [ "$_basever" != "59" ]; then
if [ -z "$_zfsfix" ]; then
plain ""
plain "Add back missing symbol for AES-NI/AVX support on ZFS"
plain "https://github.com/NixOS/nixpkgs/blob/master/pkgs/os-specific/linux/kernel/export_kernel_fpu_functions_5_3.patch"
read -rp "`echo $' > N/y : '`" CONDITION11;
fi
if [[ "$CONDITION11" =~ [yY] ]] || [ "$_zfsfix" = "true" ]; then
msg2 "Patching missing symbol for AES-NI/AVX support on ZFS"
2020-10-26 15:23:54 -05:00
tkgpatch="$srcdir/0011-ZFS-fix.patch" && _tkg_patcher
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
fi
# Community patches
if [ -n "$_community_patches" ]; then
2020-10-26 16:58:19 -05:00
if [ ! -d "$_where/../community-patches" ]; then
cd "$_where/.." && git clone https://github.com/Frogging-Family/community-patches.git && cd "${srcdir}/${_srcpath}"
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
fi
_community_patches=($_community_patches)
for _p in ${_community_patches[@]}; do
2020-10-26 16:58:19 -05:00
ln -s "$_where"/../community-patches/linux"$_basever"-tkg/$_p "$_where"/
Merge linux-tkg packages into a single package, add Void Linux and Clang/LLVM support (#63)
* Add Clang/LLVM and Void Linux support
* merge packages, update .gitignore
* Stage 2 of merge
* Stage 3 of merge
* Stage 4 of merge
* Stage 5 of mrege, almost done
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Complete merge of linux-tkg, sync with master (undead PDS 5.8)
* Forgot to add all the patches
* Fix prompt, add config_hardened files
* Fix some stuff for Void
* Merge linux-tkg README, add Void Linux info
* typo
* Fix broken MuQSS on Void at least, Fix CPU opts patch apply
* update to 5.8.8, 5.4.64, block LLVM build with kernel 5.7 because it
seems to segfault at linking vmlinux, fix RC building on Void Linux
* update to 5.8.8, 5.4.64. seems making a confdir variable wasn't
necessary, revert it. sync with master.
* remove variables for messages in favor of defined functions in the Void
template
* resync Linux58-tkg back to master
* Clear patches is the same file for every version
* glitched base is the same file for 5.8 and 5.9, fix wrong version in kernel selection for 5.8, also just use * since it's the same .-.
* merge some patches that are the same together, fix building 5.4 BMQ
* BMQ and PDS ondemand are the same file, fix missing space on kernel version selection
* add Clang makedepends to PKGBUILD, add missing compiler option in customization.cfg, make GCC recommended
* Add kernel selection to install.sh
* Somehow this wasn't edited
* Add optional clang deps to install.sh
* Update gitignore to just ignore linux-5.x instead of commenting it out
* Missing fi
* forgot to sync back install.sh...
* generalize desktop profile configs, uncomment fsync and bcachefs in
customization.cfg, add Project C /PDS and Undead PDS to README, credit
plug, add kernel version selection to customization.cfg, fallback for
compiler selection
* Fix compiler selection error out on Void (for some reason xbps-src always
runs the else statement) also avoid conflict with _compiler, rename it
to _compiler_opt for the actual options in the make command
* oops
* Fix Void extra config not appearing, missing indent for _configfile,
missed PKGBUILD in other commit...
* remove globbing in install.sh
* Move loading of external configuration to the beginning of _tkg_initscript
* Change MuQSS note in README
* 5.4.68, 5.8.12, 5.9-rc7
* Update Project C patchset to v5.8-r3
* 5.8 bcachefs
* LLVM=1 was required to be used on make commands otherwise it would reset
config, we don't need to know if gcc was used to build a kernel (since
llvm is appended to llvm builds), remove the compiler_name if not using
llvm, make kernel versions variables in prepare
* _compileropt does not need to be llvm specific
* add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9
https://lore.kernel.org/amd-gfx/4b5927dd-9f2d-40f9-ef63-007cf7b65f37@amd.com/T/#t
* Revert "add fix for AMD GPU DCN3.0 build with clang in glitched base 5.9"
This reverts commit 276e219f9fe89397332c91e601f34a37b3a0503f.
merged upstream
* Sync with linux-tkg master
* Just stick every patch into it's own kernel version folder
* update 5.4.72, 5.8.16
* check for sum check fail on Void, fix fsync patch
* Update README.md
* README.md formatting
* forgot to move that
* linux59-tkg: Import 5.9 version of the bcachefs patchset - https://gthub.com/koverstreet/bcachefs
Co-authored-by: Lukáš Horáček <flgx@protonmail.com>
2020-10-25 18:43:11 -05:00
done
fi
# userpatches
if [ "$_user_patches" = "true" ]; then
_userpatch_target="linux-${_basekernel}"
_userpatch_ext="my"
user_patcher
fi
# Community patches removal
for _p in ${_community_patches[@]}; do
rm -f "$_where"/$_p
done
if [ "$_distro" = "Arch" ] || [ "$_distro" = "Void" ]; then
# don't run depmod on 'make install'. We'll do this ourselves in packaging
sed -i '2iexit 0' scripts/depmod.sh
# get kernel version
make prepare ${llvm_opt}
fi
# modprobed-db
if [ -z "$_modprobeddb" ]; then
plain ""
plain "Use modprobed db to clean config from unneeded modules?"
plain "Speeds up compilation considerably. Requires root."
plain "https://wiki.archlinux.org/index.php/Modprobed-db"
plain "!!!! Make sure to have a well populated db !!!!"
read -rp "`echo $' > N/y : '`" CONDITIONMPDB;
fi
if [[ "$CONDITIONMPDB" =~ [yY] ]] || [ "$_modprobeddb" = "true" ]; then
if [ "$_distro" != "Void" ]; then
sudo modprobed-db recall
fi
yes "" | make localmodconfig ${llvm_opt}
fi
if [ true = "$_config_fragments" ]; then
local fragments=()
mapfile -d '' -t fragments < <(find "$_where"/ -type f -name "*.myfrag" -print0)
if [ true = "$_config_fragments_no_confirm" ]; then
printf 'Using config fragment %s\n' "${fragments[@]#$_where/}"
else
for i in "${!fragments[@]}"; do
while true; do
read -r -p 'Found config fragment '"${fragments[$i]#$_where/}"', apply it? [y/N] ' CONDITIONMPDB
CONDITIONMPDB="$(printf '%s' "$CONDITIONMPDB" | tr '[:upper:]' '[:lower:]')"
case "$CONDITIONMPDB" in
y|yes)
break;;
n|no|'')
unset fragments[$i]
break;;
*)
echo 'Please answer with yes or no'
esac
done
done
fi
if [ 0 -lt "${#fragments[@]}" ]; then
scripts/kconfig/merge_config.sh -m .config "${fragments[@]}"
fi
fi
# set _menuconfig early for Void
if [ "$_distro" = "Void" ]; then
_menuconfig="Void"
fi
# menuconfig / nconfig
if [ -z "$_menunconfig" ] && [ "$_distro" != "Void" ]; then
plain ""
plain "*Optional* For advanced users - Do you want to use make menuconfig or nconfig"
plain "to configure the kernel before building it?"
plain "If you do, make sure your terminal is currently"
plain "at least 19 lines by 80 columns large or you'll get an error :D"
read -rp "`echo $' > 0. nope\n 1. menuconfig\n 2. nconfig\n 3. xconfig\n choice[0-3?]: '`" CONDITIONMNC;
_menunconfig="$CONDITIONMNC"
fi
if [ 1 = "$_menunconfig" ]; then
cp .config .config.orig
make menuconfig ${llvm_opt}
elif [ 2 = "$_menunconfig" ]; then
cp .config .config.orig
make nconfig ${llvm_opt}
elif [ 3 = "$_menunconfig" ]; then
cp .config .config.orig
make xconfig ${llvm_opt}
else
# rewrite configuration
yes "" | make config ${llvm_opt} >/dev/null
fi
if [ 1 = "$_menunconfig" ] || [ 2 = "$_menunconfig" ] || [ 3 = "$_menunconfig" ]; then
if [ -z "${_diffconfig}" ]; then
while true; do
read -r -p 'Generate a config fragment from your changes? [y/N] ' CONDITIONF
CONDITIONF="$(printf '%s' "$CONDITIONF" | tr '[:upper:]' '[:lower:]')"
case "$CONDITIONF" in
y|yes)
_diffconfig=true
break;;
n|no|'')
_diffconfig=false
break;;
*)
echo 'Please answer with yes or no'
esac
done
fi
if [ true = "$_diffconfig" ]; then
if [ -z "$_diffconfig_name" ]; then
IFS= read -r -p 'Filename for the config fragment [leave empty to not generate fragment]: ' _diffconfig_name
fi
if [ -z "$_diffconfig_name" ]; then
echo 'No file name given, not generating config fragment.'
else (
prev_pwd="${PWD:-$(pwd)}"
cd "$_where"
"${prev_pwd}/scripts/diffconfig" -m "${prev_pwd}/.config.orig" "${prev_pwd}/.config" > "$_diffconfig_name"
) fi
fi
rm .config.orig
fi
if [ "$_distro" = "Arch" ]; then
make -s kernelrelease > version
msg2 "Prepared %s version %s" "$pkgbase" "$(<version)"
fi
}
exit_cleanup() {
# Remove state tracker
rm -f "$_where"/cpuschedset
rm -f "$_where"/compilerset
rm -f "$_where"/versel
# Remove temporarily copied files
rm -rf "$_where"/*.patch
rm -rf "$_where"/*-profile.cfg
rm -f "$_where"/config*
rm -f "$_where"/*.hook
rm -f "$_where"/cleanup
rm -f "$_where"/prepare
# Community patches removal in case of failure
for _p in ${_community_patches[@]}; do
rm -f "$_where"/"$_p"
done
if [ "$_NUKR" = "true" ] && [ "$_where" != "$srcdir" ]; then
rm -rf "$_where"/src/*
# Double tap
rm -rf "$srcdir"/linux-*
rm -rf "$srcdir"/*.xz
rm -rf "$srcdir"/*.patch
rm -rf "$srcdir"/*-profile.cfg
rm -f "$srcdir"/config.x86_64
rm -f "$srcdir"/customization.cfg
else
# Meh
rm -rf "$srcdir"/linux-${_basekernel}/Documentation/filesystems/aufs/*
rm -f "$srcdir"/linux-${_basekernel}/Documentation/ABI/testing/*-aufs
rm -rf "$srcdir"/linux-${_basekernel}/fs/aufs/*
rm -f "$srcdir"/linux-${_basekernel}/include/uapi/linux/aufs*
rm -f "$srcdir"/linux-${_basekernel}/mm/prfile.c
rm -f "$srcdir"/linux-${_basekernel}/block/bfq*
rm -rf "$srcdir"/linux-${_basekernel}/drivers/scsi/vhba/*
rm -rf "$srcdir"/linux-${_basekernel}/fs/exfat/*
rm -f "$srcdir"/linux-${_basekernel}/include/trace/events/fs.h
rm -f "$srcdir"/linux-${_basekernel}/Documentation/scheduler/sched-PDS-mq.txt
rm -f "$srcdir"/linux-${_basekernel}/include/linux/skip_list.h
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/pds.c
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/pds_sched.h
rm -f "$srcdir"/linux-${_basekernel}/Documentation/scheduler/sched-BMQ.txt
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/${_sched}.c
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/sched/alt_debug.c
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/alt_sched.h
rm -f "$srcdir"/linux-${_basekernel}/Documentation/scheduler/sched-BFS.txt
rm -f "$srcdir"/linux-${_basekernel}/Documentation/scheduler/sched-MuQSS.txt
rm -rf "$srcdir"/linux-${_basekernel}/arch/blackfin/*
rm -f "$srcdir"/linux-${_basekernel}/arch/powerpc/configs/c2k_defconfig
rm -f "$srcdir"/linux-${_basekernel}/arch/score/configs/spct6600_defconfig
rm -f "$srcdir"/linux-${_basekernel}/arch/tile/configs/tilegx_defconfig
rm -f "$srcdir"/linux-${_basekernel}/arch/tile/configs/tilepro_defconfig
rm -f "$srcdir"/linux-${_basekernel}/drivers/staging/lustre/lnet/lnet/lib-eq.c
rm -f "$srcdir"/linux-${_basekernel}/kernel/sched/MuQSS*
rm -f "$srcdir"/linux-${_basekernel}/kernel/skip_list.c
rm -f "$srcdir"/linux-${_basekernel}/Documentation/vm/uksm.txt
rm -f "$srcdir"/linux-${_basekernel}/include/linux/sradix-tree.h
rm -f "$srcdir"/linux-${_basekernel}/include/linux/uksm.h
rm -f "$srcdir"/linux-${_basekernel}/lib/sradix-tree.c
rm -f "$srcdir"/linux-${_basekernel}/mm/uksm.c
fi
if [ "${_distro}" = "Arch" ]; then
remove_deps
fi
msg2 'exit cleanup done\n'
if [ -n "$_runtime" ]; then
msg2 "compilation time : \n$_runtime"
fi
}
if [ "$_distro" != "Void" ]; then
trap exit_cleanup EXIT
fi