On 8/8/23 15:38, Mark Kettenis wrote:
>> From: Stuart Henderson <[email protected]>
>> Date: Mon, 07 Aug 2023 22:59:21 +0100
>>
>> Just had a quick read through on my phone, I'll try to have another look
>> tomorrow, generally looks good.
>>
>> For each of the new PLIST files you need to add "@pkgpath
>> sysutils/u-boot,old_flavour_name" alongside any existing @pkgpath so that
>> pkg_add -u accepts it as an update despite the different path.
> Thanks, that does indeed make updates work! New diff attached.
I think you forgot to attach :P
>> I'd suggest splitting the build/install steps to the arch Makefiles (either
>> move completely, or keep the common parts in Makefile.inc by using
>> do-build/do-install in one file, post-build/post-install for the other) but
>> probably simpler to do that as a separate step.
> Yes I thought about that. I think that's best done after I split out
> a few of the SoCs.
>
>
>> On 7 August 2023 22:11:43 Mark Kettenis <[email protected]> wrote:
>>
>> This splits sysutils/u-boot into three different ports instead of
>> using flavours. The motivation behind this is that the current port
>> is very hard to update without breaking shit. By turning this into
>> separate ports we can update them individually. My idea is that we
>> split this up by SoC family/generation where appropriate. Then we can
>> test a few boards with that particular SoC and be reasonably sure that
>> things still work on the other boards. For example I will probably
>> create a new "sun50i" port with proper support for suspend/resume
>> (this needs a newer version of u-boot as well as some additional
>> firmware). Support for older SoCs will probably not be updated at
>> all.
>>
>> Since I am fairly clueless regarding ports, please let me know if this
>> makes sense. The new packages should have the same name as the old
>> flavours. Does that mean upgrading them will work?
>>
>> I created a git diff for this since I didn't want to pollute the CVS
>> repo with new directories yet. This has the benefit that it clearly
>> shows that the patch files have simply been moved.
>>
>> Thoughts?
>>
>> From 3dcb8724513098a710972a3b3f47c7601756cd76 Mon Sep 17 00:00:00 2001
>> From: Mark Kettenis <[email protected]>
>> Date: Mon, 7 Aug 2023 22:56:47 +0200
>> Subject: [PATCH] Split u-boot port
>>
>> ---
>> sysutils/u-boot/Makefile | 248 +---------------
>> sysutils/u-boot/Makefile.inc | 143 ++++++++++
>> sysutils/u-boot/aarch64/Makefile | 39 +++
>> sysutils/u-boot/{ => aarch64}/distinfo | 0
>> .../patches/patch-arch_arm_dts_Makefile | 0
>> .../patch-arch_arm_dts_rk3328-nanopi-r2s_dts | 0
>> .../patch-arch_arm_dts_rk3328-rock64_dts | 0
>> .../patch-arch_arm_dts_rk3399-nanopi4_dtsi | 0
>> ...patch-arch_arm_dts_rk3399-pinebook-pro_dts | 0
>> .../patch-arch_arm_dts_rk3399-rock-pi-4_dtsi | 0
>> .../patch-arch_arm_dts_rk3399-rock960_dts | 0
>> .../patch-arch_arm_dts_rk3399-rockpro64_dtsi | 0
>> .../patch-arch_arm_dts_rk3399-u-boot_dtsi | 0
>> ...tch-arch_arm_dts_rk3399pro-rock-pi-n10_dts | 0
>> ...rch_arm_dts_sun50i-h6-pine-h64-model-b_dts | 0
>> .../patch-configs_firefly-rk3399_defconfig | 0
>> .../patch-configs_nanopc-t4-rk3399_defconfig | 0
>> ...patch-configs_nanopi-neo4-rk3399_defconfig | 0
>> .../patch-configs_nanopi-r2s-rk3328_defconfig | 0
>> .../patch-configs_nanopi-r4s-rk3399_defconfig | 0
>> .../patch-configs_pine_h64-model-b_defconfig | 0
>> ...atch-configs_pinebook-pro-rk3399_defconfig | 0
>> .../patch-configs_rock-pi-4-rk3399_defconfig | 0
>> ...ch-configs_rock-pi-n10-rk3399pro_defconfig | 0
>> .../patch-configs_rock64-rk3328_defconfig | 0
>> .../patch-configs_rock960-rk3399_defconfig | 0
>> .../patch-configs_rockpro64-rk3399_defconfig | 0
>> .../patches/patch-drivers_pci_pcie_brcmstb_c | 0
>> sysutils/u-boot/aarch64/pkg/DESCR | 8 +
>> sysutils/u-boot/aarch64/pkg/PLIST | 193 +++++++++++++
>> sysutils/u-boot/arm/Makefile | 64 +++++
>> sysutils/u-boot/arm/distinfo | 2 +
>> .../patches/patch-configs_rpi_2_defconfig | 0
>> .../patches/patch-configs_rpi_3_32b_defconfig | 0
>> .../patches/patch-drivers_pci_pcie_brcmstb_c | 42 +++
>> sysutils/u-boot/arm/pkg/DESCR | 8 +
>> sysutils/u-boot/arm/pkg/PLIST | 264 ++++++++++++++++++
>> .../patches/patch-configs_rpi_3_defconfig | 28 --
>> sysutils/u-boot/riscv64/Makefile | 11 +
>> sysutils/u-boot/riscv64/distinfo | 2 +
>> .../patches/patch-arch_riscv_Makefile | 0
>> sysutils/u-boot/riscv64/pkg/DESCR | 8 +
>> sysutils/u-boot/riscv64/pkg/PLIST | 10 +
>> 43 files changed, 799 insertions(+), 271 deletions(-)
>> create mode 100644 sysutils/u-boot/Makefile.inc
>> create mode 100644 sysutils/u-boot/aarch64/Makefile
>> rename sysutils/u-boot/{ => aarch64}/distinfo (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_Makefile (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3328-nanopi-r2s_dts (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3328-rock64_dts (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-nanopi4_dtsi (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-pinebook-pro_dts (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-rock-pi-4_dtsi (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-rock960_dts (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-rockpro64_dtsi (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399-u-boot_dtsi (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_rk3399pro-rock-pi-n10_dts (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-arch_arm_dts_sun50i-h6-pine-h64-model-b_dts
>> (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_firefly-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_nanopc-t4-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_nanopi-neo4-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_nanopi-r2s-rk3328_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_nanopi-r4s-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_pine_h64-model-b_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_pinebook-pro-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_rock-pi-4-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_rock-pi-n10-rk3399pro_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_rock64-rk3328_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_rock960-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-configs_rockpro64-rk3399_defconfig (100%)
>> rename sysutils/u-boot/{ =>
>> aarch64}/patches/patch-drivers_pci_pcie_brcmstb_c (100%)
>> create mode 100644 sysutils/u-boot/aarch64/pkg/DESCR
>> create mode 100644 sysutils/u-boot/aarch64/pkg/PLIST
>> create mode 100644 sysutils/u-boot/arm/Makefile
>> create mode 100644 sysutils/u-boot/arm/distinfo
>> rename sysutils/u-boot/{ => arm}/patches/patch-configs_rpi_2_defconfig
>> (100%)
>> rename sysutils/u-boot/{ =>
>> arm}/patches/patch-configs_rpi_3_32b_defconfig (100%)
>> create mode 100644
>> sysutils/u-boot/arm/patches/patch-drivers_pci_pcie_brcmstb_c
>> create mode 100644 sysutils/u-boot/arm/pkg/DESCR
>> create mode 100644 sysutils/u-boot/arm/pkg/PLIST
>> delete mode 100644
>> sysutils/u-boot/patches/patch-configs_rpi_3_defconfig
>> create mode 100644 sysutils/u-boot/riscv64/Makefile
>> create mode 100644 sysutils/u-boot/riscv64/distinfo
>> rename sysutils/u-boot/{ => riscv64}/patches/patch-arch_riscv_Makefile
>> (100%)
>> create mode 100644 sysutils/u-boot/riscv64/pkg/DESCR
>> create mode 100644 sysutils/u-boot/riscv64/pkg/PLIST
>>
>> diff --git a/sysutils/u-boot/Makefile b/sysutils/u-boot/Makefile
>> index d2dd2fad980..857155ac9f6 100644
>> --- a/sysutils/u-boot/Makefile
>> +++ b/sysutils/u-boot/Makefile
>> @@ -1,244 +1,6 @@
>> -BROKEN-sparc64= Error: the specified option is not accepted in ISB at
>> operand 1 -- isb sy
>> -BROKEN-arm= lib/time.c:187:1: internal compiler error: Bus error
>> + SUBDIR =
>> + SUBDIR += aarch64
>> + SUBDIR += arm
>> + SUBDIR += riscv64
>>
>> -DPB_PROPERTIES= parallel
>> -
>> -FLAVORS= aarch64 arm riscv64
>> -FLAVOR?= arm
>> -
>> -COMMENT= U-Boot firmware
>> -VERSION= 2021.10
>> -REVISION= 6
>> -DISTNAME= u-boot-${VERSION}
>> -PKGNAME= u-boot-${FLAVOR}-${VERSION:S/-//}
>> -FULLPKGNAME= ${PKGNAME}
>> -CATEGORIES= sysutils
>> -HOMEPAGE= https://www.denx.de/wiki/U-Boot
>> -
>> -# GPLv2
>> -PERMIT_PACKAGE= Yes
>> -
>> -MASTER_SITES= https://ftp.denx.de/pub/u-boot/
>> -EXTRACT_SUFX= .tar.bz2
>> -PKG_ARCH= *
>> -
>> -BUILD_DEPENDS= devel/bison \
>> - devel/dtc \
>> - devel/swig
>> -
>> -# for pkg_resources used in tools/binman/control.py
>> -BUILD_DEPENDS+= devel/py-setuptools${MODPY_FLAVOR}
>> -
>> -MODULES= lang/python
>> -MODPY_RUNDEP= No
>> -
>> -MODPY_ADJ_FILES=\
>> - arch/arm/mach-rockchip/make_fit_atf.py
>> -
>> -MAKE_ENV= KBUILD_VERBOSE=1 \
>> - PYTHON="${MODPY_BIN}"
>> -
>> -.if "${FLAVOR}" == "aarch64"
>> -BUILD_DEPENDS+= devel/arm-none-eabi/gcc,aarch64 \
>> - devel/py-elftools${MODPY_FLAVOR} \
>> - sysutils/arm-trusted-firmware>=2.2p0v0
>> -MAKE_ENV+= CROSS_COMPILE="aarch64-none-elf-"
>> -RK3328_BL31= "${LOCALBASE}/share/arm-trusted-firmware/rk3328-bl31.elf"
>> -RK3399_BL31= "${LOCALBASE}/share/arm-trusted-firmware/rk3399-bl31.elf"
>> -SUNXI_BL31= "$
>> {LOCALBASE}/share/arm-trusted-firmware/sun50i_a64-bl31.bin"
>> -SUNXI_H6_BL31= "$
>> {LOCALBASE}/share/arm-trusted-firmware/sun50i_h6-bl31.bin"
>> -.elif "${FLAVOR}" == "arm"
>> -BUILD_DEPENDS+= devel/arm-none-eabi/gcc,arm
>> -MAKE_ENV+= CROSS_COMPILE="arm-none-eabi-"
>> -.elif "${FLAVOR}" == "riscv64"
>> -BUILD_DEPENDS+= devel/riscv-elf/gcc \
>> - sysutils/opensbi>=0.9p0
>> -MAKE_ENV+= CROSS_COMPILE="riscv64-unknown-elf-"
>> -FW_DYNAMIC= "${LOCALBASE}/share/opensbi/generic/fw_dynamic.bin"
>> -.endif
>> -
>> -USE_GMAKE= Yes
>> -NO_TEST= Yes
>> -
>> -.if "${FLAVOR}" == "aarch64"
>> -SUNXI64=\
>> - a64-olinuxino \
>> - bananapi_m64 \
>> - nanopi_a64 \
>> - nanopi_neo2 \
>> - orangepi_pc2 \
>> - orangepi_prime \
>> - orangepi_win \
>> - orangepi_zero_plus \
>> - pine64-lts \
>> - pine64_plus \
>> - pine_h64-model-b \
>> - pinebook \
>> - sopine_baseboard
>> -BOARDS=\
>> - firefly-rk3399 \
>> - mvebu_espressobin-88f3720 \
>> - mvebu_mcbin-88f8040 \
>> - nanopc-t4-rk3399 \
>> - nanopi-neo4-rk3399 \
>> - nanopi-r2s-rk3328 \
>> - nanopi-r4s-rk3399 \
>> - pinebook-pro-rk3399 \
>> - qemu_arm64 \
>> - rock64-rk3328 \
>> - rock960-rk3399 \
>> - rock-pi-4-rk3399 \
>> - rock-pi-n10-rk3399pro \
>> - rockpro64-rk3399 \
>> - rpi_arm64
>> -.elif "${FLAVOR}" == "arm"
>> -OMAP=\
>> - omap4_panda \
>> - am335x_evm
>> -SUNXI64=
>> -SUNXI=\
>> - A10-OLinuXino-Lime \
>> - A10s-OLinuXino-M \
>> - A20-OLinuXino-Lime \
>> - A20-OLinuXino-Lime2 \
>> - A20-OLinuXino-Lime2-eMMC \
>> - A20-OLinuXino_MICRO \
>> - Bananapi \
>> - Bananapi_M2_Ultra \
>> - Bananapi_m2m \
>> - bananapi_m2_plus_h3 \
>> - bananapi_m2_zero \
>> - Bananapro \
>> - CHIP \
>> - Cubieboard \
>> - Cubieboard2 \
>> - Cubieboard4 \
>> - Cubietruck \
>> - Lamobo_R1 \
>> - Linksprite_pcDuino \
>> - Linksprite_pcDuino3 \
>> - Linksprite_pcDuino3_Nano \
>> - nanopi_neo \
>> - Orangepi \
>> - Orangepi_mini \
>> - orangepi_2 \
>> - orangepi_lite \
>> - orangepi_one \
>> - orangepi_pc \
>> - orangepi_pc_plus \
>> - orangepi_plus \
>> - orangepi_plus2e \
>> - orangepi_zero
>> -IMX=\
>> - cm_fx6 \
>> - mx6cuboxi \
>> - mx6qsabrelite \
>> - nitrogen6q \
>> - novena \
>> - udoo \
>> - usbarmory \
>> - wandboard
>> -BOARDS=\
>> - ${OMAP} \
>> - ${SUNXI} \
>> - ${IMX} \
>> - clearfog \
>> - qemu_arm \
>> - rpi_2 \
>> - rpi_3_32b \
>> - tinker-rk3288 \
>> - turris_omnia
>> -.elif "${FLAVOR}" == "riscv64"
>> -BOARDS=\
>> - qemu-riscv64_smode \
>> - sifive_unmatched
>> -.endif
>> -
>> -FILES=\
>> - MLO \
>> - SPL \
>> - u-boot \
>> - u-boot.img \
>> - u-boot.bin \
>> - u-boot-sunxi-with-spl.bin \
>> - u-boot.imx \
>> - u-boot-dtb.imx \
>> - u-boot-spl.kwb \
>> - u-boot-with-spl.bin \
>> - u-boot.itb \
>> - u-boot-rockchip.bin \
>> - idbloader.img \
>> - spl/sunxi-spl.bin \
>> - spl/u-boot-spl.bin
>> -
>> -do-build:
>> -.for BOARD in ${BOARDS}
>> - cd ${WRKSRC} && \
>> - mkdir -p build/${BOARD} && \
>> - ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} \
>> - O="build/${BOARD}" \
>> - -f ${MAKE_FILE} "${BOARD}"_defconfig
>> -.if "${BOARD:M*-rk3399*}"
>> - cd ${WRKSRC} && \
>> - ${SETENV} ${MAKE_ENV} BL31=${RK3399_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.elif "${BOARD:M*-rk3328}"
>> - cd ${WRKSRC} && \
>> - ${SETENV} ${MAKE_ENV} BL31=${RK3328_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.elif "${BOARD:M*sifive_*}"
>> - cd ${WRKSRC} && \
>> - ${SETENV} ${MAKE_ENV} OPENSBI=${FW_DYNAMIC} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.else
>> - cd ${WRKSRC} && \
>> - ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} \
>> - O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.endif
>> -.if "${BOARD:M*-rk3288}"
>> - cd ${WRKSRC}/build/${BOARD} && \
>> - tools/mkimage -n rk3288 -T rksd -d tpl/u-boot-tpl.bin \
>> - idbloader.img && \
>> - cat spl/u-boot-spl-dtb.bin >> idbloader.img
>> -.endif
>> -.endfor
>> -.for BOARD in ${SUNXI64}
>> -.if "${BOARD:M*_h64*}"
>> - cd ${WRKSRC} && \
>> - mkdir -p build/${BOARD} && \
>> - ${SETENV} ${MAKE_ENV} BL31=${SUNXI_H6_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} "${BOARD}"_defconfig && \
>> - ${SETENV} ${MAKE_ENV} BL31=${SUNXI_H6_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.else
>> - cd ${WRKSRC} && \
>> - mkdir -p build/${BOARD} && \
>> - ${SETENV} ${MAKE_ENV} BL31=${SUNXI_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} "${BOARD}"_defconfig && \
>> - ${SETENV} ${MAKE_ENV} BL31=${SUNXI_BL31} ${MAKE_PROGRAM} \
>> - ${MAKE_FLAGS} O="build/${BOARD}" \
>> - -f ${MAKE_FILE} ${ALL_TARGET}
>> -.endif
>> - if [[ -f ${WRKSRC}/build/${BOARD}/spl/sunxi-spl.bin && \
>> - -f ${WRKSRC}/build/${BOARD}/u-boot.itb ]]; then \
>> - cd ${WRKSRC}/build/${BOARD} && \
>> - cat spl/sunxi-spl.bin u-boot.itb > u-boot-sunxi-with-spl.bin ; \
>> - fi
>> -.endfor
>> -
>> -do-install:
>> - ${INSTALL_DATA_DIR} ${PREFIX}/share/u-boot
>> -.for BOARD in ${BOARDS} ${SUNXI64}
>> - ${INSTALL_DATA_DIR} ${PREFIX}/share/u-boot/${BOARD}
>> - -cd ${WRKSRC}/build/${BOARD} && \
>> - cp ${FILES} ${PREFIX}/share/u-boot/${BOARD}/
>> -.endfor
>> -
>> -.include <bsd.port.mk>
>> +.include <bsd.port.subdir.mk>
>> diff --git a/sysutils/u-boot/Makefile.inc b/sysutils/u-boot/Makefile.inc
>> new file mode 100644
>> index 00000000000..6e80db36be0
>> --- /dev/null
>> +++ b/sysutils/u-boot/Makefile.inc
>> @@ -0,0 +1,143 @@
>> +BROKEN-sparc64= Error: the specified option is not accepted in ISB at
>> operand 1 -- isb sy
>> +BROKEN-arm= lib/time.c:187:1: internal compiler error: Bus error
>> +
>> +DPB_PROPERTIES= parallel
>> +
>> +COMMENT= U-Boot firmware
>> +DISTNAME= u-boot-${VERSION}
>> +PKGNAME= u-boot-${SOC}-${VERSION:S/-//}
>> +FULLPKGNAME= ${PKGNAME}
>> +CATEGORIES= sysutils
>> +HOMEPAGE= https://www.denx.de/wiki/U-Boot
>> +
>> +# GPLv2
>> +PERMIT_PACKAGE= Yes
>> +
>> +MASTER_SITES= https://ftp.denx.de/pub/u-boot/
>> +EXTRACT_SUFX= .tar.bz2
>> +PKG_ARCH= *
>> +
>> +BUILD_DEPENDS= devel/bison \
>> + devel/dtc \
>> + devel/swig
>> +
>> +# for pkg_resources used in tools/binman/control.py
>> +BUILD_DEPENDS+= devel/py-setuptools${MODPY_FLAVOR}
>> +
>> +MODULES= lang/python
>> +MODPY_RUNDEP= No
>> +
>> +MODPY_ADJ_FILES=\
>> + arch/arm/mach-rockchip/make_fit_atf.py
>> +
>> +MAKE_ENV= KBUILD_VERBOSE=1 \
>> + PYTHON="${MODPY_BIN}"
>> +
>> +.if "${SOC_CPU}" == "arm64"
>> +BUILD_DEPENDS+= devel/arm-none-eabi/gcc,aarch64 \
>> + devel/py-elftools${MODPY_FLAVOR} \
>> + sysutils/arm-trusted-firmware>=2.2p0v0
>> +MAKE_ENV+= CROSS_COMPILE="aarch64-none-elf-"
>> +RK3328_BL31= "${LOCALBASE}/share/arm-trusted-firmware/rk3328-bl31.elf"
>> +RK3399_BL31= "${LOCALBASE}/share/arm-trusted-firmware/rk3399-bl31.elf"
>> +SUNXI_BL31= "$
>> {LOCALBASE}/share/arm-trusted-firmware/sun50i_a64-bl31.bin"
>> +SUNXI_H6_BL31= "$
>> {LOCALBASE}/share/arm-trusted-firmware/sun50i_h6-bl31.bin"
>> +.elif "${SOC_CPU}" == "arm"
>> +BUILD_DEPENDS+= devel/arm-none-eabi/gcc,arm
>> +MAKE_ENV+= CROSS_COMPILE="arm-none-eabi-"
>> +.elif "${SOC_CPU}" == "riscv64"
>> +BUILD_DEPENDS+= devel/riscv-elf/gcc \
>> + sysutils/opensbi>=0.9p0
>> +MAKE_ENV+= CROSS_COMPILE="riscv64-unknown-elf-"
>> +FW_DYNAMIC= "${LOCALBASE}/share/opensbi/generic/fw_dynamic.bin"
>> +.endif
>> +
>> +USE_GMAKE= Yes
>> +NO_TEST= Yes
>> +
>> +FILES=\
>> + MLO \
>> + SPL \
>> + u-boot \
>> + u-boot.img \
>> + u-boot.bin \
>> + u-boot-sunxi-with-spl.bin \
>> + u-boot.imx \
>> + u-boot-dtb.imx \
>> + u-boot-spl.kwb \
>> + u-boot-with-spl.bin \
>> + u-boot.itb \
>> + u-boot-rockchip.bin \
>> + idbloader.img \
>> + spl/sunxi-spl.bin \
>> + spl/u-boot-spl.bin
>> +
>> +do-build:
>> +.for BOARD in ${BOARDS}
>> + cd ${WRKSRC} && \
>> + mkdir -p build/${BOARD} && \
>> + ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} \
>> + O="build/${BOARD}" \
>> + -f ${MAKE_FILE} "${BOARD}"_defconfig
>> +.if "${BOARD:M*-rk3399*}"
>> + cd ${WRKSRC} && \
>> + ${SETENV} ${MAKE_ENV} BL31=${RK3399_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.elif "${BOARD:M*-rk3328}"
>> + cd ${WRKSRC} && \
>> + ${SETENV} ${MAKE_ENV} BL31=${RK3328_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.elif "${BOARD:M*sifive_*}"
>> + cd ${WRKSRC} && \
>> + ${SETENV} ${MAKE_ENV} OPENSBI=${FW_DYNAMIC} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.else
>> + cd ${WRKSRC} && \
>> + ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} \
>> + O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.endif
>> +.if "${BOARD:M*-rk3288}"
>> + cd ${WRKSRC}/build/${BOARD} && \
>> + tools/mkimage -n rk3288 -T rksd -d tpl/u-boot-tpl.bin \
>> + idbloader.img && \
>> + cat spl/u-boot-spl-dtb.bin >> idbloader.img
>> +.endif
>> +.endfor
>> +.for BOARD in ${SUNXI64}
>> +.if "${BOARD:M*_h64*}"
>> + cd ${WRKSRC} && \
>> + mkdir -p build/${BOARD} && \
>> + ${SETENV} ${MAKE_ENV} BL31=${SUNXI_H6_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} "${BOARD}"_defconfig && \
>> + ${SETENV} ${MAKE_ENV} BL31=${SUNXI_H6_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.else
>> + cd ${WRKSRC} && \
>> + mkdir -p build/${BOARD} && \
>> + ${SETENV} ${MAKE_ENV} BL31=${SUNXI_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} "${BOARD}"_defconfig && \
>> + ${SETENV} ${MAKE_ENV} BL31=${SUNXI_BL31} ${MAKE_PROGRAM} \
>> + ${MAKE_FLAGS} O="build/${BOARD}" \
>> + -f ${MAKE_FILE} ${ALL_TARGET}
>> +.endif
>> + if [[ -f ${WRKSRC}/build/${BOARD}/spl/sunxi-spl.bin && \
>> + -f ${WRKSRC}/build/${BOARD}/u-boot.itb ]]; then \
>> + cd ${WRKSRC}/build/${BOARD} && \
>> + cat spl/sunxi-spl.bin u-boot.itb > u-boot-sunxi-with-spl.bin ; \
>> + fi
>> +.endfor
>> +
>> +do-install:
>> + ${INSTALL_DATA_DIR} ${PREFIX}/share/u-boot
>> +.for BOARD in ${BOARDS} ${SUNXI64}
>> + ${INSTALL_DATA_DIR} ${PREFIX}/share/u-boot/${BOARD}
>> + -cd ${WRKSRC}/build/${BOARD} && \
>> + cp ${FILES} ${PREFIX}/share/u-boot/${BOARD}/
>> +.endfor
>> diff --git a/sysutils/u-boot/aarch64/Makefile
>> b/sysutils/u-boot/aarch64/Makefile
>> new file mode 100644
>> index 00000000000..f2ef4a4a3e0
>> --- /dev/null
>> +++ b/sysutils/u-boot/aarch64/Makefile
>> @@ -0,0 +1,39 @@
>> +VERSION= 2021.10
>> +REVISION= 7
>> +
>> +SOC= aarch64
>> +SOC_CPU= arm64
>> +
>> +SUNXI64=\
>> + a64-olinuxino \
>> + bananapi_m64 \
>> + nanopi_a64 \
>> + nanopi_neo2 \
>> + orangepi_pc2 \
>> + orangepi_prime \
>> + orangepi_win \
>> + orangepi_zero_plus \
>> + pine64-lts \
>> + pine64_plus \
>> + pine_h64-model-b \
>> + pinebook \
>> + sopine_baseboard
>> +
>> +BOARDS=\
>> + firefly-rk3399 \
>> + mvebu_espressobin-88f3720 \
>> + mvebu_mcbin-88f8040 \
>> + nanopc-t4-rk3399 \
>> + nanopi-neo4-rk3399 \
>> + nanopi-r2s-rk3328 \
>> + nanopi-r4s-rk3399 \
>> + pinebook-pro-rk3399 \
>> + qemu_arm64 \
>> + rock64-rk3328 \
>> + rock960-rk3399 \
>> + rock-pi-4-rk3399 \
>> + rock-pi-n10-rk3399pro \
>> + rockpro64-rk3399 \
>> + rpi_arm64
>> +
>> +.include <bsd.port.mk>
>> diff --git a/sysutils/u-boot/distinfo b/sysutils/u-boot/aarch64/distinfo
>> similarity index 100%
>> rename from sysutils/u-boot/distinfo
>> rename to sysutils/u-boot/aarch64/distinfo
>> diff --git a/sysutils/u-boot/patches/patch-arch_arm_dts_Makefile
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_Makefile
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-arch_arm_dts_Makefile
>> rename to sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_Makefile
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3328-nanopi-r2s_dts
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3328-nanopi-r2s_dts
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3328-nanopi-r2s_dts
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3328-nanopi-r2s_dts
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3328-rock64_dts
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3328-rock64_dts
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-arch_arm_dts_rk3328-rock64_dts
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3328-rock64_dts
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-nanopi4_dtsi
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-nanopi4_dtsi
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-nanopi4_dtsi
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-nanopi4_dtsi
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-pinebook-pro_dts
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-pinebook-pro_dts
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-pinebook-pro_dts
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-pinebook-pro_dts
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rock-pi-4_dtsi
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rock-pi-4_dtsi
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rock-pi-4_dtsi
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rock-pi-4_dtsi
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rock960_dts
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rock960_dts
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rock960_dts
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rock960_dts
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rockpro64_dtsi
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rockpro64_dtsi
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-rockpro64_dtsi
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-rockpro64_dtsi
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-u-boot_dtsi
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-u-boot_dtsi
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399-u-boot_dtsi
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399-u-boot_dtsi
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_rk3399pro-rock-pi-n10_dts
>>
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399pro-rock-pi-n10_dts
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_rk3399pro-rock-pi-n10_dts
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_rk3399pro-rock-pi-n10_dts
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-arch_arm_dts_sun50i-h6-pine-h64-model-b_dts
>>
>> b/sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_sun50i-h6-pine-h64-model-b_dts
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-arch_arm_dts_sun50i-h6-pine-h64-model-b_dts
>>
>> rename to
>>
>> sysutils/u-boot/aarch64/patches/patch-arch_arm_dts_sun50i-h6-pine-h64-model-b_dts
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_firefly-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_firefly-rk3399_defconfig
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_firefly-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_firefly-rk3399_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_nanopc-t4-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_nanopc-t4-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_nanopc-t4-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_nanopc-t4-rk3399_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_nanopi-neo4-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_nanopi-neo4-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_nanopi-neo4-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_nanopi-neo4-rk3399_defconfig
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_nanopi-r2s-rk3328_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_nanopi-r2s-rk3328_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_nanopi-r2s-rk3328_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_nanopi-r2s-rk3328_defconfig
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_nanopi-r4s-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_nanopi-r4s-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_nanopi-r4s-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_nanopi-r4s-rk3399_defconfig
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_pine_h64-model-b_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_pine_h64-model-b_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_pine_h64-model-b_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_pine_h64-model-b_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_pinebook-pro-rk3399_defconfig
>>
>> b/sysutils/u-boot/aarch64/patches/patch-configs_pinebook-pro-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_pinebook-pro-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_pinebook-pro-rk3399_defconfig
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_rock-pi-4-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_rock-pi-4-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_rock-pi-4-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_rock-pi-4-rk3399_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_rock-pi-n10-rk3399pro_defconfig
>>
>> b/sysutils/u-boot/aarch64/patches/patch-configs_rock-pi-n10-rk3399pro_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_rock-pi-n10-rk3399pro_defconfig
>> rename to
>>
>> sysutils/u-boot/aarch64/patches/patch-configs_rock-pi-n10-rk3399pro_defconfig
>>
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_rock64-rk3328_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_rock64-rk3328_defconfig
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_rock64-rk3328_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_rock64-rk3328_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_rock960-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_rock960-rk3399_defconfig
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_rock960-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_rock960-rk3399_defconfig
>> diff --git
>> a/sysutils/u-boot/patches/patch-configs_rockpro64-rk3399_defconfig
>> b/sysutils/u-boot/aarch64/patches/patch-configs_rockpro64-rk3399_defconfig
>>
>> similarity index 100%
>> rename from
>> sysutils/u-boot/patches/patch-configs_rockpro64-rk3399_defconfig
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-configs_rockpro64-rk3399_defconfig
>> diff --git a/sysutils/u-boot/patches/patch-drivers_pci_pcie_brcmstb_c
>> b/sysutils/u-boot/aarch64/patches/patch-drivers_pci_pcie_brcmstb_c
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-drivers_pci_pcie_brcmstb_c
>> rename to
>> sysutils/u-boot/aarch64/patches/patch-drivers_pci_pcie_brcmstb_c
>> diff --git a/sysutils/u-boot/aarch64/pkg/DESCR
>> b/sysutils/u-boot/aarch64/pkg/DESCR
>> new file mode 100644
>> index 00000000000..7425448b396
>> --- /dev/null
>> +++ b/sysutils/u-boot/aarch64/pkg/DESCR
>> @@ -0,0 +1,8 @@
>> +U-Boot is a firmware for embedded boards based on PowerPC, ARM, MIPS
>> and
>> +several other processors, which can be installed in a boot ROM and used
>> to
>> +initialize and test the hardware or to download and run application
>> code.
>> +
>> +As ARM systems often do not come with firmware it must be supplied on
>> +an SD card or MMC device to have a bootable system.
>> +
>> +This package provides U-Boot for various boards using ARM processors.
>> diff --git a/sysutils/u-boot/aarch64/pkg/PLIST
>> b/sysutils/u-boot/aarch64/pkg/PLIST
>> new file mode 100644
>> index 00000000000..2d2fc9e6454
>> --- /dev/null
>> +++ b/sysutils/u-boot/aarch64/pkg/PLIST
>> @@ -0,0 +1,193 @@
>> +@pkgpath sysutils/u-boot-pinebook
>> +share/u-boot/
>> +share/u-boot/a64-olinuxino/
>> +share/u-boot/a64-olinuxino/sunxi-spl.bin
>> +@comment share/u-boot/a64-olinuxino/u-boot
>> +@comment share/u-boot/a64-olinuxino/u-boot-spl.bin
>> +share/u-boot/a64-olinuxino/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/a64-olinuxino/u-boot.bin
>> +@comment share/u-boot/a64-olinuxino/u-boot.img
>> +share/u-boot/bananapi_m64/
>> +share/u-boot/bananapi_m64/sunxi-spl.bin
>> +@comment share/u-boot/bananapi_m64/u-boot
>> +@comment share/u-boot/bananapi_m64/u-boot-spl.bin
>> +share/u-boot/bananapi_m64/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/bananapi_m64/u-boot.bin
>> +@comment share/u-boot/bananapi_m64/u-boot.img
>> +share/u-boot/firefly-rk3399/
>> +share/u-boot/firefly-rk3399/idbloader.img
>> +@comment share/u-boot/firefly-rk3399/u-boot
>> +share/u-boot/firefly-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/firefly-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/firefly-rk3399/u-boot.bin
>> +@comment share/u-boot/firefly-rk3399/u-boot.img
>> +share/u-boot/firefly-rk3399/u-boot.itb
>> +share/u-boot/mvebu_espressobin-88f3720/
>> +share/u-boot/mvebu_espressobin-88f3720/u-boot
>> +share/u-boot/mvebu_espressobin-88f3720/u-boot.bin
>> +share/u-boot/mvebu_mcbin-88f8040/
>> +share/u-boot/mvebu_mcbin-88f8040/u-boot
>> +share/u-boot/mvebu_mcbin-88f8040/u-boot.bin
>> +share/u-boot/nanopc-t4-rk3399/
>> +share/u-boot/nanopc-t4-rk3399/idbloader.img
>> +@comment share/u-boot/nanopc-t4-rk3399/u-boot
>> +share/u-boot/nanopc-t4-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/nanopc-t4-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/nanopc-t4-rk3399/u-boot.bin
>> +@comment share/u-boot/nanopc-t4-rk3399/u-boot.img
>> +share/u-boot/nanopc-t4-rk3399/u-boot.itb
>> +share/u-boot/nanopi-neo4-rk3399/
>> +share/u-boot/nanopi-neo4-rk3399/idbloader.img
>> +@comment share/u-boot/nanopi-neo4-rk3399/u-boot
>> +share/u-boot/nanopi-neo4-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/nanopi-neo4-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/nanopi-neo4-rk3399/u-boot.bin
>> +@comment share/u-boot/nanopi-neo4-rk3399/u-boot.img
>> +share/u-boot/nanopi-neo4-rk3399/u-boot.itb
>> +share/u-boot/nanopi-r2s-rk3328/
>> +share/u-boot/nanopi-r2s-rk3328/idbloader.img
>> +@comment share/u-boot/nanopi-r2s-rk3328/u-boot
>> +share/u-boot/nanopi-r2s-rk3328/u-boot-rockchip.bin
>> +@comment share/u-boot/nanopi-r2s-rk3328/u-boot-spl.bin
>> +@comment share/u-boot/nanopi-r2s-rk3328/u-boot.bin
>> +@comment share/u-boot/nanopi-r2s-rk3328/u-boot.img
>> +share/u-boot/nanopi-r2s-rk3328/u-boot.itb
>> +share/u-boot/nanopi-r4s-rk3399/
>> +share/u-boot/nanopi-r4s-rk3399/idbloader.img
>> +@comment share/u-boot/nanopi-r4s-rk3399/u-boot
>> +share/u-boot/nanopi-r4s-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/nanopi-r4s-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/nanopi-r4s-rk3399/u-boot.bin
>> +@comment share/u-boot/nanopi-r4s-rk3399/u-boot.img
>> +share/u-boot/nanopi-r4s-rk3399/u-boot.itb
>> +share/u-boot/nanopi_a64/
>> +share/u-boot/nanopi_a64/sunxi-spl.bin
>> +@comment share/u-boot/nanopi_a64/u-boot
>> +@comment share/u-boot/nanopi_a64/u-boot-spl.bin
>> +share/u-boot/nanopi_a64/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/nanopi_a64/u-boot.bin
>> +@comment share/u-boot/nanopi_a64/u-boot.img
>> +share/u-boot/nanopi_neo2/
>> +share/u-boot/nanopi_neo2/sunxi-spl.bin
>> +@comment share/u-boot/nanopi_neo2/u-boot
>> +@comment share/u-boot/nanopi_neo2/u-boot-spl.bin
>> +share/u-boot/nanopi_neo2/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/nanopi_neo2/u-boot.bin
>> +@comment share/u-boot/nanopi_neo2/u-boot.img
>> +share/u-boot/orangepi_pc2/
>> +share/u-boot/orangepi_pc2/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_pc2/u-boot
>> +@comment share/u-boot/orangepi_pc2/u-boot-spl.bin
>> +share/u-boot/orangepi_pc2/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_pc2/u-boot.bin
>> +@comment share/u-boot/orangepi_pc2/u-boot.img
>> +share/u-boot/orangepi_prime/
>> +share/u-boot/orangepi_prime/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_prime/u-boot
>> +@comment share/u-boot/orangepi_prime/u-boot-spl.bin
>> +share/u-boot/orangepi_prime/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_prime/u-boot.bin
>> +@comment share/u-boot/orangepi_prime/u-boot.img
>> +share/u-boot/orangepi_win/
>> +share/u-boot/orangepi_win/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_win/u-boot
>> +@comment share/u-boot/orangepi_win/u-boot-spl.bin
>> +share/u-boot/orangepi_win/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_win/u-boot.bin
>> +@comment share/u-boot/orangepi_win/u-boot.img
>> +share/u-boot/orangepi_zero_plus/
>> +share/u-boot/orangepi_zero_plus/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_zero_plus/u-boot
>> +@comment share/u-boot/orangepi_zero_plus/u-boot-spl.bin
>> +share/u-boot/orangepi_zero_plus/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_zero_plus/u-boot.bin
>> +@comment share/u-boot/orangepi_zero_plus/u-boot.img
>> +share/u-boot/pine64-lts/
>> +share/u-boot/pine64-lts/sunxi-spl.bin
>> +@comment share/u-boot/pine64-lts/u-boot
>> +@comment share/u-boot/pine64-lts/u-boot-spl.bin
>> +share/u-boot/pine64-lts/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/pine64-lts/u-boot.bin
>> +@comment share/u-boot/pine64-lts/u-boot.img
>> +share/u-boot/pine64_plus/
>> +share/u-boot/pine64_plus/sunxi-spl.bin
>> +@comment share/u-boot/pine64_plus/u-boot
>> +@comment share/u-boot/pine64_plus/u-boot-spl.bin
>> +share/u-boot/pine64_plus/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/pine64_plus/u-boot.bin
>> +@comment share/u-boot/pine64_plus/u-boot.img
>> +share/u-boot/pine_h64-model-b/
>> +share/u-boot/pine_h64-model-b/sunxi-spl.bin
>> +@comment share/u-boot/pine_h64-model-b/u-boot
>> +@comment share/u-boot/pine_h64-model-b/u-boot-spl.bin
>> +share/u-boot/pine_h64-model-b/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/pine_h64-model-b/u-boot.bin
>> +@comment share/u-boot/pine_h64-model-b/u-boot.img
>> +share/u-boot/pinebook-pro-rk3399/
>> +share/u-boot/pinebook-pro-rk3399/idbloader.img
>> +@comment share/u-boot/pinebook-pro-rk3399/u-boot
>> +share/u-boot/pinebook-pro-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/pinebook-pro-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/pinebook-pro-rk3399/u-boot.bin
>> +@comment share/u-boot/pinebook-pro-rk3399/u-boot.img
>> +share/u-boot/pinebook-pro-rk3399/u-boot.itb
>> +share/u-boot/pinebook/
>> +share/u-boot/pinebook/sunxi-spl.bin
>> +@comment share/u-boot/pinebook/u-boot
>> +@comment share/u-boot/pinebook/u-boot-spl.bin
>> +share/u-boot/pinebook/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/pinebook/u-boot.bin
>> +@comment share/u-boot/pinebook/u-boot.img
>> +share/u-boot/qemu_arm64/
>> +share/u-boot/qemu_arm64/u-boot
>> +share/u-boot/qemu_arm64/u-boot.bin
>> +share/u-boot/rock-pi-4-rk3399/
>> +share/u-boot/rock-pi-4-rk3399/idbloader.img
>> +@comment share/u-boot/rock-pi-4-rk3399/u-boot
>> +share/u-boot/rock-pi-4-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/rock-pi-4-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/rock-pi-4-rk3399/u-boot.bin
>> +@comment share/u-boot/rock-pi-4-rk3399/u-boot.img
>> +share/u-boot/rock-pi-4-rk3399/u-boot.itb
>> +share/u-boot/rock-pi-n10-rk3399pro/
>> +share/u-boot/rock-pi-n10-rk3399pro/idbloader.img
>> +@comment share/u-boot/rock-pi-n10-rk3399pro/u-boot
>> +share/u-boot/rock-pi-n10-rk3399pro/u-boot-rockchip.bin
>> +@comment share/u-boot/rock-pi-n10-rk3399pro/u-boot-spl.bin
>> +@comment share/u-boot/rock-pi-n10-rk3399pro/u-boot.bin
>> +@comment share/u-boot/rock-pi-n10-rk3399pro/u-boot.img
>> +share/u-boot/rock-pi-n10-rk3399pro/u-boot.itb
>> +share/u-boot/rock64-rk3328/
>> +share/u-boot/rock64-rk3328/idbloader.img
>> +@comment share/u-boot/rock64-rk3328/u-boot
>> +share/u-boot/rock64-rk3328/u-boot-rockchip.bin
>> +@comment share/u-boot/rock64-rk3328/u-boot-spl.bin
>> +@comment share/u-boot/rock64-rk3328/u-boot.bin
>> +@comment share/u-boot/rock64-rk3328/u-boot.img
>> +share/u-boot/rock64-rk3328/u-boot.itb
>> +share/u-boot/rock960-rk3399/
>> +share/u-boot/rock960-rk3399/idbloader.img
>> +@comment share/u-boot/rock960-rk3399/u-boot
>> +share/u-boot/rock960-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/rock960-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/rock960-rk3399/u-boot.bin
>> +@comment share/u-boot/rock960-rk3399/u-boot.img
>> +share/u-boot/rock960-rk3399/u-boot.itb
>> +share/u-boot/rockpro64-rk3399/
>> +share/u-boot/rockpro64-rk3399/idbloader.img
>> +@comment share/u-boot/rockpro64-rk3399/u-boot
>> +share/u-boot/rockpro64-rk3399/u-boot-rockchip.bin
>> +@comment share/u-boot/rockpro64-rk3399/u-boot-spl.bin
>> +@comment share/u-boot/rockpro64-rk3399/u-boot.bin
>> +@comment share/u-boot/rockpro64-rk3399/u-boot.img
>> +share/u-boot/rockpro64-rk3399/u-boot.itb
>> +share/u-boot/rpi_arm64/
>> +@comment share/u-boot/rpi_arm64/u-boot
>> +share/u-boot/rpi_arm64/u-boot.bin
>> +share/u-boot/sopine_baseboard/
>> +share/u-boot/sopine_baseboard/sunxi-spl.bin
>> +@comment share/u-boot/sopine_baseboard/u-boot
>> +@comment share/u-boot/sopine_baseboard/u-boot-spl.bin
>> +share/u-boot/sopine_baseboard/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/sopine_baseboard/u-boot.bin
>> +@comment share/u-boot/sopine_baseboard/u-boot.img
>> diff --git a/sysutils/u-boot/arm/Makefile b/sysutils/u-boot/arm/Makefile
>> new file mode 100644
>> index 00000000000..6e6e746ae20
>> --- /dev/null
>> +++ b/sysutils/u-boot/arm/Makefile
>> @@ -0,0 +1,64 @@
>> +VERSION= 2021.10
>> +REVISION= 7
>> +
>> +SOC= arm
>> +SOC_CPU= arm
>> +
>> +OMAP=\
>> + omap4_panda \
>> + am335x_evm
>> +SUNXI64=
>> +SUNXI=\
>> + A10-OLinuXino-Lime \
>> + A10s-OLinuXino-M \
>> + A20-OLinuXino-Lime \
>> + A20-OLinuXino-Lime2 \
>> + A20-OLinuXino-Lime2-eMMC \
>> + A20-OLinuXino_MICRO \
>> + Bananapi \
>> + Bananapi_M2_Ultra \
>> + Bananapi_m2m \
>> + bananapi_m2_plus_h3 \
>> + bananapi_m2_zero \
>> + Bananapro \
>> + CHIP \
>> + Cubieboard \
>> + Cubieboard2 \
>> + Cubieboard4 \
>> + Cubietruck \
>> + Lamobo_R1 \
>> + Linksprite_pcDuino \
>> + Linksprite_pcDuino3 \
>> + Linksprite_pcDuino3_Nano \
>> + nanopi_neo \
>> + Orangepi \
>> + Orangepi_mini \
>> + orangepi_2 \
>> + orangepi_lite \
>> + orangepi_one \
>> + orangepi_pc \
>> + orangepi_pc_plus \
>> + orangepi_plus \
>> + orangepi_plus2e \
>> + orangepi_zero
>> +IMX=\
>> + cm_fx6 \
>> + mx6cuboxi \
>> + mx6qsabrelite \
>> + nitrogen6q \
>> + novena \
>> + udoo \
>> + usbarmory \
>> + wandboard
>> +BOARDS=\
>> + ${OMAP} \
>> + ${SUNXI} \
>> + ${IMX} \
>> + clearfog \
>> + qemu_arm \
>> + rpi_2 \
>> + rpi_3_32b \
>> + tinker-rk3288 \
>> + turris_omnia
>> +
>> +.include <bsd.port.mk>
>> diff --git a/sysutils/u-boot/arm/distinfo b/sysutils/u-boot/arm/distinfo
>> new file mode 100644
>> index 00000000000..674a428905c
>> --- /dev/null
>> +++ b/sysutils/u-boot/arm/distinfo
>> @@ -0,0 +1,2 @@
>> +SHA256 (u-boot-2021.10.tar.bz2) =
>> zecj4ZJi5kbyZw0l5exLGzaEkN6VDU4mJ1qYjDbfC9Q=
>> +SIZE (u-boot-2021.10.tar.bz2) = 17358295
>> diff --git a/sysutils/u-boot/patches/patch-configs_rpi_2_defconfig
>> b/sysutils/u-boot/arm/patches/patch-configs_rpi_2_defconfig
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-configs_rpi_2_defconfig
>> rename to sysutils/u-boot/arm/patches/patch-configs_rpi_2_defconfig
>> diff --git a/sysutils/u-boot/patches/patch-configs_rpi_3_32b_defconfig
>> b/sysutils/u-boot/arm/patches/patch-configs_rpi_3_32b_defconfig
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-configs_rpi_3_32b_defconfig
>> rename to sysutils/u-boot/arm/patches/patch-configs_rpi_3_32b_defconfig
>> diff --git
>> a/sysutils/u-boot/arm/patches/patch-drivers_pci_pcie_brcmstb_c
>> b/sysutils/u-boot/arm/patches/patch-drivers_pci_pcie_brcmstb_c
>> new file mode 100644
>> index 00000000000..5c52791c841
>> --- /dev/null
>> +++ b/sysutils/u-boot/arm/patches/patch-drivers_pci_pcie_brcmstb_c
>> @@ -0,0 +1,42 @@
>> +revert 'pci: brcmstb: Cleanup controller state before handover'
>> +85f3fddbcc2e8282f1c26dcef4684f59490d47ba
>> +
>> +resetting pcie breaks pcie xhci on rpi4
>> +
>> +Index: drivers/pci/pcie_brcmstb.c
>> +--- drivers/pci/pcie_brcmstb.c.orig
>> ++++ drivers/pci/pcie_brcmstb.c
>> +@@ -577,24 +577,6 @@ static int brcm_pcie_probe(struct udevice *dev)
>> + return 0;
>> + }
>> +
>> +-static int brcm_pcie_remove(struct udevice *dev)
>> +-{
>> +- struct brcm_pcie *pcie = dev_get_priv(dev);
>> +- void __iomem *base = pcie->base;
>> +-
>> +- /* Assert fundamental reset */
>> +- setbits_le32(base + PCIE_RGR1_SW_INIT_1, RGR1_SW_INIT_1_PERST_MASK);
>> +-
>> +- /* Turn off SerDes */
>> +- setbits_le32(base + PCIE_MISC_HARD_PCIE_HARD_DEBUG,
>> +- PCIE_HARD_DEBUG_SERDES_IDDQ_MASK);
>> +-
>> +- /* Shutdown bridge */
>> +- setbits_le32(base + PCIE_RGR1_SW_INIT_1, RGR1_SW_INIT_1_INIT_MASK);
>> +-
>> +- return 0;
>> +-}
>> +-
>> + static int brcm_pcie_of_to_plat(struct udevice *dev)
>> + {
>> + struct brcm_pcie *pcie = dev_get_priv(dev);
>> +@@ -634,8 +616,6 @@ U_BOOT_DRIVER(pcie_brcm_base) = {
>> + .ops = &brcm_pcie_ops,
>> + .of_match = brcm_pcie_ids,
>> + .probe = brcm_pcie_probe,
>> +- .remove = brcm_pcie_remove,
>> + .of_to_plat = brcm_pcie_of_to_plat,
>> + .priv_auto = sizeof(struct brcm_pcie),
>> +- .flags = DM_FLAG_OS_PREPARE,
>> + };
>> diff --git a/sysutils/u-boot/arm/pkg/DESCR
>> b/sysutils/u-boot/arm/pkg/DESCR
>> new file mode 100644
>> index 00000000000..7425448b396
>> --- /dev/null
>> +++ b/sysutils/u-boot/arm/pkg/DESCR
>> @@ -0,0 +1,8 @@
>> +U-Boot is a firmware for embedded boards based on PowerPC, ARM, MIPS
>> and
>> +several other processors, which can be installed in a boot ROM and used
>> to
>> +initialize and test the hardware or to download and run application
>> code.
>> +
>> +As ARM systems often do not come with firmware it must be supplied on
>> +an SD card or MMC device to have a bootable system.
>> +
>> +This package provides U-Boot for various boards using ARM processors.
>> diff --git a/sysutils/u-boot/arm/pkg/PLIST
>> b/sysutils/u-boot/arm/pkg/PLIST
>> new file mode 100644
>> index 00000000000..5681374ac01
>> --- /dev/null
>> +++ b/sysutils/u-boot/arm/pkg/PLIST
>> @@ -0,0 +1,264 @@
>> +@pkgpath sysutils/u-boot,
>> +share/u-boot/
>> +share/u-boot/A10-OLinuXino-Lime/
>> +share/u-boot/A10-OLinuXino-Lime/sunxi-spl.bin
>> +@comment share/u-boot/A10-OLinuXino-Lime/u-boot
>> +share/u-boot/A10-OLinuXino-Lime/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A10-OLinuXino-Lime/u-boot.bin
>> +@comment share/u-boot/A10-OLinuXino-Lime/u-boot.img
>> +share/u-boot/A10s-OLinuXino-M/
>> +share/u-boot/A10s-OLinuXino-M/sunxi-spl.bin
>> +@comment share/u-boot/A10s-OLinuXino-M/u-boot
>> +share/u-boot/A10s-OLinuXino-M/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A10s-OLinuXino-M/u-boot.bin
>> +@comment share/u-boot/A10s-OLinuXino-M/u-boot.img
>> +share/u-boot/A20-OLinuXino-Lime/
>> +share/u-boot/A20-OLinuXino-Lime/sunxi-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime/u-boot
>> +share/u-boot/A20-OLinuXino-Lime/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime/u-boot.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime/u-boot.img
>> +share/u-boot/A20-OLinuXino-Lime2/
>> +share/u-boot/A20-OLinuXino-Lime2-eMMC/
>> +share/u-boot/A20-OLinuXino-Lime2-eMMC/sunxi-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2-eMMC/u-boot
>> +share/u-boot/A20-OLinuXino-Lime2-eMMC/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2-eMMC/u-boot.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2-eMMC/u-boot.img
>> +share/u-boot/A20-OLinuXino-Lime2/sunxi-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2/u-boot
>> +share/u-boot/A20-OLinuXino-Lime2/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2/u-boot.bin
>> +@comment share/u-boot/A20-OLinuXino-Lime2/u-boot.img
>> +share/u-boot/A20-OLinuXino_MICRO/
>> +share/u-boot/A20-OLinuXino_MICRO/sunxi-spl.bin
>> +@comment share/u-boot/A20-OLinuXino_MICRO/u-boot
>> +share/u-boot/A20-OLinuXino_MICRO/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/A20-OLinuXino_MICRO/u-boot.bin
>> +@comment share/u-boot/A20-OLinuXino_MICRO/u-boot.img
>> +share/u-boot/Bananapi/
>> +share/u-boot/Bananapi/sunxi-spl.bin
>> +@comment share/u-boot/Bananapi/u-boot
>> +share/u-boot/Bananapi/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Bananapi/u-boot.bin
>> +@comment share/u-boot/Bananapi/u-boot.img
>> +share/u-boot/Bananapi_M2_Ultra/
>> +share/u-boot/Bananapi_M2_Ultra/sunxi-spl.bin
>> +@comment share/u-boot/Bananapi_M2_Ultra/u-boot
>> +share/u-boot/Bananapi_M2_Ultra/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Bananapi_M2_Ultra/u-boot.bin
>> +@comment share/u-boot/Bananapi_M2_Ultra/u-boot.img
>> +share/u-boot/Bananapi_m2m/
>> +share/u-boot/Bananapi_m2m/sunxi-spl.bin
>> +@comment share/u-boot/Bananapi_m2m/u-boot
>> +share/u-boot/Bananapi_m2m/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Bananapi_m2m/u-boot.bin
>> +@comment share/u-boot/Bananapi_m2m/u-boot.img
>> +share/u-boot/Bananapro/
>> +share/u-boot/Bananapro/sunxi-spl.bin
>> +@comment share/u-boot/Bananapro/u-boot
>> +share/u-boot/Bananapro/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Bananapro/u-boot.bin
>> +@comment share/u-boot/Bananapro/u-boot.img
>> +share/u-boot/CHIP/
>> +share/u-boot/CHIP/sunxi-spl.bin
>> +@comment share/u-boot/CHIP/u-boot
>> +share/u-boot/CHIP/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/CHIP/u-boot.bin
>> +@comment share/u-boot/CHIP/u-boot.img
>> +share/u-boot/Cubieboard/
>> +share/u-boot/Cubieboard/sunxi-spl.bin
>> +@comment share/u-boot/Cubieboard/u-boot
>> +share/u-boot/Cubieboard/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Cubieboard/u-boot.bin
>> +@comment share/u-boot/Cubieboard/u-boot.img
>> +share/u-boot/Cubieboard2/
>> +share/u-boot/Cubieboard2/sunxi-spl.bin
>> +@comment share/u-boot/Cubieboard2/u-boot
>> +share/u-boot/Cubieboard2/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Cubieboard2/u-boot.bin
>> +@comment share/u-boot/Cubieboard2/u-boot.img
>> +share/u-boot/Cubieboard4/
>> +share/u-boot/Cubieboard4/sunxi-spl.bin
>> +@comment share/u-boot/Cubieboard4/u-boot
>> +share/u-boot/Cubieboard4/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Cubieboard4/u-boot.bin
>> +@comment share/u-boot/Cubieboard4/u-boot.img
>> +share/u-boot/Cubietruck/
>> +share/u-boot/Cubietruck/sunxi-spl.bin
>> +@comment share/u-boot/Cubietruck/u-boot
>> +share/u-boot/Cubietruck/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Cubietruck/u-boot.bin
>> +@comment share/u-boot/Cubietruck/u-boot.img
>> +share/u-boot/Lamobo_R1/
>> +share/u-boot/Lamobo_R1/sunxi-spl.bin
>> +@comment share/u-boot/Lamobo_R1/u-boot
>> +share/u-boot/Lamobo_R1/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Lamobo_R1/u-boot.bin
>> +@comment share/u-boot/Lamobo_R1/u-boot.img
>> +share/u-boot/Linksprite_pcDuino/
>> +share/u-boot/Linksprite_pcDuino/sunxi-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino/u-boot
>> +share/u-boot/Linksprite_pcDuino/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino/u-boot.bin
>> +@comment share/u-boot/Linksprite_pcDuino/u-boot.img
>> +share/u-boot/Linksprite_pcDuino3/
>> +share/u-boot/Linksprite_pcDuino3/sunxi-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino3/u-boot
>> +share/u-boot/Linksprite_pcDuino3/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino3/u-boot.bin
>> +@comment share/u-boot/Linksprite_pcDuino3/u-boot.img
>> +share/u-boot/Linksprite_pcDuino3_Nano/
>> +share/u-boot/Linksprite_pcDuino3_Nano/sunxi-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino3_Nano/u-boot
>> +share/u-boot/Linksprite_pcDuino3_Nano/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Linksprite_pcDuino3_Nano/u-boot.bin
>> +@comment share/u-boot/Linksprite_pcDuino3_Nano/u-boot.img
>> +share/u-boot/Orangepi/
>> +share/u-boot/Orangepi/sunxi-spl.bin
>> +@comment share/u-boot/Orangepi/u-boot
>> +share/u-boot/Orangepi/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Orangepi/u-boot.bin
>> +@comment share/u-boot/Orangepi/u-boot.img
>> +share/u-boot/Orangepi_mini/
>> +share/u-boot/Orangepi_mini/sunxi-spl.bin
>> +@comment share/u-boot/Orangepi_mini/u-boot
>> +share/u-boot/Orangepi_mini/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/Orangepi_mini/u-boot.bin
>> +@comment share/u-boot/Orangepi_mini/u-boot.img
>> +share/u-boot/am335x_evm/
>> +share/u-boot/am335x_evm/MLO
>> +@comment share/u-boot/am335x_evm/u-boot
>> +@comment share/u-boot/am335x_evm/u-boot.bin
>> +share/u-boot/am335x_evm/u-boot.img
>> +share/u-boot/bananapi_m2_plus_h3/
>> +share/u-boot/bananapi_m2_plus_h3/sunxi-spl.bin
>> +@comment share/u-boot/bananapi_m2_plus_h3/u-boot
>> +share/u-boot/bananapi_m2_plus_h3/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/bananapi_m2_plus_h3/u-boot.bin
>> +@comment share/u-boot/bananapi_m2_plus_h3/u-boot.img
>> +share/u-boot/bananapi_m2_zero/
>> +share/u-boot/bananapi_m2_zero/sunxi-spl.bin
>> +@comment share/u-boot/bananapi_m2_zero/u-boot
>> +share/u-boot/bananapi_m2_zero/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/bananapi_m2_zero/u-boot.bin
>> +@comment share/u-boot/bananapi_m2_zero/u-boot.img
>> +share/u-boot/clearfog/
>> +@comment share/u-boot/clearfog/u-boot
>> +share/u-boot/clearfog/u-boot-spl.kwb
>> +@comment share/u-boot/clearfog/u-boot.bin
>> +@comment share/u-boot/clearfog/u-boot.img
>> +share/u-boot/cm_fx6/
>> +share/u-boot/cm_fx6/SPL
>> +@comment share/u-boot/cm_fx6/u-boot
>> +@comment share/u-boot/cm_fx6/u-boot.bin
>> +share/u-boot/cm_fx6/u-boot.img
>> +share/u-boot/mx6cuboxi/
>> +share/u-boot/mx6cuboxi/SPL
>> +@comment share/u-boot/mx6cuboxi/u-boot
>> +@comment share/u-boot/mx6cuboxi/u-boot.bin
>> +share/u-boot/mx6cuboxi/u-boot.img
>> +share/u-boot/mx6qsabrelite/
>> +@comment share/u-boot/mx6qsabrelite/u-boot
>> +share/u-boot/mx6qsabrelite/u-boot-dtb.imx
>> +@comment share/u-boot/mx6qsabrelite/u-boot.bin
>> +share/u-boot/nanopi_neo/
>> +share/u-boot/nanopi_neo/sunxi-spl.bin
>> +@comment share/u-boot/nanopi_neo/u-boot
>> +share/u-boot/nanopi_neo/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/nanopi_neo/u-boot.bin
>> +@comment share/u-boot/nanopi_neo/u-boot.img
>> +share/u-boot/nitrogen6q/
>> +@comment share/u-boot/nitrogen6q/u-boot
>> +share/u-boot/nitrogen6q/u-boot-dtb.imx
>> +@comment share/u-boot/nitrogen6q/u-boot.bin
>> +share/u-boot/novena/
>> +share/u-boot/novena/SPL
>> +@comment share/u-boot/novena/u-boot
>> +@comment share/u-boot/novena/u-boot.bin
>> +share/u-boot/novena/u-boot.img
>> +share/u-boot/omap4_panda/
>> +share/u-boot/omap4_panda/MLO
>> +@comment share/u-boot/omap4_panda/u-boot
>> +@comment share/u-boot/omap4_panda/u-boot.bin
>> +share/u-boot/omap4_panda/u-boot.img
>> +share/u-boot/orangepi_2/
>> +share/u-boot/orangepi_2/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_2/u-boot
>> +share/u-boot/orangepi_2/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_2/u-boot.bin
>> +@comment share/u-boot/orangepi_2/u-boot.img
>> +share/u-boot/orangepi_lite/
>> +share/u-boot/orangepi_lite/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_lite/u-boot
>> +share/u-boot/orangepi_lite/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_lite/u-boot.bin
>> +@comment share/u-boot/orangepi_lite/u-boot.img
>> +share/u-boot/orangepi_one/
>> +share/u-boot/orangepi_one/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_one/u-boot
>> +share/u-boot/orangepi_one/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_one/u-boot.bin
>> +@comment share/u-boot/orangepi_one/u-boot.img
>> +share/u-boot/orangepi_pc/
>> +share/u-boot/orangepi_pc/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_pc/u-boot
>> +share/u-boot/orangepi_pc/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_pc/u-boot.bin
>> +@comment share/u-boot/orangepi_pc/u-boot.img
>> +share/u-boot/orangepi_pc_plus/
>> +share/u-boot/orangepi_pc_plus/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_pc_plus/u-boot
>> +share/u-boot/orangepi_pc_plus/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_pc_plus/u-boot.bin
>> +@comment share/u-boot/orangepi_pc_plus/u-boot.img
>> +share/u-boot/orangepi_plus/
>> +share/u-boot/orangepi_plus/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_plus/u-boot
>> +share/u-boot/orangepi_plus/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_plus/u-boot.bin
>> +@comment share/u-boot/orangepi_plus/u-boot.img
>> +share/u-boot/orangepi_plus2e/
>> +share/u-boot/orangepi_plus2e/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_plus2e/u-boot
>> +share/u-boot/orangepi_plus2e/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_plus2e/u-boot.bin
>> +@comment share/u-boot/orangepi_plus2e/u-boot.img
>> +share/u-boot/orangepi_zero/
>> +share/u-boot/orangepi_zero/sunxi-spl.bin
>> +@comment share/u-boot/orangepi_zero/u-boot
>> +share/u-boot/orangepi_zero/u-boot-sunxi-with-spl.bin
>> +@comment share/u-boot/orangepi_zero/u-boot.bin
>> +@comment share/u-boot/orangepi_zero/u-boot.img
>> +share/u-boot/qemu_arm/
>> +share/u-boot/qemu_arm/u-boot
>> +share/u-boot/qemu_arm/u-boot.bin
>> +share/u-boot/rpi_2/
>> +@comment share/u-boot/rpi_2/u-boot
>> +share/u-boot/rpi_2/u-boot.bin
>> +share/u-boot/rpi_3_32b/
>> +@comment share/u-boot/rpi_3_32b/u-boot
>> +share/u-boot/rpi_3_32b/u-boot.bin
>> +share/u-boot/tinker-rk3288/
>> +share/u-boot/tinker-rk3288/idbloader.img
>> +@comment share/u-boot/tinker-rk3288/u-boot
>> +@comment share/u-boot/tinker-rk3288/u-boot.bin
>> +share/u-boot/tinker-rk3288/u-boot.img
>> +share/u-boot/turris_omnia/
>> +@comment share/u-boot/turris_omnia/u-boot
>> +share/u-boot/turris_omnia/u-boot-spl.kwb
>> +@comment share/u-boot/turris_omnia/u-boot.bin
>> +@comment share/u-boot/turris_omnia/u-boot.img
>> +share/u-boot/udoo/
>> +share/u-boot/udoo/SPL
>> +@comment share/u-boot/udoo/u-boot
>> +@comment share/u-boot/udoo/u-boot.bin
>> +share/u-boot/udoo/u-boot.img
>> +share/u-boot/usbarmory/
>> +share/u-boot/usbarmory/u-boot
>> +share/u-boot/usbarmory/u-boot.bin
>> +share/u-boot/wandboard/
>> +share/u-boot/wandboard/SPL
>> +@comment share/u-boot/wandboard/u-boot
>> +@comment share/u-boot/wandboard/u-boot.bin
>> +share/u-boot/wandboard/u-boot.img
>> diff --git a/sysutils/u-boot/patches/patch-configs_rpi_3_defconfig
>> b/sysutils/u-boot/patches/patch-configs_rpi_3_defconfig
>> deleted file mode 100644
>> index 6c3e6862d5a..00000000000
>> --- a/sysutils/u-boot/patches/patch-configs_rpi_3_defconfig
>> +++ /dev/null
>> @@ -1,28 +0,0 @@
>> -rpi: Use firmware provided device tree
>> -
>> -Currently the firmware generates a device tree for us that we could
>> -just use to adjust ourselves. We then on boot throw that away and
>> -use our own built-in device tree to configure device access.
>> -
>> -This is bad for a multitude of reasons. For starters, it breaks
>> -overlay support in config.txt, confusing users. Much worse however
>> -is that we are stuck with individual U-Boot builds per board.
>> -The firmware can easily give us the right DT depending on the
>> -target board and revision though.
>> -
>> -So let's use the firmware provided device tree instead. That way
>> -U-Boot as well as payloads loaded by it can automatically adapt
>> -to variants of RPi hardware.
>> -
>> -Index: configs/rpi_3_defconfig
>> ---- configs/rpi_3_defconfig.orig
>> -+++ configs/rpi_3_defconfig
>> -@@ -18,7 +18,7 @@ CONFIG_CMD_GPIO=y
>> - CONFIG_CMD_MMC=y
>> - CONFIG_CMD_USB=y
>> - CONFIG_CMD_FS_UUID=y
>> --CONFIG_OF_EMBED=y
>> -+CONFIG_OF_BOARD=y
>> - CONFIG_ENV_FAT_DEVICE_AND_PART="0:1"
>> - CONFIG_SYS_RELOC_GD_ENV_ADDR=y
>> - CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG=y
>> diff --git a/sysutils/u-boot/riscv64/Makefile
>> b/sysutils/u-boot/riscv64/Makefile
>> new file mode 100644
>> index 00000000000..4927e7c1715
>> --- /dev/null
>> +++ b/sysutils/u-boot/riscv64/Makefile
>> @@ -0,0 +1,11 @@
>> +VERSION= 2021.10
>> +REVISION= 7
>> +
>> +SOC= riscv64
>> +SOC_CPU= riscv64
>> +
>> +BOARDS=\
>> + qemu-riscv64_smode \
>> + sifive_unmatched
>> +
>> +.include <bsd.port.mk>
>> diff --git a/sysutils/u-boot/riscv64/distinfo
>> b/sysutils/u-boot/riscv64/distinfo
>> new file mode 100644
>> index 00000000000..674a428905c
>> --- /dev/null
>> +++ b/sysutils/u-boot/riscv64/distinfo
>> @@ -0,0 +1,2 @@
>> +SHA256 (u-boot-2021.10.tar.bz2) =
>> zecj4ZJi5kbyZw0l5exLGzaEkN6VDU4mJ1qYjDbfC9Q=
>> +SIZE (u-boot-2021.10.tar.bz2) = 17358295
>> diff --git a/sysutils/u-boot/patches/patch-arch_riscv_Makefile
>> b/sysutils/u-boot/riscv64/patches/patch-arch_riscv_Makefile
>> similarity index 100%
>> rename from sysutils/u-boot/patches/patch-arch_riscv_Makefile
>> rename to sysutils/u-boot/riscv64/patches/patch-arch_riscv_Makefile
>> diff --git a/sysutils/u-boot/riscv64/pkg/DESCR
>> b/sysutils/u-boot/riscv64/pkg/DESCR
>> new file mode 100644
>> index 00000000000..7425448b396
>> --- /dev/null
>> +++ b/sysutils/u-boot/riscv64/pkg/DESCR
>> @@ -0,0 +1,8 @@
>> +U-Boot is a firmware for embedded boards based on PowerPC, ARM, MIPS
>> and
>> +several other processors, which can be installed in a boot ROM and used
>> to
>> +initialize and test the hardware or to download and run application
>> code.
>> +
>> +As ARM systems often do not come with firmware it must be supplied on
>> +an SD card or MMC device to have a bootable system.
>> +
>> +This package provides U-Boot for various boards using ARM processors.
>> diff --git a/sysutils/u-boot/riscv64/pkg/PLIST
>> b/sysutils/u-boot/riscv64/pkg/PLIST
>> new file mode 100644
>> index 00000000000..e0d4902e58e
>> --- /dev/null
>> +++ b/sysutils/u-boot/riscv64/pkg/PLIST
>> @@ -0,0 +1,10 @@
>> +share/u-boot/
>> +share/u-boot/qemu-riscv64_smode/
>> +share/u-boot/qemu-riscv64_smode/u-boot
>> +share/u-boot/qemu-riscv64_smode/u-boot.bin
>> +share/u-boot/sifive_unmatched/
>> +@comment share/u-boot/sifive_unmatched/u-boot
>> +share/u-boot/sifive_unmatched/u-boot-spl.bin
>> +@comment share/u-boot/sifive_unmatched/u-boot.bin
>> +@comment share/u-boot/sifive_unmatched/u-boot.img
>> +share/u-boot/sifive_unmatched/u-boot.itb
>> --
>> 2.41.0