[yocto] How to define and build device tree in Yocto?
Bas Mevissen
abuse at basmevissen.nl
Tue May 7 02:36:34 PDT 2019
On 2019-05-07 08:41, Gabriele Zampieri wrote:
> Hi all,
>
> Bas' defconfig trick (do_set_custom_defconfig) is already implemented
> by Yocto itself: just add a file called defconfig to SRC_URI and the
> system will apply it for you (you can read kernel_do_configure in
> kernel.bbclass) . For more information check
> https://www.yoctoproject.org/docs/latest/mega-manual/mega-manual.html#changing-the-configuration
>
Yes, that is the better solution. Not sure why I did not use it. I
created the "do_set_custom_defconfig" years ago. Maybe to be able in the
future to select one of different defconfigs based upon a local.conf
setting. There can only be one in the kernel bbclass. I would prefer to
be able to add multiple files ending on e.g. _defconfig and be able to
set a variable to select the one to use.
Maybe we can define something similar for the device tree file source
file in the bbclass. It would obviously only be valid for architectures
supporting device trees.
>> how did you do the defconfig usually?
>
> The link I put above asks this question too.
>
>>> # The first patch simply appends my custom DTS to the list of DTD
>>> files in the Makefile
>
> and
>
>>> I usually don't need to make large modifications to the kernel
>>> source,
>>> so I don't need to clone the kernel, but use the default kernel for
>>> the
>>> SoC with some patches.
>
> How do you generate that patches?
>
> I know that the kernel repo is huge, but having a local kernel tree can
> be very useful and allows you to do all the patchworks easily. It also
> speeds up the test if you are planning to upgrade some part of it.
>
I use custom BSP development environment that contains a small build
environment for building the device tree from source, u-boot
development, kernel tree (shallow) clone, extended mfgtools ramdisk with
some utilities and a customized version of mfgtools that loads the
before-mentioned parts in RAM and starts them. This allows me to do very
quick cycles.
The kernel patches are created using git against a (shallow) clone of
the kernel I want to use. Mostly it is nothing more than a few small
fixes.
U-boot is a full clone as I setup a new board definition for the custom
board (mostly derived from an existing dev board, both hw and sw wise).
-- Bas.
> Best regards,
>
> Gabriele
>
> Il giorno mar 7 mag 2019 alle ore 02:14 JH <jupiter.hce at gmail.com> ha
> scritto:
>
>> Hi Bas and Gabriele,
>>
>> Thank you so much for you advice.
>>
>>> My usual way of doing it is as follows:
>>>
>>> I usually don't need to make large modifications to the kernel
>>> source,
>>> so I don't need to clone the kernel, but use the default kernel for
>>> the
>>> SoC with some patches.
>>
>> So do I.
>>
>>> I use a platform support layer and add a .bbappend file for the (arm)
>>> kernel to add a custom dts and .config files, together with some
>>> small
>>> patches:
>>>
>>> *** File
>>> meta-<platform>/recipes-kernel/linux/linux-<version>_%.bbappend:
>>>
>>> THISAPPENDFILESDIR := "${THISDIR}/files"
>>> FILESEXTRAPATHS_prepend := "${THISDIR}/files:"
>>>
>>> require linux-set-custom-defconfig.inc
>>> require linux-add-custom-dts.inc
>>>
>>> # The first patch simply appends my custom DTS to the list of DTD
>>> files
>>> in the Makefile
>>> SRC_URI += \
>>> "file://add-custom-dts.patch \
>>> file://some_other.patch \
>>> file://another_driver_patch.patch \
>>> "
>>>
>>> *** File
>>> meta-<platform>/recipes-kernel/linux/linux-add-custom-dts.inc
>>>
>>> do_add_platform_dts() {
>>> cp -f "${THISAPPENDFILESDIR}/custom.dts" \
>>> "${WORKDIR}/git/arch/arm/boot/dts"
>>> }
>>
>> That is exactly I am looking for the proper location of the dts files,
>> thank you so much.
>>
>>> addtask add_platform_dts before do_preconfigure after do_patch
>>>
>>> *** File
>>> meta-<platform>/recipes-kernel/linux/linux-set-custom-defconfig.inc
>>>
>>> do_set_custom_defconfig() {
>>> cp -f "${THISAPPENDFILESDIR}/defconfig" "${WORKDIR}/defconfig"
>>> }
>>>
>>> addtask set_custom_defconfig before do_preconfigure after do_patch
>>
>> Good advice, I missed that one, how did you do the defconfig usually?
>> Compile it in kernel source like using following command?
>>
>> make ARCH=arm imx_v6_v7_defconfig
>>
>>> It is maybe a bit complex, but it saves cloning the kernel for the
>>> sake
>>> of just adding a single DTS with defconfig and a few patches.
>>
>> That is procedure I was looking for.
>>
>>> Hope this helps,
>>
>> Great helps, thank you so much.
>>
>> - jupiter
>>
>>> Bas.
>>>
>> --
>> _______________________________________________
>> yocto mailing list
>> yocto at yoctoproject.org
>> https://lists.yoctoproject.org/listinfo/yocto
More information about the yocto
mailing list