2019-03-20 11:30:40 +03:00
|
|
|
From 34ef04f3845ed2b47d57dd9d3b795b16e1f8185a Mon Sep 17 00:00:00 2001
|
|
|
|
From: Evgeniy Didin <Evgeniy.Didin@synopsys.com>
|
|
|
|
Date: Fri, 15 Mar 2019 18:53:38 +0300
|
|
|
|
Subject: [PATCH] arc add OWRTDTB section
|
2017-10-29 19:32:10 +01:00
|
|
|
|
|
|
|
This change allows OpenWRT to patch resulting kernel binary with
|
|
|
|
external .dtb.
|
|
|
|
|
|
|
|
That allows us to re-use exactky the same vmlinux on different boards
|
|
|
|
given its ARC core configurations match (at least cache line sizes etc).
|
|
|
|
|
|
|
|
""patch-dtb" searches for ASCII "OWRTDTB:" strign and copies external
|
|
|
|
.dtb right after it, keeping the string in place.
|
|
|
|
|
2019-03-20 11:30:40 +03:00
|
|
|
Signed-off-by: Eugeniy Paltsev <Eugeniy.Paltsev@synopsys.com>
|
2017-10-29 19:32:10 +01:00
|
|
|
Signed-off-by: Alexey Brodkin <abrodkin@synopsys.com>
|
2019-03-20 11:30:40 +03:00
|
|
|
Signed-off-by: Evgeniy Didin <Evgeniy.Didin@synopsys.com>
|
2017-10-29 19:32:10 +01:00
|
|
|
---
|
|
|
|
arch/arc/kernel/head.S | 10 ++++++++++
|
|
|
|
arch/arc/kernel/setup.c | 4 +++-
|
|
|
|
arch/arc/kernel/vmlinux.lds.S | 13 +++++++++++++
|
|
|
|
3 files changed, 26 insertions(+), 1 deletion(-)
|
|
|
|
|
|
|
|
--- a/arch/arc/kernel/head.S
|
|
|
|
+++ b/arch/arc/kernel/head.S
|
2019-02-27 17:07:48 +01:00
|
|
|
@@ -59,6 +59,16 @@
|
|
|
|
#endif
|
2017-10-29 19:32:10 +01:00
|
|
|
.endm
|
|
|
|
|
2019-03-20 11:30:40 +03:00
|
|
|
+ ; Here "patch-dtb" will embed external .dtb
|
|
|
|
+ ; Note "patch-dtb" searches for ASCII "OWRTDTB:" string
|
|
|
|
+ ; and pastes .dtb right after it, hense the string precedes
|
|
|
|
+ ; __image_dtb symbol.
|
2017-10-29 19:32:10 +01:00
|
|
|
+ .section .owrt, "aw",@progbits
|
2019-03-20 11:30:40 +03:00
|
|
|
+ .ascii "OWRTDTB:"
|
2017-10-29 19:32:10 +01:00
|
|
|
+ENTRY(__image_dtb)
|
2019-03-20 11:30:40 +03:00
|
|
|
+ .fill 0x4000
|
2017-10-29 19:32:10 +01:00
|
|
|
+END(__image_dtb)
|
|
|
|
+
|
|
|
|
.section .init.text, "ax",@progbits
|
|
|
|
|
|
|
|
;----------------------------------------------------------------
|
|
|
|
--- a/arch/arc/kernel/setup.c
|
|
|
|
+++ b/arch/arc/kernel/setup.c
|
2019-04-22 21:51:43 +02:00
|
|
|
@@ -437,6 +437,8 @@ static inline bool uboot_arg_invalid(uns
|
|
|
|
/* We always pass 0 as magic from U-boot */
|
|
|
|
#define UBOOT_MAGIC_VALUE 0
|
2019-03-20 11:30:40 +03:00
|
|
|
|
|
|
|
+extern struct boot_param_header __image_dtb;
|
|
|
|
+
|
|
|
|
void __init handle_uboot_args(void)
|
|
|
|
{
|
|
|
|
bool use_embedded_dtb = true;
|
2019-04-22 21:51:43 +02:00
|
|
|
@@ -477,7 +479,7 @@ ignore_uboot_args:
|
2017-10-29 19:32:10 +01:00
|
|
|
#endif
|
2019-02-27 17:07:48 +01:00
|
|
|
|
|
|
|
if (use_embedded_dtb) {
|
2017-10-29 19:32:10 +01:00
|
|
|
- machine_desc = setup_machine_fdt(__dtb_start);
|
|
|
|
+ machine_desc = setup_machine_fdt(&__image_dtb);
|
|
|
|
if (!machine_desc)
|
|
|
|
panic("Embedded DT invalid\n");
|
2019-02-27 17:07:48 +01:00
|
|
|
}
|
2017-10-29 19:32:10 +01:00
|
|
|
--- a/arch/arc/kernel/vmlinux.lds.S
|
|
|
|
+++ b/arch/arc/kernel/vmlinux.lds.S
|
2019-03-20 11:30:40 +03:00
|
|
|
@@ -29,6 +29,19 @@ SECTIONS
|
|
|
|
*/
|
2017-10-29 19:32:10 +01:00
|
|
|
|
|
|
|
. = CONFIG_LINUX_LINK_BASE;
|
|
|
|
+ /*
|
2019-03-20 11:30:40 +03:00
|
|
|
+ * In OpenWRT we want to patch built binary embedding .dtb of choice.
|
|
|
|
+ * This is implemented with "patch-dtb" utility which searches for
|
|
|
|
+ * "OWRTDTB:" string in first 16k of image and if it is found
|
|
|
|
+ * copies .dtb right after mentioned string.
|
|
|
|
+ *
|
|
|
|
+ * Note: "OWRTDTB:" won't be overwritten with .dtb, .dtb will follow it.
|
|
|
|
+ */
|
|
|
|
+ .owrt : {
|
2017-10-29 19:32:10 +01:00
|
|
|
+ *(.owrt)
|
2019-03-20 11:30:40 +03:00
|
|
|
+ . = ALIGN(PAGE_SIZE);
|
2017-10-29 19:32:10 +01:00
|
|
|
+ }
|
|
|
|
+
|
2019-03-20 11:30:40 +03:00
|
|
|
|
2017-10-29 19:32:10 +01:00
|
|
|
_int_vec_base_lds = .;
|
|
|
|
.vector : {
|