Сборка ядра под себя

Зачем:

Думаю многие слышали про дистрибутив gentoo, как и про то, что его обновление может занимать часы (дни, месяцы, годы, …). Такой геморрой определён политикой дистрибутива, так называемый source-based. То есть компиляция всего и вся из исходников. И в этом есть свой профит. Если вы собираете программу на своём компьютере и прописываете  определённые флаги компиляции, то конечный исполняемый файл оптимизируется именно под ваш процессор. Да, прирост производительности может быть небольшим, незаметным глазу, но за счёт количества пересобранных приложений достигается ощутимый выигрыш в скорости работы системы (по идее).

С ядром же история несколько иная. Да, компиляция под себя оптимизирует ядро под ваш проц, но есть ещё один важный нюанс. Патчи.

Их огромное количество и я при всём желании не смогу описать их все. Тем более что они описаны на  арчевики.

Мой рандомайзер выстрелил в список и попал в патч linux-pf.

Кстати вот статейка на хабре, ему посвящёна. В этой статье приведены какие-то таблицы, созданные с помощью UnixBench. Я не поленился и прогнал этот бенчмарк у себя. Так как выхлоп слишком большой я заменю его ссылочками на pastebin.

Ядро mainline — типа экспериментальная версия, которая в манжаре уже собрана (но без драйверов и важных финтифлюшек), и которую я собрал на арче сам чисто по приколу.

========================================================================
   BYTE UNIX Benchmarks (Version 5.1.3)

   System: archlinux: GNU/Linux
   OS: GNU/Linux -- 5.3.0-rc4-mainline -- #1 SMP PREEMPT Mon Aug 12 18:38:59 MSK 2019
   Machine: x86_64 (unknown)
   Language: en_US.utf8 (charmap="UTF-8", collate="UTF-8")
   CPU 0: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 1: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 2: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 3: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 4: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 5: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 6: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 7: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (4790.4 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   03:37:14 up 2 min,  1 user,  load average: 3.10, 1.90, 0.76; runlevel unknown

------------------------------------------------------------------------
Benchmark Run: Вс авг 18 2019 03:37:14 - 04:05:37
8 CPUs in system; running 1 parallel copy of tests

Dhrystone 2 using register variables       34169001.9 lps   (10.0 s, 7 samples)
Double-Precision Whetstone                     5421.1 MWIPS (9.4 s, 7 samples)
Execl Throughput                               3016.0 lps   (29.9 s, 2 samples)
File Copy 1024 bufsize 2000 maxblocks        410703.4 KBps  (30.0 s, 2 samples)
File Copy 256 bufsize 500 maxblocks           96583.2 KBps  (30.0 s, 2 samples)
File Copy 4096 bufsize 8000 maxblocks       1148064.9 KBps  (30.0 s, 2 samples)
Pipe Throughput                              503500.0 lps   (10.0 s, 7 samples)
Pipe-based Context Switching                  49623.9 lps   (10.0 s, 7 samples)
Process Creation                               2992.2 lps   (30.0 s, 2 samples)
Shell Scripts (1 concurrent)                   2130.3 lpm   (60.0 s, 2 samples)
Shell Scripts (8 concurrent)                    764.0 lpm   (60.0 s, 2 samples)
System Call Overhead                         271406.7 lps   (10.0 s, 7 samples)

System Benchmarks Index Values               BASELINE       RESULT    INDEX
Dhrystone 2 using register variables         116700.0   34169001.9   2927.9
Double-Precision Whetstone                       55.0       5421.1    985.7
Execl Throughput                                 43.0       3016.0    701.4
File Copy 1024 bufsize 2000 maxblocks          3960.0     410703.4   1037.1
File Copy 256 bufsize 500 maxblocks            1655.0      96583.2    583.6
File Copy 4096 bufsize 8000 maxblocks          5800.0    1148064.9   1979.4
Pipe Throughput                               12440.0     503500.0    404.7
Pipe-based Context Switching                   4000.0      49623.9    124.1
Process Creation                                126.0       2992.2    237.5
Shell Scripts (1 concurrent)                     42.4       2130.3    502.4
Shell Scripts (8 concurrent)                      6.0        764.0   1273.4
System Call Overhead                          15000.0     271406.7    180.9
                                                                   ========
System Benchmarks Index Score                                         621.9

------------------------------------------------------------------------
Benchmark Run: Вс авг 18 2019 04:05:37 - 04:33:56
8 CPUs in system; running 8 parallel copies of tests

Dhrystone 2 using register variables       80371026.4 lps   (10.0 s, 7 samples)
Double-Precision Whetstone                    35358.2 MWIPS (10.8 s, 7 samples)
Execl Throughput                               7521.7 lps   (29.9 s, 2 samples)
File Copy 1024 bufsize 2000 maxblocks        196291.0 KBps  (30.0 s, 2 samples)
File Copy 256 bufsize 500 maxblocks           64360.9 KBps  (30.0 s, 2 samples)
File Copy 4096 bufsize 8000 maxblocks        733168.9 KBps  (30.0 s, 2 samples)
Pipe Throughput                              873622.1 lps   (10.0 s, 7 samples)
Pipe-based Context Switching                  92215.8 lps   (10.0 s, 7 samples)
Process Creation                               9947.5 lps   (30.0 s, 2 samples)
Shell Scripts (1 concurrent)                  10548.6 lpm   (60.0 s, 2 samples)
Shell Scripts (8 concurrent)                   1492.0 lpm   (60.1 s, 2 samples)
System Call Overhead                        1201385.6 lps   (10.0 s, 7 samples)

System Benchmarks Index Values               BASELINE       RESULT    INDEX
Dhrystone 2 using register variables         116700.0   80371026.4   6887.0
Double-Precision Whetstone                       55.0      35358.2   6428.8
Execl Throughput                                 43.0       7521.7   1749.2
File Copy 1024 bufsize 2000 maxblocks          3960.0     196291.0    495.7
File Copy 256 bufsize 500 maxblocks            1655.0      64360.9    388.9
File Copy 4096 bufsize 8000 maxblocks          5800.0     733168.9   1264.1
Pipe Throughput                               12440.0     873622.1    702.3
Pipe-based Context Switching                   4000.0      92215.8    230.5
Process Creation                                126.0       9947.5    789.5
Shell Scripts (1 concurrent)                     42.4      10548.6   2487.9
Shell Scripts (8 concurrent)                      6.0       1492.0   2486.7
System Call Overhead                          15000.0    1201385.6    800.9
                                                                   ========
System Benchmarks Index Score                                        1229.7

Патченное ядро linux-pf.

========================================================================
   BYTE UNIX Benchmarks (Version 5.1.3)

   System: archlinux: GNU/Linux
   OS: GNU/Linux -- 5.2.5-pf -- #1 SMP PREEMPT Sun Aug 18 01:54:40 MSK 2019
   Machine: x86_64 (unknown)
   Language: en_US.utf8 (charmap="UTF-8", collate="UTF-8")
   CPU 0: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 1: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 2: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 3: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 4: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 5: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 6: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   CPU 7: Intel(R) Core(TM) i7-4700MQ CPU @ 2.40GHz (15963.0 bogomips)
          Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT, SYSCALL/SYSRET, Intel virtualization
   02:27:30 up 14 min,  1 user,  load average: 3.07, 2.62, 1.87; runlevel unknown

------------------------------------------------------------------------
Benchmark Run: Вс авг 18 2019 02:27:30 - 02:55:26
8 CPUs in system; running 1 parallel copy of tests

Dhrystone 2 using register variables       28102565.1 lps   (10.0 s, 7 samples)
Double-Precision Whetstone                     5322.5 MWIPS (7.7 s, 7 samples)
Execl Throughput                               3065.8 lps   (29.7 s, 2 samples)
File Copy 1024 bufsize 2000 maxblocks        424274.1 KBps  (30.0 s, 2 samples)
File Copy 256 bufsize 500 maxblocks          111489.1 KBps  (30.0 s, 2 samples)
File Copy 4096 bufsize 8000 maxblocks       1216662.6 KBps  (30.0 s, 2 samples)
Pipe Throughput                              614354.3 lps   (10.0 s, 7 samples)
Pipe-based Context Switching                 146982.7 lps   (10.0 s, 7 samples)
Process Creation                               6229.7 lps   (30.0 s, 2 samples)
Shell Scripts (1 concurrent)                   3328.3 lpm   (60.0 s, 2 samples)
Shell Scripts (8 concurrent)                   1092.1 lpm   (60.0 s, 2 samples)
System Call Overhead                         348862.5 lps   (10.0 s, 7 samples)

System Benchmarks Index Values               BASELINE       RESULT    INDEX
Dhrystone 2 using register variables         116700.0   28102565.1   2408.1
Double-Precision Whetstone                       55.0       5322.5    967.7
Execl Throughput                                 43.0       3065.8    713.0
File Copy 1024 bufsize 2000 maxblocks          3960.0     424274.1   1071.4
File Copy 256 bufsize 500 maxblocks            1655.0     111489.1    673.7
File Copy 4096 bufsize 8000 maxblocks          5800.0    1216662.6   2097.7
Pipe Throughput                               12440.0     614354.3    493.9
Pipe-based Context Switching                   4000.0     146982.7    367.5
Process Creation                                126.0       6229.7    494.4
Shell Scripts (1 concurrent)                     42.4       3328.3    785.0
Shell Scripts (8 concurrent)                      6.0       1092.1   1820.2
System Call Overhead                          15000.0     348862.5    232.6
                                                                   ========
System Benchmarks Index Score                                         805.9

------------------------------------------------------------------------
Benchmark Run: Вс авг 18 2019 02:55:26 - 03:23:44
8 CPUs in system; running 8 parallel copies of tests

Dhrystone 2 using register variables       77432227.4 lps   (10.0 s, 7 samples)
Double-Precision Whetstone                    22659.5 MWIPS (8.4 s, 7 samples)
Execl Throughput                               8654.5 lps   (29.8 s, 2 samples)
File Copy 1024 bufsize 2000 maxblocks        684336.4 KBps  (30.0 s, 2 samples)
File Copy 256 bufsize 500 maxblocks          199066.7 KBps  (30.0 s, 2 samples)
File Copy 4096 bufsize 8000 maxblocks       1899537.2 KBps  (30.0 s, 2 samples)
Pipe Throughput                             3647132.9 lps   (10.0 s, 7 samples)
Pipe-based Context Switching                 222343.4 lps   (10.0 s, 7 samples)
Process Creation                              50463.7 lps   (30.0 s, 2 samples)
Shell Scripts (1 concurrent)                  15001.1 lpm   (60.0 s, 2 samples)
Shell Scripts (8 concurrent)                   1018.2 lpm   (60.2 s, 2 samples)
System Call Overhead                        2216016.2 lps   (10.0 s, 7 samples)

System Benchmarks Index Values               BASELINE       RESULT    INDEX
Dhrystone 2 using register variables         116700.0   77432227.4   6635.2
Double-Precision Whetstone                       55.0      22659.5   4119.9
Execl Throughput                                 43.0       8654.5   2012.7
File Copy 1024 bufsize 2000 maxblocks          3960.0     684336.4   1728.1
File Copy 256 bufsize 500 maxblocks            1655.0     199066.7   1202.8
File Copy 4096 bufsize 8000 maxblocks          5800.0    1899537.2   3275.1
Pipe Throughput                               12440.0    3647132.9   2931.8
Pipe-based Context Switching                   4000.0     222343.4    555.9
Process Creation                                126.0      50463.7   4005.1
Shell Scripts (1 concurrent)                     42.4      15001.1   3538.0
Shell Scripts (8 concurrent)                      6.0       1018.2   1697.0
System Call Overhead                          15000.0    2216016.2   1477.3
                                                                   ========
System Benchmarks Index Score                                        2298.0

Насколько я понял, тест прогонялся в однопоточном и восьмипоточном режимах. И если для одного потока конечный балл не сильно различается (621 для mainline и 805 для pf), то для многопоточного режима разница уже ппц как ощутима (2298 для pf и 1229 для mainline).

Опишу немного что было протестировано:

  • Dhrystone — используется для измерения и сравнения производительности компьютеров. (и сами понимайте что это значит, я не понял).
  • Double-Precision — используется для измерения скорости и эффективности операций с плавающей запятой.
  • Execl Throughput — используется для измерения количества вызовов execl, которые могут быть выполнены в секунду.
  • File Copy — используется для измерения скорости, с которой данные могут передаваться из одного файла в другой. При тестировании изменяется размер блоков для копирования и их количество.
  • Pipe Throughput — сколько раз (в секунду) процесс может записать 512 байт в канал и прочитать их обратно.
  • Process creation — время создания потока
  • Shell scripts — сколько раз в секунду можно запустить скрипты на shell
  • Systyem call overload — задержки системных вызовов

На стандартном ядре арча я запускать тест не стал, потому что мне лениво ждать ещё пол-часа. Но не думаю что результат будет сильно отличаться от linux-mainline, так как он был собран с дефолтным конфигом арча.

Если вас впечатлили результаты тестов и вам захочется собрать для себя ядро linux-pf, то вот кратенький инструкшн

yay -S linux-pf

ВАЖНО!!!

Так как ядро большое и собираться будет долго, то настоятельно вам советую поправить /etc/makepkg.conf в соответствии с мануалом. Внимательно смотреть на секцию «Настройка: архитектура и флаги компиляции» и всё что ниже.

ВАЖНО!!!

Сборка потребует от юзера тыкать на кнопочки, поэтому pamac и octopi сразу пролетают. Сразу юзайте консольные утилиты во избежание баттхерта.

В процессе сборки ядра вас 2 раза будут спрашивать, надо ли вам что-то изменить:Running kernel config выбирать бессмысленно, так как у вас он будет таким же, как дефолтная опция. А вот make localmodconfig уже интереснее: он настроит ядро на сборку только тех модулей, что сейчас используются.

Это позволяет не собирать кучу ненужных драйверов и всякого мусора, но так же может выстрелить вам в ногу (как мне). Например если вы захотите скинуть данные на флешку или внешний хард, то система (ядро) ваше устройство просто не увидит, так как за это отвечает отдельный модуль, который конечно же собран не был. Он бы собрался, если бы вы при сборке ядра воткнули в комп флешку. И таких неочевидных мест довольно много: за сеть в виртуальной машине отвечает отдельный модуль (за саму вирутализацию тоже). Поэтому используйте эту опцию если уверены в своих силах и вам хватит воли и терпения пересобирать  ядро несколько раз, чтобы включить недостающий модуль.

Конечно проще нажать энтер и собрать олл-инклюзив, и оно даже будет работать, но это не по-гиковски)

И второй вопрос, сразу после первого:

Это опции «досборки» ядра. Если вам позарез надо включить какую-то фичу или добавить модуль. Первые четыре опции отличаются только графикой, с помощью которой будут отрисовываться. Самый первый вариант выбирать не советую, так как это крайне неудобно. make nconfig вполне достаточно.

make localyesconfig это отдельная тема. Он похож на localmodconfig, но если первый все запущенные модули включит в ядро в виде модуля, то localyesconfig вкомпилирует эти модули в ядро. Это может быть очень болезненно, например, если у вас видеокарта NVIDIA и вы захотите использовать проприеритарные драйвера. По умолчанию nouveau (свободный драйвер нвидии) включён в ядро как модуль и его можно выгрузить с помощью команды modprobe -r nouveau. Собственно для работы проприеритарного драйвера он и должен быть выгружен. Если же драйвер вкомпилирован в ядро, то вытащить его оттуда уже нельзя и не видать вам игрулек с фпс выше 10.

Сама сборка займёт минут 20-40, в зависимости от мощности проца.

ВАЖНО!!!

После сборки я обнаружил то-ли баг, то-ли фичу. По умолчанию для ядра собираются так же и хедеры, в данном случае linux-pf-headers. И при сборке пакета они собираются, и находятся в той же папке где и собранный пакет с ядром. Но по какой-то странной причине они не ставятся вместе с ядром. Чтобы это недоразумание исправить, вам нужно зайти в папку где ядрышко собиралось и ручками доустановить оставшиеся пакеты:

cd ~/.cache/yay/linux-pf
yay -U *.pkg.tar*

Если вы пакеты не поставите, то могут быть проблемы при запуске, установке драйверов, да и граб просто ядро не найдёт.

Самое интересное

Пора ставить драйвера!

Тем, у кого AMD или Intel бояться нечего, а вот пользующим нвидию лучше покрепче сжать сфинктер.

Если вы используете bumblebee или у вас только видеокарта нвидия, то вам достаточно поставить пакеты nvidia-pf и bbswitch-pf.

У меня такой мэджик почему-то не сработал, возможно из за того что я использую optimus-manager. На замену я поставил bbswitch-dkms и nvidia-dkms. Тут описано, что это за зверь. Самое важное уже во втором абзаце:

​Это означает, что пользователь может не ждать, пока какая-то компания, проект или сопроводитель пакета выпустит новую версию модуля. После введения Pacman#Hooks пересборка модулей осуществляется автоматически во время обновления ядра.

То, что доктор прописал для нашего кастомного ядра.

ВАЖНО!!!

В манжаре нету nvidia-dkms, но есть тема на форуме, где ответил сам (!!!) oberon.

https://forum.manjaro.org/t/installation-linux-pf-in-manjaro/8642

В итоге всё решилось установкой двух арчовых пакетов. Раз вы досюда дочитали, то проще уж накатить арчик.

Рейтинг
( Пока оценок нет )
Понравилась статья? Поделиться с друзьями:
Добавить комментарий

;-) :| :x :twisted: :smile: :shock: :sad: :roll: :razz: :oops: :o :mrgreen: :lol: :idea: :grin: :evil: :cry: :cool: :arrow: :???: :?: :!: