[PATCH 1/2] of: Add support for linking device tree blobs into vmlinux
Dirk Brandewie
dirk.brandewie at gmail.com
Tue Nov 16 16:28:27 EST 2010
On 11/15/2010 09:17 PM, Grant Likely wrote:
> On Mon, Nov 15, 2010 at 10:06 PM, Dirk Brandewie
> <dirk.brandewie at gmail.com> wrote:
>> On 11/15/2010 08:41 PM, Grant Likely wrote:
>>>
>>> On Mon, Nov 15, 2010 at 08:01:20PM -0800, dirk.brandewie at gmail.com wrote:
>>>>
>>>> From: Dirk Brandewie<dirk.brandewie at gmail.com>
>>>>
>>>> This patch adds support for linking device tree blobs into
>>>> vmlinux. The device tree blobs are placed in the init.data
>>>> section.
>>>>
>>>> Signed-off-by: Dirk Brandewie<dirk.brandewie at gmail.com>
>>>> ---
>>>> include/asm-generic/vmlinux.lds.h | 19 +++++++++++++++++--
>>>> scripts/Makefile.lib | 17 +++++++++++++++++
>>>> 2 files changed, 34 insertions(+), 2 deletions(-)
>>>>
>>>> diff --git a/include/asm-generic/vmlinux.lds.h
>>>> b/include/asm-generic/vmlinux.lds.h
>>>> index bd69d79..ea671e7 100644
>>>> --- a/include/asm-generic/vmlinux.lds.h
>>>> +++ b/include/asm-generic/vmlinux.lds.h
>>>> @@ -67,7 +67,14 @@
>>>> * Align to a 32 byte boundary equal to the
>>>> * alignment gcc 4.5 uses for a struct
>>>> */
>>>> -#define STRUCT_ALIGN() . = ALIGN(32)
>>>> +#define STRUCT_ALIGNMENT 32
>>>> +#define STRUCT_ALIGN() . = ALIGN(STRUCT_ALIGNMENT)
>>>> +
>>>> +/* Device tree blobs linked into the kernel need to have proper
>>>> + * structure alignment to be parsed by the flat device tree library
>>>> + * used in early boot
>>>> +*/
>>>> +#define DTB_ALIGNMENT STRUCT_ALIGNMENT
>>>>
>>>> /* The actual configuration determine if the init/exit sections
>>>> * are handled as text/data or they can be discarded (which
>>>> @@ -146,6 +153,13 @@
>>>> #define TRACE_SYSCALLS()
>>>> #endif
>>>>
>>>> +
>>>> +#define KERNEL_DTB() \
>>>> + . = ALIGN(DTB_ALIGNMENT); \
>>>> + VMLINUX_SYMBOL(__dtb_start) = .; \
>>>> + *(.dtb.init.rodata) \
>>>> + VMLINUX_SYMBOL(__dtb_end) = .;
>>>> +
>>>> /* .data section */
>>>> #define DATA_DATA \
>>>> *(.data) \
>>>> @@ -468,7 +482,8 @@
>>>> MCOUNT_REC() \
>>>> DEV_DISCARD(init.rodata) \
>>>> CPU_DISCARD(init.rodata) \
>>>> - MEM_DISCARD(init.rodata)
>>>> + MEM_DISCARD(init.rodata) \
>>>> + KERNEL_DTB()
>>>>
>>>> #define INIT_TEXT \
>>>> *(.init.text) \
>>>> diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib
>>>> index 4c72c11..a8a4774 100644
>>>> --- a/scripts/Makefile.lib
>>>> +++ b/scripts/Makefile.lib
>>>> @@ -200,6 +200,23 @@ quiet_cmd_gzip = GZIP $@
>>>> cmd_gzip = (cat $(filter-out FORCE,$^) | gzip -f -9> $@) || \
>>>> (rm -f $@ ; false)
>>>>
>>>> +# DTC
>>>> +#
>>>> ---------------------------------------------------------------------------
>>>> +$(obj)/%.dtb.S: $(obj)/%.dtb FORCE
>>>> + @echo '#include<asm-generic/vmlinux.lds.h>'> $@
>>>> + @echo '.section .dtb.init.rodata,"a"'>> $@
>>>> + @echo '.balign DTB_ALIGNMENT'>> $@
>>>> + @echo '.global __dtb_$(*F)_begin'>> $@
>>>> + @echo '__dtb_$(*F)_begin:'>> $@
>>>> + @echo '.incbin "$<" '>> $@
>>>> + @echo '__dtb_$(*F)_end:'>> $@
>>>> + @echo '.global __dtb_$(*F)_end'>> $@
>>>> + @echo '.balign DTB_ALIGNMENT'>> $@
>>>> +
>>>> +DTC = $(objtree)/scripts/dtc/dtc
>>>> +
>>>> +quiet_cmd_dtc = DTC $@
>>>> + cmd_dtc = $(DTC) -O dtb -o $(obj)/$*.dtb -b 0 $(src)/$*.dts
>>>
>>> Missing the %.dtb: %.dts rule, but otherwise looks okay. You will
>>> need to make sure this doesn't break powerpc or microblaze when the
>>> dts->dtb rule is added.
>>>
>> I have the rule
>> $(obj)/%.dtb: $(src)/%.dts
>> $(call if_changed,dtc)
>> in the arch/x86/kernel/Makefile to prevent this sneaking into other other
>> architectures.
>
> This rule looks correct. PowerPC and Microblaze need to be modified
> to use it. It should not be hard to do, give it a try. Worst case,
> your first attempt is wrong and the rest of us fix it up. :-)
>
> Hint: PowerPC currently puts the .dtb file in a different directory
> from the source .dts file. It doesn't need to do it that way.
> arch/powerpc/boot/Makefile will need to be modified.
>
I will give it a shot. The only real difference except for the directory
structures is powerpc and microblaze add padding to the dtb with the -p 1024
command line argument to dtc. Is the padding needed when the blob are linked
into vmlinux proper?
--Dirk
More information about the devicetree-discuss
mailing list