Ver Fonte

add support for rockpi4-plus

Waldemar Brodkorb há 2 anos atrás
pai
commit
767514154b

+ 1 - 1
mk/image.mk

@@ -357,7 +357,7 @@ endif
 	PATH='${HOST_PATH}' $(FAKEROOT) mkfs.ext2 \
 		-d "$(TARGET_DIR)" \
 		-r 1 -N 0 -m 5 -L "rootfs" \
-		$(FW_DIR)/rootfs.ext "32M" $(MAKE_TRACE)
+		$(FW_DIR)/rootfs.ext "48M" $(MAKE_TRACE)
 	PATH='${HOST_PATH}' genimage \
 		--config "$(GENCFG)" \
 		--tmppath "${FW_DIR}/temp" \

+ 5 - 5
mk/linux-ver.mk

@@ -15,17 +15,17 @@ KERNEL_FILE_VER:=	$(ADK_TARGET_LINUX_KERNEL_GIT)
 KERNEL_RELEASE:=	1
 KERNEL_VERSION:=	$(ADK_TARGET_LINUX_KERNEL_GIT_VER)-$(KERNEL_RELEASE)
 endif
-ifeq ($(ADK_TARGET_LINUX_KERNEL_VERSION_5_19),y)
-KERNEL_FILE_VER:=	5.19.12
+ifeq ($(ADK_TARGET_LINUX_KERNEL_VERSION_6_0),y)
+KERNEL_FILE_VER:=	6.0.11
 KERNEL_RELEASE:=	1
 KERNEL_VERSION:=	$(KERNEL_FILE_VER)-$(KERNEL_RELEASE)
-KERNEL_HASH:=		c436a548c7312ce6fc5a3472cbead895eef8f52841fbe7c71fd8e48bdfe2b0ba
+KERNEL_HASH:=		2bae6131e64971e1e34ff395fa542971134c857bdb0b29069ab847c7c9a9c762
 endif
 ifeq ($(ADK_TARGET_LINUX_KERNEL_VERSION_5_15),y)
-KERNEL_FILE_VER:=	5.15.71
+KERNEL_FILE_VER:=	5.15.81
 KERNEL_RELEASE:=	1
 KERNEL_VERSION:=	$(KERNEL_FILE_VER)-$(KERNEL_RELEASE)
-KERNEL_HASH:=		5f5408138e016c0e029e015d98ceab86f4e6366c65cd611259dac808ab1d1e53
+KERNEL_HASH:=		8f885cdebd754d6e63b920cf6c3e5713e91bbf5f52e9d99eb0054ef7e8f096ab
 endif
 ifeq ($(ADK_TARGET_LINUX_KERNEL_VERSION_5_10),y)
 KERNEL_FILE_VER:=	5.10.146

+ 2 - 1
mk/linux.mk

@@ -9,7 +9,8 @@ PKG_GIT:=	$(ADK_TARGET_LINUX_KERNEL_GIT_TYPE)
 PKG_SITES:=	$(ADK_TARGET_LINUX_KERNEL_GIT_REPO)
 else
 PKG_VERSION:=	$(KERNEL_FILE_VER)
-PKG_SITES:=  	${MASTER_SITE_KERNEL:=kernel/v5.x/} \
+PKG_SITES:=  	${MASTER_SITE_KERNEL:=kernel/v6.x/} \
+		${MASTER_SITE_KERNEL:=kernel/v5.x/} \
 		${MASTER_SITE_KERNEL:=kernel/v4.x/} \
 		${MASTER_SITE_KERNEL:=kernel/v3.x/} \
 		${MASTER_SITE_KERNEL:=kernel/v3.0/testing/} \

+ 2 - 2
package/genimage/Makefile

@@ -4,9 +4,9 @@
 include $(ADK_TOPDIR)/rules.mk
 
 PKG_NAME:=		genimage
-PKG_VERSION:=		9
+PKG_VERSION:=		16
 PKG_RELEASE:=		1
-PKG_HASH:=		69f35af7edf6f4dbdac7a18ddc69dcf38c501e43d8b50c524555754c51479078
+PKG_HASH:=		869f9662d3b778c69b1d1fe70df658e1c9e90aeda26abb753f6fe55e8b0c6e73
 PKG_DESCR:=		image creation utility
 PKG_SECTION:=		dev/tools
 HOST_BUILDDEP:=		confuse-host

+ 8 - 2
package/u-boot/Makefile

@@ -16,7 +16,7 @@ PKG_SITES:=		ftp://ftp.denx.de/pub/u-boot/
 
 DISTFILES:=		$(PKG_NAME)-$(PKG_VERSION).tar.bz2
 
-PKG_SYSTEM_DEPENDS:=	beaglebone-black orange-pi0 raspberry-pi raspberry-pi2 raspberry-pi3 banana-pro solidrun-imx6 solidrun-clearfog raspberry-pi3-64 raspberry-pi3p raspberry-pi3p-64 phytec-imx6 pcduino-3b imgtec-ci20 st-stm32f746g
+PKG_SYSTEM_DEPENDS:=	beaglebone-black orange-pi0 raspberry-pi raspberry-pi2 raspberry-pi3 banana-pro solidrun-imx6 solidrun-clearfog raspberry-pi3-64 raspberry-pi3p raspberry-pi3p-64 rockpi4-plus phytec-imx6 pcduino-3b imgtec-ci20 st-stm32f746g
 
 include $(ADK_TOPDIR)/mk/host.mk
 include $(ADK_TOPDIR)/mk/package.mk
@@ -58,6 +58,10 @@ endif
 ifeq ($(ADK_TARGET_SYSTEM_RASPBERRY_PI3P_64),y)
 CONFIG:=		rpi_3_defconfig
 endif
+ifeq ($(ADK_TARGET_SYSTEM_ROCKPI4_PLUS),y)
+CONFIG:=		rock-pi-4c-rk3399_defconfig
+UBOOT:=			u-boot.itb
+endif
 ifeq ($(ADK_TARGET_SYSTEM_BANANA_PRO),y)
 CONFIG:=		Bananapro_defconfig
 UBOOT:=			u-boot-sunxi-with-spl.bin
@@ -104,7 +108,6 @@ do-build:
 		V=1 \
 		PATH='$(HOST_PATH)' \
 		CROSS_COMPILE='$(TARGET_CROSS)' \
