Initial commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			
		
			
				
	
				Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			
		
			
				
	
				Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			
		
			
				
	
				Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			
		
			
				
	
				Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			
		
			
				
	
				Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			This commit is contained in:
		
							
								
								
									
										29
									
								
								target/linux/ixp4xx/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								target/linux/ixp4xx/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| # SPDX-License-Identifier: GPL-2.0-only | ||||
| # | ||||
| # Copyright (C) 2006-2023 OpenWrt.org | ||||
|  | ||||
| include $(TOPDIR)/rules.mk | ||||
|  | ||||
| ARCH:=armeb | ||||
| BOARD:=ixp4xx | ||||
| BOARDNAME:=Intel XScale IXP4xx | ||||
| FEATURES:=dt squashfs gpio ext4 rootfs-part | ||||
| CPU_TYPE:=xscale | ||||
| SUBTARGETS:=generic | ||||
|  | ||||
| KERNEL_PATCHVER:=6.6 | ||||
|  | ||||
| define Target/Description | ||||
| 	Build firmware images for the IXP4xx XScale CPU | ||||
| endef | ||||
|  | ||||
| KERNELNAME:=zImage dtbs | ||||
|  | ||||
| include $(INCLUDE_DIR)/target.mk | ||||
|  | ||||
| DEFAULT_PACKAGES += fconfig \ | ||||
| 	kmod-crypto-hw-ixp4xx \ | ||||
| 	kmod-usb-ledtrig-usbport \ | ||||
| 	kmod-leds-gpio | ||||
|  | ||||
| $(eval $(call BuildTarget)) | ||||
							
								
								
									
										29
									
								
								target/linux/ixp4xx/base-files/etc/board.d/02_network
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								target/linux/ixp4xx/base-files/etc/board.d/02_network
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| # SPDX-License-Identifier: GPL-2.0-only | ||||
| . /lib/functions/uci-defaults.sh | ||||
|  | ||||
| board_config_update | ||||
|  | ||||
| case "$(board_name)" in | ||||
| freecom,fsg-3|\ | ||||
| gateworks,gw2348|\ | ||||
| gateworks,gw2358) | ||||
| 	ucidef_set_interfaces_lan_wan "eth0" "eth1" | ||||
| 	;; | ||||
| dlink,dsm-g600-a|\ | ||||
| iom,nas-100d|\ | ||||
| linksys,nslu2) | ||||
| 	ucidef_set_interface_lan "eth0" "dhcp" | ||||
| 	;; | ||||
| usr,usr8200) | ||||
| 	# LAN ports connected to eth1 thru the MV88E6060 DSA switch | ||||
| 	ucidef_set_interface "eth" device "eth1" protocol "none" | ||||
| 	ucidef_set_interfaces_lan_wan "lan1 lan2 lan3 lan4" "eth0" | ||||
| 	;; | ||||
| *) | ||||
| 	ucidef_set_interface_lan "eth0" "dhcp" | ||||
| 	;; | ||||
| esac | ||||
|  | ||||
| board_config_flush | ||||
|  | ||||
| exit 0 | ||||
| @@ -0,0 +1,38 @@ | ||||
| #!/bin/sh | ||||
| . /lib/functions.sh | ||||
| . /lib/functions/system.sh | ||||
|  | ||||
| set_from_redboot () { | ||||
| 	for npe in eth0 eth1 eth2 | ||||
| 	do | ||||
| 		if ip link show dev $npe > /dev/null 2>&1; then | ||||
| 			ip link set dev $npe address $(fconfig -s -r -d /dev/$1 -n npe_"$npe"_esa) | ||||
| 		fi | ||||
| 	done | ||||
|  | ||||
| 	# Devices with MAC address set blank: set a dummy value. | ||||
| 	if [ "$(ip link show dev eth0 2>/dev/null | grep -c 00:00:00:00:00:00)" = "1" ]; then | ||||
| 		ip link set dev eth0 address 00:11:22:33:44:55 | ||||
| 	fi | ||||
| 	if [ "$(ip link show dev eth1 2>/dev/null | grep -c 00:00:00:00:00:00)" = "1" ]; then | ||||
| 		ip link set dev eth0 address 00:11:22:33:44:56 | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| set_from_sysconf () { | ||||
| 	ip link set dev eth0 address $(mtd_get_mac_ascii SysConf hw_addr) | ||||
| } | ||||
|  | ||||
| set_ether_mac () { | ||||
| 	RBC="$(grep "RedBoot config" /proc/mtd | cut -d: -f1)" | ||||
| 	if [ ! -z $RBC ] ; then | ||||
| 		set_from_redboot $RBC | ||||
| 	else | ||||
| 		SYSC="$(grep "SysConf" /proc/mtd | cut -d: -f1)" | ||||
| 		if [ ! -z $SYSC ] ; then | ||||
| 			set_from_sysconf | ||||
| 		fi | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| boot_hook_add preinit_main set_ether_mac | ||||
							
								
								
									
										263
									
								
								target/linux/ixp4xx/config-6.6
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										263
									
								
								target/linux/ixp4xx/config-6.6
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,263 @@ | ||||
| CONFIG_ALIGNMENT_TRAP=y | ||||
| CONFIG_AMD_PHY=y | ||||
| CONFIG_ARCH_32BIT_OFF_T=y | ||||
| CONFIG_ARCH_HIBERNATION_POSSIBLE=y | ||||
| CONFIG_ARCH_IXP4XX=y | ||||
| CONFIG_ARCH_KEEP_MEMBLOCK=y | ||||
| CONFIG_ARCH_MIGHT_HAVE_PC_PARPORT=y | ||||
| CONFIG_ARCH_MULTIPLATFORM=y | ||||
| CONFIG_ARCH_MULTI_CPU_AUTO=y | ||||
| # CONFIG_ARCH_MULTI_V4 is not set | ||||
| # CONFIG_ARCH_MULTI_V4T is not set | ||||
| CONFIG_ARCH_MULTI_V4_V5=y | ||||
| CONFIG_ARCH_MULTI_V5=y | ||||
| CONFIG_ARCH_OPTIONAL_KERNEL_RWX=y | ||||
| CONFIG_ARCH_SELECT_MEMORY_MODEL=y | ||||
| CONFIG_ARCH_SPARSEMEM_ENABLE=y | ||||
| CONFIG_ARCH_STACKWALK=y | ||||
| CONFIG_ARCH_SUSPEND_POSSIBLE=y | ||||
| CONFIG_ARM=y | ||||
| CONFIG_ARM_APPENDED_DTB=y | ||||
| # CONFIG_ARM_ATAG_DTB_COMPAT is not set | ||||
| CONFIG_ARM_HAS_GROUP_RELOCS=y | ||||
| CONFIG_ARM_L1_CACHE_SHIFT=5 | ||||
| CONFIG_ARM_PATCH_PHYS_VIRT=y | ||||
| CONFIG_ARM_THUMB=y | ||||
| CONFIG_ARM_UNWIND=y | ||||
| CONFIG_ATA=y | ||||
| CONFIG_ATAGS=y | ||||
| CONFIG_AUTO_ZRELADDR=y | ||||
| CONFIG_BINFMT_FLAT_ARGVP_ENVP_ON_STACK=y | ||||
| CONFIG_BLK_DEV_SD=y | ||||
| CONFIG_BLK_MQ_PCI=y | ||||
| CONFIG_BUFFER_HEAD=y | ||||
| CONFIG_CC_HAVE_STACKPROTECTOR_TLS=y | ||||
| CONFIG_CC_IMPLICIT_FALLTHROUGH="-Wimplicit-fallthrough=5" | ||||
| CONFIG_CC_NO_ARRAY_BOUNDS=y | ||||
| CONFIG_CLKSRC_MMIO=y | ||||
| CONFIG_CLONE_BACKWARDS=y | ||||
| CONFIG_COMMON_CLK=y | ||||
| CONFIG_COMPACT_UNEVICTABLE_DEFAULT=1 | ||||
| CONFIG_COMPAT_32BIT_TIME=y | ||||
| CONFIG_CPU_32v5=y | ||||
| CONFIG_CPU_ABRT_EV5T=y | ||||
| CONFIG_CPU_BIG_ENDIAN=y | ||||
| CONFIG_CPU_CACHE_VIVT=y | ||||
| CONFIG_CPU_CP15=y | ||||
| CONFIG_CPU_CP15_MMU=y | ||||
| CONFIG_CPU_ENDIAN_BE32=y | ||||
| CONFIG_CPU_MITIGATIONS=y | ||||
| CONFIG_CPU_PABRT_LEGACY=y | ||||
| CONFIG_CPU_THUMB_CAPABLE=y | ||||
| CONFIG_CPU_TLB_V4WBI=y | ||||
| CONFIG_CPU_USE_DOMAINS=y | ||||
| CONFIG_CPU_XSCALE=y | ||||
| CONFIG_CRC16=y | ||||
| CONFIG_CRYPTO_AUTHENC=m | ||||
| CONFIG_CRYPTO_CBC=m | ||||
| CONFIG_CRYPTO_CRC32C=y | ||||
| CONFIG_CRYPTO_DES=m | ||||
| CONFIG_CRYPTO_DEV_IXP4XX=m | ||||
| CONFIG_CRYPTO_ECB=m | ||||
| CONFIG_CRYPTO_HW=y | ||||
| CONFIG_CRYPTO_LIB_BLAKE2S_GENERIC=y | ||||
| CONFIG_CRYPTO_LIB_DES=m | ||||
| CONFIG_CRYPTO_LIB_GF128MUL=y | ||||
| CONFIG_CRYPTO_LIB_SHA1=y | ||||
| CONFIG_CRYPTO_LIB_UTILS=y | ||||
| CONFIG_DEBUG_BUGVERBOSE=y | ||||
| CONFIG_DEBUG_INFO=y | ||||
| CONFIG_DEBUG_LL_INCLUDE="debug/8250.S" | ||||
| CONFIG_DEBUG_UART_8250=y | ||||
| CONFIG_DEBUG_UART_8250_SHIFT=2 | ||||
| CONFIG_DEBUG_UART_PHYS=0xc8000003 | ||||
| CONFIG_DEBUG_UART_VIRT=0xfec00003 | ||||
| CONFIG_DMA_OPS=y | ||||
| CONFIG_DTC=y | ||||
| CONFIG_EDAC_ATOMIC_SCRUB=y | ||||
| CONFIG_EDAC_SUPPORT=y | ||||
| CONFIG_EXCLUSIVE_SYSTEM_RAM=y | ||||
| CONFIG_EXT4_FS=y | ||||
| # CONFIG_FARSYNC is not set | ||||
| CONFIG_FIXED_PHY=y | ||||
| CONFIG_FIX_EARLYCON_MEM=y | ||||
| CONFIG_FORCE_PCI=y | ||||
| CONFIG_FS_IOMAP=y | ||||
| CONFIG_FS_MBCACHE=y | ||||
| CONFIG_FUNCTION_ALIGNMENT=0 | ||||
| CONFIG_FWNODE_MDIO=y | ||||
| CONFIG_FW_LOADER_PAGED_BUF=y | ||||
| CONFIG_FW_LOADER_SYSFS=y | ||||
| CONFIG_GCC10_NO_ARRAY_BOUNDS=y | ||||
| CONFIG_GCC_ASM_GOTO_OUTPUT_WORKAROUND=y | ||||
| CONFIG_GENERIC_ALLOCATOR=y | ||||
| CONFIG_GENERIC_ATOMIC64=y | ||||
| CONFIG_GENERIC_BUG=y | ||||
| CONFIG_GENERIC_CLOCKEVENTS=y | ||||
| CONFIG_GENERIC_CPU_AUTOPROBE=y | ||||
| CONFIG_GENERIC_EARLY_IOREMAP=y | ||||
| CONFIG_GENERIC_IDLE_POLL_SETUP=y | ||||
| CONFIG_GENERIC_IRQ_MULTI_HANDLER=y | ||||
| CONFIG_GENERIC_IRQ_SHOW=y | ||||
| CONFIG_GENERIC_IRQ_SHOW_LEVEL=y | ||||
| CONFIG_GENERIC_LIB_DEVMEM_IS_ALLOWED=y | ||||
| CONFIG_GENERIC_PCI_IOMAP=y | ||||
| CONFIG_GENERIC_SCHED_CLOCK=y | ||||
| CONFIG_GENERIC_SMP_IDLE_THREAD=y | ||||
| CONFIG_GENERIC_STRNCPY_FROM_USER=y | ||||
| CONFIG_GENERIC_STRNLEN_USER=y | ||||
| CONFIG_GLOB=y | ||||
| CONFIG_GPIOLIB_IRQCHIP=y | ||||
| CONFIG_GPIO_CDEV=y | ||||
| CONFIG_GPIO_GENERIC=y | ||||
| CONFIG_GPIO_GW_PLD=y | ||||
| CONFIG_GPIO_IXP4XX=y | ||||
| CONFIG_GRO_CELLS=y | ||||
| CONFIG_HARDIRQS_SW_RESEND=y | ||||
| CONFIG_HAS_DMA=y | ||||
| CONFIG_HAS_IOMEM=y | ||||
| CONFIG_HAS_IOPORT=y | ||||
| CONFIG_HAS_IOPORT_MAP=y | ||||
| CONFIG_HDLC=y | ||||
| CONFIG_HWMON=y | ||||
| CONFIG_HW_RANDOM=y | ||||
| CONFIG_HW_RANDOM_IXP4XX=y | ||||
| CONFIG_HZ_FIXED=0 | ||||
| CONFIG_HZ_PERIODIC=y | ||||
| CONFIG_I2C=y | ||||
| CONFIG_I2C_ALGOBIT=y | ||||
| CONFIG_I2C_BOARDINFO=y | ||||
| CONFIG_I2C_CHARDEV=y | ||||
| CONFIG_I2C_GPIO=y | ||||
| CONFIG_I2C_IOP3XX=y | ||||
| CONFIG_INITRAMFS_SOURCE="" | ||||
| CONFIG_INTEL_IXP4XX_EB=y | ||||
| CONFIG_IRQCHIP=y | ||||
| CONFIG_IRQSTACKS=y | ||||
| CONFIG_IRQ_DOMAIN=y | ||||
| CONFIG_IRQ_DOMAIN_HIERARCHY=y | ||||
| CONFIG_IRQ_FORCED_THREADING=y | ||||
| CONFIG_IRQ_WORK=y | ||||
| # CONFIG_IWMMXT is not set | ||||
| CONFIG_IXP4XX_ETH=y | ||||
| CONFIG_IXP4XX_HSS=y | ||||
| CONFIG_IXP4XX_IRQ=y | ||||
| CONFIG_IXP4XX_NPE=y | ||||
| CONFIG_IXP4XX_QMGR=y | ||||
| CONFIG_IXP4XX_TIMER=y | ||||
| CONFIG_IXP4XX_WATCHDOG=y | ||||
| CONFIG_JBD2=y | ||||
| CONFIG_LEDS_GPIO=y | ||||
| CONFIG_LEGACY_PTYS=y | ||||
| CONFIG_LEGACY_PTY_COUNT=256 | ||||
| CONFIG_LIBFDT=y | ||||
| CONFIG_LOCK_DEBUGGING_SUPPORT=y | ||||
| CONFIG_MDIO_BUS=y | ||||
| CONFIG_MDIO_DEVICE=y | ||||
| CONFIG_MDIO_DEVRES=y | ||||
| CONFIG_MFD_SYSCON=y | ||||
| CONFIG_MIGRATION=y | ||||
| CONFIG_MMU_LAZY_TLB_REFCOUNT=y | ||||
| CONFIG_MODULES_USE_ELF_REL=y | ||||
| CONFIG_MTD_CFI_ADV_OPTIONS=y | ||||
| # CONFIG_MTD_CFI_GEOMETRY is not set | ||||
| CONFIG_MTD_OTP=y | ||||
| CONFIG_MTD_PHYSMAP=y | ||||
| CONFIG_MTD_PHYSMAP_IXP4XX=y | ||||
| CONFIG_MTD_REDBOOT_PARTS=y | ||||
| CONFIG_MTD_SPLIT_FIRMWARE=y | ||||
| CONFIG_MTD_SPLIT_FIRMWARE_NAME="linux" | ||||
| CONFIG_NEED_DMA_MAP_STATE=y | ||||
| CONFIG_NEED_KUSER_HELPERS=y | ||||
| CONFIG_NEED_PER_CPU_KM=y | ||||
| CONFIG_NET_DEVLINK=y | ||||
| CONFIG_NET_DSA=y | ||||
| CONFIG_NET_DSA_MV88E6060=y | ||||
| CONFIG_NET_DSA_TAG_TRAILER=y | ||||
| CONFIG_NET_EGRESS=y | ||||
| CONFIG_NET_INGRESS=y | ||||
| CONFIG_NET_PTP_CLASSIFY=y | ||||
| CONFIG_NET_SELFTESTS=y | ||||
| CONFIG_NET_SWITCHDEV=y | ||||
| CONFIG_NET_VENDOR_XSCALE=y | ||||
| CONFIG_NET_XGRESS=y | ||||
| CONFIG_NLS=y | ||||
| CONFIG_NVMEM=y | ||||
| CONFIG_NVMEM_LAYOUTS=y | ||||
| CONFIG_NVMEM_SYSFS=y | ||||
| CONFIG_OF=y | ||||
| CONFIG_OF_ADDRESS=y | ||||
| CONFIG_OF_EARLY_FLATTREE=y | ||||
| CONFIG_OF_FLATTREE=y | ||||
| CONFIG_OF_GPIO=y | ||||
| CONFIG_OF_IRQ=y | ||||
| CONFIG_OF_KOBJ=y | ||||
| CONFIG_OF_MDIO=y | ||||
| CONFIG_OLD_SIGACTION=y | ||||
| CONFIG_OLD_SIGSUSPEND3=y | ||||
| CONFIG_PAGE_OFFSET=0xC0000000 | ||||
| CONFIG_PAGE_POOL=y | ||||
| CONFIG_PAGE_SIZE_LESS_THAN_256KB=y | ||||
| CONFIG_PAGE_SIZE_LESS_THAN_64KB=y | ||||
| CONFIG_PAHOLE_HAS_LANG_EXCLUDE=y | ||||
| CONFIG_PATA_IXP4XX_CF=y | ||||
| CONFIG_PCI=y | ||||
| CONFIG_PCI_DOMAINS=y | ||||
| CONFIG_PCI_DOMAINS_GENERIC=y | ||||
| CONFIG_PCI_IXP4XX=y | ||||
| CONFIG_PERF_USE_VMALLOC=y | ||||
| CONFIG_PGTABLE_LEVELS=2 | ||||
| CONFIG_PHYLIB=y | ||||
| CONFIG_PHYLIB_LEDS=y | ||||
| CONFIG_PHYLINK=y | ||||
| CONFIG_POWER_RESET=y | ||||
| CONFIG_POWER_RESET_GPIO=y | ||||
| CONFIG_PREEMPT_NONE_BUILD=y | ||||
| CONFIG_PTP_1588_CLOCK_OPTIONAL=y | ||||
| CONFIG_RANDSTRUCT_NONE=y | ||||
| CONFIG_RATIONAL=y | ||||
| CONFIG_REALTEK_PHY=y | ||||
| CONFIG_REGMAP=y | ||||
| CONFIG_REGMAP_MMIO=y | ||||
| CONFIG_SCSI=y | ||||
| CONFIG_SCSI_COMMON=y | ||||
| CONFIG_SERIAL_8250_FSL=y | ||||
| CONFIG_SERIAL_MCTRL_GPIO=y | ||||
| CONFIG_SERIAL_OF_PLATFORM=y | ||||
| CONFIG_SG_POOL=y | ||||
| CONFIG_SOFTIRQ_ON_OWN_STACK=y | ||||
| CONFIG_SPARSE_IRQ=y | ||||
| CONFIG_SPLIT_PTLOCK_CPUS=999999 | ||||
| CONFIG_SQUASHFS_DECOMP_MULTI_PERCPU=y | ||||
| CONFIG_SWPHY=y | ||||
| CONFIG_SYS_SUPPORTS_APM_EMULATION=y | ||||
| CONFIG_THREAD_INFO_IN_TASK=y | ||||
| CONFIG_TICK_CPU_ACCOUNTING=y | ||||
| CONFIG_TIMER_OF=y | ||||
| CONFIG_TIMER_PROBE=y | ||||
| CONFIG_TINY_SRCU=y | ||||
| CONFIG_UNCOMPRESS_INCLUDE="debug/uncompress.h" | ||||
| CONFIG_UNWINDER_ARM=y | ||||
| CONFIG_USB=y | ||||
| CONFIG_USB_COMMON=y | ||||
| CONFIG_USB_EHCI_BIG_ENDIAN_DESC=y | ||||
| CONFIG_USB_EHCI_BIG_ENDIAN_MMIO=y | ||||
| CONFIG_USB_EHCI_HCD=y | ||||
| CONFIG_USB_EHCI_HCD_PLATFORM=y | ||||
| CONFIG_USB_EHCI_PCI=y | ||||
| CONFIG_USB_OHCI_HCD=y | ||||
| CONFIG_USB_OHCI_HCD_PCI=y | ||||
| # CONFIG_USB_OHCI_HCD_PLATFORM is not set | ||||
| CONFIG_USB_PCI=y | ||||
| CONFIG_USB_STORAGE=y | ||||
| CONFIG_USB_SUPPORT=y | ||||
| CONFIG_USB_UHCI_HCD=y | ||||
| CONFIG_USE_OF=y | ||||
| CONFIG_VM_EVENT_COUNTERS=y | ||||
| CONFIG_WAN=y | ||||
| CONFIG_WATCHDOG_CORE=y | ||||
| CONFIG_WATCHDOG_NOWAYOUT=y | ||||
| CONFIG_XZ_DEC_ARM=y | ||||
| CONFIG_XZ_DEC_BCJ=y | ||||
| CONFIG_ZBOOT_ROM_BSS=0x0 | ||||
| CONFIG_ZBOOT_ROM_TEXT=0x0 | ||||
							
								
								
									
										1
									
								
								target/linux/ixp4xx/generic/target.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								target/linux/ixp4xx/generic/target.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| BOARDNAME:=Generic | ||||
							
								
								
									
										140
									
								
								target/linux/ixp4xx/image/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										140
									
								
								target/linux/ixp4xx/image/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,140 @@ | ||||
| # SPDX-License-Identifier: GPL-2.0-only | ||||
| # | ||||
| # Copyright (C) 2006-2021 OpenWrt.org | ||||
|  | ||||
| include $(TOPDIR)/rules.mk | ||||
| include $(INCLUDE_DIR)/image.mk | ||||
|  | ||||
| # Cook a Linksys NSLU2 etc image | ||||
| define Build/linksys-ixp425-image | ||||
| 	touch $@.null-initrd | ||||
| 	$(TOPDIR)/scripts/slugimage.pl -L $(STAGING_DIR_IMAGE)/apex/apex-$(1)-armeb.bin -k $@ -r $@.null-initrd -p -o $@.new | ||||
| 	mv $@.new $@ | ||||
| endef | ||||
|  | ||||
| define Build/freecom-image | ||||
| 	mkdir -p $@.tmptar | ||||
| 	# Add kernel | ||||
| 	cp $@ $@.tmptar/zImage | ||||
| 	cd $@.tmptar && tar -c -j -f $@.new --numeric-owner --owner=0 --group=0 * | ||||
| 	rm -rf $@.tmptar | ||||
| 	encode_crc $@.new $@ | ||||
| 	rm -f $@.new | ||||
| endef | ||||
|  | ||||
| # Build sysupgrade image | ||||
| define BuildFirmware/Generic | ||||
| 	dd if=$(KDIR)/zImage of=$(KDIR)/zImage.pad bs=64k conv=sync; \ | ||||
| 	dd if=$(KDIR)/root.$(1) of=$(KDIR)/root.$(1).pad bs=128k conv=sync; \ | ||||
| 	sh $(TOPDIR)/scripts/combined-image.sh \ | ||||
| 		$(KDIR)/zImage.pad \ | ||||
| 		$(KDIR)/root.$(1).pad \ | ||||
| 		$(BIN_DIR)/$(IMG_PREFIX)-$(patsubst jffs2-%,jffs2,$(patsubst squashfs-%,squashfs,$(1)))-sysupgrade.bin | ||||
| endef | ||||
|  | ||||
| define Image/Build | ||||
| 	$(call Image/Build/$(1),$(1)) | ||||
| 	$(call BuildFirmware/Generic,$(1)) | ||||
| endef | ||||
|  | ||||
| define Device/Default | ||||
| 	PROFILES := Default | ||||
| 	DEVICE_DTS_DIR = $$(DTS_DIR)/intel/ixp | ||||
| 	KERNEL_DEPENDS = $$(wildcard $(DTS_DIR)/$$(DEVICE_DTS).dts) | ||||
| 	KERNEL_NAME := zImage | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	BLOCKSIZE := 128k | ||||
| endef | ||||
|  | ||||
| define Device/dlink_dsm_g600_a | ||||
| 	DEVICE_VENDOR := D-Link | ||||
| 	DEVICE_MODEL := DSM G600 A | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-pcf8563 kmod-via-velocity kmod-ata-artop kmod-ath5k wpad-basic-mbedtls | ||||
| 	DEVICE_DTS := intel-ixp42x-dlink-dsm-g600 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := kernel.bin rootfs.bin | ||||
| 	IMAGE/kernel.bin := append-kernel | ||||
| 	IMAGE/rootfs.bin := append-rootfs | pad-rootfs | pad-to 128k | ||||
| endef | ||||
| TARGET_DEVICES += dlink_dsm_g600_a | ||||
|  | ||||
| define Device/freecom_fsg_3 | ||||
| 	DEVICE_VENDOR := Freecom | ||||
| 	DEVICE_MODEL := FSG-3 | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-isl1208 kmod-ath5k wpad-basic-mbedtls | ||||
| 	# Only 4 MB of Flash so not building by default | ||||
| 	DEFAULT := n | ||||
| 	DEVICE_DTS := intel-ixp42x-freecom-fsg-3 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := factory.bin | ||||
| 	# This has to boot from harddisk so just append the kernel | ||||
| 	IMAGE/factory.bin := append-kernel | freecom-image | ||||
| endef | ||||
| TARGET_DEVICES += freecom_fsg_3 | ||||
|  | ||||
| define Device/gateworks_avila | ||||
| 	DEVICE_VENDOR := Gateworks | ||||
| 	DEVICE_MODEL := Avila GW2348-4 | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-ds1672 kmod-eeprom-at24 kmod-hwmon-ad7418 | ||||
| 	DEVICE_DTS := intel-ixp42x-gateworks-gw2348 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := kernel.bin rootfs.bin | ||||
| 	IMAGE/kernel.bin := append-kernel | ||||
| 	IMAGE/rootfs.bin := append-rootfs | pad-rootfs | pad-to 128k | ||||
| endef | ||||
| TARGET_DEVICES += gateworks_avila | ||||
|  | ||||
| define Device/gateworks_cambria | ||||
| 	DEVICE_VENDOR := Gateworks | ||||
| 	DEVICE_MODEL := Cambria GW2358-4 | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-ds1672 kmod-eeprom-at24 kmod-hwmon-ad7418 | ||||
| 	DEVICE_DTS := intel-ixp43x-gateworks-gw2358 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := kernel.bin rootfs.bin | ||||
| 	IMAGE/kernel.bin := append-kernel | ||||
| 	IMAGE/rootfs.bin := append-rootfs | pad-rootfs | pad-to 128k | ||||
| endef | ||||
| TARGET_DEVICES += gateworks_cambria | ||||
|  | ||||
| define Device/iomega_nas100d | ||||
| 	DEVICE_VENDOR := Iomega | ||||
| 	DEVICE_MODEL := NAS100d | ||||
| 	# USB2 is compiled in and needs no package | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-pcf8563 | ||||
| 	DEVICE_DTS := intel-ixp42x-iomega-nas100d | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := factory.bin | ||||
| 	# This has to boot from harddisk so just append the kernel | ||||
| 	IMAGE/factory.bin := append-kernel | linksys-ixp425-image "nas100d" | ||||
| endef | ||||
| TARGET_DEVICES += iomega_nas100d | ||||
|  | ||||
| define Device/linksys_nslu2 | ||||
| 	DEVICE_VENDOR := Linksys | ||||
| 	DEVICE_MODEL := NSLU2 | ||||
| 	# USB2 is compiled in and needs no package | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-x1205 | ||||
| 	# Only 32 MB of RAM so not building by default | ||||
| 	DEFAULT := n | ||||
| 	DEVICE_DTS := intel-ixp42x-linksys-nslu2 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := factory.bin | ||||
| 	# This has to boot from harddisk so just append the kernel | ||||
| 	IMAGE/factory.bin := append-kernel | linksys-ixp425-image "nslu2" | ||||
| endef | ||||
| TARGET_DEVICES += linksys_nslu2 | ||||
|  | ||||
| define Device/usrobotics_usr8200 | ||||
| 	DEVICE_VENDOR := USRobotics | ||||
| 	DEVICE_MODEL := USR8200 | ||||
| 	# USB2 is compiled in and needs no package | ||||
| 	DEVICE_PACKAGES := ixp4xx-microcode-ethernet kmod-rtc-r7301 kmod-firewire kmod-firewire-ohci | ||||
| 	DEVICE_DTS := intel-ixp42x-usrobotics-usr8200 | ||||
| 	KERNEL := kernel-bin | append-dtb | ||||
| 	IMAGES := kernel.bin rootfs.bin | ||||
| 	IMAGE/kernel.bin := append-kernel | ||||
| 	IMAGE/rootfs.bin := append-rootfs | pad-rootfs | pad-to 128k | ||||
| endef | ||||
| TARGET_DEVICES += usrobotics_usr8200 | ||||
|  | ||||
| $(eval $(call BuildImage)) | ||||
| @@ -0,0 +1,93 @@ | ||||
| From fc58944733a2082e3290eda240eb3247a00ad73a Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Thu, 21 Sep 2023 00:12:42 +0200 | ||||
| Subject: [PATCH] gpio: ixp4xx: Handle clock output on pin 14 and 15 | ||||
|  | ||||
| This makes it possible to provide basic clock output on pins | ||||
| 14 and 15. The clocks are typically used by random electronics, | ||||
| not modeled in the device tree, so they just need to be provided | ||||
| on request. | ||||
|  | ||||
| In order to not disturb old systems that require that the | ||||
| hardware defaults are kept in the clock setting bits, we only | ||||
| manipulate these if either device tree property is present. | ||||
| Once we know a device needs one of the clocks we can set it | ||||
| in the device tree. | ||||
|  | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  drivers/gpio/gpio-ixp4xx.c | 49 +++++++++++++++++++++++++++++++++++++- | ||||
|  1 file changed, 48 insertions(+), 1 deletion(-) | ||||
|  | ||||
| --- a/drivers/gpio/gpio-ixp4xx.c | ||||
| +++ b/drivers/gpio/gpio-ixp4xx.c | ||||
| @@ -38,6 +38,18 @@ | ||||
|  #define IXP4XX_GPIO_STYLE_MASK		GENMASK(2, 0) | ||||
|  #define IXP4XX_GPIO_STYLE_SIZE		3 | ||||
|   | ||||
| +/* | ||||
| + * Clock output control register defines. | ||||
| + */ | ||||
| +#define IXP4XX_GPCLK_CLK0DC_SHIFT	0 | ||||
| +#define IXP4XX_GPCLK_CLK0TC_SHIFT	4 | ||||
| +#define IXP4XX_GPCLK_CLK0_MASK		GENMASK(7, 0) | ||||
| +#define IXP4XX_GPCLK_MUX14		BIT(8) | ||||
| +#define IXP4XX_GPCLK_CLK1DC_SHIFT	16 | ||||
| +#define IXP4XX_GPCLK_CLK1TC_SHIFT	20 | ||||
| +#define IXP4XX_GPCLK_CLK1_MASK		GENMASK(23, 16) | ||||
| +#define IXP4XX_GPCLK_MUX15		BIT(24) | ||||
| + | ||||
|  /** | ||||
|   * struct ixp4xx_gpio - IXP4 GPIO state container | ||||
|   * @dev: containing device for this instance | ||||
| @@ -202,6 +214,8 @@ static int ixp4xx_gpio_probe(struct plat | ||||
|  	struct ixp4xx_gpio *g; | ||||
|  	struct gpio_irq_chip *girq; | ||||
|  	struct device_node *irq_parent; | ||||
| +	bool clk_14, clk_15; | ||||
| +	u32 val; | ||||
|  	int ret; | ||||
|   | ||||
|  	g = devm_kzalloc(dev, sizeof(*g), GFP_KERNEL); | ||||
| @@ -231,7 +245,40 @@ static int ixp4xx_gpio_probe(struct plat | ||||
|  	 */ | ||||
|  	if (of_machine_is_compatible("dlink,dsm-g600-a") || | ||||
|  	    of_machine_is_compatible("iom,nas-100d")) | ||||
| -		__raw_writel(0x0, g->base + IXP4XX_REG_GPCLK); | ||||
| +		val = 0; | ||||
| +	else | ||||
| +		val = __raw_readl(g->base + IXP4XX_REG_GPCLK); | ||||
| + | ||||
| +	/* | ||||
| +	 * If either clock output is enabled explicitly in the device tree | ||||
| +	 * we take full control of the clock by masking off all bits for | ||||
| +	 * the clock control and selectively enabling them. Otherwise | ||||
| +	 * we leave the hardware default settings. | ||||
| +	 * | ||||
| +	 * Enable clock outputs with default timings of requested clock. | ||||
| +	 * If you need control over TC and DC, add these to the device | ||||
| +	 * tree bindings and use them here. | ||||
| +	 */ | ||||
| +	clk_14 = of_property_read_bool(np, "intel,ixp4xx-gpio14-clkout"); | ||||
| +	clk_15 = of_property_read_bool(np, "intel,ixp4xx-gpio15-clkout"); | ||||
| +	if (clk_14 || clk_15) { | ||||
| +		val &= ~(IXP4XX_GPCLK_MUX14 | IXP4XX_GPCLK_MUX15); | ||||
| +		val &= ~IXP4XX_GPCLK_CLK0_MASK; | ||||
| +		val &= ~IXP4XX_GPCLK_CLK1_MASK; | ||||
| +		if (clk_14) { | ||||
| +			val |= (0 << IXP4XX_GPCLK_CLK0DC_SHIFT); | ||||
| +			val |= (1 << IXP4XX_GPCLK_CLK0TC_SHIFT); | ||||
| +			val |= IXP4XX_GPCLK_MUX14; | ||||
| +		} | ||||
| + | ||||
| +		if (clk_15) { | ||||
| +			val |= (0 << IXP4XX_GPCLK_CLK1DC_SHIFT); | ||||
| +			val |= (1 << IXP4XX_GPCLK_CLK1TC_SHIFT); | ||||
| +			val |= IXP4XX_GPCLK_MUX15; | ||||
| +		} | ||||
| +	} | ||||
| + | ||||
| +	__raw_writel(val, g->base + IXP4XX_REG_GPCLK); | ||||
|   | ||||
|  	/* | ||||
|  	 * This is a very special big-endian ARM issue: when the IXP4xx is | ||||
| @@ -0,0 +1,132 @@ | ||||
| From 6599df775e2cbb4988bdf8239acf4fbec70e5ef9 Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Sat, 23 Sep 2023 20:38:22 +0200 | ||||
| Subject: [PATCH 3/4] net: ixp4xx_eth: Support changing the MTU | ||||
|  | ||||
| As we don't specify the MTU in the driver, the framework | ||||
| will fall back to 1500 bytes and this doesn't work very | ||||
| well when we try to attach a DSA switch: | ||||
|  | ||||
|   eth1: mtu greater than device maximum | ||||
|   ixp4xx_eth c800a000.ethernet eth1: error -22 setting | ||||
|   MTU to 1504 to include DSA overhead | ||||
|  | ||||
| After locating an out-of-tree patch in OpenWrt I found | ||||
| suitable code to set the MTU on the interface and ported | ||||
| it and updated it. Now the MTU gets set properly. | ||||
|  | ||||
| Reviewed-by: Jacob Keller <jacob.e.keller@intel.com> | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  drivers/net/ethernet/xscale/ixp4xx_eth.c | 65 +++++++++++++++++++++++- | ||||
|  1 file changed, 64 insertions(+), 1 deletion(-) | ||||
|  | ||||
| --- a/drivers/net/ethernet/xscale/ixp4xx_eth.c | ||||
| +++ b/drivers/net/ethernet/xscale/ixp4xx_eth.c | ||||
| @@ -24,6 +24,7 @@ | ||||
|  #include <linux/dma-mapping.h> | ||||
|  #include <linux/dmapool.h> | ||||
|  #include <linux/etherdevice.h> | ||||
| +#include <linux/if_vlan.h> | ||||
|  #include <linux/io.h> | ||||
|  #include <linux/kernel.h> | ||||
|  #include <linux/net_tstamp.h> | ||||
| @@ -63,7 +64,15 @@ | ||||
|   | ||||
|  #define POOL_ALLOC_SIZE		(sizeof(struct desc) * (RX_DESCS + TX_DESCS)) | ||||
|  #define REGS_SIZE		0x1000 | ||||
| -#define MAX_MRU			1536 /* 0x600 */ | ||||
| + | ||||
| +/* MRU is said to be 14320 in a code dump, the SW manual says that | ||||
| + * MRU/MTU is 16320 and includes VLAN and ethernet headers. | ||||
| + * See "IXP400 Software Programmer's Guide" section 10.3.2, page 161. | ||||
| + * | ||||
| + * FIXME: we have chosen the safe default (14320) but if you can test | ||||
| + * jumboframes, experiment with 16320 and see what happens! | ||||
| + */ | ||||
| +#define MAX_MRU			(14320 - VLAN_ETH_HLEN) | ||||
|  #define RX_BUFF_SIZE		ALIGN((NET_IP_ALIGN) + MAX_MRU, 4) | ||||
|   | ||||
|  #define NAPI_WEIGHT		16 | ||||
| @@ -1182,6 +1191,54 @@ static void destroy_queues(struct port * | ||||
|  	} | ||||
|  } | ||||
|   | ||||
| +static int ixp4xx_do_change_mtu(struct net_device *dev, int new_mtu) | ||||
| +{ | ||||
| +	struct port *port = netdev_priv(dev); | ||||
| +	struct npe *npe = port->npe; | ||||
| +	int framesize, chunks; | ||||
| +	struct msg msg = {}; | ||||
| + | ||||
| +	/* adjust for ethernet headers */ | ||||
| +	framesize = new_mtu + VLAN_ETH_HLEN; | ||||
| +	/* max rx/tx 64 byte chunks */ | ||||
| +	chunks = DIV_ROUND_UP(framesize, 64); | ||||
| + | ||||
| +	msg.cmd = NPE_SETMAXFRAMELENGTHS; | ||||
| +	msg.eth_id = port->id; | ||||
| + | ||||
| +	/* Firmware wants to know buffer size in 64 byte chunks */ | ||||
| +	msg.byte2 = chunks << 8; | ||||
| +	msg.byte3 = chunks << 8; | ||||
| + | ||||
| +	msg.byte4 = msg.byte6 = framesize >> 8; | ||||
| +	msg.byte5 = msg.byte7 = framesize & 0xff; | ||||
| + | ||||
| +	if (npe_send_recv_message(npe, &msg, "ETH_SET_MAX_FRAME_LENGTH")) | ||||
| +		return -EIO; | ||||
| +	netdev_dbg(dev, "set MTU on NPE %s to %d bytes\n", | ||||
| +		   npe_name(npe), new_mtu); | ||||
| + | ||||
| +	return 0; | ||||
| +} | ||||
| + | ||||
| +static int ixp4xx_eth_change_mtu(struct net_device *dev, int new_mtu) | ||||
| +{ | ||||
| +	int ret; | ||||
| + | ||||
| +	/* MTU can only be changed when the interface is up. We also | ||||
| +	 * set the MTU from dev->mtu when opening the device. | ||||
| +	 */ | ||||
| +	if (dev->flags & IFF_UP) { | ||||
| +		ret = ixp4xx_do_change_mtu(dev, new_mtu); | ||||
| +		if (ret < 0) | ||||
| +			return ret; | ||||
| +	} | ||||
| + | ||||
| +	dev->mtu = new_mtu; | ||||
| + | ||||
| +	return 0; | ||||
| +} | ||||
| + | ||||
|  static int eth_open(struct net_device *dev) | ||||
|  { | ||||
|  	struct port *port = netdev_priv(dev); | ||||
| @@ -1232,6 +1289,8 @@ static int eth_open(struct net_device *d | ||||
|  	if (npe_send_recv_message(port->npe, &msg, "ETH_SET_FIREWALL_MODE")) | ||||
|  		return -EIO; | ||||
|   | ||||
| +	ixp4xx_do_change_mtu(dev, dev->mtu); | ||||
| + | ||||
|  	if ((err = request_queues(port)) != 0) | ||||
|  		return err; | ||||
|   | ||||
| @@ -1374,6 +1433,7 @@ static int eth_close(struct net_device * | ||||
|  static const struct net_device_ops ixp4xx_netdev_ops = { | ||||
|  	.ndo_open = eth_open, | ||||
|  	.ndo_stop = eth_close, | ||||
| +	.ndo_change_mtu = ixp4xx_eth_change_mtu, | ||||
|  	.ndo_start_xmit = eth_xmit, | ||||
|  	.ndo_set_rx_mode = eth_set_mcast_list, | ||||
|  	.ndo_eth_ioctl = eth_ioctl, | ||||
| @@ -1488,6 +1548,9 @@ static int ixp4xx_eth_probe(struct platf | ||||
|  	ndev->dev.dma_mask = dev->dma_mask; | ||||
|  	ndev->dev.coherent_dma_mask = dev->coherent_dma_mask; | ||||
|   | ||||
| +	ndev->min_mtu = ETH_MIN_MTU; | ||||
| +	ndev->max_mtu = MAX_MRU; | ||||
| + | ||||
|  	netif_napi_add_weight(ndev, &port->napi, eth_poll, NAPI_WEIGHT); | ||||
|   | ||||
|  	if (!(port->npe = npe_request(NPE_ID(port->id)))) | ||||
| @@ -0,0 +1,260 @@ | ||||
| From a1490c1e8a12a8286c6a34c3d277a519066fc51e Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Sat, 7 Oct 2023 14:32:40 +0200 | ||||
| Subject: [PATCH] ARM: dts: ixp4xx: Add USRobotics USR8200 device tree | ||||
|  | ||||
| This is a USRobotics NAS/Firewall/router that has been supported | ||||
| by OpenWrt in the past. It had dedicated users so let's get it | ||||
| properly supported. | ||||
|  | ||||
| Some debugging and fixing was provided by Howard Harte. | ||||
|  | ||||
| Link: https://lore.kernel.org/r/20231007-ixp4xx-usr8200-v1-1-aded3d6ff6f1@linaro.org | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  arch/arm/boot/dts/intel/ixp/Makefile          |   3 +- | ||||
|  .../ixp/intel-ixp42x-usrobotics-usr8200.dts   | 229 ++++++++++++++++++ | ||||
|  2 files changed, 231 insertions(+), 1 deletion(-) | ||||
|  create mode 100644 arch/arm/boot/dts/intel/ixp/intel-ixp42x-usrobotics-usr8200.dts | ||||
|  | ||||
| --- a/arch/arm/boot/dts/intel/ixp/Makefile | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/Makefile | ||||
| @@ -16,4 +16,5 @@ dtb-$(CONFIG_ARCH_IXP4XX) += \ | ||||
|  	intel-ixp43x-gateworks-gw2358.dtb \ | ||||
|  	intel-ixp42x-netgear-wg302v1.dtb \ | ||||
|  	intel-ixp42x-arcom-vulcan.dtb \ | ||||
| -	intel-ixp42x-gateway-7001.dtb | ||||
| +	intel-ixp42x-gateway-7001.dtb \ | ||||
| +	intel-ixp42x-usrobotics-usr8200.dtb | ||||
| --- /dev/null | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-usrobotics-usr8200.dts | ||||
| @@ -0,0 +1,229 @@ | ||||
| +// SPDX-License-Identifier: ISC | ||||
| +/* | ||||
| + * Device Tree file for the USRobotics USR8200 firewall | ||||
| + * VPN and NAS. Based on know-how from Peter Denison. | ||||
| + * | ||||
| + * This machine is based on IXP422, the USR internal codename | ||||
| + * is "Jeeves". | ||||
| + */ | ||||
| + | ||||
| +/dts-v1/; | ||||
| + | ||||
| +#include "intel-ixp42x.dtsi" | ||||
| +#include <dt-bindings/input/input.h> | ||||
| + | ||||
| +/ { | ||||
| +	model = "USRobotics USR8200"; | ||||
| +	compatible = "usr,usr8200", "intel,ixp42x"; | ||||
| +	#address-cells = <1>; | ||||
| +	#size-cells = <1>; | ||||
| + | ||||
| +	memory@0 { | ||||
| +		device_type = "memory"; | ||||
| +		reg = <0x00000000 0x4000000>; | ||||
| +	}; | ||||
| + | ||||
| +	chosen { | ||||
| +		bootargs = "console=ttyS0,115200n8"; | ||||
| +		stdout-path = "uart1:115200n8"; | ||||
| +	}; | ||||
| + | ||||
| +	aliases { | ||||
| +		/* These are switched around */ | ||||
| +		serial0 = &uart1; | ||||
| +		serial1 = &uart0; | ||||
| +	}; | ||||
| + | ||||
| +	leds { | ||||
| +		compatible = "gpio-leds"; | ||||
| +		ieee1394_led: led-1394 { | ||||
| +			label = "usr8200:green:1394"; | ||||
| +			gpios = <&gpio0 0 GPIO_ACTIVE_LOW>; | ||||
| +			default-state = "off"; | ||||
| +		}; | ||||
| +		usb1_led: led-usb1 { | ||||
| +			label = "usr8200:green:usb1"; | ||||
| +			gpios = <&gpio0 1 GPIO_ACTIVE_LOW>; | ||||
| +			default-state = "off"; | ||||
| +		}; | ||||
| +		usb2_led: led-usb2 { | ||||
| +			label = "usr8200:green:usb2"; | ||||
| +			gpios = <&gpio0 2 GPIO_ACTIVE_LOW>; | ||||
| +			default-state = "off"; | ||||
| +		}; | ||||
| +		wireless_led: led-wireless { | ||||
| +			/* | ||||
| +			 * This LED is mounted inside the case but cannot be | ||||
| +			 * seen from the outside: probably USR planned at one | ||||
| +			 * point for the device to have a wireless card, then | ||||
| +			 * changed their mind and didn't mount it, leaving the | ||||
| +			 * LED in place. | ||||
| +			 */ | ||||
| +			label = "usr8200:green:wireless"; | ||||
| +			gpios = <&gpio0 3 GPIO_ACTIVE_LOW>; | ||||
| +			default-state = "off"; | ||||
| +		}; | ||||
| +		pwr_led: led-pwr { | ||||
| +			label = "usr8200:green:pwr"; | ||||
| +			gpios = <&gpio0 14 GPIO_ACTIVE_HIGH>; | ||||
| +			default-state = "on"; | ||||
| +			linux,default-trigger = "heartbeat"; | ||||
| +		}; | ||||
| +	}; | ||||
| + | ||||
| +	gpio_keys { | ||||
| +		compatible = "gpio-keys"; | ||||
| + | ||||
| +		button-reset { | ||||
| +			wakeup-source; | ||||
| +			linux,code = <KEY_RESTART>; | ||||
| +			label = "reset"; | ||||
| +			gpios = <&gpio0 12 GPIO_ACTIVE_LOW>; | ||||
| +		}; | ||||
| +	}; | ||||
| + | ||||
| +	soc { | ||||
| +		bus@c4000000 { | ||||
| +			flash@0,0 { | ||||
| +				compatible = "intel,ixp4xx-flash", "cfi-flash"; | ||||
| +				bank-width = <2>; | ||||
| +				/* Enable writes on the expansion bus */ | ||||
| +				intel,ixp4xx-eb-write-enable = <1>; | ||||
| +				/* 16 MB of Flash mapped in at CS0 */ | ||||
| +				reg = <0 0x00000000 0x1000000>; | ||||
| + | ||||
| +				partitions { | ||||
| +					compatible = "redboot-fis"; | ||||
| +					/* Eraseblock at 0x0fe0000 */ | ||||
| +					fis-index-block = <0x7f>; | ||||
| +				}; | ||||
| +			}; | ||||
| +			rtc@2,0 { | ||||
| +				/* EPSON RTC7301 DG DIL-capsule */ | ||||
| +				compatible = "epson,rtc7301dg"; | ||||
| +				/* | ||||
| +				 * These timing settings were found in the boardfile patch: | ||||
| +				 * IXP4XX_EXP_CS2 = 0x3fff000 | IXP4XX_EXP_BUS_SIZE(0) | IXP4XX_EXP_BUS_WR_EN | | ||||
| +				 *                  IXP4XX_EXP_BUS_CS_EN | IXP4XX_EXP_BUS_BYTE_EN; | ||||
| +				 */ | ||||
| +				intel,ixp4xx-eb-t1 = <0>; // no cycles extra address phase | ||||
| +				intel,ixp4xx-eb-t2 = <0>; // no cycles extra setup phase | ||||
| +				intel,ixp4xx-eb-t3 = <15>; // 15 cycles extra strobe phase | ||||
| +				intel,ixp4xx-eb-t4 = <3>; // 3 cycles extra hold phase | ||||
| +				intel,ixp4xx-eb-t5 = <15>; // 15 cycles extra recovery phase | ||||
| +				intel,ixp4xx-eb-cycle-type = <0>; // Intel cycle | ||||
| +				intel,ixp4xx-eb-byte-access-on-halfword = <0>; | ||||
| +				intel,ixp4xx-eb-mux-address-and-data = <0>; | ||||
| +				intel,ixp4xx-eb-ahb-split-transfers = <0>; | ||||
| +				intel,ixp4xx-eb-write-enable = <1>; | ||||
| +				intel,ixp4xx-eb-byte-access = <1>; | ||||
| +				/* 512 bytes at CS2 */ | ||||
| +				reg = <2 0x00000000 0x0000200>; | ||||
| +				reg-io-width = <1>; | ||||
| +				native-endian; | ||||
| +				/* FIXME: try to check if there is an IRQ for the RTC? */ | ||||
| +			}; | ||||
| +		}; | ||||
| + | ||||
| +		pci@c0000000 { | ||||
| +			status = "okay"; | ||||
| + | ||||
| +			/* | ||||
| +			 * Taken from USR8200 boardfile from OpenWrt | ||||
| +			 * | ||||
| +			 * We have 3 slots (IDSEL) with partly swizzled IRQs on slot 16. | ||||
| +			 * We assume the same IRQ for all pins on the remaining slots, that | ||||
| +			 * is what the boardfile was doing. | ||||
| +			 */ | ||||
| +			#interrupt-cells = <1>; | ||||
| +			interrupt-map-mask = <0xf800 0 0 7>; | ||||
| +			interrupt-map = | ||||
| +			/* IDSEL 14 used for "Wireless" in the board file */ | ||||
| +			<0x7000 0 0 1 &gpio0 7  IRQ_TYPE_LEVEL_LOW>, /* INT A on slot 14 is irq 7 */ | ||||
| +			/* IDSEL 15 used for VIA VT6307 IEEE 1394 Firewire */ | ||||
| +			<0x7800 0 0 1 &gpio0 8  IRQ_TYPE_LEVEL_LOW>, /* INT A on slot 15 is irq 8 */ | ||||
| +			/* IDSEL 16 used for VIA VT6202 USB 2.0 4+1 */ | ||||
| +			<0x8000 0 0 1 &gpio0 11 IRQ_TYPE_LEVEL_LOW>, /* INT A on slot 16 is irq 11 */ | ||||
| +			<0x8000 0 0 2 &gpio0 10 IRQ_TYPE_LEVEL_LOW>, /* INT B on slot 16 is irq 10 */ | ||||
| +			<0x8000 0 0 3 &gpio0 9  IRQ_TYPE_LEVEL_LOW>; /* INT C on slot 16 is irq 9 */ | ||||
| +		}; | ||||
| + | ||||
| +		gpio@c8004000 { | ||||
| +			/* Enable clock out on GPIO 15 */ | ||||
| +			intel,ixp4xx-gpio15-clkout; | ||||
| +		}; | ||||
| + | ||||
| +		/* EthB WAN */ | ||||
| +		ethernet@c8009000 { | ||||
| +			status = "okay"; | ||||
| +			queue-rx = <&qmgr 3>; | ||||
| +			queue-txready = <&qmgr 20>; | ||||
| +			phy-mode = "rgmii"; | ||||
| +			phy-handle = <&phy9>; | ||||
| + | ||||
| +			mdio { | ||||
| +				#address-cells = <1>; | ||||
| +				#size-cells = <0>; | ||||
| + | ||||
| +				phy9: ethernet-phy@9 { | ||||
| +					reg = <9>; | ||||
| +				}; | ||||
| + | ||||
| +				/* The switch uses MDIO addresses 16 thru 31 */ | ||||
| +				switch@16 { | ||||
| +					compatible = "marvell,mv88e6060"; | ||||
| +					reg = <16>; | ||||
| + | ||||
| +					ports { | ||||
| +						#address-cells = <1>; | ||||
| +						#size-cells = <0>; | ||||
| + | ||||
| +						port@0 { | ||||
| +							reg = <0>; | ||||
| +							label = "lan1"; | ||||
| +						}; | ||||
| + | ||||
| +						port@1 { | ||||
| +							reg = <1>; | ||||
| +							label = "lan2"; | ||||
| +						}; | ||||
| + | ||||
| +						port@2 { | ||||
| +							reg = <2>; | ||||
| +							label = "lan3"; | ||||
| +						}; | ||||
| + | ||||
| +						port@3 { | ||||
| +							reg = <3>; | ||||
| +							label = "lan4"; | ||||
| +						}; | ||||
| + | ||||
| +						port@5 { | ||||
| +							/* Port 5 is the CPU port according to the MV88E6060 datasheet */ | ||||
| +							reg = <5>; | ||||
| +							phy-mode = "rgmii-id"; | ||||
| +							ethernet = <ðc>; | ||||
| +							label = "cpu"; | ||||
| +							fixed-link { | ||||
| +								speed = <100>; | ||||
| +								full-duplex; | ||||
| +							}; | ||||
| +						}; | ||||
| +					}; | ||||
| +				}; | ||||
| +			}; | ||||
| +		}; | ||||
| + | ||||
| +		/* EthC LAN connected to the Marvell DSA Switch */ | ||||
| +		ethc: ethernet@c800a000 { | ||||
| +			status = "okay"; | ||||
| +			queue-rx = <&qmgr 4>; | ||||
| +			queue-txready = <&qmgr 21>; | ||||
| +			phy-mode = "rgmii"; | ||||
| +			fixed-link { | ||||
| +				speed = <100>; | ||||
| +				full-duplex; | ||||
| +			}; | ||||
| +		}; | ||||
| +	}; | ||||
| +}; | ||||
| @@ -0,0 +1,69 @@ | ||||
| From 98f3b5f44b9ae86c4a80185b57149867472a2570 Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Fri, 20 Oct 2023 15:11:41 +0200 | ||||
| Subject: [PATCH] ARM: dts: usr8200: Fix phy registers | ||||
|  | ||||
| The MV88E6060 switch has internal PHY registers at MDIO | ||||
| addresses 0x00..0x04. Tie each port to the corresponding | ||||
| PHY. | ||||
|  | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| Link: https://lore.kernel.org/r/20231020-ixp4xx-usr8200-dtsfix-v1-1-3a8591dea259@linaro.org | ||||
| Signed-off-by: Arnd Bergmann <arnd@arndb.de> | ||||
| --- | ||||
|  .../ixp/intel-ixp42x-usrobotics-usr8200.dts   | 22 +++++++++++++++++++ | ||||
|  1 file changed, 22 insertions(+) | ||||
|  | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-usrobotics-usr8200.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-usrobotics-usr8200.dts | ||||
| @@ -165,6 +165,24 @@ | ||||
|  				#address-cells = <1>; | ||||
|  				#size-cells = <0>; | ||||
|   | ||||
| +				/* | ||||
| +				 * PHY 0..4 are internal to the MV88E6060 switch but appear | ||||
| +				 * as independent devices. | ||||
| +				 */ | ||||
| +				phy0: ethernet-phy@0 { | ||||
| +					reg = <0>; | ||||
| +				}; | ||||
| +				phy1: ethernet-phy@1 { | ||||
| +					reg = <1>; | ||||
| +				}; | ||||
| +				phy2: ethernet-phy@2 { | ||||
| +					reg = <2>; | ||||
| +				}; | ||||
| +				phy3: ethernet-phy@3 { | ||||
| +					reg = <3>; | ||||
| +				}; | ||||
| + | ||||
| +				/* Altima AMI101L used by the WAN port */ | ||||
|  				phy9: ethernet-phy@9 { | ||||
|  					reg = <9>; | ||||
|  				}; | ||||
| @@ -181,21 +199,25 @@ | ||||
|  						port@0 { | ||||
|  							reg = <0>; | ||||
|  							label = "lan1"; | ||||
| +							phy-handle = <&phy0>; | ||||
|  						}; | ||||
|   | ||||
|  						port@1 { | ||||
|  							reg = <1>; | ||||
|  							label = "lan2"; | ||||
| +							phy-handle = <&phy1>; | ||||
|  						}; | ||||
|   | ||||
|  						port@2 { | ||||
|  							reg = <2>; | ||||
|  							label = "lan3"; | ||||
| +							phy-handle = <&phy2>; | ||||
|  						}; | ||||
|   | ||||
|  						port@3 { | ||||
|  							reg = <3>; | ||||
|  							label = "lan4"; | ||||
| +							phy-handle = <&phy3>; | ||||
|  						}; | ||||
|   | ||||
|  						port@5 { | ||||
| @@ -0,0 +1,25 @@ | ||||
| From 89eccb6726d93c9c78997e91bd641b0e46bc3c5f Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Fri, 8 Sep 2023 12:49:48 +0200 | ||||
| Subject: [PATCH] ARM: dts: ixp4xx-nslu2: Enable write on flash | ||||
|  | ||||
| To upgrade the firmware and similar, the flash needs write | ||||
| access. | ||||
|  | ||||
| Link: https://lore.kernel.org/r/20230908-ixp4xx-dts-v1-1-98d36264ed6d@linaro.org | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | 2 ++ | ||||
|  1 file changed, 2 insertions(+) | ||||
|  | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| @@ -101,6 +101,8 @@ | ||||
|  			flash@0,0 { | ||||
|  				compatible = "intel,ixp4xx-flash", "cfi-flash"; | ||||
|  				bank-width = <2>; | ||||
| +				/* Enable writes on the expansion bus */ | ||||
| +				intel,ixp4xx-eb-write-enable = <1>; | ||||
|  				/* | ||||
|  				 * 8 MB of Flash in 0x20000 byte blocks | ||||
|  				 * mapped in at CS0. | ||||
| @@ -0,0 +1,62 @@ | ||||
| From deb93908958e74dffbef1ce6a1cc2f82ac4f96ed Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Fri, 8 Sep 2023 12:49:49 +0200 | ||||
| Subject: [PATCH] ARM: dts: ixp4xx: Use right restart keycode | ||||
|  | ||||
| The "reset" key on a few IXP4xx routers were sending KEY_ESC | ||||
| but what we want to send is KEY_RESTART which will make | ||||
| OpenWrt and similar userspace do a controlled reboot. | ||||
|  | ||||
| Link: https://lore.kernel.org/r/20230908-ixp4xx-dts-v1-2-98d36264ed6d@linaro.org | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-dlink-dsm-g600.dts | 2 +- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-freecom-fsg-3.dts  | 2 +- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-iomega-nas100d.dts | 2 +- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts  | 2 +- | ||||
|  4 files changed, 4 insertions(+), 4 deletions(-) | ||||
|  | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-dlink-dsm-g600.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-dlink-dsm-g600.dts | ||||
| @@ -57,7 +57,7 @@ | ||||
|   | ||||
|  		button-reset { | ||||
|  			wakeup-source; | ||||
| -			linux,code = <KEY_ESC>; | ||||
| +			linux,code = <KEY_RESTART>; | ||||
|  			label = "reset"; | ||||
|  			gpios = <&gpio0 3 GPIO_ACTIVE_LOW>; | ||||
|  		}; | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-freecom-fsg-3.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-freecom-fsg-3.dts | ||||
| @@ -44,7 +44,7 @@ | ||||
|  		}; | ||||
|  		button-reset { | ||||
|  			wakeup-source; | ||||
| -			linux,code = <KEY_ESC>; | ||||
| +			linux,code = <KEY_RESTART>; | ||||
|  			label = "reset"; | ||||
|  			gpios = <&gpio0 9 GPIO_ACTIVE_LOW>; | ||||
|  		}; | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-iomega-nas100d.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-iomega-nas100d.dts | ||||
| @@ -63,7 +63,7 @@ | ||||
|  		}; | ||||
|  		button-reset { | ||||
|  			wakeup-source; | ||||
| -			linux,code = <KEY_ESC>; | ||||
| +			linux,code = <KEY_RESTART>; | ||||
|  			label = "reset"; | ||||
|  			gpios = <&gpio0 4 GPIO_ACTIVE_LOW>; | ||||
|  		}; | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| @@ -65,7 +65,7 @@ | ||||
|  		}; | ||||
|  		button-reset { | ||||
|  			wakeup-source; | ||||
| -			linux,code = <KEY_ESC>; | ||||
| +			linux,code = <KEY_RESTART>; | ||||
|  			label = "reset"; | ||||
|  			gpios = <&gpio0 12 GPIO_ACTIVE_LOW>; | ||||
|  		}; | ||||
| @@ -0,0 +1,24 @@ | ||||
| From 6484f966af53447deefcd4b805c201d8624981cb Mon Sep 17 00:00:00 2001 | ||||
| From: Linus Walleij <linus.walleij@linaro.org> | ||||
| Date: Mon, 29 May 2023 23:32:44 +0200 | ||||
| Subject: [PATCH] ARM: dts: ixp4xx: Boot NSLU2 from harddrive | ||||
|  | ||||
| This enforces harddrive boot on the NSLU2. The flash is too small | ||||
| to hold any rootfs these days. | ||||
|  | ||||
| Signed-off-by: Linus Walleij <linus.walleij@linaro.org> | ||||
| --- | ||||
|  arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | 2 +- | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
|  | ||||
| --- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| +++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-nslu2.dts | ||||
| @@ -21,7 +21,7 @@ | ||||
|  	}; | ||||
|   | ||||
|  	chosen { | ||||
| -		bootargs = "console=ttyS0,115200n8 root=/dev/mtdblock2 rw rootfstype=squashfs,jffs2 rootwait"; | ||||
| +		bootargs = "console=ttyS0,115200n8 root=/dev/sda1 rw rootwait"; | ||||
|  		stdout-path = "uart0:115200n8"; | ||||
|  	}; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico