- PVSM.RU - https://www.pvsm.ru -
После разработки кастомного загрузчика для своего телефона мне захотелось реализовать вывод ядерных логов на дисплей, как это умеют делать десктопные дистрибутивы Linux. А всё потому, что лично мне при загрузке телефона намного интереснее наблюдать мелькающие kmsg логи, нежели наблюдать сначала логотип загрузчика, а затем ещё и бут-анимацию Android системы. За два года «скучные обоины» уже приелись.
Сейчас попытаюсь вкратце рассказать о модуле LLCON для Android ядра, который реализует низкоуровневый вывод kmsg логов на дисплей.
Сразу упомяну о том, что в любом Linux ядре есть модуль, который занимается выводом ядерных логов на экран. Данный механизм ядра включается при помощи указания опции FRAMEBUFFER_CONSOLE. Но данный механизм работает только через драйвер дисплея, который обычно инициализируется в самую последнюю очередь (этап late_init). Из-за этой особенности первичный логотип загрузчика будет отображаться довольно значительное время.
Слова «низкоуровневый вывод» я употребляю не спроста, т.к. модуль LLCON напрямую работает с видео-памятью (сразу вспоминаются юные поделки для MS-DOS) и при этом начинает свою работу перед инициализацией внутренних драйверов Linux ядра (early_init). Именно данные особенности и позволяют LLCON начать вывод логов ядра на экран как можно быстрее.
После добавления LLCON модуля следует в конфиг ядра добавить следующие опции:
CONFIG_VT=y
CONFIG_LLCON=y
CONFIG_FONTS=y
CONFIG_FONT_6x11=y
CONFIG_FONT_8x16=y
CONFIG_FONT_SUN12x22=y
В данном случае я указал 3 разных шрифта, т.к. в используемом мною загрузчике можно выбирать любой шрифт. Но если нужно соблюдать минимальный размер образа ядра, то следует указать только один шрифт.
Перед стартом сборки доработанного ядра не стоит забыть предварительно добавить в BoardConfig новую опцию ядра:
androidboot.llcon=<mode>,<delay>,<textwrap>,<fb_addr>,<fb_bpp>,<fb_height>,<fb_width>,<fb_stride>,<font_size>,<font_color>
Пример:
androidboot.llcon=2,100,0,0x03200000,24,1280,720,720,8,0xFFFFFF
Целиком копировать сюда исходники модуля LLCON я не стану, а только укажу ссылки на соответствующие патчи:
Так же стоит отметить, что без доработки init модуля (который находится в ramdisk'е) при инициализации подсистем андройда начнётся воспроизводиться бут-анимация. Поэтому при использовании LLCON следует автоматизировать отключение бут-анимации. Патч для отключения бут-анимации: github.com/jsr-d10/android_device_jsr_d10f/commit/bb7caeffe38e26a5d9d855d2ba3a7cb162884696 [3]
Демонстрация работы модуля LLCON:
Модуль LLCON так же имеет дополнительный функционал, который полезен для:
Но об этих возможностях LLCON я постараюсь рассказать в следующий раз.
Автор: acDev
Источник [4]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/linux/191880
Ссылки в тексте:
[1] github.com/jsr-d10/android_kernel_jsr_msm8226/commits/mm-llcon5: https://github.com/jsr-d10/android_kernel_jsr_msm8226/commits/mm-llcon5
[2] github.com/jsr-d10/android_kernel_jsr_msm8228_1.3.3/commits/d10-llcon5: https://github.com/jsr-d10/android_kernel_jsr_msm8228_1.3.3/commits/d10-llcon5
[3] github.com/jsr-d10/android_device_jsr_d10f/commit/bb7caeffe38e26a5d9d855d2ba3a7cb162884696: https://github.com/jsr-d10/android_device_jsr_d10f/commit/bb7caeffe38e26a5d9d855d2ba3a7cb162884696
[4] Источник: https://habrahabr.ru/post/310886/?utm_source=habrahabr&utm_medium=rss&utm_campaign=best
Нажмите здесь для печати.