-		KCFLAGS='-mno-fdpic' \
 		$(MAKE))
 ifneq ($(OS_FOR_BUILD),Darwin)
 	(cd $(WRKBUILD) && env \
@@ -115,6 +118,9 @@ endif
 
 u-boot-install:
 	$(CP) $(WRKBUILD)/$(UBOOT) $(FW_DIR)
+ifeq ($(ADK_TARGET_SYSTEM_ROCKPI4_PLUS),y)
+	$(CP) $(WRKBUILD)/idbloader.img $(FW_DIR)
+endif
 ifeq ($(ADK_TARGET_SYSTEM_IMGTEC_CI20),y)
 	$(CP) $(WRKBUILD)/spl/u-boot-spl.bin $(FW_DIR)
 endif

+ 11 - 0
package/u-boot/patches/patch-configs_rock-pi-4c-rk3399_defconfig

@@ -0,0 +1,11 @@
+--- u-boot-2022.10.orig/configs/rock-pi-4c-rk3399_defconfig	2022-10-03 21:25:32.000000000 +0200
++++ u-boot-2022.10/configs/rock-pi-4c-rk3399_defconfig	2022-12-06 13:45:16.410352759 +0100
+@@ -60,7 +60,7 @@ CONFIG_REGULATOR_RK8XX=y
+ CONFIG_PWM_ROCKCHIP=y
+ CONFIG_RAM_RK3399_LPDDR4=y
+ CONFIG_DM_RESET=y
+-CONFIG_BAUDRATE=1500000
++CONFIG_BAUDRATE=115200
+ CONFIG_DEBUG_UART_SHIFT=2
+ CONFIG_SYSRESET=y
+ CONFIG_USB=y

+ 12 - 2
scripts/install.sh

@@ -155,7 +155,7 @@ tgt=$2
 src=$3
 
 case $target {
-(banana-pro|orange-pi0|pcengines-apu|phytec-imx6|phytec-wega|raspberry-pi|raspberry-pi0|raspberry-pi2|raspberry-pi3|raspberry-pi3-64|raspberry-pi4|raspberry-pi4-64|solidrun-imx6|solidrun-clearfog|imgtec-ci20|default) ;;
+(banana-pro|orange-pi0|pcengines-apu|phytec-imx6|phytec-wega|raspberry-pi|raspberry-pi0|raspberry-pi2|raspberry-pi3|raspberry-pi3-64|raspberry-pi4|raspberry-pi4-64|rockpi4-plus|solidrun-imx6|solidrun-clearfog|imgtec-ci20|default) ;;
 (*)
 	print -u2 "Unknown target '$target', exiting"
 	exit 1 ;;
@@ -351,7 +351,7 @@ fi
 #(( partofs = ((coreendsec / secs) + 1) * secs ))
 # we just use 2048 all the time, since some loaders are longer
 partofs=2048
-if [[ $target = raspberry-pi || $target = raspberry-pi0 || $target = raspberry-pi2 || $target = raspberry-pi3 || $target = raspberry-pi3-64 || $target = raspberry-pi4 || $target = raspberry-pi4-64 || $target = phytec-wega ]]; then
+if [[ $target = raspberry-pi || $target = raspberry-pi0 || $target = raspberry-pi2 || $target = raspberry-pi3 || $target = raspberry-pi3-64 || $target = raspberry-pi4 || $target = raspberry-pi4-64 || $target = phytec-wega || $target = rockpi4-plus ]]; then
 	(( spartofs = partofs + (100 * 2048) ))
 else
 	spartofs=$partofs
@@ -545,6 +545,10 @@ fi
 fwdir=$(dirname "$src")
 
 case $target {
+(rockpi4-plus)
+	dd if="$fwdir/idbloader.img" of="$tgt" bs=512 seek=64 > /dev/null 2>&1
+	dd if="$fwdir/u-boot.itb" of="$tgt" bs=512 seek=16384 > /dev/null 2>&1
+	;;
 (imgtec-ci20)
 	dd if="$fwdir/u-boot-spl.bin" of="$tgt" obs=512 seek=1 > /dev/null 2>&1
 	dd if="$fwdir/u-boot-dtb.img" of="$tgt" obs=1k seek=14 > /dev/null 2>&1
@@ -631,6 +635,12 @@ case $target {
 	done
 	umount_fs "$B"
 	;;
+(rockpi4-plus)
+	for x in "$fwdir"/*.dtb; do
+		[[ -e "$x" ]] && cp "$fwdir"/*.dtb "$R/boot/"
+		break
+	done
+	;;
 (solidrun-clearfog)
 	for x in "$fwdir"/*.dtb; do
 		[[ -e "$x" ]] && cp "$fwdir"/*.dtb "$R/boot/"

+ 20 - 0
target/aarch64/Makefile

@@ -24,6 +24,10 @@ ifeq ($(ADK_TARGET_BOARD_BCM28XX),y)
 	@echo "Use following command to install it on SD card:"
 	@echo "sudo ./scripts/install.sh $(ADK_TARGET_SYSTEM) /dev/sdX $(FW_DIR)/$(ROOTFSTARBALL)"
 endif
+ifeq ($(ADK_TARGET_SYSTEM_ROCKPI4_PLUS),y)
+	@echo "Use following command to install it on SD card:"
+	@echo "sudo ./scripts/install.sh $(ADK_TARGET_SYSTEM) /dev/sdX $(FW_DIR)/$(ROOTFSTARBALL)"
+endif
 ifeq ($(ADK_TARGET_QEMU),y)
 	@echo 'The kernel file is: $(FW_DIR)/${TARGET_KERNEL}'
 	@echo "Use following command to create a QEMU Image:"
@@ -54,6 +58,12 @@ ifeq ($(ADK_TARGET_QEMU),y)
 	@echo 'qemu-system-${ADK_TARGET_CPU_ARCH} ${QEMU_ARGS} -kernel $(FW_DIR)/$(TARGET_KERNEL)'
 endif
 endif
+ifeq ($(ADK_TARGET_FS),genimage)
+targethelp:
+	@echo "The disk image is: $(FW_DIR)/sdcard.img"
+	@echo "Use following command to install it on SD card:"
+	@echo 'sudo dd if=$(FW_DIR)/sdcard.img of=/dev/sdX bs=2048k'
+endif
 
 kernel-strip:
 	@cp $(KERNEL) $(BUILD_DIR)/$(TARGET_KERNEL)
@@ -74,6 +84,13 @@ ifeq ($(ADK_TARGET_BOARD_BCM28XX),y)
 		break; \
 	done
 endif
+ifeq ($(ADK_TARGET_SYSTEM_ROCKPI4_PLUS),y)
+	${KERNEL_MAKE} rockchip/rk3399-rock-pi-4c-plus.dtb $(MAKE_TRACE)
+endif
+	for x in $(LINUX_DIR)/arch/arm64/boot/dts/*/*.dtb; do \
+		[[ -e "$$x" ]] && cp $(LINUX_DIR)/arch/arm64/boot/dts/*/*.dtb $(FW_DIR); \
+		break; \
+	done
 
 # filesystem specific targets
 ifeq ($(ADK_TARGET_FS),archive)
@@ -88,3 +105,6 @@ endif
 ifeq ($(ADK_TARGET_FS),initramfspiggyback)
 imageinstall: createinitramfs targethelp
 endif
+ifeq ($(ADK_TARGET_FS),genimage)
+imageinstall: dtb-install $(FW_DIR)/$(GENIMAGE) targethelp
+endif

+ 5 - 0
target/aarch64/kernel/rockpi4-plus

@@ -0,0 +1,5 @@
+CONFIG_ARM64=y
+CONFIG_ARCH_ROCKCHIP=y
+CONFIG_SERIAL_8250=y
+CONFIG_SERIAL_8250_CONSOLE=y
+CONFIG_SERIAL_OF_PLATFORM=y

+ 4 - 0
target/aarch64/rockpi4-plus/extlinux.conf

@@ -0,0 +1,4 @@
+label rockpi4-plus-openadk
+  kernel /kernel
+  devicetree /rk3399-rock-pi-4c-plus.dtb
+  append console=ttyS2,115200n8 rw rootwait

+ 39 - 0
target/aarch64/rockpi4-plus/genimage.cfg

@@ -0,0 +1,39 @@
+image boot.vfat {
+	vfat {
+		files = {
+			"kernel",
+			"rk3399-rock-pi-4c-plus.dtb",
+			"extlinux"
+		}
+	}
+
+	size = 112M
+}
+
+image sdcard.img {
+	hdimage {
+		partition-table-type = "gpt"
+	}
+
+	partition loader1 {
+		image = "idbloader.img"
+		offset = 32K
+	}
+
+	partition loader2 {
+		image = "u-boot.itb"
+		offset = 8M
+	}
+
+	partition boot {
+		partition-type-uuid = F
+		bootable = "true"
+		image = "boot.vfat"
+		offset = 16M
+	}
+
+	partition rootfs {
+		partition-type-uuid = b921b045-1df0-41c3-af44-4c6f280d3fae
+		image = "rootfs.ext"
+	}
+}

+ 22 - 0
target/aarch64/systems/rockpi4-plus

@@ -0,0 +1,22 @@
+config ADK_TARGET_SYSTEM_ROCKPI4_PLUS
+	bool "Rock PI 4 Plus"
+	depends on ADK_TARGET_OS_LINUX
+	select ADK_TARGET_LITTLE_ENDIAN
+	select ADK_TARGET_CPU_AARCH64_CORTEX_A53
+	select ADK_TARGET_WITH_VGA
+	select ADK_TARGET_WITH_SERIAL
+	select ADK_TARGET_WITH_CPU_FREQ
+	select ADK_TARGET_WITH_USB
+	select ADK_TARGET_WITH_INPUT
+	select ADK_TARGET_WITH_SD
+	select ADK_TARGET_WITH_I2C
+	select ADK_TARGET_WITH_SPI
+	select ADK_TARGET_WITH_SMP
+	select ADK_TARGET_WITH_NET
+	select ADK_TARGET_WITH_NETDEVICE
+	select ADK_TARGET_WITH_BLOCK
+	select ADK_TARGET_WITH_SOUND
+	select ADK_TARGET_KERNEL_IMAGE
+	help
+	  Rock PI 4 Plus
+

+ 2 - 0
target/linux/Config.in.kernelcfg

@@ -51,6 +51,8 @@ config ADK_TARGET_LINUX_KERNEL_DEFCONFIG
 	default "stm32_defconfig" if ADK_TARGET_SYSTEM_ST_STM32F746G
 	default "nommu_k210_defconfig" if ADK_TARGET_SYSTEM_SIPEED_MAIX_BIT
 	default "loongson3_defconfig" if ADK_TARGET_SYSTEM_QEMU_LOONGARCH
+	default "defconfig" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
+	default "rockpi4_defconfig" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS && ADK_TARGET_LINUX_KERNEL_VERSION_GIT
 	default ""
 
 config ADK_TARGET_LINUX_KERNEL_CUSTOMCONFIG_PATH

+ 8 - 3
target/linux/Config.in.kernelversion

@@ -34,8 +34,8 @@ config ADK_TARGET_LINUX_KERNEL_VERSION_GIT
 	select ADK_TARGET_LINUX_KERNEL_IMAGE if ADK_TARGET_SYSTEM_SOLIDRUN_IMX6
 	select ADK_TARGET_LINUX_KERNEL_IMAGE if ADK_TARGET_SYSTEM_BEAGLEBONE_BLACK
 
-config ADK_TARGET_LINUX_KERNEL_VERSION_5_19
-	bool "5.19.12"
+config ADK_TARGET_LINUX_KERNEL_VERSION_6_0
+	bool "6.0.11"
 	depends on !ADK_TARGET_ARCH_AVR32
 	depends on !ADK_TARGET_ARCH_BFIN
 	depends on !ADK_TARGET_ARCH_CRIS
@@ -43,7 +43,7 @@ config ADK_TARGET_LINUX_KERNEL_VERSION_5_19
 	depends on !ADK_TARGET_ARCH_METAG
 
 config ADK_TARGET_LINUX_KERNEL_VERSION_5_15
-	bool "5.15.71"
+	bool "5.15.81"
 	depends on !ADK_TARGET_ARCH_AVR32
 	depends on !ADK_TARGET_ARCH_BFIN
 	depends on !ADK_TARGET_ARCH_CRIS
@@ -177,6 +177,7 @@ config ADK_TARGET_LINUX_KERNEL_GIT_REPO
 	default "https://git.phytec.de/git/linux-ti.git" if ADK_TARGET_SYSTEM_PHYTEC_WEGA
 	default "https://github.com/kalray/linux_coolidge.git" if ADK_TARGET_ARCH_KVX
 	default "https://github.com/shenki/linux-lm32.git" if ADK_TARGET_ARCH_LM32
+	default "https://github.com/radxa/kernel.git" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
 	default "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git"
 	help
 	  GIT repository to use.
@@ -194,6 +195,7 @@ config ADK_TARGET_LINUX_KERNEL_GIT_REPO_NAME
 	default "phytec" if ADK_TARGET_SYSTEM_PHYTEC_WEGA
 	default "clearfog" if ADK_TARGET_SYSTEM_SOLIDRUN_CLEARFOG
 	default "fslc" if ADK_TARGET_SYSTEM_SOLIDRUN_IMX6
+	default "radxa" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
 	default "linus"
 
 config ADK_TARGET_LINUX_KERNEL_GIT
@@ -207,6 +209,7 @@ config ADK_TARGET_LINUX_KERNEL_GIT
 	default "902739f3353150ac9eb69ad995098f3079d862a3" if ADK_TARGET_SYSTEM_SOLIDRUN_CLEARFOG
 	default "c85fbc86c61a8c8fd45ab1fe3d1bdd2df12f7962" if ADK_TARGET_SYSTEM_SOLIDRUN_IMX6
 	default "8624998967676862843aed1f8ee2141e98987f81" if ADK_TARGET_SYSTEM_BEAGLEBONE_BLACK
+	default "stable-4.4-rockpi4" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
 	default "v4.4.52-phy" if ADK_TARGET_SYSTEM_PHYTEC_WEGA
 	default "loongarch-next" if ADK_TARGET_LINUX_ARCH_LOONGARCH
 
@@ -215,6 +218,7 @@ config ADK_TARGET_LINUX_KERNEL_GIT_VER
 	depends on ADK_TARGET_LINUX_KERNEL_VERSION_GIT
 	default "5.19" if ADK_TARGET_LINUX_ARCH_LOONGARCH
 	default "5.10.110" if ADK_TARGET_BOARD_BCM28XX
+	default "5.10.110" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
 	default "4.4.37" if ADK_TARGET_SYSTEM_BEAGLEBONE_BLACK
 	default "4.4.52" if ADK_TARGET_SYSTEM_PHYTEC_WEGA
 	default "2.6.33" if ADK_TARGET_SYSTEM_KINETIS_K70
@@ -227,6 +231,7 @@ config ADK_TARGET_LINUX_KERNEL_GIT_TYPE
 	depends on ADK_TARGET_LINUX_KERNEL_VERSION_GIT
 	default "branch" if ADK_TARGET_LINUX_ARCH_LOONGARCH 
 	default "branch" if ADK_TARGET_SYSTEM_PHYTEC_WEGA
+	default "branch" if ADK_TARGET_SYSTEM_ROCKPI4_PLUS
 	default "hash"
 
 config ADK_TARGET_LINUX_KERNEL_NO_MIRROR

+ 738 - 0
target/linux/patches/5.15.81/add-board-rock-pi-4c-plus.patch

@@ -0,0 +1,738 @@
+diff --git a/arch/arm64/boot/dts/rockchip/Makefile b/arch/arm64/boot/dts/rockchip/Makefile
+index 7eb135a5143f..1574279e61e8 100644
+--- a/arch/arm64/boot/dts/rockchip/Makefile
++++ b/arch/arm64/boot/dts/rockchip/Makefile
+@@ -39,6 +39,7 @@ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-roc-pc-mezzanine.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rock-pi-4a.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rock-pi-4b.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rock-pi-4c.dtb
++dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rock-pi-4c-plus.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rock960.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rockpro64-v2.dtb
+ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399-rockpro64.dtb
+diff --git a/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4c-plus.dts b/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4c-plus.dts
+new file mode 100644
+index 000000000000..9fc8d5baba54
+--- /dev/null
++++ b/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4c-plus.dts
+@@ -0,0 +1,720 @@
++// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
++/*
++ * Copyright (c) 2022 Fuzhou Rockchip Electronics Co., Ltd
++ * Copyright (c) 2022 Radxa Limited
++ */
++
++/dts-v1/;
++#include <dt-bindings/input/linux-event-codes.h>
++#include <dt-bindings/pwm/pwm.h>
++#include "rk3399.dtsi"
++#include "rk3399-opp.dtsi"
++
++/ {
++	model = "Radxa ROCK Pi 4C+";
++	compatible = "radxa,rockpi4c-plus", "radxa,rockpi4", "rockchip,rk3399";
++
++	aliases {
++		mmc0 = &sdmmc;
++		mmc1 = &sdhci;
++		mmc2 = &sdio0;
++	};
++
++	chosen {
++		stdout-path = "serial2:115200n8";
++	};
++
++	clkin_gmac: external-gmac-clock {
++		compatible = "fixed-clock";
++		clock-frequency = <125000000>;
++		clock-output-names = "clkin_gmac";
++		#clock-cells = <0>;
++	};
++
++	vcc_lan: vcc3v3-phy-regulator {
++		compatible = "regulator-fixed";
++		regulator-name = "vcc_lan";
++		regulator-always-on;
++		regulator-boot-on;
++		regulator-min-microvolt = <3300000>;
++		regulator-max-microvolt = <3300000>;
++
++		regulator-state-mem {
++			regulator-off-in-suspend;
++		};
++	};
++
++	vcc5v0_sys: vcc-sys {
++		compatible = "regulator-fixed";
++		regulator-name = "vcc5v0_sys";
++		regulator-always-on;
++		regulator-boot-on;
++		regulator-min-microvolt = <5000000>;
++		regulator-max-microvolt = <5000000>;
++	};
++
++	vbus_host: vbus-host {
++		compatible = "regulator-fixed";
++		enable-active-high;
++		gpio = <&gpio3 RK_PD6 GPIO_ACTIVE_HIGH>;
++		pinctrl-names = "default";
++		pinctrl-0 = <&usb1_en_oc>;
++		regulator-name = "vbus_host"; /* HOST-5V */
++		regulator-always-on;
++		regulator-boot-on;
++		vin-supply = <&vcc5v0_usb2>;
++	};
++
++	vcc5v0_typec: vcc5v0-typec-regulator {
++		compatible = "regulator-fixed";
++		enable-active-high;
++		gpio = <&gpio1 RK_PA3 GPIO_ACTIVE_HIGH>;
++		pinctrl-names = "default";
++		pinctrl-0 = <&vcc5v0_typec_en>;
++		regulator-name = "vcc5v0_typec";
++		regulator-always-on;
++		vin-supply = <&vcc5v0_sys>;
++	};
++
++	virtual_pd: virtual-pd {
++		status = "disabled";
++		compatible = "linux,extcon-pd-virtual";
++		/* 0: positive, 1: negative*/
++		vpd,init-flip = <0>;
++		/* 0: u2, 1: u3*/
++		vpd,init-ss = <1>;
++		/* 0: dfp, 1: ufp, 2: dp 3: dp/ufp */
++		vpd,init-mode = <2>;
++		hpd-gpios = <&gpio4 25 GPIO_ACTIVE_LOW>;
++		pinctrl-names = "default";
++		pinctrl-0 = <&hpd_en>;
++		dp-pwr-supply = <&vcc3v3_sys>;
++	};
++
++	vcc_0v9: vcc-0v9 {
++		compatible = "regulator-fixed";
++		regulator-name = "vcc_0v9";
++		regulator-always-on;
++		regulator-boot-on;
++		regulator-min-microvolt = <900000>;
++		regulator-max-microvolt = <900000>;
++		vin-supply = <&vcc3v3_sys>;
++	};
++
++	vcc3v3_pcie: vcc3v3-pcie-regulator {
++		compatible = "regulator-fixed";
++		enable-active-high;
++		gpio = <&gpio3 RK_PD1 GPIO_ACTIVE_HIGH>;
++		pinctrl-names = "default";
++		pinctrl-0 = <&pcie_drv>;
++		regulator-boot-on;
++		regulator-always-on;
++		regulator-name = "vcc3v3_pcie";
++		vin-supply = <&vcc5v0_sys>;
++	};
++
++	sdio_pwrseq: sdio-pwrseq {
++		compatible = "mmc-pwrseq-simple";
++		clocks = <&rk809 1>;
++		clock-names = "ext_clock";
++		pinctrl-names = "default";
++		pinctrl-0 = <&wifi_enable_h>;
++
++		/*
++		 * On the module itself this is one of these (depending
++		 * on the actual card populated):
++		 * - SDIO_RESET_L_WL_REG_ON
++		 * - PDN (power down when low)
++		 */
++		reset-gpios = <&gpio0 RK_PB2 GPIO_ACTIVE_LOW>;
++	};
++
++	wireless_wlan: wireless-wlan {
++		compatible = "wlan-platdata";
++		rockchip,grf = <&grf>;
++		wifi_chip_type = "ap6256";
++		sdio_vref = <1800>;
++		WIFI,host_wake_irq = <&gpio0 RK_PA3 GPIO_ACTIVE_HIGH>;
++		status = "okay";
++	};
++
++	gpio-leds {
++		compatible = "gpio-leds";
++		status = "okay";
++
++		user-led1 {
++			gpios = <&gpio3 RK_PD4 GPIO_ACTIVE_LOW>;
++			linux,default-trigger = "default-on";
++			default-state = "on";
++		};
++
++		user-led2 {
++			gpios = <&gpio3 RK_PD5 GPIO_ACTIVE_HIGH>;
++			linux,default-trigger = "heartbeat";
++			default-state = "on";
++		};
++	};
++};
++
++&cdn_dp {
++	extcon = <&virtual_pd>;
++	status = "disabled";
++};
++
++&cpu_l0 {
++	cpu-supply = <&vdd_cpu_l>;
++};
++
++&cpu_l1 {
++	cpu-supply = <&vdd_cpu_l>;
++};
++
++&cpu_l2 {
++	cpu-supply = <&vdd_cpu_l>;
++};
++
++&cpu_l3 {
++	cpu-supply = <&vdd_cpu_l>;
++};
++
++&cpu_b0 {
++	cpu-supply = <&vdd_cpu_b>;
++};
++
++&cpu_b1 {
++	cpu-supply = <&vdd_cpu_b>;
++};
++
++&gmac {
++	assigned-clocks = <&cru SCLK_RMII_SRC>;
++	assigned-clock-parents = <&clkin_gmac>;
++	clock_in_out = "input";
++	phy-supply = <&vcc_lan>;
++	phy-mode = "rgmii";
++	pinctrl-names = "default";
++	pinctrl-0 = <&rgmii_pins>;
++	snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;
++	snps,reset-active-low;
++	snps,reset-delays-us = <0 10000 50000>;
++	tx_delay = <0x28>;
++	rx_delay = <0x11>;
++	status = "okay";
++};
++
++&i2c0 {
++	status = "okay";
++	i2c-scl-falling-time-ns = <30>;
++	i2c-scl-rising-time-ns = <180>;
++	clock-frequency = <400000>;
++
++	rk809: pmic@20 {
++		compatible = "rockchip,rk809";
++		reg = <0x20>;
++		interrupt-parent = <&gpio1>;
++		interrupts = <RK_PC5 IRQ_TYPE_LEVEL_LOW>;
++		#clock-cells = <1>;
++		clock-output-names = "rk808-clkout1", "rk808-clkout2";
++		pinctrl-names = "default";
++		pinctrl-0 = <&pmic_int_l>;
++		rockchip,system-power-controller;
++		wakeup-source;
++
++		vcc1-supply = <&vcc5v0_sys>;
++		vcc2-supply = <&vcc5v0_sys>;
++		vcc3-supply = <&vcc5v0_sys>;
++		vcc4-supply = <&vcc5v0_sys>;
++		vcc5-supply = <&vcc_buck5>;
++		vcc6-supply = <&vcc_buck5>;
++		vcc7-supply = <&vcc5v0_sys>;
++		vcc8-supply = <&vcc3v3_sys>;
++		vcc9-supply = <&vcc5v0_sys>;
++
++		regulators {
++			vdd_log: DCDC_REG1 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <750000>;
++				regulator-max-microvolt = <1350000>;
++				regulator-initial-mode = <0x2>;
++				regulator-name = "vdd_log";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++					regulator-suspend-microvolt = <900000>;
++				};
++			};
++
++			vdd_cpu_l: DCDC_REG2 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <750000>;
++				regulator-max-microvolt = <1350000>;
++				regulator-ramp-delay = <6001>;
++				regulator-initial-mode = <0x2>;
++				regulator-name = "vdd_cpu_l";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_ddr: DCDC_REG3 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-name = "vcc_ddr";
++				regulator-initial-mode = <0x2>;
++				regulator-state-mem {
++					regulator-on-in-suspend;
++				};
++			};
++
++			vcc3v3_sys: DCDC_REG4 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <3300000>;
++				regulator-max-microvolt = <3300000>;
++				regulator-initial-mode = <0x2>;
++				regulator-name = "vcc3v3_sys";
++				regulator-state-mem {
++					regulator-on-in-suspend;
++					regulator-suspend-microvolt = <3300000>;
++				};
++			};
++
++			vcc_buck5: DCDC_REG5 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <3300000>;
++				regulator-max-microvolt = <3300000>;
++				regulator-name = "vcc_buck5";
++				regulator-state-mem {
++					regulator-on-in-suspend;
++					regulator-suspend-microvolt = <3300000>;
++				};
++			};
++
++			vcca_0v9: LDO_REG1 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <900000>;
++				regulator-max-microvolt = <900000>;
++				regulator-name = "vcca_0v9";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_1v8: LDO_REG2 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <1800000>;
++				regulator-max-microvolt = <1800000>;
++
++				regulator-name = "vcc_1v8";
++				regulator-state-mem {
++					regulator-on-in-suspend;
++					regulator-suspend-microvolt = <1800000>;
++				};
++			};
++
++			vcc0v9_soc: LDO_REG3 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <900000>;
++				regulator-max-microvolt = <900000>;
++
++				regulator-name = "vcc0v9_soc";
++				regulator-state-mem {
++					regulator-on-in-suspend;
++					regulator-suspend-microvolt = <900000>;
++				};
++			};
++
++			vcca_1v8: LDO_REG4 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <1850000>;
++				regulator-max-microvolt = <1850000>;
++
++				regulator-name = "vcca_1v8";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_mipi: LDO_REG5 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <1500000>;
++				regulator-max-microvolt = <1500000>;
++
++				regulator-name = "vcc_mipi";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_1v5: LDO_REG6 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <1500000>;
++				regulator-max-microvolt = <1500000>;
++
++				regulator-name = "vcc_1v5";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_3v0: LDO_REG7 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <3000000>;
++				regulator-max-microvolt = <3000000>;
++
++				regulator-name = "vcc_3v0";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vccio_sd: LDO_REG8 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <1800000>;
++				regulator-max-microvolt = <3300000>;
++
++				regulator-name = "vccio_sd";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc_cam: LDO_REG9 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <3300000>;
++				regulator-max-microvolt = <3300000>;
++
++				regulator-name = "vcc_cam";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++
++			vcc5v0_usb2: SWITCH_REG1 {
++				regulator-min-microvolt = <5000000>;
++				regulator-max-microvolt = <5000000>;
++
++				regulator-name = "vcc5v0_usb2.0";
++				regulator-state-mem {
++					regulator-on-in-suspend;
++					regulator-suspend-microvolt = <5000000>;
++				};
++			};
++
++			lcd_3v3: SWITCH_REG2 {
++				regulator-always-on;
++				regulator-boot-on;
++				regulator-min-microvolt = <3300000>;
++				regulator-max-microvolt = <3300000>;
++
++				regulator-name = "lcd_3v3";
++				regulator-state-mem {
++					regulator-off-in-suspend;
++				};
++			};
++		};
++	};
++
++	vdd_cpu_b: syr827@40 {
++		compatible = "silergy,syr827";
++		reg = <0x40>;
++		regulator-compatible = "fan53555-reg";
++		pinctrl-0 = <&vsel1_gpio>;
++		vsel-gpios = <&gpio1 RK_PC1 GPIO_ACTIVE_HIGH>;
++		regulator-name = "vdd_cpu_b";
++		regulator-min-microvolt = <712500>;
++		regulator-max-microvolt = <1500000>;
++		regulator-ramp-delay = <1000>;
++		fcs,suspend-voltage-selector = <1>;
++		regulator-always-on;
++		regulator-boot-on;
++		vin-supply = <&vcc5v0_sys>;
++		regulator-state-mem {
++			regulator-off-in-suspend;
++		};
++	};
++
++	vdd_gpu: syr828@41 {
++		compatible = "silergy,syr828";
++		reg = <0x41>;
++		regulator-compatible = "fan53555-reg";
++		pinctrl-0 = <&vsel2_gpio>;
++		vsel-gpios = <&gpio1 RK_PB6 GPIO_ACTIVE_HIGH>;
++		regulator-name = "vdd_gpu";
++		regulator-min-microvolt = <712500>;
++		regulator-max-microvolt = <1500000>;
++		regulator-ramp-delay = <1000>;
++		fcs,suspend-voltage-selector = <1>;
++		regulator-always-on;
++		regulator-boot-on;
++		vin-supply = <&vcc5v0_sys>;
++		regulator-initial-mode = <1>; /* 1:force PWM 2:auto */
++		regulator-state-mem {
++			regulator-off-in-suspend;
++		};
++	};
++};
++
++&io_domains {
++	status = "okay";
++
++	bt656-supply = <&vcc_3v0>;
++	audio-supply = <&vcca_1v8>;
++	sdmmc-supply = <&vccio_sd>;
++	gpio1830-supply = <&vcc_3v0>;
++};
++
++&pmu_io_domains {
++	status = "okay";
++
++	pmu1830-supply = <&vcc_3v0>;
++};
++
++&sdmmc {
++	bus-width = <4>;
++	cap-mmc-highspeed;
++	cap-sd-highspeed;
++	card-detect-delay = <800>;
++	disable-wp;
++	pinctrl-names = "default";
++	pinctrl-0 = <&sdmmc_clk &sdmmc_cd &sdmmc_cmd &sdmmc_bus4>;
++	vqmmc-supply = <&vccio_sd>;
++	status = "okay";
++};
++
++&sdio0 {
++	max-frequency = <200000000>;
++	supports-sdio;
++	bus-width = <4>;
++	disable-wp;
++	cap-sd-highspeed;
++	cap-sdio-irq;
++	keep-power-in-suspend;
++	mmc-pwrseq = <&sdio_pwrseq>;
++	non-removable;
++	num-slots = <1>;
++	pinctrl-names = "default";
++	pinctrl-0 = <&sdio0_bus4 &sdio0_cmd &sdio0_clk>;
++	sd-uhs-sdr104;
++	status = "okay";
++};
++
++&emmc_phy {
++	status = "okay";
++};
++
++&sdhci {
++	bus-width = <8>;
++	mmc-hs400-1_8v;
++	mmc-hs400-enhanced-strobe;
++	non-removable;
++	status = "okay";
++};
++
++&tcphy0 {
++	status = "okay";
++};
++
++&tcphy1 {
++	status = "okay";
++};
++
++&u2phy0 {
++	status = "okay";
++
++	u2phy0_otg: otg-port {
++		status = "okay";
++	};
++
++	u2phy0_host: host-port {
++		phy-supply = <&vbus_host>;
++		status = "okay";
++	};
++};
++
++&u2phy1 {
++	status = "okay";
++
++	u2phy1_otg: otg-port {
++		status = "okay";
++	};
++
++	u2phy1_host: host-port {
++		phy-supply = <&vbus_host>;
++		status = "okay";
++	};
++};
++
++&uart0 {
++	pinctrl-names = "default";
++	pinctrl-0 = <&uart0_xfer &uart0_cts &uart0_rts>;
++};
++
++&uart2 {
++	status = "okay";
++};
++
++&usb_host0_ehci {
++	status = "okay";
++};
++
++&usb_host0_ohci {
++	status = "okay";
++};
++
++&usb_host1_ehci {
++	status = "okay";
++};
++
++&usb_host1_ohci {
++	status = "okay";
++};
++
++&usbdrd3_0 {
++	status = "okay";
++};
++
++&usbdrd_dwc3_0 {
++	status = "okay";
++	extcon = <&u2phy0>;
++	dr_mode = "otg";
++};
++
++&usbdrd3_1 {
++	status = "okay";
++};
++
++&usbdrd_dwc3_1 {
++	status = "okay";
++	dr_mode = "host";
++};
++
++&vopb {
++	status = "okay";
++};
++
++&vopb_mmu {
++	status = "okay";
++};
++
++&vopl {
++	status = "okay";
++};
++
++&vopl_mmu {
++	status = "okay";
++};
++
++&hdmi {
++	pinctrl-names = "default";
++	pinctrl-0 = <&hdmi_i2c_xfer>, <&hdmi_cec>;
++	status = "okay";
++};
++
++&hdmi_sound {
++	status = "okay";
++};
++
++&hdmi_in_vopb {
++	status = "okay";
++};
++
++&hdmi_in_vopl {
++	status = "okay";
++};
++
++&i2c1 {
++	i2c-scl-rising-time-ns = <450>;
++	i2c-scl-falling-time-ns = <15>;
++	status = "okay";
++};
++
++&pcie_phy {
++	status = "okay";
++};
++
++&pcie0 {
++	ep-gpios = <&gpio4 RK_PD3 GPIO_ACTIVE_HIGH>;
++	num-lanes = <4>;
++	pinctrl-0 = <&pcie_clkreqnb_cpm>;
++	pinctrl-names = "default";
++	vpcie0v9-supply = <&vcc_0v9>;
++	vpcie1v8-supply = <&vcc_1v8>;
++	vpcie3v3-supply = <&vcc3v3_pcie>;
++	status = "okay";
++};
++
++&pinctrl {
++	hpd {
++		hpd_en: hpd-en {
++			rockchip,pins = <4 RK_PD1 RK_FUNC_GPIO &pcfg_pull_none>;
++		};
++	};
++
++	pmic {
++		pmic_int_l: pmic-int-l {
++			rockchip,pins = <1 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>;
++		};
++
++		vsel1_gpio: vsel1-gpio {
++			rockchip,pins = <1 RK_PC1 RK_FUNC_GPIO &pcfg_pull_down>;
++		};
++
++		vsel2_gpio: vsel2-gpio {
++			rockchip,pins = <1 RK_PB6 RK_FUNC_GPIO &pcfg_pull_down>;
++		};
++	};
++
++	sdmmc {
++		sdmmc_bus4: sdmmc-bus4 {
++			rockchip,pins = <4 8 1 &pcfg_pull_up_8ma>,
++					<4 9 1 &pcfg_pull_up_8ma>,
++					<4 10 1 &pcfg_pull_up_8ma>,
++					<4 11 1 &pcfg_pull_up_8ma>;
++		};
++
++		sdmmc_clk: sdmmc-clk {
++			rockchip,pins = <4 12 1 &pcfg_pull_none_18ma>;
++		};
++
++		sdmmc_cmd: sdmmc-cmd {
++			rockchip,pins = <4 13 1 &pcfg_pull_up_8ma>;
++		};
++	};
++
++	usb-typec {
++		vcc5v0_typec_en: vcc5v0-typec-en {
++			rockchip,pins = <1 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;
++		};
++	};
++
++	vbus_host {
++		usb1_en_oc: usb1-en-oc {
++			rockchip,pins = <3 RK_PD6 RK_FUNC_GPIO &pcfg_pull_up>;
++		};
++	};
++
++	pcie {
++		pcie_drv: pcie-drv {
++			rockchip,pins =
++				<3 RK_PD1 RK_FUNC_GPIO &pcfg_pull_none>;
++		};
++	};
++
++	sdio-pwrseq {
++		wifi_enable_h: wifi-enable-h {
++			rockchip,pins =
++				<0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
++		};
++	};
++};

+ 0 - 0
target/linux/patches/5.15.71/darwin-dtc.patch → target/linux/patches/5.15.81/darwin-dtc.patch


+ 0 - 0
target/linux/patches/5.15.71/darwin-file2alias.patch → target/linux/patches/5.15.81/darwin-file2alias.patch


+ 0 - 0
target/linux/patches/5.15.71/dtc-noyaml.patch → target/linux/patches/5.15.81/dtc-noyaml.patch


+ 0 - 0
target/linux/patches/5.15.71/nds32-ag101p.patch → target/linux/patches/5.15.81/nds32-ag101p.patch


+ 0 - 0
target/linux/patches/5.15.71/or1k-more-ram.patch → target/linux/patches/5.15.81/or1k-more-ram.patch


+ 0 - 0
target/linux/patches/5.15.71/relocs.patch → target/linux/patches/5.15.81/relocs.patch


+ 0 - 0
target/linux/patches/5.15.71/startup.patch → target/linux/patches/5.15.81/startup.patch


+ 0 - 26
target/linux/patches/5.19.12/darwin-dtc.patch

@@ -1,26 +0,0 @@
-diff -Nur linux-4.19.132.orig/scripts/dtc/dtc.h linux-4.19.132/scripts/dtc/dtc.h
---- linux-4.19.132.orig/scripts/dtc/dtc.h	2020-07-09 09:37:13.000000000 +0200
-+++ linux-4.19.132/scripts/dtc/dtc.h	2020-07-15 02:38:00.000000000 +0200
-@@ -33,8 +33,8 @@
- #include <unistd.h>
- #include <inttypes.h>
- 
--#include <libfdt_env.h>
--#include <fdt.h>
-+#include "libfdt/libfdt_env.h"
-+#include "libfdt/fdt.h"
- 
- #include "util.h"
- 
-diff -Nur linux-4.19.132.orig/scripts/dtc/util.c linux-4.19.132/scripts/dtc/util.c
---- linux-4.19.132.orig/scripts/dtc/util.c	2020-07-09 09:37:13.000000000 +0200
-+++ linux-4.19.132/scripts/dtc/util.c	2020-07-15 02:38:18.000000000 +0200
-@@ -32,7 +32,7 @@
- #include <fcntl.h>
- #include <unistd.h>
- 
--#include "libfdt.h"
-+#include "libfdt/libfdt.h"
- #include "util.h"
- #include "version_gen.h"
- 

+ 0 - 14
target/linux/patches/5.19.12/darwin-file2alias.patch

@@ -1,14 +0,0 @@
-diff -Nur linux-5.4.42.orig/scripts/mod/file2alias.c linux-5.4.42/scripts/mod/file2alias.c
---- linux-5.4.42.orig/scripts/mod/file2alias.c	2020-05-20 08:20:41.000000000 +0200
-+++ linux-5.4.42/scripts/mod/file2alias.c	2020-06-06 20:14:59.000000000 +0200
-@@ -10,6 +10,10 @@
-  * of the GNU General Public License, incorporated herein by reference.
-  */
- 
-+/* workaround for Darwin */
-+#define _UUID_T
-+#define __GETHOSTUUID_H
-+
- #include "modpost.h"
- #include "devicetable-offsets.h"
- 

+ 0 - 16
target/linux/patches/5.19.12/dtc-noyaml.patch

@@ -1,16 +0,0 @@
-diff -Nur linux-5.4.53.orig/scripts/dtc/dtc.c linux-5.4.53/scripts/dtc/dtc.c
---- linux-5.4.53.orig/scripts/dtc/dtc.c	2020-07-22 09:33:18.000000000 +0200
-+++ linux-5.4.53/scripts/dtc/dtc.c	2020-07-28 14:20:10.000000000 +0200
-@@ -349,12 +349,6 @@
- 
- 	if (streq(outform, "dts")) {
- 		dt_to_source(outf, dti);
--#ifndef NO_YAML
--	} else if (streq(outform, "yaml")) {
--		if (!streq(inform, "dts"))
--			die("YAML output format requires dts input format\n");
--		dt_to_yaml(outf, dti);
--#endif
- 	} else if (streq(outform, "dtb")) {
- 		dt_to_blob(outf, dti, outversion);
- 	} else if (streq(outform, "asm")) {

+ 0 - 12
target/linux/patches/5.19.12/or1k-more-ram.patch

@@ -1,12 +0,0 @@
-diff -Nur linux-4.8.11.orig/arch/openrisc/boot/dts/or1ksim.dts linux-4.8.11/arch/openrisc/boot/dts/or1ksim.dts
---- linux-4.8.11.orig/arch/openrisc/boot/dts/or1ksim.dts	2016-11-26 09:57:13.000000000 +0100
-+++ linux-4.8.11/arch/openrisc/boot/dts/or1ksim.dts	2016-12-04 14:39:46.092952799 +0100
-@@ -11,7 +11,7 @@
- 
- 	memory@0 {
- 		device_type = "memory";
--		reg = <0x00000000 0x02000000>;
-+		reg = <0x00000000 0x04000000>;
- 	};
- 
- 	cpus {

+ 0 - 2698
target/linux/patches/5.19.12/relocs.patch

@@ -1,2698 +0,0 @@
-diff -Nur linux-5.4.42.orig/arch/x86/tools/relocs.h linux-5.4.42/arch/x86/tools/relocs.h
---- linux-5.4.42.orig/arch/x86/tools/relocs.h	2020-05-20 08:20:41.000000000 +0200
-+++ linux-5.4.42/arch/x86/tools/relocs.h	2020-06-06 18:18:17.000000000 +0200
-@@ -10,11 +10,19 @@
- #include <string.h>
- #include <errno.h>
- #include <unistd.h>
-+#ifdef __linux__
- #include <elf.h>
- #include <byteswap.h>
- #define USE_BSD
- #include <endian.h>
-+#else
-+#include "elf.h"
-+#endif
-+#ifdef __APPLE__
-+#include <pcreposix.h>
-+#else
- #include <regex.h>
-+#endif
- #include <tools/le_byteshift.h>
- 
- void die(char *fmt, ...) __attribute__((noreturn));
-diff -Nur linux-5.4.42.orig/tools/include/elf.h linux-5.4.42/tools/include/elf.h
---- linux-5.4.42.orig/tools/include/elf.h	1970-01-01 01:00:00.000000000 +0100
-+++ linux-5.4.42/tools/include/elf.h	2020-06-06 18:18:17.000000000 +0200
-@@ -0,0 +1,2671 @@
-+#ifndef _ELF_H
-+#define _ELF_H
-+
-+#ifdef __cplusplus
-+extern "C" {
-+#endif
-+
-+#include <stdint.h>
-+
-+typedef uint16_t Elf32_Half;
-+typedef uint16_t Elf64_Half;
-+
-+typedef uint32_t Elf32_Word;
-+typedef	int32_t  Elf32_Sword;
-+typedef uint32_t Elf64_Word;
-+typedef	int32_t  Elf64_Sword;
-+
-+typedef uint64_t Elf32_Xword;
-+typedef	int64_t  Elf32_Sxword;
-+typedef uint64_t Elf64_Xword;
-+typedef	int64_t  Elf64_Sxword;
-+
-+typedef uint32_t Elf32_Addr;
-+typedef uint64_t Elf64_Addr;
-+
-+typedef uint32_t Elf32_Off;
-+typedef uint64_t Elf64_Off;
-+
-+typedef uint16_t Elf32_Section;
-+typedef uint16_t Elf64_Section;
-+
-+typedef Elf32_Half Elf32_Versym;
-+typedef Elf64_Half Elf64_Versym;
-+
-+#define EI_NIDENT (16)
-+
-+typedef struct {
-+  unsigned char	e_ident[EI_NIDENT];
-+  Elf32_Half	e_type;
-+  Elf32_Half	e_machine;
-+  Elf32_Word	e_version;
-+  Elf32_Addr	e_entry;
-+  Elf32_Off	e_phoff;
-+  Elf32_Off	e_shoff;
-+  Elf32_Word	e_flags;
-+  Elf32_Half	e_ehsize;
-+  Elf32_Half	e_phentsize;
-+  Elf32_Half	e_phnum;
-+  Elf32_Half	e_shentsize;
-+  Elf32_Half	e_shnum;
-+  Elf32_Half	e_shstrndx;
-+} Elf32_Ehdr;
-+
-+typedef struct {
-+  unsigned char	e_ident[EI_NIDENT];
-+  Elf64_Half	e_type;
-+  Elf64_Half	e_machine;
-+  Elf64_Word	e_version;
-+  Elf64_Addr	e_entry;
-+  Elf64_Off	e_phoff;
-+  Elf64_Off	e_shoff;
-+  Elf64_Word	e_flags;
-+  Elf64_Half	e_ehsize;
-+  Elf64_Half	e_phentsize;
-+  Elf64_Half	e_phnum;
-+  Elf64_Half	e_shentsize;
-+  Elf64_Half	e_shnum;
-+  Elf64_Half	e_shstrndx;
-+} Elf64_Ehdr;
-+
-+#define EI_MAG0		0
-+#define ELFMAG0		0x7f
-+
-+#define EI_MAG1		1
-+#define ELFMAG1		'E'
-+
-+#define EI_MAG2		2
-+#define ELFMAG2		'L'
-+
-+#define EI_MAG3		3
-+#define ELFMAG3		'F'
-+
-+
-+#define	ELFMAG		"\177ELF"
-+#define	SELFMAG		4
-+
-+#define EI_CLASS	4
-+#define ELFCLASSNONE	0
-+#define ELFCLASS32	1
-+#define ELFCLASS64	2
-+#define ELFCLASSNUM	3
-+
-+#define EI_DATA		5
-+#define ELFDATANONE	0
-+#define ELFDATA2LSB	1
-+#define ELFDATA2MSB	2
-+#define ELFDATANUM	3
-+
-+#define EI_VERSION	6
-+
-+
-+#define EI_OSABI	7
-+#define ELFOSABI_NONE		0
-+#define ELFOSABI_SYSV		0
-+#define ELFOSABI_HPUX		1
-+#define ELFOSABI_NETBSD		2
-+#define ELFOSABI_LINUX		3
-+#define ELFOSABI_GNU		3
-+#define ELFOSABI_SOLARIS	6
-+#define ELFOSABI_AIX		7
-+#define ELFOSABI_IRIX		8
-+#define ELFOSABI_FREEBSD	9
-+#define ELFOSABI_TRU64		10
-+#define ELFOSABI_MODESTO	11
-+#define ELFOSABI_OPENBSD	12
-+#define ELFOSABI_ARM		97
-+#define ELFOSABI_STANDALONE	255
-+
-+#define EI_ABIVERSION	8
-+
-+#define EI_PAD		9
-+
-+
-+
-+#define ET_NONE		0
-+#define ET_REL		1
-+#define ET_EXEC		2
-+#define ET_DYN		3
-+#define ET_CORE		4
-+#define	ET_NUM		5
-+#define ET_LOOS		0xfe00
-+#define ET_HIOS		0xfeff
-+#define ET_LOPROC	0xff00
-+#define ET_HIPROC	0xffff
-+
-+
-+
-+#define EM_NONE		 0
-+#define EM_M32		 1
-+#define EM_SPARC	 2
-+#define EM_386		 3
-+#define EM_68K		 4
-+#define EM_88K		 5
-+#define EM_860		 7
-+#define EM_MIPS		 8
-+#define EM_S370		 9
-+#define EM_MIPS_RS3_LE	10
-+
-+#define EM_PARISC	15
-+#define EM_VPP500	17
-+#define EM_SPARC32PLUS	18
-+#define EM_960		19
-+#define EM_PPC		20
-+#define EM_PPC64	21
-+#define EM_S390		22
-+
-+#define EM_V800		36
-+#define EM_FR20		37
-+#define EM_RH32		38
-+#define EM_RCE		39
-+#define EM_ARM		40
-+#define EM_FAKE_ALPHA	41
-+#define EM_SH		42
-+#define EM_SPARCV9	43
-+#define EM_TRICORE	44
-+#define EM_ARC		45
-+#define EM_H8_300	46
-+#define EM_H8_300H	47
-+#define EM_H8S		48
-+#define EM_H8_500	49
-+#define EM_IA_64	50
-+#define EM_MIPS_X	51
-+#define EM_COLDFIRE	52
-+#define EM_68HC12	53
-+#define EM_MMA		54
-+#define EM_PCP		55
-+#define EM_NCPU		56
-+#define EM_NDR1		57
-+#define EM_STARCORE	58
-+#define EM_ME16		59
-+#define EM_ST100	60
-+#define EM_TINYJ	61
-+#define EM_X86_64	62
-+#define EM_PDSP		63
-+
-+#define EM_FX66		66
-+#define EM_ST9PLUS	67
-+#define EM_ST7		68
-+#define EM_68HC16	69
-+#define EM_68HC11	70
-+#define EM_68HC08	71
-+#define EM_68HC05	72
-+#define EM_SVX		73
-+#define EM_ST19		74
-+#define EM_VAX		75
-+#define EM_CRIS		76
-+#define EM_JAVELIN	77
-+#define EM_FIREPATH	78
-+#define EM_ZSP		79
-+#define EM_MMIX		80
-+#define EM_HUANY	81
-+#define EM_PRISM	82
-+#define EM_AVR		83
-+#define EM_FR30		84
-+#define EM_D10V		85
-+#define EM_D30V		86
-+#define EM_V850		87
-+#define EM_M32R		88
-+#define EM_MN10300	89
-+#define EM_MN10200	90
-+#define EM_PJ		91
-+#define EM_OPENRISC	92
-+#define EM_ARC_A5	93
-+#define EM_XTENSA	94
-+#define EM_AARCH64	183
-+#define EM_TILEPRO	188
-+#define EM_MICROBLAZE	189
-+#define EM_TILEGX	191
-+#define EM_NUM		192
-+#define EM_ALPHA	0x9026
-+
-+#define EV_NONE		0
-+#define EV_CURRENT	1
-+#define EV_NUM		2
-+
-+typedef struct {
-+  Elf32_Word	sh_name;
-+  Elf32_Word	sh_type;
-+  Elf32_Word	sh_flags;
-+  Elf32_Addr	sh_addr;
-+  Elf32_Off	sh_offset;
-+  Elf32_Word	sh_size;
-+  Elf32_Word	sh_link;
-+  Elf32_Word	sh_info;
-+  Elf32_Word	sh_addralign;
-+  Elf32_Word	sh_entsize;
-+} Elf32_Shdr;
-+
-+typedef struct {
-+  Elf64_Word	sh_name;
-+  Elf64_Word	sh_type;
-+  Elf64_Xword	sh_flags;
-+  Elf64_Addr	sh_addr;
-+  Elf64_Off	sh_offset;
-+  Elf64_Xword	sh_size;
-+  Elf64_Word	sh_link;
-+  Elf64_Word	sh_info;
-+  Elf64_Xword	sh_addralign;
-+  Elf64_Xword	sh_entsize;
-+} Elf64_Shdr;
-+
-+
-+
-+#define SHN_UNDEF	0
-+#define SHN_LORESERVE	0xff00
-+#define SHN_LOPROC	0xff00
-+#define SHN_BEFORE	0xff00
-+
-+#define SHN_AFTER	0xff01
-+
-+#define SHN_HIPROC	0xff1f
-+#define SHN_LOOS	0xff20
-+#define SHN_HIOS	0xff3f
-+#define SHN_ABS		0xfff1
-+#define SHN_COMMON	0xfff2
-+#define SHN_XINDEX	0xffff
-+#define SHN_HIRESERVE	0xffff
-+
-+
-+
-+#define SHT_NULL	  0
-+#define SHT_PROGBITS	  1
-+#define SHT_SYMTAB	  2
-+#define SHT_STRTAB	  3
-+#define SHT_RELA	  4
-+#define SHT_HASH	  5
-+#define SHT_DYNAMIC	  6
-+#define SHT_NOTE	  7
-+#define SHT_NOBITS	  8
-+#define SHT_REL		  9
-+#define SHT_SHLIB	  10
-+#define SHT_DYNSYM	  11
-+#define SHT_INIT_ARRAY	  14
-+#define SHT_FINI_ARRAY	  15
-+#define SHT_PREINIT_ARRAY 16
-+#define SHT_GROUP	  17
-+#define SHT_SYMTAB_SHNDX  18
-+#define	SHT_NUM		  19
-+#define SHT_LOOS	  0x60000000
-+#define SHT_GNU_ATTRIBUTES 0x6ffffff5
-+#define SHT_GNU_HASH	  0x6ffffff6
-+#define SHT_GNU_LIBLIST	  0x6ffffff7
-+#define SHT_CHECKSUM	  0x6ffffff8
-+#define SHT_LOSUNW	  0x6ffffffa
-+#define SHT_SUNW_move	  0x6ffffffa
-+#define SHT_SUNW_COMDAT   0x6ffffffb
-+#define SHT_SUNW_syminfo  0x6ffffffc
-+#define SHT_GNU_verdef	  0x6ffffffd
-+#define SHT_GNU_verneed	  0x6ffffffe
-+#define SHT_GNU_versym	  0x6fffffff
-+#define SHT_HISUNW	  0x6fffffff
-+#define SHT_HIOS	  0x6fffffff
-+#define SHT_LOPROC	  0x70000000
-+#define SHT_HIPROC	  0x7fffffff
-+#define SHT_LOUSER	  0x80000000
-+#define SHT_HIUSER	  0x8fffffff
-+
-+#define SHF_WRITE	     (1 << 0)
-+#define SHF_ALLOC	     (1 << 1)
-+#define SHF_EXECINSTR	     (1 << 2)
-+#define SHF_MERGE	     (1 << 4)
-+#define SHF_STRINGS	     (1 << 5)
-+#define SHF_INFO_LINK	     (1 << 6)
-+#define SHF_LINK_ORDER	     (1 << 7)
-+#define SHF_OS_NONCONFORMING (1 << 8)
-+
-+#define SHF_GROUP	     (1 << 9)
-+#define SHF_TLS		     (1 << 10)
-+#define SHF_MASKOS	     0x0ff00000
-+#define SHF_MASKPROC	     0xf0000000
-+#define SHF_ORDERED	     (1 << 30)
-+#define SHF_EXCLUDE	     (1 << 31)
-+
-+#define GRP_COMDAT	0x1
-+
-+typedef struct {
-+  Elf32_Word	st_name;
-+  Elf32_Addr	st_value;
-+  Elf32_Word	st_size;
-+  unsigned char	st_info;
-+  unsigned char	st_other;
-+  Elf32_Section	st_shndx;
-+} Elf32_Sym;
-+
-+typedef struct {
-+  Elf64_Word	st_name;
-+  unsigned char	st_info;
-+  unsigned char st_other;
-+  Elf64_Section	st_shndx;
-+  Elf64_Addr	st_value;
-+  Elf64_Xword	st_size;
-+} Elf64_Sym;
-+
-+typedef struct {
-+  Elf32_Half si_boundto;
-+  Elf32_Half si_flags;
-+} Elf32_Syminfo;
-+
-+typedef struct {
-+  Elf64_Half si_boundto;
-+  Elf64_Half si_flags;
-+} Elf64_Syminfo;
-+
-+#define SYMINFO_BT_SELF		0xffff
-+#define SYMINFO_BT_PARENT	0xfffe
-+#define SYMINFO_BT_LOWRESERVE	0xff00
-+
-+#define SYMINFO_FLG_DIRECT	0x0001
-+#define SYMINFO_FLG_PASSTHRU	0x0002
-+#define SYMINFO_FLG_COPY	0x0004
-+#define SYMINFO_FLG_LAZYLOAD	0x0008
-+
-+#define SYMINFO_NONE		0
-+#define SYMINFO_CURRENT		1
-+#define SYMINFO_NUM		2
-+
-+#define ELF32_ST_BIND(val)		(((unsigned char) (val)) >> 4)
-+#define ELF32_ST_TYPE(val)		((val) & 0xf)
-+#define ELF32_ST_INFO(bind, type)	(((bind) << 4) + ((type) & 0xf))
-+
-+#define ELF64_ST_BIND(val)		ELF32_ST_BIND (val)
-+#define ELF64_ST_TYPE(val)		ELF32_ST_TYPE (val)
-+#define ELF64_ST_INFO(bind, type)	ELF32_ST_INFO ((bind), (type))
-+
-+#define STB_LOCAL	0
-+#define STB_GLOBAL	1
-+#define STB_WEAK	2
-+#define	STB_NUM		3
-+#define STB_LOOS	10
-+#define STB_GNU_UNIQUE	10
-+#define STB_HIOS	12
-+#define STB_LOPROC	13
-+#define STB_HIPROC	15
-+
-+#define STT_NOTYPE	0
-+#define STT_OBJECT	1
-+#define STT_FUNC	2
-+#define STT_SECTION	3
-+#define STT_FILE	4
-+#define STT_COMMON	5
-+#define STT_TLS		6
-+#define	STT_NUM		7
-+#define STT_LOOS	10
-+#define STT_GNU_IFUNC	10
-+#define STT_HIOS	12
-+#define STT_LOPROC	13
-+#define STT_HIPROC	15
-+
-+#define STN_UNDEF	0
-+
-+#define ELF32_ST_VISIBILITY(o)	((o) & 0x03)
-+#define ELF64_ST_VISIBILITY(o)	ELF32_ST_VISIBILITY (o)
-+
-+#define STV_DEFAULT	0
-+#define STV_INTERNAL	1
-+#define STV_HIDDEN	2
-+#define STV_PROTECTED	3
-+
-+
-+
-+
-+typedef struct
-+{
-+  Elf32_Addr	r_offset;
-+  Elf32_Word	r_info;
-+} Elf32_Rel;
-+
-+typedef struct {
-+  Elf64_Addr	r_offset;
-+  Elf64_Xword	r_info;
-+} Elf64_Rel;
-+
-+
-+
-+typedef struct {
-+  Elf32_Addr	r_offset;
-+  Elf32_Word	r_info;
-+  Elf32_Sword	r_addend;
-+} Elf32_Rela;
-+
-+typedef struct {
-+  Elf64_Addr	r_offset;
-+  Elf64_Xword	r_info;
-+  Elf64_Sxword	r_addend;
-+} Elf64_Rela;
-+
-+
-+
-+#define ELF32_R_SYM(val)		((val) >> 8)
-+#define ELF32_R_TYPE(val)		((val) & 0xff)
-+#define ELF32_R_INFO(sym, type)		(((sym) << 8) + ((type) & 0xff))
-+
-+#define ELF64_R_SYM(i)			((i) >> 32)
-+#define ELF64_R_TYPE(i)			((i) & 0xffffffff)
-+#define ELF64_R_INFO(sym,type)		((((Elf64_Xword) (sym)) << 32) + (type))
-+
-+
-+
-+typedef struct {
-+  Elf32_Word	p_type;
-+  Elf32_Off	p_offset;
-+  Elf32_Addr	p_vaddr;
-+  Elf32_Addr	p_paddr;
-+  Elf32_Word	p_filesz;
-+  Elf32_Word	p_memsz;
-+  Elf32_Word	p_flags;
-+  Elf32_Word	p_align;
-+} Elf32_Phdr;
-+
-+typedef struct {
-+  Elf64_Word	p_type;
-+  Elf64_Word	p_flags;
-+  Elf64_Off	p_offset;
-+  Elf64_Addr	p_vaddr;
-+  Elf64_Addr	p_paddr;
-+  Elf64_Xword	p_filesz;
-+  Elf64_Xword	p_memsz;
-+  Elf64_Xword	p_align;
-+} Elf64_Phdr;
-+
-+
-+
-+#define	PT_NULL		0
-+#define PT_LOAD		1
-+#define PT_DYNAMIC	2
-+#define PT_INTERP	3
-+#define PT_NOTE		4
-+#define PT_SHLIB	5
-+#define PT_PHDR		6
-+#define PT_TLS		7
-+#define	PT_NUM		8
-+#define PT_LOOS		0x60000000
-+#define PT_GNU_EH_FRAME	0x6474e550
-+#define PT_GNU_STACK	0x6474e551
-+#define PT_GNU_RELRO	0x6474e552
-+#define PT_LOSUNW	0x6ffffffa
-+#define PT_SUNWBSS	0x6ffffffa
-+#define PT_SUNWSTACK	0x6ffffffb
-+#define PT_HISUNW	0x6fffffff
-+#define PT_HIOS		0x6fffffff
-+#define PT_LOPROC	0x70000000
-+#define PT_HIPROC	0x7fffffff
-+
-+
-+#define PN_XNUM 0xffff
-+
-+
-+#define PF_X		(1 << 0)
-+#define PF_W		(1 << 1)
-+#define PF_R		(1 << 2)
-+#define PF_MASKOS	0x0ff00000
-+#define PF_MASKPROC	0xf0000000
-+
-+
-+
-+#define NT_PRSTATUS	1
-+#define NT_FPREGSET	2
-+#define NT_PRPSINFO	3
-+#define NT_PRXREG	4
-+#define NT_TASKSTRUCT	4
-+#define NT_PLATFORM	5
-+#define NT_AUXV		6
-+#define NT_GWINDOWS	7
-+#define NT_ASRS		8
-+#define NT_PSTATUS	10
-+#define NT_PSINFO	13
-+#define NT_PRCRED	14
-+#define NT_UTSNAME	15
-+#define NT_LWPSTATUS	16
-+#define NT_LWPSINFO	17
-+#define NT_PRFPXREG	20
-+#define NT_SIGINFO	0x53494749
-+#define NT_FILE		0x46494c45
-+#define NT_PRXFPREG	0x46e62b7f
-+#define NT_PPC_VMX	0x100
-+#define NT_PPC_SPE	0x101
-+#define NT_PPC_VSX	0x102
-+#define NT_386_TLS	0x200
-+#define NT_386_IOPERM	0x201
-+#define NT_X86_XSTATE	0x202
-+#define NT_S390_HIGH_GPRS	0x300
-+#define NT_S390_TIMER	0x301
-+#define NT_S390_TODCMP	0x302
-+#define NT_S390_TODPREG	0x303
-+#define NT_S390_CTRS	0x304
-+#define NT_S390_PREFIX	0x305
-+#define NT_S390_LAST_BREAK	0x306
-+#define NT_S390_SYSTEM_CALL	0x307
-+#define NT_S390_TDB	0x308
-+#define NT_ARM_VFP	0x400
-+#define NT_ARM_TLS	0x401
-+#define NT_ARM_HW_BREAK	0x402
-+#define NT_ARM_HW_WATCH	0x403
-+#define NT_METAG_CBUF	0x500
-+#define NT_METAG_RPIPE	0x501
-+#define NT_METAG_TLS	0x502
-+#define NT_VERSION	1
-+
-+
-+
-+
-+typedef struct {
-+  Elf32_Sword d_tag;
-+  union {
-+      Elf32_Word d_val;
-+      Elf32_Addr d_ptr;
-+  } d_un;
-+} Elf32_Dyn;
-+
-+typedef struct {
-+  Elf64_Sxword d_tag;
-+  union {
-+      Elf64_Xword d_val;
-+      Elf64_Addr d_ptr;
-+  } d_un;
-+} Elf64_Dyn;
-+
-+
-+
-+#define DT_NULL		0
-+#define DT_NEEDED	1
-+#define DT_PLTRELSZ	2
-+#define DT_PLTGOT	3
-+#define DT_HASH		4
-+#define DT_STRTAB	5
-+#define DT_SYMTAB	6
-+#define DT_RELA		7
-+#define DT_RELASZ	8
-+#define DT_RELAENT	9
-+#define DT_STRSZ	10
-+#define DT_SYMENT	11
-+#define DT_INIT		12
-+#define DT_FINI		13
-+#define DT_SONAME	14
-+#define DT_RPATH	15
-+#define DT_SYMBOLIC	16
-+#define DT_REL		17
-+#define DT_RELSZ	18
-+#define DT_RELENT	19
-+#define DT_PLTREL	20
-+#define DT_DEBUG	21
-+#define DT_TEXTREL	22
-+#define DT_JMPREL	23
-+#define	DT_BIND_NOW	24
-+#define	DT_INIT_ARRAY	25
-+#define	DT_FINI_ARRAY	26
-+#define	DT_INIT_ARRAYSZ	27
-+#define	DT_FINI_ARRAYSZ	28
-+#define DT_RUNPATH	29
-+#define DT_FLAGS	30
-+#define DT_ENCODING	32
-+#define DT_PREINIT_ARRAY 32
-+#define DT_PREINIT_ARRAYSZ 33
-+#define	DT_NUM		34
-+#define DT_LOOS		0x6000000d
-+#define DT_HIOS		0x6ffff000
-+#define DT_LOPROC	0x70000000
-+#define DT_HIPROC	0x7fffffff
-+#define	DT_PROCNUM	DT_MIPS_NUM
-+
-+#define DT_VALRNGLO	0x6ffffd00
-+#define DT_GNU_PRELINKED 0x6ffffdf5
-+#define DT_GNU_CONFLICTSZ 0x6ffffdf6
-+#define DT_GNU_LIBLISTSZ 0x6ffffdf7
-+#define DT_CHECKSUM	0x6ffffdf8
-+#define DT_PLTPADSZ	0x6ffffdf9
-+#define DT_MOVEENT	0x6ffffdfa
-+#define DT_MOVESZ	0x6ffffdfb
-+#define DT_FEATURE_1	0x6ffffdfc
-+#define DT_POSFLAG_1	0x6ffffdfd
-+
-+#define DT_SYMINSZ	0x6ffffdfe
-+#define DT_SYMINENT	0x6ffffdff
-+#define DT_VALRNGHI	0x6ffffdff
-+#define DT_VALTAGIDX(tag)	(DT_VALRNGHI - (tag))
-+#define DT_VALNUM 12
-+
-+#define DT_ADDRRNGLO	0x6ffffe00
-+#define DT_GNU_HASH	0x6ffffef5
-+#define DT_TLSDESC_PLT	0x6ffffef6
-+#define DT_TLSDESC_GOT	0x6ffffef7
-+#define DT_GNU_CONFLICT	0x6ffffef8
-+#define DT_GNU_LIBLIST	0x6ffffef9
-+#define DT_CONFIG	0x6ffffefa
-+#define DT_DEPAUDIT	0x6ffffefb
-+#define DT_AUDIT	0x6ffffefc
-+#define	DT_PLTPAD	0x6ffffefd
-+#define	DT_MOVETAB	0x6ffffefe
-+#define DT_SYMINFO	0x6ffffeff
-+#define DT_ADDRRNGHI	0x6ffffeff
-+#define DT_ADDRTAGIDX(tag)	(DT_ADDRRNGHI - (tag))
-+#define DT_ADDRNUM 11
-+
-+
-+
-+#define DT_VERSYM	0x6ffffff0
-+
-+#define DT_RELACOUNT	0x6ffffff9
-+#define DT_RELCOUNT	0x6ffffffa
-+
-+
-+#define DT_FLAGS_1	0x6ffffffb
-+#define	DT_VERDEF	0x6ffffffc
-+
-+#define	DT_VERDEFNUM	0x6ffffffd
-+#define	DT_VERNEED	0x6ffffffe
-+
-+#define	DT_VERNEEDNUM	0x6fffffff
-+#define DT_VERSIONTAGIDX(tag)	(DT_VERNEEDNUM - (tag))
-+#define DT_VERSIONTAGNUM 16
-+
-+
-+
-+#define DT_AUXILIARY    0x7ffffffd
-+#define DT_FILTER       0x7fffffff
-+#define DT_EXTRATAGIDX(tag)	((Elf32_Word)-((Elf32_Sword) (tag) <<1>>1)-1)
-+#define DT_EXTRANUM	3
-+
-+
-+#define DF_ORIGIN	0x00000001
-+#define DF_SYMBOLIC	0x00000002
-+#define DF_TEXTREL	0x00000004
-+#define DF_BIND_NOW	0x00000008
-+#define DF_STATIC_TLS	0x00000010
-+
-+
-+
-+#define DF_1_NOW	0x00000001
-+#define DF_1_GLOBAL	0x00000002
-+#define DF_1_GROUP	0x00000004
-+#define DF_1_NODELETE	0x00000008
-+#define DF_1_LOADFLTR	0x00000010
-+#define DF_1_INITFIRST	0x00000020
-+#define DF_1_NOOPEN	0x00000040
-+#define DF_1_ORIGIN	0x00000080
-+#define DF_1_DIRECT	0x00000100
-+#define DF_1_TRANS	0x00000200
-+#define DF_1_INTERPOSE	0x00000400
-+#define DF_1_NODEFLIB	0x00000800
-+#define DF_1_NODUMP	0x00001000
-+#define DF_1_CONFALT	0x00002000
-+#define DF_1_ENDFILTEE	0x00004000
-+#define	DF_1_DISPRELDNE	0x00008000
-+#define	DF_1_DISPRELPND	0x00010000
-+#define	DF_1_NODIRECT	0x00020000
-+#define	DF_1_IGNMULDEF	0x00040000
-+#define	DF_1_NOKSYMS	0x00080000
-+#define	DF_1_NOHDR	0x00100000
-+#define	DF_1_EDITED	0x00200000
-+#define	DF_1_NORELOC	0x00400000
-+#define	DF_1_SYMINTPOSE	0x00800000
-+#define	DF_1_GLOBAUDIT	0x01000000
-+#define	DF_1_SINGLETON	0x02000000
-+
-+#define DTF_1_PARINIT	0x00000001
-+#define DTF_1_CONFEXP	0x00000002
-+
-+
-+#define DF_P1_LAZYLOAD	0x00000001
-+#define DF_P1_GROUPPERM	0x00000002
-+
-+
-+
-+
-+typedef struct {
-+  Elf32_Half	vd_version;
-+  Elf32_Half	vd_flags;
-+  Elf32_Half	vd_ndx;
-+  Elf32_Half	vd_cnt;
-+  Elf32_Word	vd_hash;
-+  Elf32_Word	vd_aux;
-+  Elf32_Word	vd_next;
-+} Elf32_Verdef;
-+
-+typedef struct {
-+  Elf64_Half	vd_version;
-+  Elf64_Half	vd_flags;
-+  Elf64_Half	vd_ndx;
-+  Elf64_Half	vd_cnt;
-+  Elf64_Word	vd_hash;
-+  Elf64_Word	vd_aux;
-+  Elf64_Word	vd_next;
-+} Elf64_Verdef;
-+
-+
-+
-+#define VER_DEF_NONE	0
-+#define VER_DEF_CURRENT	1
-+#define VER_DEF_NUM	2
-+
-+
-+#define VER_FLG_BASE	0x1
-+#define VER_FLG_WEAK	0x2
-+
-+
-+#define	VER_NDX_LOCAL		0
-+#define	VER_NDX_GLOBAL		1
-+#define	VER_NDX_LORESERVE	0xff00
-+#define	VER_NDX_ELIMINATE	0xff01
-+
-+
-+
-+typedef struct {
-+  Elf32_Word	vda_name;
-+  Elf32_Word	vda_next;
-+} Elf32_Verdaux;
-+
-+typedef struct {
-+  Elf64_Word	vda_name;
-+  Elf64_Word	vda_next;
-+} Elf64_Verdaux;
-+
-+
-+
-+
-+typedef struct {
-+  Elf32_Half	vn_version;
-+  Elf32_Half	vn_cnt;
-+  Elf32_Word	vn_file;
-+  Elf32_Word	vn_aux;
-+  Elf32_Word	vn_next;
-+} Elf32_Verneed;
-+
-+typedef struct {
-+  Elf64_Half	vn_version;
-+  Elf64_Half	vn_cnt;
-+  Elf64_Word	vn_file;
-+  Elf64_Word	vn_aux;
-+  Elf64_Word	vn_next;
-+} Elf64_Verneed;
-+
-+
-+
-+#define VER_NEED_NONE	 0
-+#define VER_NEED_CURRENT 1
-+#define VER_NEED_NUM	 2
-+
-+
-+
-+typedef struct {
-+  Elf32_Word	vna_hash;
-+  Elf32_Half	vna_flags;
-+  Elf32_Half	vna_other;
-+  Elf32_Word	vna_name;
-+  Elf32_Word	vna_next;
-+} Elf32_Vernaux;
-+
-+typedef struct {
-+  Elf64_Word	vna_hash;
-+  Elf64_Half	vna_flags;
-+  Elf64_Half	vna_other;
-+  Elf64_Word	vna_name;
-+  Elf64_Word	vna_next;
-+} Elf64_Vernaux;
-+
-+
-+
-+#define VER_FLG_WEAK	0x2
-+
-+
-+
-+typedef struct {
-+  uint32_t a_type;
-+  union {
-+      uint32_t a_val;
-+  } a_un;
-+} Elf32_auxv_t;
-+
-+typedef struct {
-+  uint64_t a_type;
-+  union {
-+      uint64_t a_val;
-+  } a_un;
-+} Elf64_auxv_t;
-+
-+
-+
-+#define AT_NULL		0
-+#define AT_IGNORE	1
-+#define AT_EXECFD	2
-+#define AT_PHDR		3
-+#define AT_PHENT	4
-+#define AT_PHNUM	5
-+#define AT_PAGESZ	6
-+#define AT_BASE		7
-+#define AT_FLAGS	8
-+#define AT_ENTRY	9
-+#define AT_NOTELF	10
-+#define AT_UID		11
-+#define AT_EUID		12
-+#define AT_GID		13
-+#define AT_EGID		14
-+#define AT_CLKTCK	17
-+
-+
-+#define AT_PLATFORM	15
-+#define AT_HWCAP	16
-+
-+
-+
-+
-+#define AT_FPUCW	18
-+
-+
-+#define AT_DCACHEBSIZE	19
-+#define AT_ICACHEBSIZE	20
-+#define AT_UCACHEBSIZE	21
-+
-+
-+
-+#define AT_IGNOREPPC	22
-+
-+#define	AT_SECURE	23
-+
-+#define AT_BASE_PLATFORM 24
-+
-+#define AT_RANDOM	25
-+
-+#define AT_HWCAP2	26
-+
-+#define AT_EXECFN	31
-+
-+
-+
-+#define AT_SYSINFO	32
-+#define AT_SYSINFO_EHDR	33
-+
-+
-+
-+#define AT_L1I_CACHESHAPE	34
-+#define AT_L1D_CACHESHAPE	35
-+#define AT_L2_CACHESHAPE	36
-+#define AT_L3_CACHESHAPE	37
-+
-+
-+
-+
-+typedef struct {
-+  Elf32_Word n_namesz;
-+  Elf32_Word n_descsz;
-+  Elf32_Word n_type;
-+} Elf32_Nhdr;
-+
-+typedef struct {
-+  Elf64_Word n_namesz;
-+  Elf64_Word n_descsz;
-+  Elf64_Word n_type;
-+} Elf64_Nhdr;
-+
-+
-+
-+
-+#define ELF_NOTE_SOLARIS	"SUNW Solaris"
-+
-+
-+#define ELF_NOTE_GNU		"GNU"
-+
-+
-+
-+
-+
-+#define ELF_NOTE_PAGESIZE_HINT	1
-+
-+
-+#define NT_GNU_ABI_TAG	1
-+#define ELF_NOTE_ABI	NT_GNU_ABI_TAG
-+
-+
-+
-+#define ELF_NOTE_OS_LINUX	0
-+#define ELF_NOTE_OS_GNU		1
-+#define ELF_NOTE_OS_SOLARIS2	2
-+#define ELF_NOTE_OS_FREEBSD	3
-+
-+#define NT_GNU_BUILD_ID	3
-+#define NT_GNU_GOLD_VERSION	4
-+
-+
-+
-+typedef struct {
-+  Elf32_Xword m_value;
-+  Elf32_Word m_info;
-+  Elf32_Word m_poffset;
-+  Elf32_Half m_repeat;
-+  Elf32_Half m_stride;
-+} Elf32_Move;
-+
-+typedef struct {
-+  Elf64_Xword m_value;
-+  Elf64_Xword m_info;
-+  Elf64_Xword m_poffset;
-+  Elf64_Half m_repeat;
-+  Elf64_Half m_stride;
-+} Elf64_Move;
-+
-+
-+#define ELF32_M_SYM(info)	((info) >> 8)
-+#define ELF32_M_SIZE(info)	((unsigned char) (info))
-+#define ELF32_M_INFO(sym, size)	(((sym) << 8) + (unsigned char) (size))
-+
-+#define ELF64_M_SYM(info)	ELF32_M_SYM (info)
-+#define ELF64_M_SIZE(info)	ELF32_M_SIZE (info)
-+#define ELF64_M_INFO(sym, size)	ELF32_M_INFO (sym, size)
-+
-+#define EF_CPU32	0x00810000
-+
-+#define R_68K_NONE	0
-+#define R_68K_32	1
-+#define R_68K_16	2
-+#define R_68K_8		3
-+#define R_68K_PC32	4
-+#define R_68K_PC16	5
-+#define R_68K_PC8	6
-+#define R_68K_GOT32	7
-+#define R_68K_GOT16	8
-+#define R_68K_GOT8	9
-+#define R_68K_GOT32O	10
-+#define R_68K_GOT16O	11
-+#define R_68K_GOT8O	12
-+#define R_68K_PLT32	13
-+#define R_68K_PLT16	14
-+#define R_68K_PLT8	15
-+#define R_68K_PLT32O	16
-+#define R_68K_PLT16O	17
-+#define R_68K_PLT8O	18
-+#define R_68K_COPY	19
-+#define R_68K_GLOB_DAT	20
-+#define R_68K_JMP_SLOT	21
-+#define R_68K_RELATIVE	22
-+#define R_68K_NUM	23
-+
-+#define R_386_NONE	   0
-+#define R_386_32	   1
-+#define R_386_PC32	   2
-+#define R_386_GOT32	   3
-+#define R_386_PLT32	   4
-+#define R_386_COPY	   5
-+#define R_386_GLOB_DAT	   6
-+#define R_386_JMP_SLOT	   7
-+#define R_386_RELATIVE	   8
-+#define R_386_GOTOFF	   9
-+#define R_386_GOTPC	   10
-+#define R_386_32PLT	   11
-+#define R_386_TLS_TPOFF	   14
-+#define R_386_TLS_IE	   15
-+#define R_386_TLS_GOTIE	   16
-+#define R_386_TLS_LE	   17
-+#define R_386_TLS_GD	   18
-+#define R_386_TLS_LDM	   19
-+#define R_386_16	   20
-+#define R_386_PC16	   21
-+#define R_386_8		   22
-+#define R_386_PC8	   23
-+#define R_386_TLS_GD_32	   24
-+#define R_386_TLS_GD_PUSH  25
-+#define R_386_TLS_GD_CALL  26
-+#define R_386_TLS_GD_POP   27
-+#define R_386_TLS_LDM_32   28
-+#define R_386_TLS_LDM_PUSH 29
-+#define R_386_TLS_LDM_CALL 30
-+#define R_386_TLS_LDM_POP  31
-+#define R_386_TLS_LDO_32   32
-+#define R_386_TLS_IE_32	   33
-+#define R_386_TLS_LE_32	   34
-+#define R_386_TLS_DTPMOD32 35
-+#define R_386_TLS_DTPOFF32 36
-+#define R_386_TLS_TPOFF32  37
-+#define R_386_SIZE32       38
-+#define R_386_TLS_GOTDESC  39
-+#define R_386_TLS_DESC_CALL 40
-+#define R_386_TLS_DESC     41
-+#define R_386_IRELATIVE	   42
-+#define R_386_NUM	   43
-+
-+
-+
-+
-+
-+#define STT_SPARC_REGISTER	13
-+
-+
-+
-+#define EF_SPARCV9_MM		3
-+#define EF_SPARCV9_TSO		0
-+#define EF_SPARCV9_PSO		1
-+#define EF_SPARCV9_RMO		2
-+#define EF_SPARC_LEDATA		0x800000
-+#define EF_SPARC_EXT_MASK	0xFFFF00
-+#define EF_SPARC_32PLUS		0x000100
-+#define EF_SPARC_SUN_US1	0x000200
-+#define EF_SPARC_HAL_R1		0x000400
-+#define EF_SPARC_SUN_US3	0x000800
-+
-+
-+
-+#define R_SPARC_NONE		0
-+#define R_SPARC_8		1
-+#define R_SPARC_16		2
-+#define R_SPARC_32		3
-+#define R_SPARC_DISP8		4
-+#define R_SPARC_DISP16		5
-+#define R_SPARC_DISP32		6
-+#define R_SPARC_WDISP30		7
-+#define R_SPARC_WDISP22		8
-+#define R_SPARC_HI22		9
-+#define R_SPARC_22		10
-+#define R_SPARC_13		11
-+#define R_SPARC_LO10		12
-+#define R_SPARC_GOT10		13
-+#define R_SPARC_GOT13		14
-+#define R_SPARC_GOT22		15
-+#define R_SPARC_PC10		16
-+#define R_SPARC_PC22		17
-+#define R_SPARC_WPLT30		18
-+#define R_SPARC_COPY		19
-+#define R_SPARC_GLOB_DAT	20
-+#define R_SPARC_JMP_SLOT	21
-+#define R_SPARC_RELATIVE	22
-+#define R_SPARC_UA32		23
-+
-+
-+
-+#define R_SPARC_PLT32		24
-+#define R_SPARC_HIPLT22		25
-+#define R_SPARC_LOPLT10		26
-+#define R_SPARC_PCPLT32		27
-+#define R_SPARC_PCPLT22		28
-+#define R_SPARC_PCPLT10		29
-+#define R_SPARC_10		30
-+#define R_SPARC_11		31
-+#define R_SPARC_64		32
-+#define R_SPARC_OLO10		33
-+#define R_SPARC_HH22		34
-+#define R_SPARC_HM10		35
-+#define R_SPARC_LM22		36
-+#define R_SPARC_PC_HH22		37
-+#define R_SPARC_PC_HM10		38
-+#define R_SPARC_PC_LM22		39
-+#define R_SPARC_WDISP16		40
-+#define R_SPARC_WDISP19		41
-+#define R_SPARC_GLOB_JMP	42
-+#define R_SPARC_7		43
-+#define R_SPARC_5		44
-+#define R_SPARC_6		45
-+#define R_SPARC_DISP64		46
-+#define R_SPARC_PLT64		47
-+#define R_SPARC_HIX22		48
-+#define R_SPARC_LOX10		49
-+#define R_SPARC_H44		50
-+#define R_SPARC_M44		51
-+#define R_SPARC_L44		52
-+#define R_SPARC_REGISTER	53
-+#define R_SPARC_UA64		54
-+#define R_SPARC_UA16		55
-+#define R_SPARC_TLS_GD_HI22	56
-+#define R_SPARC_TLS_GD_LO10	57
-+#define R_SPARC_TLS_GD_ADD	58
-+#define R_SPARC_TLS_GD_CALL	59
-+#define R_SPARC_TLS_LDM_HI22	60
-+#define R_SPARC_TLS_LDM_LO10	61
-+#define R_SPARC_TLS_LDM_ADD	62
-+#define R_SPARC_TLS_LDM_CALL	63
-+#define R_SPARC_TLS_LDO_HIX22	64
-+#define R_SPARC_TLS_LDO_LOX10	65
-+#define R_SPARC_TLS_LDO_ADD	66
-+#define R_SPARC_TLS_IE_HI22	67
-+#define R_SPARC_TLS_IE_LO10	68
-+#define R_SPARC_TLS_IE_LD	69
-+#define R_SPARC_TLS_IE_LDX	70
-+#define R_SPARC_TLS_IE_ADD	71
-+#define R_SPARC_TLS_LE_HIX22	72
-+#define R_SPARC_TLS_LE_LOX10	73
-+#define R_SPARC_TLS_DTPMOD32	74
-+#define R_SPARC_TLS_DTPMOD64	75
-+#define R_SPARC_TLS_DTPOFF32	76
-+#define R_SPARC_TLS_DTPOFF64	77
-+#define R_SPARC_TLS_TPOFF32	78
-+#define R_SPARC_TLS_TPOFF64	79
-+#define R_SPARC_GOTDATA_HIX22	80
-+#define R_SPARC_GOTDATA_LOX10	81
-+#define R_SPARC_GOTDATA_OP_HIX22	82
-+#define R_SPARC_GOTDATA_OP_LOX10	83
-+#define R_SPARC_GOTDATA_OP	84
-+#define R_SPARC_H34		85
-+#define R_SPARC_SIZE32		86
-+#define R_SPARC_SIZE64		87
-+#define R_SPARC_GNU_VTINHERIT	250
-+#define R_SPARC_GNU_VTENTRY	251
-+#define R_SPARC_REV32		252
-+
-+#define R_SPARC_NUM		253
-+
-+
-+
-+#define DT_SPARC_REGISTER 0x70000001
-+#define DT_SPARC_NUM	2
-+
-+
-+#define EF_MIPS_NOREORDER   1
-+#define EF_MIPS_PIC	    2
-+#define EF_MIPS_CPIC	    4
-+#define EF_MIPS_XGOT	    8
-+#define EF_MIPS_64BIT_WHIRL 16
-+#define EF_MIPS_ABI2	    32
-+#define EF_MIPS_ABI_ON32    64
-+#define EF_MIPS_ARCH	    0xf0000000
-+
-+
-+
-+#define EF_MIPS_ARCH_1	    0x00000000
-+#define EF_MIPS_ARCH_2	    0x10000000
-+#define EF_MIPS_ARCH_3	    0x20000000
-+#define EF_MIPS_ARCH_4	    0x30000000
-+#define EF_MIPS_ARCH_5	    0x40000000
-+#define EF_MIPS_ARCH_32     0x50000000
-+#define EF_MIPS_ARCH_64     0x60000000
-+#define EF_MIPS_ARCH_32R2   0x70000000
-+#define EF_MIPS_ARCH_64R2   0x80000000
-+
-+
-+#define E_MIPS_ARCH_1	  0x00000000
-+#define E_MIPS_ARCH_2	  0x10000000
-+#define E_MIPS_ARCH_3	  0x20000000
-+#define E_MIPS_ARCH_4	  0x30000000
-+#define E_MIPS_ARCH_5	  0x40000000
-+#define E_MIPS_ARCH_32	  0x50000000
-+#define E_MIPS_ARCH_64	  0x60000000
-+
-+
-+
-+#define SHN_MIPS_ACOMMON    0xff00
-+#define SHN_MIPS_TEXT	    0xff01
-+#define SHN_MIPS_DATA	    0xff02
-+#define SHN_MIPS_SCOMMON    0xff03
-+#define SHN_MIPS_SUNDEFINED 0xff04
-+
-+
-+
-+#define SHT_MIPS_LIBLIST       0x70000000
-+#define SHT_MIPS_MSYM	       0x70000001
-+#define SHT_MIPS_CONFLICT      0x70000002
-+#define SHT_MIPS_GPTAB	       0x70000003
-+#define SHT_MIPS_UCODE	       0x70000004
-+#define SHT_MIPS_DEBUG	       0x70000005
-+#define SHT_MIPS_REGINFO       0x70000006
-+#define SHT_MIPS_PACKAGE       0x70000007
-+#define SHT_MIPS_PACKSYM       0x70000008
-+#define SHT_MIPS_RELD	       0x70000009
-+#define SHT_MIPS_IFACE         0x7000000b
-+#define SHT_MIPS_CONTENT       0x7000000c
-+#define SHT_MIPS_OPTIONS       0x7000000d
-+#define SHT_MIPS_SHDR	       0x70000010
-+#define SHT_MIPS_FDESC	       0x70000011
-+#define SHT_MIPS_EXTSYM	       0x70000012
-+#define SHT_MIPS_DENSE	       0x70000013
-+#define SHT_MIPS_PDESC	       0x70000014
-+#define SHT_MIPS_LOCSYM	       0x70000015
-+#define SHT_MIPS_AUXSYM	       0x70000016
-+#define SHT_MIPS_OPTSYM	       0x70000017
-+#define SHT_MIPS_LOCSTR	       0x70000018
-+#define SHT_MIPS_LINE	       0x70000019
-+#define SHT_MIPS_RFDESC	       0x7000001a
-+#define SHT_MIPS_DELTASYM      0x7000001b
-+#define SHT_MIPS_DELTAINST     0x7000001c
-+#define SHT_MIPS_DELTACLASS    0x7000001d
-+#define SHT_MIPS_DWARF         0x7000001e
-+#define SHT_MIPS_DELTADECL     0x7000001f
-+#define SHT_MIPS_SYMBOL_LIB    0x70000020
-+#define SHT_MIPS_EVENTS	       0x70000021
-+#define SHT_MIPS_TRANSLATE     0x70000022
-+#define SHT_MIPS_PIXIE	       0x70000023
-+#define SHT_MIPS_XLATE	       0x70000024
-+#define SHT_MIPS_XLATE_DEBUG   0x70000025
-+#define SHT_MIPS_WHIRL	       0x70000026
-+#define SHT_MIPS_EH_REGION     0x70000027
-+#define SHT_MIPS_XLATE_OLD     0x70000028
-+#define SHT_MIPS_PDR_EXCEPTION 0x70000029
-+
-+
-+
-+#define SHF_MIPS_GPREL	 0x10000000
-+#define SHF_MIPS_MERGE	 0x20000000
-+#define SHF_MIPS_ADDR	 0x40000000
-+#define SHF_MIPS_STRINGS 0x80000000
-+#define SHF_MIPS_NOSTRIP 0x08000000
-+#define SHF_MIPS_LOCAL	 0x04000000
-+#define SHF_MIPS_NAMES	 0x02000000
-+#define SHF_MIPS_NODUPE	 0x01000000
-+
-+
-+
-+
-+
-+#define STO_MIPS_DEFAULT		0x0
-+#define STO_MIPS_INTERNAL		0x1
-+#define STO_MIPS_HIDDEN			0x2
-+#define STO_MIPS_PROTECTED		0x3
-+#define STO_MIPS_PLT			0x8
-+#define STO_MIPS_SC_ALIGN_UNUSED	0xff
-+
-+
-+#define STB_MIPS_SPLIT_COMMON		13
-+
-+
-+
-+typedef union {
-+  struct {
-+      Elf32_Word gt_current_g_value;
-+      Elf32_Word gt_unused;
-+  } gt_header;
-+  struct {
-+      Elf32_Word gt_g_value;
-+      Elf32_Word gt_bytes;
-+  } gt_entry;
-+} Elf32_gptab;
-+
-+
-+
-+typedef struct {
-+  Elf32_Word	ri_gprmask;
-+  Elf32_Word	ri_cprmask[4];
-+  Elf32_Sword	ri_gp_value;
-+} Elf32_RegInfo;
-+
-+
-+
-+typedef struct {
-+  unsigned char kind;
-+
-+  unsigned char size;
-+  Elf32_Section section;
-+
-+  Elf32_Word info;
-+} Elf_Options;
-+
-+
-+
-+#define ODK_NULL	0
-+#define ODK_REGINFO	1
-+#define ODK_EXCEPTIONS	2
-+#define ODK_PAD		3
-+#define ODK_HWPATCH	4
-+#define ODK_FILL	5
-+#define ODK_TAGS	6
-+#define ODK_HWAND	7
-+#define ODK_HWOR	8
-+
-+
-+
-+#define OEX_FPU_MIN	0x1f
-+#define OEX_FPU_MAX	0x1f00
-+#define OEX_PAGE0	0x10000
-+#define OEX_SMM		0x20000
-+#define OEX_FPDBUG	0x40000
-+#define OEX_PRECISEFP	OEX_FPDBUG
-+#define OEX_DISMISS	0x80000
-+
-+#define OEX_FPU_INVAL	0x10
-+#define OEX_FPU_DIV0	0x08
-+#define OEX_FPU_OFLO	0x04
-+#define OEX_FPU_UFLO	0x02
-+#define OEX_FPU_INEX	0x01
-+
-+
-+
-+#define OHW_R4KEOP	0x1
-+#define OHW_R8KPFETCH	0x2
-+#define OHW_R5KEOP	0x4
-+#define OHW_R5KCVTL	0x8
-+
-+#define OPAD_PREFIX	0x1
-+#define OPAD_POSTFIX	0x2
-+#define OPAD_SYMBOL	0x4
-+
-+
-+
-+typedef struct {
-+  Elf32_Word hwp_flags1;
-+  Elf32_Word hwp_flags2;
-+} Elf_Options_Hw;
-+
-+
-+
-+#define OHWA0_R4KEOP_CHECKED	0x00000001
-+#define OHWA1_R4KEOP_CLEAN	0x00000002
-+
-+
-+
-+#define R_MIPS_NONE		0
-+#define R_MIPS_16		1
-+#define R_MIPS_32		2
-+#define R_MIPS_REL32		3
-+#define R_MIPS_26		4
-+#define R_MIPS_HI16		5
-+#define R_MIPS_LO16		6
-+#define R_MIPS_GPREL16		7
-+#define R_MIPS_LITERAL		8
-+#define R_MIPS_GOT16		9
-+#define R_MIPS_PC16		10
-+#define R_MIPS_CALL16		11
-+#define R_MIPS_GPREL32		12
-+
-+#define R_MIPS_SHIFT5		16
-+#define R_MIPS_SHIFT6		17
-+#define R_MIPS_64		18
-+#define R_MIPS_GOT_DISP		19
-+#define R_MIPS_GOT_PAGE		20
-+#define R_MIPS_GOT_OFST		21
-+#define R_MIPS_GOT_HI16		22
-+#define R_MIPS_GOT_LO16		23
-+#define R_MIPS_SUB		24
-+#define R_MIPS_INSERT_A		25
-+#define R_MIPS_INSERT_B		26
-+#define R_MIPS_DELETE		27
-+#define R_MIPS_HIGHER		28
-+#define R_MIPS_HIGHEST		29
-+#define R_MIPS_CALL_HI16	30
-+#define R_MIPS_CALL_LO16	31
-+#define R_MIPS_SCN_DISP		32
-+#define R_MIPS_REL16		33
-+#define R_MIPS_ADD_IMMEDIATE	34
-+#define R_MIPS_PJUMP		35
-+#define R_MIPS_RELGOT		36
-+#define R_MIPS_JALR		37
-+#define R_MIPS_TLS_DTPMOD32	38
-+#define R_MIPS_TLS_DTPREL32	39
-+#define R_MIPS_TLS_DTPMOD64	40
-+#define R_MIPS_TLS_DTPREL64	41
-+#define R_MIPS_TLS_GD		42
-+#define R_MIPS_TLS_LDM		43
-+#define R_MIPS_TLS_DTPREL_HI16	44
-+#define R_MIPS_TLS_DTPREL_LO16	45
-+#define R_MIPS_TLS_GOTTPREL	46
-+#define R_MIPS_TLS_TPREL32	47
-+#define R_MIPS_TLS_TPREL64	48
-+#define R_MIPS_TLS_TPREL_HI16	49
-+#define R_MIPS_TLS_TPREL_LO16	50
-+#define R_MIPS_GLOB_DAT		51
-+#define R_MIPS_COPY		126
-+#define R_MIPS_JUMP_SLOT        127
-+
-+#define R_MIPS_NUM		128
-+
-+
-+
-+#define PT_MIPS_REGINFO	0x70000000
-+#define PT_MIPS_RTPROC  0x70000001
-+#define PT_MIPS_OPTIONS 0x70000002
-+
-+
-+
-+#define PF_MIPS_LOCAL	0x10000000
-+
-+
-+
-+#define DT_MIPS_RLD_VERSION  0x70000001
-+#define DT_MIPS_TIME_STAMP   0x70000002
-+#define DT_MIPS_ICHECKSUM    0x70000003
-+#define DT_MIPS_IVERSION     0x70000004
-+#define DT_MIPS_FLAGS	     0x70000005
-+#define DT_MIPS_BASE_ADDRESS 0x70000006
-+#define DT_MIPS_MSYM	     0x70000007
-+#define DT_MIPS_CONFLICT     0x70000008
-+#define DT_MIPS_LIBLIST	     0x70000009
-+#define DT_MIPS_LOCAL_GOTNO  0x7000000a
-+#define DT_MIPS_CONFLICTNO   0x7000000b
-+#define DT_MIPS_LIBLISTNO    0x70000010
-+#define DT_MIPS_SYMTABNO     0x70000011
-+#define DT_MIPS_UNREFEXTNO   0x70000012
-+#define DT_MIPS_GOTSYM	     0x70000013
-+#define DT_MIPS_HIPAGENO     0x70000014
-+#define DT_MIPS_RLD_MAP	     0x70000016
-+#define DT_MIPS_DELTA_CLASS  0x70000017
-+#define DT_MIPS_DELTA_CLASS_NO    0x70000018
-+
-+#define DT_MIPS_DELTA_INSTANCE    0x70000019
-+#define DT_MIPS_DELTA_INSTANCE_NO 0x7000001a
-+
-+#define DT_MIPS_DELTA_RELOC  0x7000001b
-+#define DT_MIPS_DELTA_RELOC_NO 0x7000001c
-+
-+#define DT_MIPS_DELTA_SYM    0x7000001d
-+
-+#define DT_MIPS_DELTA_SYM_NO 0x7000001e
-+
-+#define DT_MIPS_DELTA_CLASSSYM 0x70000020
-+
-+#define DT_MIPS_DELTA_CLASSSYM_NO 0x70000021
-+
-+#define DT_MIPS_CXX_FLAGS    0x70000022
-+#define DT_MIPS_PIXIE_INIT   0x70000023
-+#define DT_MIPS_SYMBOL_LIB   0x70000024
-+#define DT_MIPS_LOCALPAGE_GOTIDX 0x70000025
-+#define DT_MIPS_LOCAL_GOTIDX 0x70000026
-+#define DT_MIPS_HIDDEN_GOTIDX 0x70000027
-+#define DT_MIPS_PROTECTED_GOTIDX 0x70000028
-+#define DT_MIPS_OPTIONS	     0x70000029
-+#define DT_MIPS_INTERFACE    0x7000002a
-+#define DT_MIPS_DYNSTR_ALIGN 0x7000002b
-+#define DT_MIPS_INTERFACE_SIZE 0x7000002c
-+#define DT_MIPS_RLD_TEXT_RESOLVE_ADDR 0x7000002d
-+
-+#define DT_MIPS_PERF_SUFFIX  0x7000002e
-+
-+#define DT_MIPS_COMPACT_SIZE 0x7000002f
-+#define DT_MIPS_GP_VALUE     0x70000030
-+#define DT_MIPS_AUX_DYNAMIC  0x70000031
-+
-+#define DT_MIPS_PLTGOT	     0x70000032
-+
-+#define DT_MIPS_RWPLT        0x70000034
-+#define DT_MIPS_NUM	     0x35
-+
-+
-+
-+#define RHF_NONE		   0
-+#define RHF_QUICKSTART		   (1 << 0)
-+#define RHF_NOTPOT		   (1 << 1)
-+#define RHF_NO_LIBRARY_REPLACEMENT (1 << 2)
-+#define RHF_NO_MOVE		   (1 << 3)
-+#define RHF_SGI_ONLY		   (1 << 4)
-+#define RHF_GUARANTEE_INIT	   (1 << 5)
-+#define RHF_DELTA_C_PLUS_PLUS	   (1 << 6)
-+#define RHF_GUARANTEE_START_INIT   (1 << 7)
-+#define RHF_PIXIE		   (1 << 8)
-+#define RHF_DEFAULT_DELAY_LOAD	   (1 << 9)
-+#define RHF_REQUICKSTART	   (1 << 10)
-+#define RHF_REQUICKSTARTED	   (1 << 11)
-+#define RHF_CORD		   (1 << 12)
-+#define RHF_NO_UNRES_UNDEF	   (1 << 13)
-+#define RHF_RLD_ORDER_SAFE	   (1 << 14)
-+
-+
-+
-+typedef struct
-+{
-+  Elf32_Word l_name;
-+  Elf32_Word l_time_stamp;
-+  Elf32_Word l_checksum;
-+  Elf32_Word l_version;
-+  Elf32_Word l_flags;
-+} Elf32_Lib;
-+
-+typedef struct
-+{
-+  Elf64_Word l_name;
-+  Elf64_Word l_time_stamp;
-+  Elf64_Word l_checksum;
-+  Elf64_Word l_version;
-+  Elf64_Word l_flags;
-+} Elf64_Lib;
-+
-+
-+
-+
-+#define LL_NONE		  0
-+#define LL_EXACT_MATCH	  (1 << 0)
-+#define LL_IGNORE_INT_VER (1 << 1)
-+#define LL_REQUIRE_MINOR  (1 << 2)
-+#define LL_EXPORTS	  (1 << 3)
-+#define LL_DELAY_LOAD	  (1 << 4)
-+#define LL_DELTA	  (1 << 5)
-+
-+
-+
-+typedef Elf32_Addr Elf32_Conflict;
-+
-+
-+
-+
-+
-+
-+#define EF_PARISC_TRAPNIL	0x00010000
-+#define EF_PARISC_EXT		0x00020000
-+#define EF_PARISC_LSB		0x00040000
-+#define EF_PARISC_WIDE		0x00080000
-+#define EF_PARISC_NO_KABP	0x00100000
-+
-+#define EF_PARISC_LAZYSWAP	0x00400000
-+#define EF_PARISC_ARCH		0x0000ffff
-+
-+
-+
-+#define EFA_PARISC_1_0		    0x020b
-+#define EFA_PARISC_1_1		    0x0210
-+#define EFA_PARISC_2_0		    0x0214
-+
-+
-+
-+#define SHN_PARISC_ANSI_COMMON	0xff00
-+
-+#define SHN_PARISC_HUGE_COMMON	0xff01
-+
-+
-+
-+#define SHT_PARISC_EXT		0x70000000
-+#define SHT_PARISC_UNWIND	0x70000001
-+#define SHT_PARISC_DOC		0x70000002
-+
-+
-+
-+#define SHF_PARISC_SHORT	0x20000000
-+#define SHF_PARISC_HUGE		0x40000000
-+#define SHF_PARISC_SBP		0x80000000
-+
-+
-+
-+#define STT_PARISC_MILLICODE	13
-+
-+#define STT_HP_OPAQUE		(STT_LOOS + 0x1)
-+#define STT_HP_STUB		(STT_LOOS + 0x2)
-+
-+
-+
-+#define R_PARISC_NONE		0
-+#define R_PARISC_DIR32		1
-+#define R_PARISC_DIR21L		2
-+#define R_PARISC_DIR17R		3
-+#define R_PARISC_DIR17F		4
-+#define R_PARISC_DIR14R		6
-+#define R_PARISC_PCREL32	9
-+#define R_PARISC_PCREL21L	10
-+#define R_PARISC_PCREL17R	11
-+#define R_PARISC_PCREL17F	12
-+#define R_PARISC_PCREL14R	14
-+#define R_PARISC_DPREL21L	18
-+#define R_PARISC_DPREL14R	22
-+#define R_PARISC_GPREL21L	26
-+#define R_PARISC_GPREL14R	30
-+#define R_PARISC_LTOFF21L	34
-+#define R_PARISC_LTOFF14R	38
-+#define R_PARISC_SECREL32	41
-+#define R_PARISC_SEGBASE	48
-+#define R_PARISC_SEGREL32	49
-+#define R_PARISC_PLTOFF21L	50
-+#define R_PARISC_PLTOFF14R	54
-+#define R_PARISC_LTOFF_FPTR32	57
-+#define R_PARISC_LTOFF_FPTR21L	58
-+#define R_PARISC_LTOFF_FPTR14R	62
-+#define R_PARISC_FPTR64		64
-+#define R_PARISC_PLABEL32	65
-+#define R_PARISC_PLABEL21L	66
-+#define R_PARISC_PLABEL14R	70
-+#define R_PARISC_PCREL64	72
-+#define R_PARISC_PCREL22F	74
-+#define R_PARISC_PCREL14WR	75
-+#define R_PARISC_PCREL14DR	76
-+#define R_PARISC_PCREL16F	77
-+#define R_PARISC_PCREL16WF	78
-+#define R_PARISC_PCREL16DF	79
-+#define R_PARISC_DIR64		80
-+#define R_PARISC_DIR14WR	83
-+#define R_PARISC_DIR14DR	84
-+#define R_PARISC_DIR16F		85
-+#define R_PARISC_DIR16WF	86
-+#define R_PARISC_DIR16DF	87
-+#define R_PARISC_GPREL64	88
-+#define R_PARISC_GPREL14WR	91
-+#define R_PARISC_GPREL14DR	92
-+#define R_PARISC_GPREL16F	93
-+#define R_PARISC_GPREL16WF	94
-+#define R_PARISC_GPREL16DF	95
-+#define R_PARISC_LTOFF64	96
-+#define R_PARISC_LTOFF14WR	99
-+#define R_PARISC_LTOFF14DR	100
-+#define R_PARISC_LTOFF16F	101
-+#define R_PARISC_LTOFF16WF	102
-+#define R_PARISC_LTOFF16DF	103
-+#define R_PARISC_SECREL64	104
-+#define R_PARISC_SEGREL64	112
-+#define R_PARISC_PLTOFF14WR	115
-+#define R_PARISC_PLTOFF14DR	116
-+#define R_PARISC_PLTOFF16F	117
-+#define R_PARISC_PLTOFF16WF	118
-+#define R_PARISC_PLTOFF16DF	119
-+#define R_PARISC_LTOFF_FPTR64	120
-+#define R_PARISC_LTOFF_FPTR14WR	123
-+#define R_PARISC_LTOFF_FPTR14DR	124
-+#define R_PARISC_LTOFF_FPTR16F	125
-+#define R_PARISC_LTOFF_FPTR16WF	126
-+#define R_PARISC_LTOFF_FPTR16DF	127
-+#define R_PARISC_LORESERVE	128
-+#define R_PARISC_COPY		128
-+#define R_PARISC_IPLT		129
-+#define R_PARISC_EPLT		130
-+#define R_PARISC_TPREL32	153
-+#define R_PARISC_TPREL21L	154
-+#define R_PARISC_TPREL14R	158
-+#define R_PARISC_LTOFF_TP21L	162
-+#define R_PARISC_LTOFF_TP14R	166
-+#define R_PARISC_LTOFF_TP14F	167
-+#define R_PARISC_TPREL64	216
-+#define R_PARISC_TPREL14WR	219
-+#define R_PARISC_TPREL14DR	220
-+#define R_PARISC_TPREL16F	221
-+#define R_PARISC_TPREL16WF	222
-+#define R_PARISC_TPREL16DF	223
-+#define R_PARISC_LTOFF_TP64	224
-+#define R_PARISC_LTOFF_TP14WR	227
-+#define R_PARISC_LTOFF_TP14DR	228
-+#define R_PARISC_LTOFF_TP16F	229
-+#define R_PARISC_LTOFF_TP16WF	230
-+#define R_PARISC_LTOFF_TP16DF	231
-+#define R_PARISC_GNU_VTENTRY	232
-+#define R_PARISC_GNU_VTINHERIT	233
-+#define R_PARISC_TLS_GD21L	234
-+#define R_PARISC_TLS_GD14R	235
-+#define R_PARISC_TLS_GDCALL	236
-+#define R_PARISC_TLS_LDM21L	237
-+#define R_PARISC_TLS_LDM14R	238
-+#define R_PARISC_TLS_LDMCALL	239
-+#define R_PARISC_TLS_LDO21L	240
-+#define R_PARISC_TLS_LDO14R	241
-+#define R_PARISC_TLS_DTPMOD32	242
-+#define R_PARISC_TLS_DTPMOD64	243
-+#define R_PARISC_TLS_DTPOFF32	244
-+#define R_PARISC_TLS_DTPOFF64	245
-+#define R_PARISC_TLS_LE21L	R_PARISC_TPREL21L
-+#define R_PARISC_TLS_LE14R	R_PARISC_TPREL14R
-+#define R_PARISC_TLS_IE21L	R_PARISC_LTOFF_TP21L
-+#define R_PARISC_TLS_IE14R	R_PARISC_LTOFF_TP14R
-+#define R_PARISC_TLS_TPREL32	R_PARISC_TPREL32
-+#define R_PARISC_TLS_TPREL64	R_PARISC_TPREL64
-+#define R_PARISC_HIRESERVE	255
-+
-+
-+
-+#define PT_HP_TLS		(PT_LOOS + 0x0)
-+#define PT_HP_CORE_NONE		(PT_LOOS + 0x1)
-+#define PT_HP_CORE_VERSION	(PT_LOOS + 0x2)
-+#define PT_HP_CORE_KERNEL	(PT_LOOS + 0x3)
-+#define PT_HP_CORE_COMM		(PT_LOOS + 0x4)
-+#define PT_HP_CORE_PROC		(PT_LOOS + 0x5)
-+#define PT_HP_CORE_LOADABLE	(PT_LOOS + 0x6)
-+#define PT_HP_CORE_STACK	(PT_LOOS + 0x7)
-+#define PT_HP_CORE_SHM		(PT_LOOS + 0x8)
-+#define PT_HP_CORE_MMF		(PT_LOOS + 0x9)
-+#define PT_HP_PARALLEL		(PT_LOOS + 0x10)
-+#define PT_HP_FASTBIND		(PT_LOOS + 0x11)
-+#define PT_HP_OPT_ANNOT		(PT_LOOS + 0x12)
-+#define PT_HP_HSL_ANNOT		(PT_LOOS + 0x13)
-+#define PT_HP_STACK		(PT_LOOS + 0x14)
-+
-+#define PT_PARISC_ARCHEXT	0x70000000
-+#define PT_PARISC_UNWIND	0x70000001
-+
-+
-+
-+#define PF_PARISC_SBP		0x08000000
-+
-+#define PF_HP_PAGE_SIZE		0x00100000
-+#define PF_HP_FAR_SHARED	0x00200000
-+#define PF_HP_NEAR_SHARED	0x00400000
-+#define PF_HP_CODE		0x01000000
-+#define PF_HP_MODIFY		0x02000000
-+#define PF_HP_LAZYSWAP		0x04000000
-+#define PF_HP_SBP		0x08000000
-+
-+
-+
-+
-+
-+
-+#define EF_ALPHA_32BIT		1
-+#define EF_ALPHA_CANRELAX	2
-+
-+
-+
-+
-+#define SHT_ALPHA_DEBUG		0x70000001
-+#define SHT_ALPHA_REGINFO	0x70000002
-+
-+
-+
-+#define SHF_ALPHA_GPREL		0x10000000
-+
-+
-+#define STO_ALPHA_NOPV		0x80
-+#define STO_ALPHA_STD_GPLOAD	0x88
-+
-+
-+
-+#define R_ALPHA_NONE		0
-+#define R_ALPHA_REFLONG		1
-+#define R_ALPHA_REFQUAD		2
-+#define R_ALPHA_GPREL32		3
-+#define R_ALPHA_LITERAL		4
-+#define R_ALPHA_LITUSE		5
-+#define R_ALPHA_GPDISP		6
-+#define R_ALPHA_BRADDR		7
-+#define R_ALPHA_HINT		8
-+#define R_ALPHA_SREL16		9
-+#define R_ALPHA_SREL32		10
-+#define R_ALPHA_SREL64		11
-+#define R_ALPHA_GPRELHIGH	17
-+#define R_ALPHA_GPRELLOW	18
-+#define R_ALPHA_GPREL16		19
-+#define R_ALPHA_COPY		24
-+#define R_ALPHA_GLOB_DAT	25
-+#define R_ALPHA_JMP_SLOT	26
-+#define R_ALPHA_RELATIVE	27
-+#define R_ALPHA_TLS_GD_HI	28
-+#define R_ALPHA_TLSGD		29
-+#define R_ALPHA_TLS_LDM		30
-+#define R_ALPHA_DTPMOD64	31
-+#define R_ALPHA_GOTDTPREL	32
-+#define R_ALPHA_DTPREL64	33
-+#define R_ALPHA_DTPRELHI	34
-+#define R_ALPHA_DTPRELLO	35
-+#define R_ALPHA_DTPREL16	36
-+#define R_ALPHA_GOTTPREL	37
-+#define R_ALPHA_TPREL64		38
-+#define R_ALPHA_TPRELHI		39
-+#define R_ALPHA_TPRELLO		40
-+#define R_ALPHA_TPREL16		41
-+
-+#define R_ALPHA_NUM		46
-+
-+
-+#define LITUSE_ALPHA_ADDR	0
-+#define LITUSE_ALPHA_BASE	1
-+#define LITUSE_ALPHA_BYTOFF	2
-+#define LITUSE_ALPHA_JSR	3
-+#define LITUSE_ALPHA_TLS_GD	4
-+#define LITUSE_ALPHA_TLS_LDM	5
-+
-+
-+#define DT_ALPHA_PLTRO		(DT_LOPROC + 0)
-+#define DT_ALPHA_NUM		1
-+
-+
-+
-+
-+#define EF_PPC_EMB		0x80000000
-+
-+
-+#define EF_PPC_RELOCATABLE	0x00010000
-+#define EF_PPC_RELOCATABLE_LIB	0x00008000
-+
-+
-+
-+#define R_PPC_NONE		0
-+#define R_PPC_ADDR32		1
-+#define R_PPC_ADDR24		2
-+#define R_PPC_ADDR16		3
-+#define R_PPC_ADDR16_LO		4
-+#define R_PPC_ADDR16_HI		5
-+#define R_PPC_ADDR16_HA		6
-+#define R_PPC_ADDR14		7
-+#define R_PPC_ADDR14_BRTAKEN	8
-+#define R_PPC_ADDR14_BRNTAKEN	9
-+#define R_PPC_REL24		10
-+#define R_PPC_REL14		11
-+#define R_PPC_REL14_BRTAKEN	12
-+#define R_PPC_REL14_BRNTAKEN	13
-+#define R_PPC_GOT16		14
-+#define R_PPC_GOT16_LO		15
-+#define R_PPC_GOT16_HI		16
-+#define R_PPC_GOT16_HA		17
-+#define R_PPC_PLTREL24		18
-+#define R_PPC_COPY		19
-+#define R_PPC_GLOB_DAT		20
-+#define R_PPC_JMP_SLOT		21
-+#define R_PPC_RELATIVE		22
-+#define R_PPC_LOCAL24PC		23
-+#define R_PPC_UADDR32		24
-+#define R_PPC_UADDR16		25
-+#define R_PPC_REL32		26
-+#define R_PPC_PLT32		27
-+#define R_PPC_PLTREL32		28
-+#define R_PPC_PLT16_LO		29
-+#define R_PPC_PLT16_HI		30
-+#define R_PPC_PLT16_HA		31
-+#define R_PPC_SDAREL16		32
-+#define R_PPC_SECTOFF		33
-+#define R_PPC_SECTOFF_LO	34
-+#define R_PPC_SECTOFF_HI	35
-+#define R_PPC_SECTOFF_HA	36
-+
-+
-+#define R_PPC_TLS		67
-+#define R_PPC_DTPMOD32		68
-+#define R_PPC_TPREL16		69
-+#define R_PPC_TPREL16_LO	70
-+#define R_PPC_TPREL16_HI	71
-+#define R_PPC_TPREL16_HA	72
-+#define R_PPC_TPREL32		73
-+#define R_PPC_DTPREL16		74
-+#define R_PPC_DTPREL16_LO	75
-+#define R_PPC_DTPREL16_HI	76
-+#define R_PPC_DTPREL16_HA	77
-+#define R_PPC_DTPREL32		78
-+#define R_PPC_GOT_TLSGD16	79
-+#define R_PPC_GOT_TLSGD16_LO	80
-+#define R_PPC_GOT_TLSGD16_HI	81
-+#define R_PPC_GOT_TLSGD16_HA	82
-+#define R_PPC_GOT_TLSLD16	83
-+#define R_PPC_GOT_TLSLD16_LO	84
-+#define R_PPC_GOT_TLSLD16_HI	85
-+#define R_PPC_GOT_TLSLD16_HA	86
-+#define R_PPC_GOT_TPREL16	87
-+#define R_PPC_GOT_TPREL16_LO	88
-+#define R_PPC_GOT_TPREL16_HI	89
-+#define R_PPC_GOT_TPREL16_HA	90
-+#define R_PPC_GOT_DTPREL16	91
-+#define R_PPC_GOT_DTPREL16_LO	92
-+#define R_PPC_GOT_DTPREL16_HI	93
-+#define R_PPC_GOT_DTPREL16_HA	94
-+
-+
-+
-+#define R_PPC_EMB_NADDR32	101
-+#define R_PPC_EMB_NADDR16	102
-+#define R_PPC_EMB_NADDR16_LO	103
-+#define R_PPC_EMB_NADDR16_HI	104
-+#define R_PPC_EMB_NADDR16_HA	105
-+#define R_PPC_EMB_SDAI16	106
-+#define R_PPC_EMB_SDA2I16	107
-+#define R_PPC_EMB_SDA2REL	108
-+#define R_PPC_EMB_SDA21		109
-+#define R_PPC_EMB_MRKREF	110
-+#define R_PPC_EMB_RELSEC16	111
-+#define R_PPC_EMB_RELST_LO	112
-+#define R_PPC_EMB_RELST_HI	113
-+#define R_PPC_EMB_RELST_HA	114
-+#define R_PPC_EMB_BIT_FLD	115
-+#define R_PPC_EMB_RELSDA	116
-+
-+
-+#define R_PPC_DIAB_SDA21_LO	180
-+#define R_PPC_DIAB_SDA21_HI	181
-+#define R_PPC_DIAB_SDA21_HA	182
-+#define R_PPC_DIAB_RELSDA_LO	183
-+#define R_PPC_DIAB_RELSDA_HI	184
-+#define R_PPC_DIAB_RELSDA_HA	185
-+
-+
-+#define R_PPC_IRELATIVE		248
-+
-+
-+#define R_PPC_REL16		249
-+#define R_PPC_REL16_LO		250
-+#define R_PPC_REL16_HI		251
-+#define R_PPC_REL16_HA		252
-+
-+
-+
-+#define R_PPC_TOC16		255
-+
-+
-+#define DT_PPC_GOT		(DT_LOPROC + 0)
-+#define DT_PPC_NUM		1
-+
-+
-+#define R_PPC64_NONE		R_PPC_NONE
-+#define R_PPC64_ADDR32		R_PPC_ADDR32
-+#define R_PPC64_ADDR24		R_PPC_ADDR24
-+#define R_PPC64_ADDR16		R_PPC_ADDR16
-+#define R_PPC64_ADDR16_LO	R_PPC_ADDR16_LO
-+#define R_PPC64_ADDR16_HI	R_PPC_ADDR16_HI
-+#define R_PPC64_ADDR16_HA	R_PPC_ADDR16_HA
-+#define R_PPC64_ADDR14		R_PPC_ADDR14
-+#define R_PPC64_ADDR14_BRTAKEN	R_PPC_ADDR14_BRTAKEN
-+#define R_PPC64_ADDR14_BRNTAKEN	R_PPC_ADDR14_BRNTAKEN
-+#define R_PPC64_REL24		R_PPC_REL24
-+#define R_PPC64_REL14		R_PPC_REL14
-+#define R_PPC64_REL14_BRTAKEN	R_PPC_REL14_BRTAKEN
-+#define R_PPC64_REL14_BRNTAKEN	R_PPC_REL14_BRNTAKEN
-+#define R_PPC64_GOT16		R_PPC_GOT16
-+#define R_PPC64_GOT16_LO	R_PPC_GOT16_LO
-+#define R_PPC64_GOT16_HI	R_PPC_GOT16_HI
-+#define R_PPC64_GOT16_HA	R_PPC_GOT16_HA
-+
-+#define R_PPC64_COPY		R_PPC_COPY
-+#define R_PPC64_GLOB_DAT	R_PPC_GLOB_DAT
-+#define R_PPC64_JMP_SLOT	R_PPC_JMP_SLOT
-+#define R_PPC64_RELATIVE	R_PPC_RELATIVE
-+
-+#define R_PPC64_UADDR32		R_PPC_UADDR32
-+#define R_PPC64_UADDR16		R_PPC_UADDR16
-+#define R_PPC64_REL32		R_PPC_REL32
-+#define R_PPC64_PLT32		R_PPC_PLT32
-+#define R_PPC64_PLTREL32	R_PPC_PLTREL32
-+#define R_PPC64_PLT16_LO	R_PPC_PLT16_LO
-+#define R_PPC64_PLT16_HI	R_PPC_PLT16_HI
-+#define R_PPC64_PLT16_HA	R_PPC_PLT16_HA
-+
-+#define R_PPC64_SECTOFF		R_PPC_SECTOFF
-+#define R_PPC64_SECTOFF_LO	R_PPC_SECTOFF_LO
-+#define R_PPC64_SECTOFF_HI	R_PPC_SECTOFF_HI
-+#define R_PPC64_SECTOFF_HA	R_PPC_SECTOFF_HA
-+#define R_PPC64_ADDR30		37
-+#define R_PPC64_ADDR64		38
-+#define R_PPC64_ADDR16_HIGHER	39
-+#define R_PPC64_ADDR16_HIGHERA	40
-+#define R_PPC64_ADDR16_HIGHEST	41
-+#define R_PPC64_ADDR16_HIGHESTA	42
-+#define R_PPC64_UADDR64		43
-+#define R_PPC64_REL64		44
-+#define R_PPC64_PLT64		45
-+#define R_PPC64_PLTREL64	46
-+#define R_PPC64_TOC16		47
-+#define R_PPC64_TOC16_LO	48
-+#define R_PPC64_TOC16_HI	49
-+#define R_PPC64_TOC16_HA	50
-+#define R_PPC64_TOC		51
-+#define R_PPC64_PLTGOT16	52
-+#define R_PPC64_PLTGOT16_LO	53
-+#define R_PPC64_PLTGOT16_HI	54
-+#define R_PPC64_PLTGOT16_HA	55
-+
-+#define R_PPC64_ADDR16_DS	56
-+#define R_PPC64_ADDR16_LO_DS	57
-+#define R_PPC64_GOT16_DS	58
-+#define R_PPC64_GOT16_LO_DS	59
-+#define R_PPC64_PLT16_LO_DS	60
-+#define R_PPC64_SECTOFF_DS	61
-+#define R_PPC64_SECTOFF_LO_DS	62
-+#define R_PPC64_TOC16_DS	63
-+#define R_PPC64_TOC16_LO_DS	64
-+#define R_PPC64_PLTGOT16_DS	65
-+#define R_PPC64_PLTGOT16_LO_DS	66
-+
-+
-+#define R_PPC64_TLS		67
-+#define R_PPC64_DTPMOD64	68
-+#define R_PPC64_TPREL16		69
-+#define R_PPC64_TPREL16_LO	70
-+#define R_PPC64_TPREL16_HI	71
-+#define R_PPC64_TPREL16_HA	72
-+#define R_PPC64_TPREL64		73
-+#define R_PPC64_DTPREL16	74
-+#define R_PPC64_DTPREL16_LO	75
-+#define R_PPC64_DTPREL16_HI	76
-+#define R_PPC64_DTPREL16_HA	77
-+#define R_PPC64_DTPREL64	78
-+#define R_PPC64_GOT_TLSGD16	79
-+#define R_PPC64_GOT_TLSGD16_LO	80
-+#define R_PPC64_GOT_TLSGD16_HI	81
-+#define R_PPC64_GOT_TLSGD16_HA	82
-+#define R_PPC64_GOT_TLSLD16	83
-+#define R_PPC64_GOT_TLSLD16_LO	84
-+#define R_PPC64_GOT_TLSLD16_HI	85
-+#define R_PPC64_GOT_TLSLD16_HA	86
-+#define R_PPC64_GOT_TPREL16_DS	87
-+#define R_PPC64_GOT_TPREL16_LO_DS 88
-+#define R_PPC64_GOT_TPREL16_HI	89
-+#define R_PPC64_GOT_TPREL16_HA	90
-+#define R_PPC64_GOT_DTPREL16_DS	91
-+#define R_PPC64_GOT_DTPREL16_LO_DS 92
-+#define R_PPC64_GOT_DTPREL16_HI	93
-+#define R_PPC64_GOT_DTPREL16_HA	94
-+#define R_PPC64_TPREL16_DS	95
-+#define R_PPC64_TPREL16_LO_DS	96
-+#define R_PPC64_TPREL16_HIGHER	97
-+#define R_PPC64_TPREL16_HIGHERA	98
-+#define R_PPC64_TPREL16_HIGHEST	99
-+#define R_PPC64_TPREL16_HIGHESTA 100
-+#define R_PPC64_DTPREL16_DS	101
-+#define R_PPC64_DTPREL16_LO_DS	102
-+#define R_PPC64_DTPREL16_HIGHER	103
-+#define R_PPC64_DTPREL16_HIGHERA 104
-+#define R_PPC64_DTPREL16_HIGHEST 105
-+#define R_PPC64_DTPREL16_HIGHESTA 106
-+
-+
-+#define R_PPC64_JMP_IREL	247
-+#define R_PPC64_IRELATIVE	248
-+#define R_PPC64_REL16		249
-+#define R_PPC64_REL16_LO	250
-+#define R_PPC64_REL16_HI	251
-+#define R_PPC64_REL16_HA	252
-+
-+
-+#define DT_PPC64_GLINK  (DT_LOPROC + 0)
-+#define DT_PPC64_OPD	(DT_LOPROC + 1)
-+#define DT_PPC64_OPDSZ	(DT_LOPROC + 2)
-+#define DT_PPC64_NUM    3
-+
-+
-+
-+
-+
-+#define EF_ARM_RELEXEC		0x01
-+#define EF_ARM_HASENTRY		0x02
-+#define EF_ARM_INTERWORK	0x04
-+#define EF_ARM_APCS_26		0x08
-+#define EF_ARM_APCS_FLOAT	0x10
-+#define EF_ARM_PIC		0x20
-+#define EF_ARM_ALIGN8		0x40
-+#define EF_ARM_NEW_ABI		0x80
-+#define EF_ARM_OLD_ABI		0x100
-+#define EF_ARM_SOFT_FLOAT	0x200
-+#define EF_ARM_VFP_FLOAT	0x400
-+#define EF_ARM_MAVERICK_FLOAT	0x800
-+
-+#define EF_ARM_ABI_FLOAT_SOFT	0x200
-+#define EF_ARM_ABI_FLOAT_HARD	0x400
-+
-+
-+#define EF_ARM_SYMSARESORTED	0x04
-+#define EF_ARM_DYNSYMSUSESEGIDX	0x08
-+#define EF_ARM_MAPSYMSFIRST	0x10
-+#define EF_ARM_EABIMASK		0XFF000000
-+
-+
-+#define EF_ARM_BE8	    0x00800000
-+#define EF_ARM_LE8	    0x00400000
-+
-+#define EF_ARM_EABI_VERSION(flags)	((flags) & EF_ARM_EABIMASK)
-+#define EF_ARM_EABI_UNKNOWN	0x00000000
-+#define EF_ARM_EABI_VER1	0x01000000
-+#define EF_ARM_EABI_VER2	0x02000000
-+#define EF_ARM_EABI_VER3	0x03000000
-+#define EF_ARM_EABI_VER4	0x04000000
-+#define EF_ARM_EABI_VER5	0x05000000
-+
-+
-+#define STT_ARM_TFUNC		STT_LOPROC
-+#define STT_ARM_16BIT		STT_HIPROC
-+
-+
-+#define SHF_ARM_ENTRYSECT	0x10000000
-+#define SHF_ARM_COMDEF		0x80000000
-+
-+
-+
-+#define PF_ARM_SB		0x10000000
-+
-+#define PF_ARM_PI		0x20000000
-+#define PF_ARM_ABS		0x40000000
-+
-+
-+#define PT_ARM_EXIDX		(PT_LOPROC + 1)
-+
-+
-+#define SHT_ARM_EXIDX		(SHT_LOPROC + 1)
-+#define SHT_ARM_PREEMPTMAP	(SHT_LOPROC + 2)
-+#define SHT_ARM_ATTRIBUTES	(SHT_LOPROC + 3)
-+
-+
-+#define R_AARCH64_NONE            0
-+#define R_AARCH64_ABS64         257
-+#define R_AARCH64_ABS32         258
-+#define R_AARCH64_COPY         1024
-+#define R_AARCH64_GLOB_DAT     1025
-+#define R_AARCH64_JUMP_SLOT    1026
-+#define R_AARCH64_RELATIVE     1027
-+#define R_AARCH64_TLS_DTPMOD64 1028
-+#define R_AARCH64_TLS_DTPREL64 1029
-+#define R_AARCH64_TLS_TPREL64  1030
-+#define R_AARCH64_TLSDESC      1031
-+
-+
-+#define R_ARM_NONE		0
-+#define R_ARM_PC24		1
-+#define R_ARM_ABS32		2
-+#define R_ARM_REL32		3
-+#define R_ARM_PC13		4
-+#define R_ARM_ABS16		5
-+#define R_ARM_ABS12		6
-+#define R_ARM_THM_ABS5		7
-+#define R_ARM_ABS8		8
-+#define R_ARM_SBREL32		9
-+#define R_ARM_THM_PC22		10
-+#define R_ARM_THM_PC8		11
-+#define R_ARM_AMP_VCALL9	12
-+#define R_ARM_TLS_DESC		13
-+#define R_ARM_THM_SWI8		14
-+#define R_ARM_XPC25		15
-+#define R_ARM_THM_XPC22		16
-+#define R_ARM_TLS_DTPMOD32	17
-+#define R_ARM_TLS_DTPOFF32	18
-+#define R_ARM_TLS_TPOFF32	19
-+#define R_ARM_COPY		20
-+#define R_ARM_GLOB_DAT		21
-+#define R_ARM_JUMP_SLOT		22
-+#define R_ARM_RELATIVE		23
-+#define R_ARM_GOTOFF		24
-+#define R_ARM_GOTPC		25
-+#define R_ARM_GOT32		26
-+#define R_ARM_PLT32		27
-+#define R_ARM_CALL		28
-+#define R_ARM_JUMP24		29
-+#define R_ARM_THM_JUMP24	30
-+#define R_ARM_BASE_ABS		31
-+#define R_ARM_ALU_PCREL_7_0	32
-+#define R_ARM_ALU_PCREL_15_8	33
-+#define R_ARM_ALU_PCREL_23_15	34
-+#define R_ARM_LDR_SBREL_11_0	35
-+#define R_ARM_ALU_SBREL_19_12	36
-+#define R_ARM_ALU_SBREL_27_20	37
-+#define R_ARM_TARGET1		38
-+#define R_ARM_SBREL31		39
-+#define R_ARM_V4BX		40
-+#define R_ARM_TARGET2		41
-+#define R_ARM_PREL31		42
-+#define R_ARM_MOVW_ABS_NC	43
-+#define R_ARM_MOVT_ABS		44
-+#define R_ARM_MOVW_PREL_NC	45
-+#define R_ARM_MOVT_PREL		46
-+#define R_ARM_THM_MOVW_ABS_NC	47
-+#define R_ARM_THM_MOVT_ABS	48
-+#define R_ARM_THM_MOVW_PREL_NC	49
-+#define R_ARM_THM_MOVT_PREL	50
-+#define R_ARM_THM_JUMP19	51
-+#define R_ARM_THM_JUMP6		52
-+#define R_ARM_THM_ALU_PREL_11_0	53
-+#define R_ARM_THM_PC12		54
-+#define R_ARM_ABS32_NOI		55
-+#define R_ARM_REL32_NOI		56
-+#define R_ARM_ALU_PC_G0_NC	57
-+#define R_ARM_ALU_PC_G0		58
-+#define R_ARM_ALU_PC_G1_NC	59
-+#define R_ARM_ALU_PC_G1		60
-+#define R_ARM_ALU_PC_G2		61
-+#define R_ARM_LDR_PC_G1		62
-+#define R_ARM_LDR_PC_G2		63
-+#define R_ARM_LDRS_PC_G0	64
-+#define R_ARM_LDRS_PC_G1	65
-+#define R_ARM_LDRS_PC_G2	66
-+#define R_ARM_LDC_PC_G0		67
-+#define R_ARM_LDC_PC_G1		68
-+#define R_ARM_LDC_PC_G2		69
-+#define R_ARM_ALU_SB_G0_NC	70
-+#define R_ARM_ALU_SB_G0		71
-+#define R_ARM_ALU_SB_G1_NC	72
-+#define R_ARM_ALU_SB_G1		73
-+#define R_ARM_ALU_SB_G2		74
-+#define R_ARM_LDR_SB_G0		75
-+#define R_ARM_LDR_SB_G1		76
-+#define R_ARM_LDR_SB_G2		77
-+#define R_ARM_LDRS_SB_G0	78
-+#define R_ARM_LDRS_SB_G1	79
-+#define R_ARM_LDRS_SB_G2	80
-+#define R_ARM_LDC_SB_G0		81
-+#define R_ARM_LDC_SB_G1		82
-+#define R_ARM_LDC_SB_G2		83
-+#define R_ARM_MOVW_BREL_NC	84
-+#define R_ARM_MOVT_BREL		85
-+#define R_ARM_MOVW_BREL		86
-+#define R_ARM_THM_MOVW_BREL_NC	87
-+#define R_ARM_THM_MOVT_BREL	88
-+#define R_ARM_THM_MOVW_BREL	89
-+#define R_ARM_TLS_GOTDESC	90
-+#define R_ARM_TLS_CALL		91
-+#define R_ARM_TLS_DESCSEQ	92
-+#define R_ARM_THM_TLS_CALL	93
-+#define R_ARM_PLT32_ABS		94
-+#define R_ARM_GOT_ABS		95
-+#define R_ARM_GOT_PREL		96
-+#define R_ARM_GOT_BREL12	97
-+#define R_ARM_GOTOFF12		98
-+#define R_ARM_GOTRELAX		99
-+#define R_ARM_GNU_VTENTRY	100
-+#define R_ARM_GNU_VTINHERIT	101
-+#define R_ARM_THM_PC11		102
-+#define R_ARM_THM_PC9		103
-+#define R_ARM_TLS_GD32		104
-+
-+#define R_ARM_TLS_LDM32		105
-+
-+#define R_ARM_TLS_LDO32		106
-+
-+#define R_ARM_TLS_IE32		107
-+
-+#define R_ARM_TLS_LE32		108
-+#define R_ARM_TLS_LDO12		109
-+#define R_ARM_TLS_LE12		110
-+#define R_ARM_TLS_IE12GP	111
-+#define R_ARM_ME_TOO		128
-+#define R_ARM_THM_TLS_DESCSEQ	129
-+#define R_ARM_THM_TLS_DESCSEQ16	129
-+#define R_ARM_THM_TLS_DESCSEQ32	130
-+#define R_ARM_THM_GOT_BREL12	131
-+#define R_ARM_IRELATIVE		160
-+#define R_ARM_RXPC25		249
-+#define R_ARM_RSBREL32		250
-+#define R_ARM_THM_RPC22		251
-+#define R_ARM_RREL32		252
-+#define R_ARM_RABS22		253
-+#define R_ARM_RPC24		254
-+#define R_ARM_RBASE		255
-+
-+#define R_ARM_NUM		256
-+
-+
-+
-+
-+#define EF_IA_64_MASKOS		0x0000000f
-+#define EF_IA_64_ABI64		0x00000010
-+#define EF_IA_64_ARCH		0xff000000
-+
-+
-+#define PT_IA_64_ARCHEXT	(PT_LOPROC + 0)
-+#define PT_IA_64_UNWIND		(PT_LOPROC + 1)
-+#define PT_IA_64_HP_OPT_ANOT	(PT_LOOS + 0x12)
-+#define PT_IA_64_HP_HSL_ANOT	(PT_LOOS + 0x13)
-+#define PT_IA_64_HP_STACK	(PT_LOOS + 0x14)
-+
-+
-+#define PF_IA_64_NORECOV	0x80000000
-+
-+
-+#define SHT_IA_64_EXT		(SHT_LOPROC + 0)
-+#define SHT_IA_64_UNWIND	(SHT_LOPROC + 1)
-+
-+
-+#define SHF_IA_64_SHORT		0x10000000
-+#define SHF_IA_64_NORECOV	0x20000000
-+
-+
-+#define DT_IA_64_PLT_RESERVE	(DT_LOPROC + 0)
-+#define DT_IA_64_NUM		1
-+
-+
-+#define R_IA64_NONE		0x00
-+#define R_IA64_IMM14		0x21
-+#define R_IA64_IMM22		0x22
-+#define R_IA64_IMM64		0x23
-+#define R_IA64_DIR32MSB		0x24
-+#define R_IA64_DIR32LSB		0x25
-+#define R_IA64_DIR64MSB		0x26
-+#define R_IA64_DIR64LSB		0x27
-+#define R_IA64_GPREL22		0x2a
-+#define R_IA64_GPREL64I		0x2b
-+#define R_IA64_GPREL32MSB	0x2c
-+#define R_IA64_GPREL32LSB	0x2d
-+#define R_IA64_GPREL64MSB	0x2e
-+#define R_IA64_GPREL64LSB	0x2f
-+#define R_IA64_LTOFF22		0x32
-+#define R_IA64_LTOFF64I		0x33
-+#define R_IA64_PLTOFF22		0x3a
-+#define R_IA64_PLTOFF64I	0x3b
-+#define R_IA64_PLTOFF64MSB	0x3e
-+#define R_IA64_PLTOFF64LSB	0x3f
-+#define R_IA64_FPTR64I		0x43
-+#define R_IA64_FPTR32MSB	0x44
-+#define R_IA64_FPTR32LSB	0x45
-+#define R_IA64_FPTR64MSB	0x46
-+#define R_IA64_FPTR64LSB	0x47
-+#define R_IA64_PCREL60B		0x48
-+#define R_IA64_PCREL21B		0x49
-+#define R_IA64_PCREL21M		0x4a
-+#define R_IA64_PCREL21F		0x4b
-+#define R_IA64_PCREL32MSB	0x4c
-+#define R_IA64_PCREL32LSB	0x4d
-+#define R_IA64_PCREL64MSB	0x4e
-+#define R_IA64_PCREL64LSB	0x4f
-+#define R_IA64_LTOFF_FPTR22	0x52
-+#define R_IA64_LTOFF_FPTR64I	0x53
-+#define R_IA64_LTOFF_FPTR32MSB	0x54
-+#define R_IA64_LTOFF_FPTR32LSB	0x55
-+#define R_IA64_LTOFF_FPTR64MSB	0x56
-+#define R_IA64_LTOFF_FPTR64LSB	0x57
-+#define R_IA64_SEGREL32MSB	0x5c
-+#define R_IA64_SEGREL32LSB	0x5d
-+#define R_IA64_SEGREL64MSB	0x5e
-+#define R_IA64_SEGREL64LSB	0x5f
-+#define R_IA64_SECREL32MSB	0x64
-+#define R_IA64_SECREL32LSB	0x65
-+#define R_IA64_SECREL64MSB	0x66
-+#define R_IA64_SECREL64LSB	0x67
-+#define R_IA64_REL32MSB		0x6c
-+#define R_IA64_REL32LSB		0x6d
-+#define R_IA64_REL64MSB		0x6e
-+#define R_IA64_REL64LSB		0x6f
-+#define R_IA64_LTV32MSB		0x74
-+#define R_IA64_LTV32LSB		0x75
-+#define R_IA64_LTV64MSB		0x76
-+#define R_IA64_LTV64LSB		0x77
-+#define R_IA64_PCREL21BI	0x79
-+#define R_IA64_PCREL22		0x7a
-+#define R_IA64_PCREL64I		0x7b
-+#define R_IA64_IPLTMSB		0x80
-+#define R_IA64_IPLTLSB		0x81
-+#define R_IA64_COPY		0x84
-+#define R_IA64_SUB		0x85
-+#define R_IA64_LTOFF22X		0x86
-+#define R_IA64_LDXMOV		0x87
-+#define R_IA64_TPREL14		0x91
-+#define R_IA64_TPREL22		0x92
-+#define R_IA64_TPREL64I		0x93
-+#define R_IA64_TPREL64MSB	0x96
-+#define R_IA64_TPREL64LSB	0x97
-+#define R_IA64_LTOFF_TPREL22	0x9a
-+#define R_IA64_DTPMOD64MSB	0xa6
-+#define R_IA64_DTPMOD64LSB	0xa7
-+#define R_IA64_LTOFF_DTPMOD22	0xaa
-+#define R_IA64_DTPREL14		0xb1
-+#define R_IA64_DTPREL22		0xb2
-+#define R_IA64_DTPREL64I	0xb3
-+#define R_IA64_DTPREL32MSB	0xb4
-+#define R_IA64_DTPREL32LSB	0xb5
-+#define R_IA64_DTPREL64MSB	0xb6
-+#define R_IA64_DTPREL64LSB	0xb7
-+#define R_IA64_LTOFF_DTPREL22	0xba
-+
-+
-+
-+
-+#define	R_SH_NONE		0
-+#define	R_SH_DIR32		1
-+#define	R_SH_REL32		2
-+#define	R_SH_DIR8WPN		3
-+#define	R_SH_IND12W		4
-+#define	R_SH_DIR8WPL		5
-+#define	R_SH_DIR8WPZ		6
-+#define	R_SH_DIR8BP		7
-+#define	R_SH_DIR8W		8
-+#define	R_SH_DIR8L		9
-+#define	R_SH_SWITCH16		25
-+#define	R_SH_SWITCH32		26
-+#define	R_SH_USES		27
-+#define	R_SH_COUNT		28
-+#define	R_SH_ALIGN		29
-+#define	R_SH_CODE		30
-+#define	R_SH_DATA		31
-+#define	R_SH_LABEL		32
-+#define	R_SH_SWITCH8		33
-+#define	R_SH_GNU_VTINHERIT	34
-+#define	R_SH_GNU_VTENTRY	35
-+#define	R_SH_TLS_GD_32		144
-+#define	R_SH_TLS_LD_32		145
-+#define	R_SH_TLS_LDO_32		146
-+#define	R_SH_TLS_IE_32		147
-+#define	R_SH_TLS_LE_32		148
-+#define	R_SH_TLS_DTPMOD32	149
-+#define	R_SH_TLS_DTPOFF32	150
-+#define	R_SH_TLS_TPOFF32	151
-+#define	R_SH_GOT32		160
-+#define	R_SH_PLT32		161
-+#define	R_SH_COPY		162
-+#define	R_SH_GLOB_DAT		163
-+#define	R_SH_JMP_SLOT		164
-+#define	R_SH_RELATIVE		165
-+#define	R_SH_GOTOFF		166
-+#define	R_SH_GOTPC		167
-+
-+#define	R_SH_NUM		256
-+
-+
-+
-+#define R_390_NONE		0
-+#define R_390_8			1
-+#define R_390_12		2
-+#define R_390_16		3
-+#define R_390_32		4
-+#define R_390_PC32		5
-+#define R_390_GOT12		6
-+#define R_390_GOT32		7
-+#define R_390_PLT32		8
-+#define R_390_COPY		9
-+#define R_390_GLOB_DAT		10
-+#define R_390_JMP_SLOT		11
-+#define R_390_RELATIVE		12
-+#define R_390_GOTOFF32		13
-+#define R_390_GOTPC		14
-+#define R_390_GOT16		15
-+#define R_390_PC16		16
-+#define R_390_PC16DBL		17
-+#define R_390_PLT16DBL		18
-+#define R_390_PC32DBL		19
-+#define R_390_PLT32DBL		20
-+#define R_390_GOTPCDBL		21
-+#define R_390_64		22
-+#define R_390_PC64		23
-+#define R_390_GOT64		24
-+#define R_390_PLT64		25
-+#define R_390_GOTENT		26
-+#define R_390_GOTOFF16		27
-+#define R_390_GOTOFF64		28
-+#define R_390_GOTPLT12		29
-+#define R_390_GOTPLT16		30
-+#define R_390_GOTPLT32		31
-+#define R_390_GOTPLT64		32
-+#define R_390_GOTPLTENT		33
-+#define R_390_PLTOFF16		34
-+#define R_390_PLTOFF32		35
-+#define R_390_PLTOFF64		36
-+#define R_390_TLS_LOAD		37
-+#define R_390_TLS_GDCALL	38
-+
-+#define R_390_TLS_LDCALL	39
-+
-+#define R_390_TLS_GD32		40
-+
-+#define R_390_TLS_GD64		41
-+
-+#define R_390_TLS_GOTIE12	42
-+
-+#define R_390_TLS_GOTIE32	43
-+
-+#define R_390_TLS_GOTIE64	44
-+
-+#define R_390_TLS_LDM32		45
-+
-+#define R_390_TLS_LDM64		46
-+
-+#define R_390_TLS_IE32		47
-+
-+#define R_390_TLS_IE64		48
-+
-+#define R_390_TLS_IEENT		49
-+
-+#define R_390_TLS_LE32		50
-+
-+#define R_390_TLS_LE64		51
-+
-+#define R_390_TLS_LDO32		52
-+
-+#define R_390_TLS_LDO64		53
-+
-+#define R_390_TLS_DTPMOD	54
-+#define R_390_TLS_DTPOFF	55
-+#define R_390_TLS_TPOFF		56
-+
-+#define R_390_20		57
-+#define R_390_GOT20		58
-+#define R_390_GOTPLT20		59
-+#define R_390_TLS_GOTIE20	60
-+
-+
-+#define R_390_NUM		61
-+
-+
-+
-+#define R_CRIS_NONE		0
-+#define R_CRIS_8		1
-+#define R_CRIS_16		2
-+#define R_CRIS_32		3
-+#define R_CRIS_8_PCREL		4
-+#define R_CRIS_16_PCREL		5
-+#define R_CRIS_32_PCREL		6
-+#define R_CRIS_GNU_VTINHERIT	7
-+#define R_CRIS_GNU_VTENTRY	8
-+#define R_CRIS_COPY		9
-+#define R_CRIS_GLOB_DAT		10
-+#define R_CRIS_JUMP_SLOT	11
-+#define R_CRIS_RELATIVE		12
-+#define R_CRIS_16_GOT		13
-+#define R_CRIS_32_GOT		14
-+#define R_CRIS_16_GOTPLT	15
-+#define R_CRIS_32_GOTPLT	16
-+#define R_CRIS_32_GOTREL	17
-+#define R_CRIS_32_PLT_GOTREL	18
-+#define R_CRIS_32_PLT_PCREL	19
-+
-+#define R_CRIS_NUM		20
-+
-+
-+
-+#define R_X86_64_NONE		0
-+#define R_X86_64_64		1
-+#define R_X86_64_PC32		2
-+#define R_X86_64_GOT32		3
-+#define R_X86_64_PLT32		4
-+#define R_X86_64_COPY		5
-+#define R_X86_64_GLOB_DAT	6
-+#define R_X86_64_JUMP_SLOT	7
-+#define R_X86_64_RELATIVE	8
-+#define R_X86_64_GOTPCREL	9
-+
-+#define R_X86_64_32		10
-+#define R_X86_64_32S		11
-+#define R_X86_64_16		12
-+#define R_X86_64_PC16		13
-+#define R_X86_64_8		14
-+#define R_X86_64_PC8		15
-+#define R_X86_64_DTPMOD64	16
-+#define R_X86_64_DTPOFF64	17
-+#define R_X86_64_TPOFF64	18
-+#define R_X86_64_TLSGD		19
-+
-+#define R_X86_64_TLSLD		20
-+
-+#define R_X86_64_DTPOFF32	21
-+#define R_X86_64_GOTTPOFF	22
-+
-+#define R_X86_64_TPOFF32	23
-+#define R_X86_64_PC64		24
-+#define R_X86_64_GOTOFF64	25
-+#define R_X86_64_GOTPC32	26
-+#define R_X86_64_GOT64		27
-+#define R_X86_64_GOTPCREL64	28
-+#define R_X86_64_GOTPC64	29
-+#define R_X86_64_GOTPLT64	30
-+#define R_X86_64_PLTOFF64	31
-+#define R_X86_64_SIZE32		32
-+#define R_X86_64_SIZE64		33
-+
-+#define R_X86_64_GOTPC32_TLSDESC 34
-+#define R_X86_64_TLSDESC_CALL   35
-+
-+#define R_X86_64_TLSDESC        36
-+#define R_X86_64_IRELATIVE	37
-+#define R_X86_64_RELATIVE64	38
-+#define R_X86_64_NUM		39
-+
-+
-+
-+#define R_MN10300_NONE		0
-+#define R_MN10300_32		1
-+#define R_MN10300_16		2
-+#define R_MN10300_8		3
-+#define R_MN10300_PCREL32	4
-+#define R_MN10300_PCREL16	5
-+#define R_MN10300_PCREL8	6
-+#define R_MN10300_GNU_VTINHERIT	7
-+#define R_MN10300_GNU_VTENTRY	8
-+#define R_MN10300_24		9
-+#define R_MN10300_GOTPC32	10
-+#define R_MN10300_GOTPC16	11
-+#define R_MN10300_GOTOFF32	12
-+#define R_MN10300_GOTOFF24	13
-+#define R_MN10300_GOTOFF16	14
-+#define R_MN10300_PLT32		15
-+#define R_MN10300_PLT16		16
-+#define R_MN10300_GOT32		17
-+#define R_MN10300_GOT24		18
-+#define R_MN10300_GOT16		19
-+#define R_MN10300_COPY		20
-+#define R_MN10300_GLOB_DAT	21
-+#define R_MN10300_JMP_SLOT	22
-+#define R_MN10300_RELATIVE	23
-+
-+#define R_MN10300_NUM		24
-+
-+
-+
-+#define R_M32R_NONE		0
-+#define R_M32R_16		1
-+#define R_M32R_32		2
-+#define R_M32R_24		3
-+#define R_M32R_10_PCREL		4
-+#define R_M32R_18_PCREL		5
-+#define R_M32R_26_PCREL		6
-+#define R_M32R_HI16_ULO		7
-+#define R_M32R_HI16_SLO		8
-+#define R_M32R_LO16		9
-+#define R_M32R_SDA16		10
-+#define R_M32R_GNU_VTINHERIT	11
-+#define R_M32R_GNU_VTENTRY	12
-+
-+#define R_M32R_16_RELA		33
-+#define R_M32R_32_RELA		34
-+#define R_M32R_24_RELA		35
-+#define R_M32R_10_PCREL_RELA	36
-+#define R_M32R_18_PCREL_RELA	37
-+#define R_M32R_26_PCREL_RELA	38
-+#define R_M32R_HI16_ULO_RELA	39
-+#define R_M32R_HI16_SLO_RELA	40
-+#define R_M32R_LO16_RELA	41
-+#define R_M32R_SDA16_RELA	42
-+#define R_M32R_RELA_GNU_VTINHERIT	43
-+#define R_M32R_RELA_GNU_VTENTRY	44
-+#define R_M32R_REL32		45
-+
-+#define R_M32R_GOT24		48
-+#define R_M32R_26_PLTREL	49
-+#define R_M32R_COPY		50
-+#define R_M32R_GLOB_DAT		51
-+#define R_M32R_JMP_SLOT		52
-+#define R_M32R_RELATIVE		53
-+#define R_M32R_GOTOFF		54
-+#define R_M32R_GOTPC24		55
-+#define R_M32R_GOT16_HI_ULO	56
-+
-+#define R_M32R_GOT16_HI_SLO	57
-+
-+#define R_M32R_GOT16_LO		58
-+#define R_M32R_GOTPC_HI_ULO	59
-+
-+#define R_M32R_GOTPC_HI_SLO	60
-+
-+#define R_M32R_GOTPC_LO		61
-+
-+#define R_M32R_GOTOFF_HI_ULO	62
-+
-+#define R_M32R_GOTOFF_HI_SLO	63
-+
-+#define R_M32R_GOTOFF_LO	64
-+#define R_M32R_NUM		256
-+
-+#define R_MICROBLAZE_NONE 0
-+#define R_MICROBLAZE_32 1
-+#define R_MICROBLAZE_32_PCREL 2
-+#define R_MICROBLAZE_64_PCREL 3
-+#define R_MICROBLAZE_32_PCREL_LO 4
-+#define R_MICROBLAZE_64 5
-+#define R_MICROBLAZE_32_LO 6
-+#define R_MICROBLAZE_SRO32 7
-+#define R_MICROBLAZE_SRW32 8
-+#define R_MICROBLAZE_64_NONE 9
-+#define R_MICROBLAZE_32_SYM_OP_SYM 10
-+#define R_MICROBLAZE_GNU_VTINHERIT 11
-+#define R_MICROBLAZE_GNU_VTENTRY 12
-+#define R_MICROBLAZE_GOTPC_64 13
-+#define R_MICROBLAZE_GOT_64 14
-+#define R_MICROBLAZE_PLT_64 15
-+#define R_MICROBLAZE_REL 16
-+#define R_MICROBLAZE_JUMP_SLOT 17
-+#define R_MICROBLAZE_GLOB_DAT 18
-+#define R_MICROBLAZE_GOTOFF_64 19
-+#define R_MICROBLAZE_GOTOFF_32 20
-+#define R_MICROBLAZE_COPY 21
-+#define R_MICROBLAZE_TLS 22
-+#define R_MICROBLAZE_TLSGD 23
-+#define R_MICROBLAZE_TLSLD 24
-+#define R_MICROBLAZE_TLSDTPMOD32 25
-+#define R_MICROBLAZE_TLSDTPREL32 26
-+#define R_MICROBLAZE_TLSDTPREL64 27
-+#define R_MICROBLAZE_TLSGOTTPREL32 28
-+#define R_MICROBLAZE_TLSTPREL32	 29
-+
-+#ifdef __cplusplus
-+}
-+#endif
-+
-+
-+#endif

+ 0 - 25
target/linux/patches/5.19.12/startup.patch

@@ -1,25 +0,0 @@
-diff -Nur linux-5.10.17.orig/init/initramfs.c linux-5.10.17/init/initramfs.c
---- linux-5.10.17.orig/init/initramfs.c	2021-02-17 11:02:30.000000000 +0100
-+++ linux-5.10.17/init/initramfs.c	2021-02-23 13:27:40.449467155 +0100
-@@ -636,6 +636,9 @@
- 	initrd_start = 0;
- 	initrd_end = 0;
- 
-+#ifdef CONFIG_DEVTMPFS_MOUNT
-+	devtmpfs_mount();
-+#endif
- 	flush_delayed_fput();
- 	return 0;
- }
-diff -Nur linux-5.10.17.orig/init/main.c linux-5.10.17/init/main.c
---- linux-5.10.17.orig/init/main.c	2021-02-17 11:02:30.000000000 +0100
-+++ linux-5.10.17/init/main.c	2021-02-23 13:39:32.238650450 +0100
-@@ -1483,6 +1483,8 @@
- 		pr_err("Warning: unable to open an initial console.\n");
- 		return;
- 	}
-+	printk(KERN_WARNING "Starting Linux (built with OpenADK).\n");
-+
- 	init_dup(file);
- 	init_dup(file);
- 	init_dup(file);

+ 23 - 0
target/linux/patches/stable-4.4-rockpi4/serial-baudrate.patch

@@ -0,0 +1,23 @@
+diff -Nur linux-stable-4.4-rockpi4.orig/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4.dtsi linux-stable-4.4-rockpi4/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4.dtsi
+--- linux-stable-4.4-rockpi4.orig/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4.dtsi	2022-12-09 18:12:00.000000000 +0100
++++ linux-stable-4.4-rockpi4/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4.dtsi	2022-12-09 22:12:59.489123950 +0100
+@@ -58,7 +58,7 @@
+ 		rockchip,signal-irq = <182>;
+ 		rockchip,wake-irq = <0>;
+ 		rockchip,irq-mode-enable = <1>;  /* If enable uart uses irq instead of fiq */
+-		rockchip,baudrate = <1500000>;  /* Only 115200 and 1500000 */
++		rockchip,baudrate = <115200>;  /* Only 115200 and 1500000 */
+ 		pinctrl-names = "default";
+ 		pinctrl-0 = <&uart2c_xfer>;
+ 	};
+diff -Nur linux-stable-4.4-rockpi4.orig/scripts/dtc/dtc-lexer.lex.c_shipped linux-stable-4.4-rockpi4/scripts/dtc/dtc-lexer.lex.c_shipped
+--- linux-stable-4.4-rockpi4.orig/scripts/dtc/dtc-lexer.lex.c_shipped	2022-12-09 18:12:07.000000000 +0100
++++ linux-stable-4.4-rockpi4/scripts/dtc/dtc-lexer.lex.c_shipped	2022-12-09 22:11:26.298627242 +0100
+@@ -631,7 +631,6 @@
+ #include "srcpos.h"
+ #include "dtc-parser.tab.h"
+ 
+-YYLTYPE yylloc;
+ extern bool treesource_error;
+ 
+ /* CAUTION: this will stop working if we ever use yyless() or yyunput() */