[PATCH 00/16] Refactor the architecture parts of mt7628
Stefan Roese
sr at denx.de
Thu Jan 9 08:52:35 CET 2020
Hi Weijie,
On 08.01.20 03:59, Weijie Gao wrote:
> This patch series are divided into two parts:
>
> The main part is to rewrite the whole architecture code of mt7628:
> 1. Lock parts of the d-cache for initial stack so the rest of the code can
> be reimplemented in C.
> 2. Memory controller & DDR initialization have been fully written to support
> detecting DDR size automatically.
> 3. DDR calibration has also been reimplemented with a clear logic.
> 4. Implemented a new sysreset driver to take advantage of the reset
> controller so we can drop the use of syscon-based sysreset to reduce size.
>
> The second part is to add SPL support for mt7628:
> 1. With SPL enabled we can build the ROM-bootable and RAM-bootable binary
> simultaneously, and we can drop RAM boot related configs and defconfig
> files.
> 2. Generate compressed u-boot.bin image for SPL to reduce size of final
> combined binary.
> 3. Add a demo board (mt7628_rfb) to make use of the compressed image.
Many thanks for working on this. Unfortunately I didn't receive these patches
directly (I remember that you had problems sending patches to me before).
I did a quick test on the LinkIt board and have a few questions before
I start reviewing the patches in more detail:
I don't see any serial output from the SPL. I assume that the muxing
for UART2 is missing here in the SPL image (see board_debug_uart_init)?
Did you compare the boot speed with using SPL + main U-Boot vs U-Boot
only?
In the current combined image the non-compressed U-Boot proper is
included. Why did you not include the LZMA compressed image per default?
Is the decompression too slow?
More comments / questions will follow in a few days.
> Weijie Gao (16):
> configs: mtmips: add missing board selection for
> gardena-smart-gateway-mt7688
> mips: add support to restore exception vector base before booting
> linux
> mips: mtmips: add predefined i-cache/d-cache size and linesize
> mips: add an option to support customized get_tbclk()
> mips: add an option to support initialize SRAM for initial stack
> mips: start.S: avoid overwriting outside gd when clearing global data
> in stack
> sysreset: add reset controller based reboot driver
> mips: mtmips: rewrite lowlevel codes of mt7628
> mips: dts: rename mt7628a.dtsi to mt7628.dtsi
> mips: unconditionally enable u_boot_list section in u-boot-spl.lds
> lib: enable lzma decompression support for SPL build
> Makefile: add support to generate LZMA compressed u-boot image
> tools: binman: add etype file for u-boot-lzma-img
> mips: mtmips: add SPL support
> mips: mtmips: enable SPL for all boards
> mips: mtmips: add support for mt7628-rfb
>
> Makefile | 22 ++
> arch/mips/Kconfig | 32 ++
> arch/mips/cpu/start.S | 10 +-
> arch/mips/cpu/time.c | 2 +
> arch/mips/cpu/u-boot-spl.lds | 2 -
> arch/mips/dts/Makefile | 1 +
> .../mips/dts/gardena-smart-gateway-mt7688.dts | 2 +-
> arch/mips/dts/linkit-smart-7688.dts | 2 +-
> arch/mips/dts/mediatek,mt7628-rfb-u-boot.dtsi | 24 ++
> arch/mips/dts/mediatek,mt7628-rfb.dts | 67 ++++
> arch/mips/dts/mt7628-u-boot.dtsi | 25 ++
> arch/mips/dts/{mt7628a.dtsi => mt7628.dtsi} | 78 +----
> arch/mips/include/asm/global_data.h | 3 +
> arch/mips/lib/bootm.c | 9 +
> arch/mips/mach-mtmips/Kconfig | 122 ++-----
> arch/mips/mach-mtmips/Makefile | 8 +-
> arch/mips/mach-mtmips/cpu.c | 58 +---
> arch/mips/mach-mtmips/ddr_cal.c | 211 +++++++++++
> arch/mips/mach-mtmips/ddr_calibrate.c | 309 -----------------
> arch/mips/mach-mtmips/ddr_init.c | 194 +++++++++++
> arch/mips/mach-mtmips/include/mach/ddr.h | 52 +++
> arch/mips/mach-mtmips/include/mach/mc.h | 180 ++++++++++
> arch/mips/mach-mtmips/lowlevel_init.S | 328 ------------------
> arch/mips/mach-mtmips/mt7628/Makefile | 5 +
> arch/mips/mach-mtmips/mt7628/ddr.c | 173 +++++++++
> arch/mips/mach-mtmips/mt7628/init.c | 109 ++++++
> arch/mips/mach-mtmips/mt7628/lowlevel_init.S | 155 +++++++++
> arch/mips/mach-mtmips/mt7628/mt7628.h | 90 +++++
> arch/mips/mach-mtmips/mt76xx.h | 32 --
> arch/mips/mach-mtmips/spl.c | 23 ++
> board/gardena/smart-gateway-mt7688/board.c | 2 +
> board/mediatek/mt7628/Kconfig | 12 +
> board/mediatek/mt7628/MAINTAINERS | 8 +
> board/mediatek/mt7628/Makefile | 4 +
> board/mediatek/mt7628/board.c | 25 ++
> board/mediatek/mt7628/spl_load.c | 102 ++++++
> ...gardena-smart-gateway-mt7688-ram_defconfig | 74 ----
> .../gardena-smart-gateway-mt7688_defconfig | 12 +-
> configs/linkit-smart-7688-ram_defconfig | 65 ----
> configs/linkit-smart-7688_defconfig | 11 +-
> configs/mt7628_rfb_defconfig | 47 +++
> drivers/sysreset/Kconfig | 6 +
> drivers/sysreset/Makefile | 1 +
> drivers/sysreset/sysreset_resetctl.c | 48 +++
> .../configs/gardena-smart-gateway-mt7688.h | 18 +-
> include/configs/linkit-smart-7688.h | 18 +-
> include/configs/mt7628.h | 57 +++
> lib/Kconfig | 5 +
> lib/Makefile | 1 +
> tools/binman/etype/u_boot_lzma_img.py | 27 ++
> 50 files changed, 1826 insertions(+), 1045 deletions(-)
> create mode 100644 arch/mips/dts/mediatek,mt7628-rfb-u-boot.dtsi
> create mode 100644 arch/mips/dts/mediatek,mt7628-rfb.dts
> create mode 100644 arch/mips/dts/mt7628-u-boot.dtsi
> rename arch/mips/dts/{mt7628a.dtsi => mt7628.dtsi} (81%)
> create mode 100644 arch/mips/mach-mtmips/ddr_cal.c
> delete mode 100644 arch/mips/mach-mtmips/ddr_calibrate.c
> create mode 100644 arch/mips/mach-mtmips/ddr_init.c
> create mode 100644 arch/mips/mach-mtmips/include/mach/ddr.h
> create mode 100644 arch/mips/mach-mtmips/include/mach/mc.h
> delete mode 100644 arch/mips/mach-mtmips/lowlevel_init.S
> create mode 100644 arch/mips/mach-mtmips/mt7628/Makefile
> create mode 100644 arch/mips/mach-mtmips/mt7628/ddr.c
> create mode 100644 arch/mips/mach-mtmips/mt7628/init.c
> create mode 100644 arch/mips/mach-mtmips/mt7628/lowlevel_init.S
> create mode 100644 arch/mips/mach-mtmips/mt7628/mt7628.h
> delete mode 100644 arch/mips/mach-mtmips/mt76xx.h
> create mode 100644 arch/mips/mach-mtmips/spl.c
> create mode 100644 board/mediatek/mt7628/Kconfig
> create mode 100644 board/mediatek/mt7628/MAINTAINERS
> create mode 100644 board/mediatek/mt7628/Makefile
> create mode 100644 board/mediatek/mt7628/board.c
> create mode 100644 board/mediatek/mt7628/spl_load.c
> delete mode 100644 configs/gardena-smart-gateway-mt7688-ram_defconfig
> delete mode 100644 configs/linkit-smart-7688-ram_defconfig
> create mode 100644 configs/mt7628_rfb_defconfig
> create mode 100644 drivers/sysreset/sysreset_resetctl.c
> create mode 100644 include/configs/mt7628.h
> create mode 100644 tools/binman/etype/u_boot_lzma_img.py
>
Viele Grüße,
Stefan
--
DENX Software Engineering GmbH, Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-51 Fax: (+49)-8142-66989-80 Email: sr at denx.de
More information about the U-Boot
mailing list