Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch tegra_xusb: fix xusb static firmware build



details:   https://anonhg.NetBSD.org/src/rev/f083e1fdd08a
branches:  trunk
changeset: 1013528:f083e1fdd08a
user:      jakllsch <jakllsch%NetBSD.org@localhost>
date:      Sat Aug 29 19:06:17 2020 +0000

description:
tegra_xusb: fix xusb static firmware build

To work around objcopy and ld now being unable to create a EABI5 object
from a binary, use the assembler directive .incbin in inline assembly
to pull in the firmware blob.

This also probably makes TEGRA210_XUSB_BIN_STATIC actually work.

diffstat:

 sys/arch/arm/nvidia/files.tegra      |   4 +++-
 sys/arch/arm/nvidia/tegra_xusb-fw.mk |  23 -----------------------
 sys/arch/arm/nvidia/tegra_xusb.c     |  30 ++++++++++++++++++++++++------
 sys/arch/evbarm/conf/mk.generic      |   4 +---
 4 files changed, 28 insertions(+), 33 deletions(-)

diffs (126 lines):

diff -r 1930c2fa3b95 -r f083e1fdd08a sys/arch/arm/nvidia/files.tegra
--- a/sys/arch/arm/nvidia/files.tegra   Sat Aug 29 18:54:33 2020 +0000
+++ b/sys/arch/arm/nvidia/files.tegra   Sat Aug 29 19:06:17 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.tegra,v 1.51 2020/07/08 22:28:21 uwe Exp $
+#      $NetBSD: files.tegra,v 1.52 2020/08/29 19:06:17 jakllsch Exp $
 #
 # Configuration info for NVIDIA Tegra ARM Peripherals
 #
@@ -108,6 +108,8 @@
 attach xhci at fdt with tegra_xusb : firmload
 file   arch/arm/nvidia/tegra_xusb.c            tegra_xusb
 defflag        opt_tegra.h                             TEGRA_XUSB_DEBUG
+defflag        opt_tegra.h                             TEGRA124_XUSB_BIN_STATIC
+defflag        opt_tegra.h                             TEGRA210_XUSB_BIN_STATIC
 
 # SDMMC
 attach sdhc at fdt with tegra_sdhc
diff -r 1930c2fa3b95 -r f083e1fdd08a sys/arch/arm/nvidia/tegra_xusb-fw.mk
--- a/sys/arch/arm/nvidia/tegra_xusb-fw.mk      Sat Aug 29 18:54:33 2020 +0000
+++ /dev/null   Thu Jan 01 00:00:00 1970 +0000
@@ -1,23 +0,0 @@
-#      $NetBSD: tegra_xusb-fw.mk,v 1.2 2017/09/19 20:46:12 jmcneill Exp $
-
-.if defined(TEGRA124_XUSB_BIN_STATIC)
-MD_OBJS+=      tegra124_xusb_bin.o
-CPPFLAGS+=     -DTEGRA124_XUSB_BIN_STATIC
-
-tegra124_xusb_bin.o:   $S/arch/arm/nvidia/tegra124_xusb.bin
-       -rm -f ${.OBJDIR}/tegra124_xusb.bin
-       -ln -s $S/arch/arm/nvidia/tegra124_xusb.bin ${.OBJDIR}
-       ${OBJCOPY} -I binary -O default -B arm tegra124_xusb.bin \
-           --rename-section .data=.rodata ${.TARGET}
-.endif
-
-.if defined(TEGRA210_XUSB_BIN_STATIC)
-MD_OBJS+=      tegra210_xusb_bin.o
-CPPFLAGS+=     -DTEGRA210_XUSB_BIN_STATIC
-
-tegra210_xusb_bin.o:   $S/arch/arm/nvidia/tegra210_xusb.bin
-       -rm -f ${.OBJDIR}/tegra210_xusb.bin
-       -ln -s $S/arch/arm/nvidia/tegra210_xusb.bin ${.OBJDIR}
-       ${OBJCOPY} -I binary -O default -B arm tegra210_xusb.bin \
-           --rename-section .data=.rodata ${.TARGET}
-.endif
diff -r 1930c2fa3b95 -r f083e1fdd08a sys/arch/arm/nvidia/tegra_xusb.c
--- a/sys/arch/arm/nvidia/tegra_xusb.c  Sat Aug 29 18:54:33 2020 +0000
+++ b/sys/arch/arm/nvidia/tegra_xusb.c  Sat Aug 29 19:06:17 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tegra_xusb.c,v 1.19 2019/10/13 06:11:31 skrll Exp $ */
+/* $NetBSD: tegra_xusb.c,v 1.20 2020/08/29 19:06:17 jakllsch Exp $ */
 
 /*
  * Copyright (c) 2016 Jonathan A. Kollasch
@@ -30,7 +30,7 @@
 #include "opt_tegra.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tegra_xusb.c,v 1.19 2019/10/13 06:11:31 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tegra_xusb.c,v 1.20 2020/08/29 19:06:17 jakllsch Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -74,13 +74,29 @@
 static int     tegra_xusb_intr_mbox(void *);
 
 #ifdef TEGRA124_XUSB_BIN_STATIC
-extern const char _binary_tegra124_xusb_bin_size[];
 extern const char _binary_tegra124_xusb_bin_start[];
+extern const char _binary_tegra124_xusb_bin_end[];
+__asm__(
+".section \".rodata\"\n"
+"_binary_tegra124_xusb_bin_start:\n"
+".incbin \"../external/nvidia-firmware/tegra/dist/tegra124/xusb.bin\"\n"
+".size _binary_tegra124_xusb_bin_start, . - _binary_tegra124_xusb_bin_start\n"
+"_binary_tegra124_xusb_bin_end:\n"
+".previous\n"
+);
 #endif
 
 #ifdef TEGRA210_XUSB_BIN_STATIC
-extern const char _binary_tegra210_xusb_bin_size[];
 extern const char _binary_tegra210_xusb_bin_start[];
+extern const char _binary_tegra210_xusb_bin_end[];
+__asm__(
+".section \".rodata\"\n"
+"_binary_tegra210_xusb_bin_start:\n"
+".incbin \"../external/nvidia-firmware/tegra/dist/tegra210/xusb.bin\"\n"
+".size _binary_tegra210_xusb_bin_start, . - _binary_tegra210_xusb_bin_start\n"
+"_binary_tegra210_xusb_bin_end:\n"
+".previous\n"
+);
 #endif
 
 enum xusb_type {
@@ -729,7 +745,8 @@
        switch (psc->sc_txd->txd_type) {
        case XUSB_T124:
 #if defined(TEGRA124_XUSB_BIN_STATIC)
-               firmware_size = (uintptr_t)&_binary_tegra124_xusb_bin_size;
+               firmware_size = (uintptr_t)&_binary_tegra124_xusb_bin_end
+                   - (uintptr_t)&_binary_tegra124_xusb_bin_start;
                fw_static = __UNCONST(_binary_tegra124_xusb_bin_start);
 #else
                fw_path = "nvidia/tegra124";
@@ -737,7 +754,8 @@
                break;
        case XUSB_T210:
 #if defined(TEGRA210_XUSB_BIN_STATIC)
-               firmware_size = (uintptr_t)&_binary_tegra210_xusb_bin_size;
+               firmware_size = (uintptr_t)&_binary_tegra210_xusb_bin_end
+                   - (uintptr_t)&_binary_tegra210_xusb_bin_start;
                fw_static = __UNCONST(_binary_tegra210_xusb_bin_start);
 #else
                fw_path = "nvidia/tegra210";
diff -r 1930c2fa3b95 -r f083e1fdd08a sys/arch/evbarm/conf/mk.generic
--- a/sys/arch/evbarm/conf/mk.generic   Sat Aug 29 18:54:33 2020 +0000
+++ b/sys/arch/evbarm/conf/mk.generic   Sat Aug 29 19:06:17 2020 +0000
@@ -1,6 +1,4 @@
-#      $NetBSD: mk.generic,v 1.9 2019/12/16 11:00:30 skrll Exp $
-
-.include "$S/arch/arm/nvidia/tegra_xusb-fw.mk"
+#      $NetBSD: mk.generic,v 1.10 2020/08/29 19:06:18 jakllsch Exp $
 
 .if !empty(MACHINE_ARCH:M*eb)
 EXTRA_LINKFLAGS+=      --be8



Home | Main Index | Thread Index | Old Index