Debian Edit Modify Build and Flash Kernel: Difference between revisions
No edit summary |
No edit summary |
||
(14 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
<!-- Set release according to "release" parameter in URL and use | <!-- Set release according to "release" parameter in URL and use RELEASE_BUSTER_V3.1_DART-MX8M as default | ||
--> {{ | --> {{INIT_RELEASE_PARAM|RELEASE_BUSTER_V3.1_DART-MX8M}} <!-- | ||
--> {{#lst:Debian_Platform_Customization|{{#var:RELEASE_PARAM | --> {{#lst:Debian_Platform_Customization|{{#var:RELEASE_PARAM}}}} <!-- | ||
--> {{PageHeader|{{#var:HARDWARE_NAME}} - Customizing Debian Linux | --> {{PageHeader|{{#var:HARDWARE_NAME}} - Customizing the Debian Linux kernel}} {{DocImage|category1={{#var:HARDWARE_NAME}}|category2=Debian}} __toc__ | ||
<br> | <br> | ||
This section describes how to | This section describes how to build a new kernel configuration using menuconfig and deploy it. | ||
= Building a custom device tree = | |||
To build and install a custom device tree, add the filename to the variable <code>G_LINUX_DTB</code> of the machine-specific file.<br> | |||
We will demonstrate it here exemplarily with the VAR-SOM-MX8M-NANO, but the same applies also to other modules.<br> | |||
Assuming you have created a custom device tree '''arch/arm64/boot/dts/freescale/imx8mn-var-som-custom.dts''', you can add this to the <code>G_LINUX_DTB</code> list | |||
<syntaxhighlight lang=bash> | |||
G_LINUX_DTB="freescale/imx8mn-var-som-symphony.dtb | |||
freescale/imx8mn-var-som-symphony-root.dtb | |||
freescale/imx8mn-var-som-symphony-m7.dtb | |||
freescale/imx8mn-var-som-symphony-legacy.dtb | |||
freescale/imx8mn-var-som-symphony-legacy-root.dtb | |||
freescale/imx8mn-var-som-symphony-legacy-m7.dtb | |||
freescale/imx8mn-var-som-inmate.dtb" | |||
</syntaxhighlight > | |||
for example, at the end: | |||
<syntaxhighlight lang=bash> | |||
G_LINUX_DTB="freescale/imx8mn-var-som-symphony.dtb | |||
freescale/imx8mn-var-som-symphony-root.dtb | |||
freescale/imx8mn-var-som-symphony-m7.dtb | |||
freescale/imx8mn-var-som-symphony-legacy.dtb | |||
freescale/imx8mn-var-som-symphony-legacy-root.dtb | |||
freescale/imx8mn-var-som-symphony-legacy-m7.dtb | |||
freescale/imx8mn-var-som-inmate.dtb | |||
freescale/imx8mn-var-som-custom.dtb" | |||
</syntaxhighlight > | |||
''File: {{#var:BUILD_FOLDER}}/variscite/imx8mn-var-som/imx8mn-var-som.sh'' | |||
After running the build script: | |||
sudo MACHINE=imx8mn-var-som ./var_make_debian.sh -c kernel | |||
the custom device tree should appear in the output folder: {{#var:BUILD_FOLDER}}/output/imx8mn-var-som-custom.dtb | |||
= Configuring the kernel = | = Configuring the kernel = | ||
The default kernel configuration file used by Debian is part of the kernel source tree and is located at: | The default kernel configuration file used by Debian is part of the kernel source tree and is located at: | ||
{{#var:BUILD_FOLDER}}/src/kernel/arch/{{#ifeq: {{#var:SOC_SERIES}}|imx8|arm64|arm}}/configs/{{#var:KERNEL_DEFCONFIG}} | {{#var:BUILD_FOLDER}}/src/kernel/arch/{{#ifeq: {{#var:SOC_SERIES}}|imx8|arm64|arm}}/configs/{{#var:KERNEL_DEFCONFIG}} | ||
= | == Modifying the kernel configuration == | ||
To modify the kernel configuration (add/remove features and drivers) please follow the steps below: <br> | To modify the kernel configuration (add/remove features and drivers) please follow the steps below: <br> | ||
Line 28: | Line 59: | ||
$ sudo cp defconfig arch/{{#var:ARCH}}/configs/{{#var:KERNEL_DEFCONFIG}} | $ sudo cp defconfig arch/{{#var:ARCH}}/configs/{{#var:KERNEL_DEFCONFIG}} | ||
== Building | == Building a new kernel configuration == | ||
=== Build kernel, dtb files and kernel modules === | === Build the kernel image, dtb files and kernel modules === | ||
$ cd {{#var:BUILD_FOLDER}} | $ cd {{#var:BUILD_FOLDER}} | ||
$ sudo {{#var:BUILD_SCRIPT}} -c kernel | $ sudo {{#var:BUILD_SCRIPT}} -c kernel | ||
$ sudo {{#var:BUILD_SCRIPT}} -c modules | $ sudo {{#var:BUILD_SCRIPT}} -c modules | ||
$ sudo {{#var:BUILD_SCRIPT}} -c kernelheaders | |||
{{#ifeq: {{#var:HARDWARE_NAME}} | VAR-SOM-MX8X |{{#ifeq: {{#var:MACHINE_NAME_B0}} | imx8qxpb0-var-som | | {{#ifeq: {{#var:HARDWARE_NAME}} | VAR-SOM-MX8X |{{#ifeq: {{#var:MACHINE_NAME_B0}} | imx8qxpb0-var-som | | ||
Or, to build kernel, dtb, kernel modules for i.MXQXP SOC revision B0: | Or, to build kernel, dtb, kernel modules for i.MXQXP SOC revision B0: | ||
$ sudo {{#var:BUILD_SCRIPT_B0}} -c kernel | $ sudo {{#var:BUILD_SCRIPT_B0}} -c kernel | ||
$ sudo {{#var:BUILD_SCRIPT_B0}} -c modules | $ sudo {{#var:BUILD_SCRIPT_B0}} -c modules | ||
$ sudo {{#var: BUILD_SCRIPT_B0}} -c kernelheaders | |||
|}}|}} | |}}|}} | ||
{{Note|Note: If you have modules newly added / removed, make sure you run | {{Note|Note: If you have modules newly added / removed, make sure you run the following command:}} | ||
$ sudo {{#var:BUILD_SCRIPT}} -c rtar | $ sudo {{#var:BUILD_SCRIPT}} -c rtar | ||
{{#ifeq: {{#var:HARDWARE_NAME}} | VAR-SOM-MX8X |{{#ifeq: {{#var:MACHINE_NAME_B0}} | imx8qxpb0-var-som | | {{#ifeq: {{#var:SOC_SERIES}}|imx8| | ||
{{#ifeq: {{#var:HARDWARE_NAME}} | VAR-SOM-MX8X |{{#ifeq: {{#var:MACHINE_NAME_B0}} | imx8qxpb0-var-som | | |||
Or, to build kernel, dtb, kernel modules for i.MXQXP SOC revision B0: | Or, to build kernel, dtb, kernel modules for i.MXQXP SOC revision B0: | ||
$ sudo {{#var:BUILD_SCRIPT_B0}} -c rtar | $ sudo {{#var:BUILD_SCRIPT_B0}} -c rtar | ||
|}}|}} | |}}|}} | ||
| | | | ||
$ sudo {{#var:BUILD_SCRIPT}} -c rubi | $ sudo {{#var:BUILD_SCRIPT}} -c rubi | ||
}} | }} | ||
This will create rootfs.tar.gz that contains your new modules. | This will create {{#ifeq: {{#var:SOC_SERIES}}|imx8|a rootfs.tar.gz file that contains|rootfs.tar.gz and rootfs.ubi.img files that contain}} your new modules. | ||
= Deploy the kernel image, dtb files and kernel modules = | |||
== Deploy Kernel, dtb via network == | == Deploy Kernel, dtb via network == | ||
Line 90: | Line 120: | ||
$ scp output/{{#var:KERNEL_IMAGE}} root@<yourboard-ip>:{{#ifeq: {{#var:SOC_SERIES}}|imx8|/boot/|/tmp/}} | $ scp output/{{#var:KERNEL_IMAGE}} root@<yourboard-ip>:{{#ifeq: {{#var:SOC_SERIES}}|imx8|/boot/|/tmp/}} | ||
Once prompted give root as password. <yourboard-ip> is ipaddress of your board.<br> | Once prompted give root as password. <yourboard-ip> is ipaddress of your board.<br> | ||
Once transfer is done, follow below commands <br> | Once transfer is done, follow below commands<br> | ||
On Target Console:<br> | On Target Console:<br> | ||
{{#ifeq: {{#var:SOC_SERIES}}|imx8| | {{#ifeq: {{#var:SOC_SERIES}}|imx8| |
Latest revision as of 21:39, 27 April 2023
This page is using the default release RELEASE_BUSTER_V3.1_DART-MX8M.
To view this page for a specific Variscite SoM and software release, please follow these steps:
- Visit variwiki.com
- Select your SoM
- Select the software release
This section describes how to build a new kernel configuration using menuconfig and deploy it.
Building a custom device tree
To build and install a custom device tree, add the filename to the variable G_LINUX_DTB
of the machine-specific file.
We will demonstrate it here exemplarily with the VAR-SOM-MX8M-NANO, but the same applies also to other modules.
Assuming you have created a custom device tree arch/arm64/boot/dts/freescale/imx8mn-var-som-custom.dts, you can add this to the G_LINUX_DTB
list
G_LINUX_DTB="freescale/imx8mn-var-som-symphony.dtb
freescale/imx8mn-var-som-symphony-root.dtb
freescale/imx8mn-var-som-symphony-m7.dtb
freescale/imx8mn-var-som-symphony-legacy.dtb
freescale/imx8mn-var-som-symphony-legacy-root.dtb
freescale/imx8mn-var-som-symphony-legacy-m7.dtb
freescale/imx8mn-var-som-inmate.dtb"
for example, at the end:
G_LINUX_DTB="freescale/imx8mn-var-som-symphony.dtb
freescale/imx8mn-var-som-symphony-root.dtb
freescale/imx8mn-var-som-symphony-m7.dtb
freescale/imx8mn-var-som-symphony-legacy.dtb
freescale/imx8mn-var-som-symphony-legacy-root.dtb
freescale/imx8mn-var-som-symphony-legacy-m7.dtb
freescale/imx8mn-var-som-inmate.dtb
freescale/imx8mn-var-som-custom.dtb"
File: ~/debian_imx8mq-var-dart/variscite/imx8mn-var-som/imx8mn-var-som.sh
After running the build script:
sudo MACHINE=imx8mn-var-som ./var_make_debian.sh -c kernel
the custom device tree should appear in the output folder: ~/debian_imx8mq-var-dart/output/imx8mn-var-som-custom.dtb
Configuring the kernel
The default kernel configuration file used by Debian is part of the kernel source tree and is located at:
~/debian_imx8mq-var-dart/src/kernel/arch/arm64/configs/imx8_var_defconfig
Modifying the kernel configuration
To modify the kernel configuration (add/remove features and drivers) please follow the steps below:
$ cd ~/debian_imx8mq-var-dart/src/kernel $ sudo make ARCH=arm64 mrproper $ sudo make ARCH=arm64 imx8_var_defconfig $ sudo make ARCH=arm64 menuconfig
Navigate the menu and select the desired kernel functionality
Exit the menu and answer "Yes" when asked "Do you wish to save your new configuration?"
$ sudo make ARCH=arm64 savedefconfig $ sudo cp arch/arm64/configs/imx8_var_defconfig arch/arm64/configs/imx8_var_defconfig.orig $ sudo cp defconfig arch/arm64/configs/imx8_var_defconfig
Building a new kernel configuration
Build the kernel image, dtb files and kernel modules
$ cd ~/debian_imx8mq-var-dart $ sudo MACHINE=imx8mq-var-dart ./var_make_debian.sh -c kernel $ sudo MACHINE=imx8mq-var-dart ./var_make_debian.sh -c modules $ sudo MACHINE=imx8mq-var-dart ./var_make_debian.sh -c kernelheaders
$ sudo MACHINE=imx8mq-var-dart ./var_make_debian.sh -c rtar
This will create a rootfs.tar.gz file that contains your new modules.
Deploy the kernel image, dtb files and kernel modules
Deploy Kernel, dtb via network
Updating Device tree to target
Transfer dtbs to target
On PC:
$ cd ~/debian_imx8mq-var-dart $ scp output/*.dtb root@<yourboard-ip>:/boot/
Once prompted give root as password. <yourboard-ip> is ipaddress of your board.
Once transfer is done, follow below commands
On Target Console:
# sync;reboot
Updating kernel Image to target
Transfer the output/zImage kernel image to target
On PC:
$ scp output/zImage root@<yourboard-ip>:/boot/
Once prompted give root as password. <yourboard-ip> is ipaddress of your board.
Once transfer is done, follow below commands
On Target Console:
# sync;reboot