[lantiq] remove 3.3 and 3.6
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@34699 3c298f89-4303-0410-b956-a3cf2f4a3e73master
parent
dc4a41291d
commit
4257df4d28
|
@ -1,48 +0,0 @@
|
|||
CONFIG_ADM6996_PHY=y
|
||||
CONFIG_AR8216_PHY=y
|
||||
CONFIG_CLKDEV_LOOKUP=y
|
||||
CONFIG_FSNOTIFY=y
|
||||
CONFIG_HAVE_MACH_CLKDEV=y
|
||||
CONFIG_HOTPLUG_PCI=y
|
||||
# CONFIG_HOTPLUG_PCI_CPCI is not set
|
||||
CONFIG_HOTPLUG_PCI_FAKE=y
|
||||
# CONFIG_HOTPLUG_PCI_SHPC is not set
|
||||
CONFIG_HW_HAS_PCI=y
|
||||
CONFIG_INPUT=y
|
||||
CONFIG_INPUT_EVDEV=y
|
||||
CONFIG_INPUT_POLLDEV=y
|
||||
CONFIG_IRQ_FORCED_THREADING=y
|
||||
# CONFIG_ISDN is not set
|
||||
CONFIG_LANTIQ_ETOP=y
|
||||
# CONFIG_LANTIQ_MACH_ARV is not set
|
||||
# CONFIG_LANTIQ_MACH_EASY50712 is not set
|
||||
CONFIG_LANTIQ_MACH_FRITZ_AR9=y
|
||||
# CONFIG_LANTIQ_MACH_FRITZ_VR9 is not set
|
||||
# CONFIG_LANTIQ_MACH_GIGASX76X is not set
|
||||
CONFIG_LANTIQ_MACH_H201L=y
|
||||
CONFIG_LANTIQ_MACH_NETGEAR=y
|
||||
CONFIG_LANTIQ_MACH_P2601HNFX=y
|
||||
CONFIG_LANTIQ_MACH_WBMR=y
|
||||
# CONFIG_LANTIQ_VRX200 is not set
|
||||
CONFIG_M25PXX_USE_FAST_READ=y
|
||||
CONFIG_MDIO_BOARDINFO=y
|
||||
CONFIG_MTD_BLOCK2MTD=y
|
||||
CONFIG_MTD_M25P80=y
|
||||
CONFIG_PCI=y
|
||||
# CONFIG_PCIEPORTBUS is not set
|
||||
# CONFIG_PCIE_LANTIQ is not set
|
||||
CONFIG_PCI_DOMAINS=y
|
||||
CONFIG_PCI_LANTIQ=y
|
||||
# CONFIG_PCI_LANTIQ_NONE is not set
|
||||
CONFIG_RTL8306_PHY=y
|
||||
# CONFIG_SOC_AMAZON_SE is not set
|
||||
# CONFIG_SOC_FALCON is not set
|
||||
# CONFIG_SOC_SVIP is not set
|
||||
CONFIG_SOC_TYPE_XWAY=y
|
||||
CONFIG_SOC_XWAY=y
|
||||
CONFIG_SPI=y
|
||||
CONFIG_SPI_BITBANG=y
|
||||
CONFIG_SPI_GPIO=y
|
||||
CONFIG_SPI_MASTER=y
|
||||
CONFIG_USB_ARCH_HAS_XHCI=y
|
||||
CONFIG_USB_SUPPORT=y
|
|
@ -1,5 +0,0 @@
|
|||
define Profile/Generic
|
||||
NAME:=Generic - all boards
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,Generic))
|
|
@ -1,10 +0,0 @@
|
|||
define Profile/EASY50812
|
||||
NAME:=EASY50812 - Eval Board
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg
|
||||
endef
|
||||
|
||||
define Profile/EASY50812/Description
|
||||
Lantiq EASY50812 evalkit
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,EASY50812))
|
|
@ -1,11 +0,0 @@
|
|||
define Profile/DGN3500B
|
||||
NAME:=DGN3500B Netgear
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ath9k kmod-ltq-dsl-firmware-b-ar9
|
||||
endef
|
||||
|
||||
define Profile/DGN3500B/Description
|
||||
Netgear DGN3500B
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,DGN3500B))
|
||||
|
|
@ -1,11 +0,0 @@
|
|||
define Profile/WBMR
|
||||
NAME:=WBMR - Buffalo WBMR-HP-G300H
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ltq-dsl-firmware-b-ar9
|
||||
endef
|
||||
|
||||
define Profile/WBMR/Description
|
||||
Package set optimized for the Buffalo WBMR routers
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,WBMR))
|
|
@ -1,7 +0,0 @@
|
|||
define Profile/FRITZ7320
|
||||
NAME:=FRITZ7320 Fritzbox
|
||||
PACKAGES:= kmod-usb-core kmod-usb-ifxhcd kmod-ledtrig-usbdev \
|
||||
kmod-ltq-dsl-firmware-b-ar9 kmod-ath9k wpad-mini
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,FRITZ7320))
|
|
@ -1,7 +0,0 @@
|
|||
define Profile/P2601HNFX
|
||||
NAME:=P2601HNFX - ZyXEL P-2601HN-Fx
|
||||
PACKAGES:= kmod-usb-dwc-otg kmod-rt2800-usb wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-ar9
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,P2601HNFX))
|
|
@ -1,7 +0,0 @@
|
|||
define Profile/H201L
|
||||
NAME:=H201L - ZTE ZXV10
|
||||
PACKAGES:= kmod-usb-dwc-otg kmod-ath9k-htc wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-ar9
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,H201L))
|
|
@ -1,12 +0,0 @@
|
|||
ARCH:=mips
|
||||
SUBTARGET:=ar9
|
||||
BOARDNAME:=AR9
|
||||
FEATURES:=squashfs jffs2 atm
|
||||
|
||||
DEFAULT_PACKAGES+=kmod-pppoa ppp-mod-pppoa linux-atm atm-tools br2684ctl kmod-ltq-dsl-ar9 ltq-dsl-app \
|
||||
kmod-input-gpio-keys-polled kmod-ledtrig-netdev kmod-leds-gpio kmod-button-hotplug \
|
||||
swconfig
|
||||
|
||||
define Target/Description
|
||||
Lantiq AR9
|
||||
endef
|
|
@ -1,109 +0,0 @@
|
|||
CONFIG_ARCH_BINFMT_ELF_RANDOMIZE_PIE=y
|
||||
CONFIG_ARCH_DISCARD_MEMBLOCK=y
|
||||
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
|
||||
CONFIG_ARCH_POPULATES_NODE_MAP=y
|
||||
CONFIG_ARCH_REQUIRE_GPIOLIB=y
|
||||
CONFIG_ARCH_SUPPORTS_OPROFILE=y
|
||||
CONFIG_ARCH_SUSPEND_POSSIBLE=y
|
||||
# CONFIG_BRCMUTIL is not set
|
||||
CONFIG_CEVT_R4K=y
|
||||
CONFIG_CEVT_R4K_LIB=y
|
||||
CONFIG_CPU_BIG_ENDIAN=y
|
||||
CONFIG_CPU_HAS_PREFETCH=y
|
||||
CONFIG_CPU_HAS_SYNC=y
|
||||
CONFIG_CPU_MIPS32=y
|
||||
# CONFIG_CPU_MIPS32_R1 is not set
|
||||
CONFIG_CPU_MIPS32_R2=y
|
||||
CONFIG_CPU_MIPSR2=y
|
||||
CONFIG_CPU_SUPPORTS_32BIT_KERNEL=y
|
||||
CONFIG_CPU_SUPPORTS_HIGHMEM=y
|
||||
CONFIG_CSRC_R4K=y
|
||||
CONFIG_CSRC_R4K_LIB=y
|
||||
CONFIG_DECOMPRESS_LZMA=y
|
||||
CONFIG_DMA_NONCOHERENT=y
|
||||
CONFIG_EARLY_PRINTK=y
|
||||
CONFIG_ETHERNET_PACKET_MANGLE=y
|
||||
# CONFIG_FSNOTIFY is not set
|
||||
CONFIG_GENERIC_ATOMIC64=y
|
||||
CONFIG_GENERIC_CLOCKEVENTS=y
|
||||
CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
|
||||
CONFIG_GENERIC_CMOS_UPDATE=y
|
||||
CONFIG_GENERIC_GPIO=y
|
||||
CONFIG_GENERIC_IRQ_SHOW=y
|
||||
CONFIG_GENERIC_PCI_IOMAP=y
|
||||
CONFIG_GPIOLIB=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_HARDWARE_WATCHPOINTS=y
|
||||
CONFIG_HAS_DMA=y
|
||||
CONFIG_HAS_IOMEM=y
|
||||
CONFIG_HAS_IOPORT=y
|
||||
CONFIG_HAVE_ARCH_JUMP_LABEL=y
|
||||
CONFIG_HAVE_ARCH_KGDB=y
|
||||
CONFIG_HAVE_CLK=y
|
||||
CONFIG_HAVE_C_RECORDMCOUNT=y
|
||||
CONFIG_HAVE_DMA_API_DEBUG=y
|
||||
CONFIG_HAVE_DMA_ATTRS=y
|
||||
CONFIG_HAVE_DYNAMIC_FTRACE=y
|
||||
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
|
||||
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
|
||||
CONFIG_HAVE_FUNCTION_TRACER=y
|
||||
CONFIG_HAVE_FUNCTION_TRACE_MCOUNT_TEST=y
|
||||
CONFIG_HAVE_GENERIC_DMA_COHERENT=y
|
||||
CONFIG_HAVE_GENERIC_HARDIRQS=y
|
||||
CONFIG_HAVE_IDE=y
|
||||
CONFIG_HAVE_IRQ_WORK=y
|
||||
CONFIG_HAVE_MEMBLOCK=y
|
||||
CONFIG_HAVE_MEMBLOCK_NODE_MAP=y
|
||||
CONFIG_HAVE_OPROFILE=y
|
||||
CONFIG_HAVE_PERF_EVENTS=y
|
||||
CONFIG_HW_RANDOM=y
|
||||
CONFIG_HZ=250
|
||||
# CONFIG_HZ_100 is not set
|
||||
CONFIG_HZ_250=y
|
||||
CONFIG_IFX_UDP_REDIRECT=y
|
||||
CONFIG_IMAGE_CMDLINE_HACK=y
|
||||
CONFIG_INITRAMFS_SOURCE=""
|
||||
CONFIG_IRQ_CPU=y
|
||||
CONFIG_LANTIQ=y
|
||||
CONFIG_LANTIQ_MACH_95C3AM1=y
|
||||
CONFIG_LANTIQ_MACH_EASY98000=y
|
||||
CONFIG_LANTIQ_MACH_EASY98020=y
|
||||
CONFIG_LANTIQ_WDT=y
|
||||
CONFIG_LEDS_GPIO=y
|
||||
CONFIG_MACH_NO_WESTBRIDGE=y
|
||||
CONFIG_MIPS=y
|
||||
CONFIG_MIPS_L1_CACHE_SHIFT=5
|
||||
CONFIG_MIPS_MACHINE=y
|
||||
CONFIG_MIPS_MT_DISABLED=y
|
||||
# CONFIG_MIPS_MT_SMP is not set
|
||||
# CONFIG_MIPS_MT_SMTC is not set
|
||||
# CONFIG_MIPS_VPE_LOADER is not set
|
||||
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||
CONFIG_MTD_CFI_GEOMETRY=y
|
||||
CONFIG_MTD_CMDLINE_PARTS=y
|
||||
CONFIG_MTD_LANTIQ=y
|
||||
CONFIG_MTD_UIMAGE_SPLIT=y
|
||||
CONFIG_NEED_DMA_MAP_STATE=y
|
||||
CONFIG_NEED_PER_CPU_KM=y
|
||||
CONFIG_NO_GENERIC_PCI_IOPORT_MAP=y
|
||||
CONFIG_PAGEFLAGS_EXTENDED=y
|
||||
CONFIG_PERF_USE_VMALLOC=y
|
||||
CONFIG_PHYLIB=y
|
||||
# CONFIG_PREEMPT_RCU is not set
|
||||
CONFIG_PSB6970_PHY=y
|
||||
CONFIG_RTL8366RB_PHY=y
|
||||
# CONFIG_RTL8366S_PHY_DEBUG_FS is not set
|
||||
CONFIG_RTL8366_SMI=y
|
||||
# CONFIG_SCSI_DMA is not set
|
||||
# CONFIG_SERIAL_8250 is not set
|
||||
CONFIG_SERIAL_LANTIQ=y
|
||||
CONFIG_SWAP_IO_SPACE=y
|
||||
CONFIG_SWCONFIG=y
|
||||
CONFIG_SYS_HAS_CPU_MIPS32_R1=y
|
||||
CONFIG_SYS_HAS_CPU_MIPS32_R2=y
|
||||
CONFIG_SYS_HAS_EARLY_PRINTK=y
|
||||
CONFIG_SYS_SUPPORTS_32BIT_KERNEL=y
|
||||
CONFIG_SYS_SUPPORTS_ARBIT_HZ=y
|
||||
CONFIG_SYS_SUPPORTS_BIG_ENDIAN=y
|
||||
CONFIG_SYS_SUPPORTS_MULTITHREADING=y
|
||||
CONFIG_ZONE_DMA_FLAG=0
|
|
@ -1,148 +0,0 @@
|
|||
CONFIG_ARCH_BINFMT_ELF_RANDOMIZE_PIE=y
|
||||
CONFIG_ARCH_DISCARD_MEMBLOCK=y
|
||||
CONFIG_ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE=y
|
||||
CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y
|
||||
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
|
||||
CONFIG_ARCH_REQUIRE_GPIOLIB=y
|
||||
CONFIG_ARCH_SUSPEND_POSSIBLE=y
|
||||
CONFIG_ARCH_WANT_IPC_PARSE_VERSION=y
|
||||
CONFIG_CEVT_R4K=y
|
||||
CONFIG_CEVT_R4K_LIB=y
|
||||
CONFIG_CLKDEV_LOOKUP=y
|
||||
CONFIG_CPU_BIG_ENDIAN=y
|
||||
CONFIG_CPU_HAS_PREFETCH=y
|
||||
CONFIG_CPU_HAS_SYNC=y
|
||||
CONFIG_CPU_MIPS32=y
|
||||
# CONFIG_CPU_MIPS32_R1 is not set
|
||||
CONFIG_CPU_MIPS32_R2=y
|
||||
CONFIG_CPU_MIPSR2=y
|
||||
CONFIG_CPU_SUPPORTS_32BIT_KERNEL=y
|
||||
CONFIG_CPU_SUPPORTS_HIGHMEM=y
|
||||
CONFIG_CSRC_R4K=y
|
||||
CONFIG_CSRC_R4K_LIB=y
|
||||
# CONFIG_DEBUG_PINCTRL is not set
|
||||
CONFIG_DECOMPRESS_LZMA=y
|
||||
CONFIG_DMA_NONCOHERENT=y
|
||||
CONFIG_DTC=y
|
||||
# CONFIG_DT_EASY50712 is not set
|
||||
CONFIG_DT_EASY80920=y
|
||||
CONFIG_EARLY_PRINTK=y
|
||||
CONFIG_ETHERNET_PACKET_MANGLE=y
|
||||
CONFIG_GENERIC_ATOMIC64=y
|
||||
CONFIG_GENERIC_CLOCKEVENTS=y
|
||||
CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
|
||||
CONFIG_GENERIC_CMOS_UPDATE=y
|
||||
CONFIG_GENERIC_GPIO=y
|
||||
CONFIG_GENERIC_IO=y
|
||||
CONFIG_GENERIC_IRQ_SHOW=y
|
||||
CONFIG_GENERIC_PCI_IOMAP=y
|
||||
CONFIG_GENERIC_SMP_IDLE_THREAD=y
|
||||
CONFIG_GPIOLIB=y
|
||||
CONFIG_GPIO_MM_LANTIQ=y
|
||||
CONFIG_GPIO_STP_XWAY=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_HARDWARE_WATCHPOINTS=y
|
||||
CONFIG_HAS_DMA=y
|
||||
CONFIG_HAS_IOMEM=y
|
||||
CONFIG_HAS_IOPORT=y
|
||||
CONFIG_HAVE_ARCH_JUMP_LABEL=y
|
||||
CONFIG_HAVE_ARCH_KGDB=y
|
||||
CONFIG_HAVE_CLK=y
|
||||
CONFIG_HAVE_C_RECORDMCOUNT=y
|
||||
CONFIG_HAVE_DMA_API_DEBUG=y
|
||||
CONFIG_HAVE_DMA_ATTRS=y
|
||||
CONFIG_HAVE_DYNAMIC_FTRACE=y
|
||||
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
|
||||
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
|
||||
CONFIG_HAVE_FUNCTION_TRACER=y
|
||||
CONFIG_HAVE_FUNCTION_TRACE_MCOUNT_TEST=y
|
||||
CONFIG_HAVE_GENERIC_DMA_COHERENT=y
|
||||
CONFIG_HAVE_GENERIC_HARDIRQS=y
|
||||
CONFIG_HAVE_IDE=y
|
||||
CONFIG_HAVE_IRQ_WORK=y
|
||||
CONFIG_HAVE_MACH_CLKDEV=y
|
||||
CONFIG_HAVE_MEMBLOCK=y
|
||||
CONFIG_HAVE_MEMBLOCK_NODE_MAP=y
|
||||
CONFIG_HAVE_OPROFILE=y
|
||||
CONFIG_HAVE_PERF_EVENTS=y
|
||||
CONFIG_HW_HAS_PCI=y
|
||||
CONFIG_HW_RANDOM=y
|
||||
CONFIG_HZ=250
|
||||
# CONFIG_HZ_100 is not set
|
||||
CONFIG_HZ_250=y
|
||||
CONFIG_INITRAMFS_SOURCE=""
|
||||
CONFIG_IRQ_CPU=y
|
||||
CONFIG_IRQ_DOMAIN=y
|
||||
CONFIG_IRQ_FORCED_THREADING=y
|
||||
CONFIG_LANTIQ=y
|
||||
CONFIG_LANTIQ_ETOP=y
|
||||
CONFIG_LANTIQ_PHY=y
|
||||
CONFIG_LANTIQ_WDT=y
|
||||
CONFIG_LANTIQ_XRX200=y
|
||||
CONFIG_LEDS_GPIO=y
|
||||
CONFIG_MDIO_BOARDINFO=y
|
||||
# CONFIG_MDIO_BUS_MUX_GPIO is not set
|
||||
CONFIG_MIPS=y
|
||||
CONFIG_MIPS_L1_CACHE_SHIFT=5
|
||||
# CONFIG_MIPS_MACHINE is not set
|
||||
CONFIG_MIPS_MT_DISABLED=y
|
||||
# CONFIG_MIPS_MT_SMP is not set
|
||||
# CONFIG_MIPS_MT_SMTC is not set
|
||||
# CONFIG_MIPS_VPE_LOADER is not set
|
||||
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||
CONFIG_MTD_CFI_GEOMETRY=y
|
||||
CONFIG_MTD_CMDLINE_PARTS=y
|
||||
CONFIG_MTD_LANTIQ=y
|
||||
CONFIG_MTD_OF_PARTS=y
|
||||
CONFIG_MTD_PHYSMAP_OF=y
|
||||
CONFIG_NEED_DMA_MAP_STATE=y
|
||||
CONFIG_NEED_PER_CPU_KM=y
|
||||
CONFIG_NO_GENERIC_PCI_IOPORT_MAP=y
|
||||
CONFIG_OF=y
|
||||
CONFIG_OF_ADDRESS=y
|
||||
CONFIG_OF_DEVICE=y
|
||||
CONFIG_OF_EARLY_FLATTREE=y
|
||||
CONFIG_OF_FLATTREE=y
|
||||
CONFIG_OF_GPIO=y
|
||||
CONFIG_OF_IRQ=y
|
||||
CONFIG_OF_MDIO=y
|
||||
CONFIG_OF_MTD=y
|
||||
CONFIG_OF_NET=y
|
||||
CONFIG_OF_PCI=y
|
||||
CONFIG_OF_PCI_IRQ=y
|
||||
CONFIG_PAGEFLAGS_EXTENDED=y
|
||||
CONFIG_PCI=y
|
||||
CONFIG_PCI_DOMAINS=y
|
||||
CONFIG_PCI_LANTIQ=y
|
||||
CONFIG_PERF_USE_VMALLOC=y
|
||||
CONFIG_PHYLIB=y
|
||||
CONFIG_PINCONF=y
|
||||
CONFIG_PINCTRL=y
|
||||
CONFIG_PINCTRL_LANTIQ=y
|
||||
# CONFIG_PINCTRL_SINGLE is not set
|
||||
CONFIG_PINCTRL_XWAY=y
|
||||
CONFIG_PINMUX=y
|
||||
# CONFIG_PREEMPT_RCU is not set
|
||||
CONFIG_PROC_DEVICETREE=y
|
||||
CONFIG_PSB6970_PHY=y
|
||||
CONFIG_RTL8366RB_PHY=y
|
||||
CONFIG_RTL8366_SMI=y
|
||||
# CONFIG_SCSI_DMA is not set
|
||||
# CONFIG_SERIAL_8250 is not set
|
||||
CONFIG_SERIAL_LANTIQ=y
|
||||
# CONFIG_SOC_AMAZON_SE is not set
|
||||
# CONFIG_SOC_FALCON is not set
|
||||
CONFIG_SOC_TYPE_XWAY=y
|
||||
CONFIG_SOC_XWAY=y
|
||||
CONFIG_SWAP_IO_SPACE=y
|
||||
CONFIG_SWCONFIG=y
|
||||
CONFIG_SYS_HAS_CPU_MIPS32_R1=y
|
||||
CONFIG_SYS_HAS_CPU_MIPS32_R2=y
|
||||
CONFIG_SYS_HAS_EARLY_PRINTK=y
|
||||
CONFIG_SYS_SUPPORTS_32BIT_KERNEL=y
|
||||
CONFIG_SYS_SUPPORTS_ARBIT_HZ=y
|
||||
CONFIG_SYS_SUPPORTS_BIG_ENDIAN=y
|
||||
CONFIG_SYS_SUPPORTS_MULTITHREADING=y
|
||||
CONFIG_USB_ARCH_HAS_XHCI=y
|
||||
CONFIG_USE_OF=y
|
||||
CONFIG_ZONE_DMA_FLAG=0
|
|
@ -1,38 +0,0 @@
|
|||
CONFIG_ADM6996_PHY=y
|
||||
CONFIG_AR8216_PHY=y
|
||||
# CONFIG_ATMEL_PWM is not set
|
||||
CONFIG_CLKDEV_LOOKUP=y
|
||||
CONFIG_FSNOTIFY=y
|
||||
CONFIG_HAVE_MACH_CLKDEV=y
|
||||
CONFIG_HW_HAS_PCI=y
|
||||
CONFIG_INPUT=y
|
||||
CONFIG_INPUT_EVDEV=y
|
||||
CONFIG_INPUT_POLLDEV=y
|
||||
CONFIG_IRQ_FORCED_THREADING=y
|
||||
# CONFIG_ISDN is not set
|
||||
CONFIG_LANTIQ_ETOP=y
|
||||
CONFIG_LANTIQ_MACH_ARV=y
|
||||
CONFIG_LANTIQ_MACH_EASY50712=y
|
||||
# CONFIG_LANTIQ_MACH_FRITZ_AR9 is not set
|
||||
# CONFIG_LANTIQ_MACH_FRITZ_VR9 is not set
|
||||
CONFIG_LANTIQ_MACH_GIGASX76X=y
|
||||
# CONFIG_LANTIQ_MACH_H201L is not set
|
||||
# CONFIG_LANTIQ_MACH_NETGEAR is not set
|
||||
# CONFIG_LANTIQ_MACH_P2601HNFX is not set
|
||||
# CONFIG_LANTIQ_MACH_WBMR is not set
|
||||
# CONFIG_LANTIQ_VRX200 is not set
|
||||
CONFIG_MDIO_BOARDINFO=y
|
||||
CONFIG_PCI=y
|
||||
# CONFIG_PCIEPORTBUS is not set
|
||||
# CONFIG_PCIE_LANTIQ is not set
|
||||
CONFIG_PCI_DOMAINS=y
|
||||
CONFIG_PCI_LANTIQ=y
|
||||
# CONFIG_PCI_LANTIQ_NONE is not set
|
||||
CONFIG_RTL8306_PHY=y
|
||||
# CONFIG_SOC_AMAZON_SE is not set
|
||||
# CONFIG_SOC_FALCON is not set
|
||||
# CONFIG_SOC_SVIP is not set
|
||||
CONFIG_SOC_TYPE_XWAY=y
|
||||
CONFIG_SOC_XWAY=y
|
||||
CONFIG_USB_ARCH_HAS_XHCI=y
|
||||
CONFIG_USB_SUPPORT=y
|
|
@ -1,5 +0,0 @@
|
|||
define Profile/Generic
|
||||
NAME:=Generic - all boards
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,Generic))
|
|
@ -1,10 +0,0 @@
|
|||
define Profile/EASY50712
|
||||
NAME:=EASY50712
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg
|
||||
endef
|
||||
|
||||
define Profile/EASY50712/Description
|
||||
Lantiq EASY50712 evalkit
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,EASY50712))
|
|
@ -1,135 +0,0 @@
|
|||
define Profile/ARV3527P
|
||||
NAME:=ARV3527P - Arcor Easybox 401
|
||||
PACKAGES:=kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV3527P/Description
|
||||
Package set optimized for the ARV3527P
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV3527P))
|
||||
|
||||
define Profile/ARV4510PW
|
||||
NAME:=ARV4510PW - Wippies Homebox
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-rt61-pci wpad-mini \
|
||||
kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV4510PW/Description
|
||||
Package set optimized for the ARV4518PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV4510PW))
|
||||
|
||||
define Profile/ARV4518PW
|
||||
NAME:=ARV4518PW - SMC7908A
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath5k wpad-mini \
|
||||
kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV4518PW/Description
|
||||
Package set optimized for the ARV4518PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV4518PW))
|
||||
|
||||
define Profile/ARV4519PW
|
||||
NAME:=ARV4519PW - Vodafone, Pirelli
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath5k wpad-mini kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV4519PW/Description
|
||||
Package set optimized for the ARV4519PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV4519PW))
|
||||
|
||||
define Profile/ARV4520PW
|
||||
NAME:=ARV4520PW - Arcor Easybox 800
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-rt61-pci wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV4520PW/Description
|
||||
Package set optimized for the ARV4520PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV4520PW))
|
||||
|
||||
define Profile/ARV4525PW
|
||||
NAME:=ARV4525PW - Speedport W502V
|
||||
PACKAGES:=kmod-ath5k wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV4525PW/Description
|
||||
Package set optimized for the ARV4525PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV4525PW))
|
||||
|
||||
define Profile/ARV7525PW
|
||||
NAME:=ARV7525PW - Speedport W303V Typ A
|
||||
PACKAGES:= kmod-rt2800-pci wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV7525PW/Description
|
||||
Package set optimized for the ARV4525PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV7525PW))
|
||||
|
||||
define Profile/ARV452CPW
|
||||
NAME:=ARV452CPW - Arcor Easybox 801
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath5k wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV452CPW/Description
|
||||
Package set optimized for the ARV452CPW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV452CPW))
|
||||
|
||||
define Profile/ARV752DPW
|
||||
NAME:=ARV752DPW - Arcor Easybox 802
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-rt2800-pci wpad-mini \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV752DPW/Description
|
||||
Package set optimized for the ARV752PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV752DPW))
|
||||
|
||||
define Profile/ARV752DPW22
|
||||
NAME:=ARV752DPW22 - Arcor Easybox 803
|
||||
PACKAGES:= kmod-usb-core kmod-usb2 kmod-usb-uhci kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV752DPW22/Description
|
||||
Package set optimized for the ARV752PW22
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV752DPW22))
|
||||
|
||||
define Profile/ARV7518PW
|
||||
NAME:=ARV7518PW - ya.com, Astoria
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath9k wpad-mini kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/ARV7518PW/Description
|
||||
Package set optimized for the ARV7518PW
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,ARV7518PW))
|
|
@ -1,12 +0,0 @@
|
|||
define Profile/GIGASX76X
|
||||
NAME:=GIGASX76X - Gigaset SX761,SX762,SX763
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath5k wpad-mini kmod-ltq-dsl-firmware-a-danube \
|
||||
kmod-ltq-dsl-firmware-b-danube
|
||||
endef
|
||||
|
||||
define Profile/GIGASX76X/Description
|
||||
Package set optimized for the Gigaset SX76X routers
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,GIGASX76X))
|
|
@ -1,23 +0,0 @@
|
|||
define Profile/BTHOMEHUBV2B
|
||||
NAME:=BTHOMEHUBV2B - BT Homehub V2.0 Type B
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath9k wpad-mini kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/BTHOMEHUBV2B/Description
|
||||
Package set optimized for the BT Homehub V2.0 Type B using whole nand for OpenWRT
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,BTHOMEHUBV2B))
|
||||
|
||||
define Profile/BTHOMEHUBV2BOPENRG
|
||||
NAME:=BTHOMEHUBV2B - BT Homehub V2.0 Type B (OpenRG)
|
||||
PACKAGES:= kmod-usb-core kmod-usb-dwc-otg kmod-ledtrig-usbdev \
|
||||
kmod-ath9k wpad-mini kmod-ltq-dsl-firmware-a-danube
|
||||
endef
|
||||
|
||||
define Profile/BTHOMEHUBV2BOPENRG/Description
|
||||
Package set optimized for the BT Homehub V2.0 Type B but retaining OpenRG image
|
||||
endef
|
||||
|
||||
$(eval $(call Profile,BTHOMEHUBV2BOPENRG))
|
|
@ -1,12 +0,0 @@
|
|||
ARCH:=mips
|
||||
SUBTARGET:=danube
|
||||
BOARDNAME:=Danube
|
||||
FEATURES:=squashfs jffs2 atm
|
||||
|
||||
DEFAULT_PACKAGES+=kmod-pppoa ppp-mod-pppoa linux-atm atm-tools br2684ctl kmod-ltq-dsl-danube ltq-dsl-app \
|
||||
kmod-input-gpio-keys-polled kmod-ledtrig-netdev kmod-leds-gpio kmod-button-hotplug \
|
||||
swconfig
|
||||
|
||||
define Target/Description
|
||||
Lantiq Danube/Twinpass
|
||||
endef
|
|
@ -1,67 +0,0 @@
|
|||
CONFIG_LANTIQ=y
|
||||
CONFIG_SOC_AMAZON_SE=y
|
||||
CONFIG_CPU_MIPS32_R2=y
|
||||
CONFIG_HIGH_RES_TIMERS=y
|
||||
CONFIG_EXPERIMENTAL=y
|
||||
CONFIG_DEFAULT_HOSTNAME="amazon_se"
|
||||
CONFIG_SYSVIPC=y
|
||||
CONFIG_LOG_BUF_SHIFT=14
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_INITRAMFS_SOURCE="../root-lantiq/ ../root-lantiq/initramfs-base-files.txt"
|
||||
CONFIG_INITRAMFS_ROOT_UID=1000
|
||||
CONFIG_INITRAMFS_ROOT_GID=1000
|
||||
+# CONFIG_RD_GZIP is not set
|
||||
CONFIG_RD_LZMA=y
|
||||
CONFIG_EMBEDDED=y
|
||||
CONFIG_SLAB=y
|
||||
CONFIG_MODULES=y
|
||||
CONFIG_MODULE_UNLOAD=y
|
||||
CONFIG_DEFAULT_DEADLINE=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_MULTICAST=y
|
||||
CONFIG_IP_ADVANCED_ROUTER=y
|
||||
CONFIG_IP_MULTIPLE_TABLES=y
|
||||
CONFIG_IP_ROUTE_MULTIPATH=y
|
||||
CONFIG_IP_ROUTE_VERBOSE=y
|
||||
CONFIG_IP_MROUTE=y
|
||||
CONFIG_IP_MROUTE_MULTIPLE_TABLES=y
|
||||
CONFIG_ARPD=y
|
||||
CONFIG_SYN_COOKIES=y
|
||||
CONFIG_NETFILTER=y
|
||||
CONFIG_BRIDGE=m
|
||||
CONFIG_VLAN_8021Q=y
|
||||
CONFIG_NET_SCHED=y
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_MTD=y
|
||||
CONFIG_MTD_CMDLINE_PARTS=y
|
||||
CONFIG_MTD_CHAR=y
|
||||
CONFIG_MTD_BLOCK=y
|
||||
CONFIG_MTD_CFI=y
|
||||
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||
CONFIG_MTD_CFI_GEOMETRY=y
|
||||
CONFIG_MTD_CFI_INTELEXT=y
|
||||
CONFIG_MTD_CFI_AMDSTD=y
|
||||
CONFIG_MTD_COMPLEX_MAPPINGS=y
|
||||
CONFIG_MTD_LANTIQ=y
|
||||
CONFIG_MISC_DEVICES=y
|
||||
CONFIG_NETDEVICES=y
|
||||
CONFIG_MII=y
|
||||
CONFIG_LANTIQ_ETOP=y
|
||||
CONFIG_PHYLIB=y
|
||||
CONFIG_SERIAL_LANTIQ=y
|
||||
CONFIG_PINCTRL=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_WATCHDOG=y
|
||||
CONFIG_LANTIQ_WDT=y
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_JFFS2_FS=y
|
||||
CONFIG_JFFS2_SUMMARY=y
|
||||
CONFIG_JFFS2_FS_XATTR=y
|
||||
CONFIG_JFFS2_COMPRESSION_OPTIONS=y
|
||||
CONFIG_SQUASHFS=y
|
||||
CONFIG_SQUASHFS_XZ=y
|
||||
CONFIG_STRIP_ASM_SYMS=y
|
||||
CONFIG_DEBUG_FS=y
|
|
@ -1,72 +0,0 @@
|
|||
CONFIG_LANTIQ=y
|
||||
CONFIG_SOC_FALCON=y
|
||||
CONFIG_CPU_MIPS32_R2=y
|
||||
CONFIG_HIGH_RES_TIMERS=y
|
||||
CONFIG_EXPERIMENTAL=y
|
||||
CONFIG_DEFAULT_HOSTNAME="falcon"
|
||||
CONFIG_SYSVIPC=y
|
||||
CONFIG_LOG_BUF_SHIFT=14
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_INITRAMFS_SOURCE="../root-lantiq/ ../root-lantiq/initramfs-base-files.txt"
|
||||
CONFIG_INITRAMFS_ROOT_UID=1000
|
||||
CONFIG_INITRAMFS_ROOT_GID=1000
|
||||
+# CONFIG_RD_GZIP is not set
|
||||
CONFIG_RD_LZMA=y
|
||||
CONFIG_EMBEDDED=y
|
||||
CONFIG_SLAB=y
|
||||
CONFIG_MODULES=y
|
||||
CONFIG_MODULE_UNLOAD=y
|
||||
CONFIG_DEFAULT_DEADLINE=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_MULTICAST=y
|
||||
CONFIG_IP_ADVANCED_ROUTER=y
|
||||
CONFIG_IP_MULTIPLE_TABLES=y
|
||||
CONFIG_IP_ROUTE_MULTIPATH=y
|
||||
CONFIG_IP_ROUTE_VERBOSE=y
|
||||
CONFIG_IP_MROUTE=y
|
||||
CONFIG_IP_MROUTE_MULTIPLE_TABLES=y
|
||||
CONFIG_ARPD=y
|
||||
CONFIG_SYN_COOKIES=y
|
||||
CONFIG_NETFILTER=y
|
||||
CONFIG_BRIDGE=m
|
||||
CONFIG_VLAN_8021Q=y
|
||||
CONFIG_NET_SCHED=y
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_MTD=y
|
||||
CONFIG_MTD_CMDLINE_PARTS=y
|
||||
CONFIG_MTD_CHAR=y
|
||||
CONFIG_MTD_BLOCK=y
|
||||
CONFIG_MTD_CFI=y
|
||||
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||
CONFIG_MTD_CFI_GEOMETRY=y
|
||||
CONFIG_MTD_CFI_INTELEXT=y
|
||||
CONFIG_MTD_CFI_AMDSTD=y
|
||||
CONFIG_MTD_COMPLEX_MAPPINGS=y
|
||||
CONFIG_MTD_LANTIQ=y
|
||||
CONFIG_MTD_M25P80=y
|
||||
CONFIG_MISC_DEVICES=y
|
||||
CONFIG_EEPROM_AT24=y
|
||||
CONFIG_NETDEVICES=y
|
||||
CONFIG_MII=y
|
||||
CONFIG_PHYLIB=y
|
||||
CONFIG_SERIAL_LANTIQ=y
|
||||
CONFIG_I2C=y
|
||||
CONFIG_I2C_FALCON=y
|
||||
CONFIG_SPI=y
|
||||
CONFIG_SPI_FALCON=y
|
||||
CONFIG_PINCTRL=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_WATCHDOG=y
|
||||
CONFIG_LANTIQ_WDT=y
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_JFFS2_FS=y
|
||||
CONFIG_JFFS2_SUMMARY=y
|
||||
CONFIG_JFFS2_FS_XATTR=y
|
||||
CONFIG_JFFS2_COMPRESSION_OPTIONS=y
|
||||
CONFIG_SQUASHFS=y
|
||||
CONFIG_SQUASHFS_XZ=y
|
||||
CONFIG_STRIP_ASM_SYMS=y
|
||||
CONFIG_DEBUG_FS=y
|
|
@ -1,66 +0,0 @@
|
|||
CONFIG_LANTIQ=y
|
||||
CONFIG_CPU_MIPS32_R2=y
|
||||
CONFIG_HIGH_RES_TIMERS=y
|
||||
CONFIG_EXPERIMENTAL=y
|
||||
CONFIG_DEFAULT_HOSTNAME="danube"
|
||||
CONFIG_SYSVIPC=y
|
||||
CONFIG_LOG_BUF_SHIFT=14
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_INITRAMFS_SOURCE="../root-lantiq/ ../root-lantiq/initramfs-base-files.txt"
|
||||
CONFIG_INITRAMFS_ROOT_UID=1000
|
||||
CONFIG_INITRAMFS_ROOT_GID=1000
|
||||
# CONFIG_RD_GZIP is not set
|
||||
CONFIG_RD_LZMA=y
|
||||
CONFIG_EMBEDDED=y
|
||||
CONFIG_SLAB=y
|
||||
CONFIG_MODULES=y
|
||||
CONFIG_MODULE_UNLOAD=y
|
||||
CONFIG_DEFAULT_DEADLINE=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_MULTICAST=y
|
||||
CONFIG_IP_ADVANCED_ROUTER=y
|
||||
CONFIG_IP_MULTIPLE_TABLES=y
|
||||
CONFIG_IP_ROUTE_MULTIPATH=y
|
||||
CONFIG_IP_ROUTE_VERBOSE=y
|
||||
CONFIG_IP_MROUTE=y
|
||||
CONFIG_IP_MROUTE_MULTIPLE_TABLES=y
|
||||
CONFIG_ARPD=y
|
||||
CONFIG_SYN_COOKIES=y
|
||||
CONFIG_NETFILTER=y
|
||||
CONFIG_BRIDGE=m
|
||||
CONFIG_VLAN_8021Q=y
|
||||
CONFIG_NET_SCHED=y
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_MTD=y
|
||||
CONFIG_MTD_CMDLINE_PARTS=y
|
||||
CONFIG_MTD_CHAR=y
|
||||
CONFIG_MTD_BLOCK=y
|
||||
CONFIG_MTD_CFI=y
|
||||
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||
CONFIG_MTD_CFI_GEOMETRY=y
|
||||
CONFIG_MTD_CFI_INTELEXT=y
|
||||
CONFIG_MTD_CFI_AMDSTD=y
|
||||
CONFIG_MTD_COMPLEX_MAPPINGS=y
|
||||
CONFIG_MTD_LANTIQ=y
|
||||
CONFIG_MISC_DEVICES=y
|
||||
CONFIG_NETDEVICES=y
|
||||
CONFIG_MII=y
|
||||
CONFIG_LANTIQ_ETOP=y
|
||||
CONFIG_PHYLIB=y
|
||||
CONFIG_SERIAL_LANTIQ=y
|
||||
CONFIG_PINCTRL=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_WATCHDOG=y
|
||||
CONFIG_LANTIQ_WDT=y
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_JFFS2_FS=y
|
||||
CONFIG_JFFS2_SUMMARY=y
|
||||
CONFIG_JFFS2_FS_XATTR=y
|
||||
CONFIG_JFFS2_COMPRESSION_OPTIONS=y
|
||||
CONFIG_SQUASHFS=y
|
||||
CONFIG_SQUASHFS_XZ=y
|
||||
CONFIG_STRIP_ASM_SYMS=y
|
||||
CONFIG_DEBUG_FS=y
|
|
@ -1,25 +0,0 @@
|
|||
/*
|
||||
* based on arch/arm/include/asm/clkdev.h
|
||||
*
|
||||
* Copyright (C) 2008 Russell King.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* Helper for the clk API to assist looking up a struct clk.
|
||||
*/
|
||||
#ifndef __ASM_CLKDEV_H
|
||||
#define __ASM_CLKDEV_H
|
||||
|
||||
#include <linux/slab.h>
|
||||
|
||||
#define __clk_get(clk) ({ 1; })
|
||||
#define __clk_put(clk) do { } while (0)
|
||||
|
||||
static inline struct clk_lookup_alloc *__clkdev_alloc(size_t size)
|
||||
{
|
||||
return kzalloc(size, GFP_KERNEL);
|
||||
}
|
||||
|
||||
#endif
|
|
@ -1,26 +0,0 @@
|
|||
/*
|
||||
* Lantiq GPIO button support
|
||||
*
|
||||
* Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
|
||||
* Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#ifndef _LANTIQ_DEV_GPIO_BUTTONS_H
|
||||
#define _LANTIQ_DEV_GPIO_BUTTONS_H
|
||||
|
||||
#include <linux/input.h>
|
||||
#include <linux/gpio_keys.h>
|
||||
|
||||
#define LTQ_KEYS_POLL_INTERVAL 20 /* msecs */
|
||||
#define LTQ_KEYS_DEBOUNCE_INTERVAL (3 * LTQ_KEYS_POLL_INTERVAL)
|
||||
|
||||
void ltq_register_gpio_keys_polled(int id,
|
||||
unsigned poll_interval,
|
||||
unsigned nbuttons,
|
||||
struct gpio_keys_button *buttons);
|
||||
|
||||
#endif /* _LANTIQ_DEV_GPIO_BUTTONS_H */
|
|
@ -1,21 +0,0 @@
|
|||
/*
|
||||
* Lantiq GPIO LED device support
|
||||
*
|
||||
* Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
|
||||
* Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#ifndef _LANTIQ_DEV_LEDS_GPIO_H
|
||||
#define _LANTIQ_DEV_LEDS_GPIO_H
|
||||
|
||||
#include <linux/leds.h>
|
||||
|
||||
void ltq_add_device_gpio_leds(int id,
|
||||
unsigned num_leds,
|
||||
struct gpio_led *leds) __init;
|
||||
|
||||
#endif /* _LANTIQ_DEV_LEDS_GPIO_H */
|
|
@ -1,268 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 Thomas Langer <thomas.langer@lantiq.com>
|
||||
*/
|
||||
|
||||
#ifndef _FALCON_IRQ__
|
||||
#define _FALCON_IRQ__
|
||||
|
||||
#define INT_NUM_IRQ0 8
|
||||
#define INT_NUM_IM0_IRL0 (INT_NUM_IRQ0 + 0)
|
||||
#define INT_NUM_IM1_IRL0 (INT_NUM_IM0_IRL0 + 32)
|
||||
#define INT_NUM_IM2_IRL0 (INT_NUM_IM1_IRL0 + 32)
|
||||
#define INT_NUM_IM3_IRL0 (INT_NUM_IM2_IRL0 + 32)
|
||||
#define INT_NUM_IM4_IRL0 (INT_NUM_IM3_IRL0 + 32)
|
||||
#define INT_NUM_EXTRA_START (INT_NUM_IM4_IRL0 + 32)
|
||||
#define INT_NUM_IM_OFFSET (INT_NUM_IM1_IRL0 - INT_NUM_IM0_IRL0)
|
||||
|
||||
#define MIPS_CPU_TIMER_IRQ 7
|
||||
|
||||
/* HOST IF Event Interrupt */
|
||||
#define FALCON_IRQ_HOST (INT_NUM_IM0_IRL0 + 0)
|
||||
/* HOST IF Mailbox0 Receive Interrupt */
|
||||
#define FALCON_IRQ_HOST_MB0_RX (INT_NUM_IM0_IRL0 + 1)
|
||||
/* HOST IF Mailbox0 Transmit Interrupt */
|
||||
#define FALCON_IRQ_HOST_MB0_TX (INT_NUM_IM0_IRL0 + 2)
|
||||
/* HOST IF Mailbox1 Receive Interrupt */
|
||||
#define FALCON_IRQ_HOST_MB1_RX (INT_NUM_IM0_IRL0 + 3)
|
||||
/* HOST IF Mailbox1 Transmit Interrupt */
|
||||
#define FALCON_IRQ_HOST_MB1_TX (INT_NUM_IM0_IRL0 + 4)
|
||||
/* I2C Last Single Data Transfer Request */
|
||||
#define FALCON_IRQ_I2C_LSREQ (INT_NUM_IM0_IRL0 + 8)
|
||||
/* I2C Single Data Transfer Request */
|
||||
#define FALCON_IRQ_I2C_SREQ (INT_NUM_IM0_IRL0 + 9)
|
||||
/* I2C Last Burst Data Transfer Request */
|
||||
#define FALCON_IRQ_I2C_LBREQ (INT_NUM_IM0_IRL0 + 10)
|
||||
/* I2C Burst Data Transfer Request */
|
||||
#define FALCON_IRQ_I2C_BREQ (INT_NUM_IM0_IRL0 + 11)
|
||||
/* I2C Error Interrupt */
|
||||
#define FALCON_IRQ_I2C_I2C_ERR (INT_NUM_IM0_IRL0 + 12)
|
||||
/* I2C Protocol Interrupt */
|
||||
#define FALCON_IRQ_I2C_I2C_P (INT_NUM_IM0_IRL0 + 13)
|
||||
/* SSC Transmit Interrupt */
|
||||
#define FALCON_IRQ_SSC_T (INT_NUM_IM0_IRL0 + 14)
|
||||
/* SSC Receive Interrupt */
|
||||
#define FALCON_IRQ_SSC_R (INT_NUM_IM0_IRL0 + 15)
|
||||
/* SSC Error Interrupt */
|
||||
#define FALCON_IRQ_SSC_E (INT_NUM_IM0_IRL0 + 16)
|
||||
/* SSC Frame Interrupt */
|
||||
#define FALCON_IRQ_SSC_F (INT_NUM_IM0_IRL0 + 17)
|
||||
/* Advanced Encryption Standard Interrupt */
|
||||
#define FALCON_IRQ_AES_AES (INT_NUM_IM0_IRL0 + 27)
|
||||
/* Secure Hash Algorithm Interrupt */
|
||||
#define FALCON_IRQ_SHA_HASH (INT_NUM_IM0_IRL0 + 28)
|
||||
/* PCM Receive Interrupt */
|
||||
#define FALCON_IRQ_PCM_RX (INT_NUM_IM0_IRL0 + 29)
|
||||
/* PCM Transmit Interrupt */
|
||||
#define FALCON_IRQ_PCM_TX (INT_NUM_IM0_IRL0 + 30)
|
||||
/* PCM Transmit Crash Interrupt */
|
||||
#define FALCON_IRQ_PCM_HW2_CRASH (INT_NUM_IM0_IRL0 + 31)
|
||||
|
||||
/* EBU Serial Flash Command Error */
|
||||
#define FALCON_IRQ_EBU_SF_CMDERR (INT_NUM_IM1_IRL0 + 0)
|
||||
/* EBU Serial Flash Command Overwrite Error */
|
||||
#define FALCON_IRQ_EBU_SF_COVERR (INT_NUM_IM1_IRL0 + 1)
|
||||
/* EBU Serial Flash Busy */
|
||||
#define FALCON_IRQ_EBU_SF_BUSY (INT_NUM_IM1_IRL0 + 2)
|
||||
/* External Interrupt from GPIO P0 */
|
||||
#define FALCON_IRQ_GPIO_P0 (INT_NUM_IM1_IRL0 + 4)
|
||||
/* External Interrupt from GPIO P1 */
|
||||
#define FALCON_IRQ_GPIO_P1 (INT_NUM_IM1_IRL0 + 5)
|
||||
/* External Interrupt from GPIO P2 */
|
||||
#define FALCON_IRQ_GPIO_P2 (INT_NUM_IM1_IRL0 + 6)
|
||||
/* External Interrupt from GPIO P3 */
|
||||
#define FALCON_IRQ_GPIO_P3 (INT_NUM_IM1_IRL0 + 7)
|
||||
/* External Interrupt from GPIO P4 */
|
||||
#define FALCON_IRQ_GPIO_P4 (INT_NUM_IM1_IRL0 + 8)
|
||||
/* 8kHz backup interrupt derived from core-PLL */
|
||||
#define FALCON_IRQ_FSC_BKP (INT_NUM_IM1_IRL0 + 10)
|
||||
/* FSC Timer Interrupt 0 */
|
||||
#define FALCON_IRQ_FSCT_CMP0 (INT_NUM_IM1_IRL0 + 11)
|
||||
/* FSC Timer Interrupt 1 */
|
||||
#define FALCON_IRQ_FSCT_CMP1 (INT_NUM_IM1_IRL0 + 12)
|
||||
/* 8kHz root interrupt derived from GPON interface */
|
||||
#define FALCON_IRQ_FSC_ROOT (INT_NUM_IM1_IRL0 + 13)
|
||||
/* Time of Day */
|
||||
#define FALCON_IRQ_TOD (INT_NUM_IM1_IRL0 + 14)
|
||||
/* PMA Interrupt from IntNode of the 200MHz Domain */
|
||||
#define FALCON_IRQ_PMA_200M (INT_NUM_IM1_IRL0 + 15)
|
||||
/* PMA Interrupt from IntNode of the TX Clk Domain */
|
||||
#define FALCON_IRQ_PMA_TX (INT_NUM_IM1_IRL0 + 16)
|
||||
/* PMA Interrupt from IntNode of the RX Clk Domain */
|
||||
#define FALCON_IRQ_PMA_RX (INT_NUM_IM1_IRL0 + 17)
|
||||
/* SYS1 Interrupt */
|
||||
#define FALCON_IRQ_SYS1 (INT_NUM_IM1_IRL0 + 20)
|
||||
/* SYS GPE Interrupt */
|
||||
#define FALCON_IRQ_SYS_GPE (INT_NUM_IM1_IRL0 + 21)
|
||||
/* Watchdog Access Error Interrupt */
|
||||
#define FALCON_IRQ_WDT_AEIR (INT_NUM_IM1_IRL0 + 24)
|
||||
/* Watchdog Prewarning Interrupt */
|
||||
#define FALCON_IRQ_WDT_PIR (INT_NUM_IM1_IRL0 + 25)
|
||||
/* SBIU interrupt */
|
||||
#define FALCON_IRQ_SBIU0 (INT_NUM_IM1_IRL0 + 27)
|
||||
/* FPI Bus Control Unit Interrupt */
|
||||
#define FALCON_IRQ_BCU0 (INT_NUM_IM1_IRL0 + 29)
|
||||
/* DDR Controller Interrupt */
|
||||
#define FALCON_IRQ_DDR (INT_NUM_IM1_IRL0 + 30)
|
||||
/* Crossbar Error Interrupt */
|
||||
#define FALCON_IRQ_XBAR_ERROR (INT_NUM_IM1_IRL0 + 31)
|
||||
|
||||
/* ICTRLL 0 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLL0 (INT_NUM_IM2_IRL0 + 0)
|
||||
/* ICTRLL 1 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLL1 (INT_NUM_IM2_IRL0 + 1)
|
||||
/* ICTRLL 2 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLL2 (INT_NUM_IM2_IRL0 + 2)
|
||||
/* ICTRLL 3 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLL3 (INT_NUM_IM2_IRL0 + 3)
|
||||
/* OCTRLL 0 Interrupt */
|
||||
#define FALCON_IRQ_OCTRLL0 (INT_NUM_IM2_IRL0 + 4)
|
||||
/* OCTRLL 1 Interrupt */
|
||||
#define FALCON_IRQ_OCTRLL1 (INT_NUM_IM2_IRL0 + 5)
|
||||
/* OCTRLL 2 Interrupt */
|
||||
#define FALCON_IRQ_OCTRLL2 (INT_NUM_IM2_IRL0 + 6)
|
||||
/* OCTRLL 3 Interrupt */
|
||||
#define FALCON_IRQ_OCTRLL3 (INT_NUM_IM2_IRL0 + 7)
|
||||
/* OCTRLG Interrupt */
|
||||
#define FALCON_IRQ_OCTRLG (INT_NUM_IM2_IRL0 + 9)
|
||||
/* IQM Interrupt */
|
||||
#define FALCON_IRQ_IQM (INT_NUM_IM2_IRL0 + 10)
|
||||
/* FSQM Interrupt */
|
||||
#define FALCON_IRQ_FSQM (INT_NUM_IM2_IRL0 + 11)
|
||||
/* TMU Interrupt */
|
||||
#define FALCON_IRQ_TMU (INT_NUM_IM2_IRL0 + 12)
|
||||
/* LINK1 Interrupt */
|
||||
#define FALCON_IRQ_LINK1 (INT_NUM_IM2_IRL0 + 14)
|
||||
/* ICTRLC 0 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLC0 (INT_NUM_IM2_IRL0 + 16)
|
||||
/* ICTRLC 1 Interrupt */
|
||||
#define FALCON_IRQ_ICTRLC1 (INT_NUM_IM2_IRL0 + 17)
|
||||
/* OCTRLC Interrupt */
|
||||
#define FALCON_IRQ_OCTRLC (INT_NUM_IM2_IRL0 + 18)
|
||||
/* CONFIG Break Interrupt */
|
||||
#define FALCON_IRQ_CONFIG_BREAK (INT_NUM_IM2_IRL0 + 19)
|
||||
/* CONFIG Interrupt */
|
||||
#define FALCON_IRQ_CONFIG (INT_NUM_IM2_IRL0 + 20)
|
||||
/* Dispatcher Interrupt */
|
||||
#define FALCON_IRQ_DISP (INT_NUM_IM2_IRL0 + 21)
|
||||
/* TBM Interrupt */
|
||||
#define FALCON_IRQ_TBM (INT_NUM_IM2_IRL0 + 22)
|
||||
/* GTC Downstream Interrupt */
|
||||
#define FALCON_IRQ_GTC_DS (INT_NUM_IM2_IRL0 + 29)
|
||||
/* GTC Upstream Interrupt */
|
||||
#define FALCON_IRQ_GTC_US (INT_NUM_IM2_IRL0 + 30)
|
||||
/* EIM Interrupt */
|
||||
#define FALCON_IRQ_EIM (INT_NUM_IM2_IRL0 + 31)
|
||||
|
||||
/* ASC0 Transmit Interrupt */
|
||||
#define FALCON_IRQ_ASC0_T (INT_NUM_IM3_IRL0 + 0)
|
||||
/* ASC0 Receive Interrupt */
|
||||
#define FALCON_IRQ_ASC0_R (INT_NUM_IM3_IRL0 + 1)
|
||||
/* ASC0 Error Interrupt */
|
||||
#define FALCON_IRQ_ASC0_E (INT_NUM_IM3_IRL0 + 2)
|
||||
/* ASC0 Transmit Buffer Interrupt */
|
||||
#define FALCON_IRQ_ASC0_TB (INT_NUM_IM3_IRL0 + 3)
|
||||
/* ASC0 Autobaud Start Interrupt */
|
||||
#define FALCON_IRQ_ASC0_ABST (INT_NUM_IM3_IRL0 + 4)
|
||||
/* ASC0 Autobaud Detection Interrupt */
|
||||
#define FALCON_IRQ_ASC0_ABDET (INT_NUM_IM3_IRL0 + 5)
|
||||
/* ASC1 Modem Status Interrupt */
|
||||
#define FALCON_IRQ_ASC0_MS (INT_NUM_IM3_IRL0 + 6)
|
||||
/* ASC0 Soft Flow Control Interrupt */
|
||||
#define FALCON_IRQ_ASC0_SFC (INT_NUM_IM3_IRL0 + 7)
|
||||
/* ASC1 Transmit Interrupt */
|
||||
#define FALCON_IRQ_ASC1_T (INT_NUM_IM3_IRL0 + 8)
|
||||
/* ASC1 Receive Interrupt */
|
||||
#define FALCON_IRQ_ASC1_R (INT_NUM_IM3_IRL0 + 9)
|
||||
/* ASC1 Error Interrupt */
|
||||
#define FALCON_IRQ_ASC1_E (INT_NUM_IM3_IRL0 + 10)
|
||||
/* ASC1 Transmit Buffer Interrupt */
|
||||
#define FALCON_IRQ_ASC1_TB (INT_NUM_IM3_IRL0 + 11)
|
||||
/* ASC1 Autobaud Start Interrupt */
|
||||
#define FALCON_IRQ_ASC1_ABST (INT_NUM_IM3_IRL0 + 12)
|
||||
/* ASC1 Autobaud Detection Interrupt */
|
||||
#define FALCON_IRQ_ASC1_ABDET (INT_NUM_IM3_IRL0 + 13)
|
||||
/* ASC1 Modem Status Interrupt */
|
||||
#define FALCON_IRQ_ASC1_MS (INT_NUM_IM3_IRL0 + 14)
|
||||
/* ASC1 Soft Flow Control Interrupt */
|
||||
#define FALCON_IRQ_ASC1_SFC (INT_NUM_IM3_IRL0 + 15)
|
||||
/* GPTC Timer/Counter 1A Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC1A (INT_NUM_IM3_IRL0 + 16)
|
||||
/* GPTC Timer/Counter 1B Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC1B (INT_NUM_IM3_IRL0 + 17)
|
||||
/* GPTC Timer/Counter 2A Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC2A (INT_NUM_IM3_IRL0 + 18)
|
||||
/* GPTC Timer/Counter 2B Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC2B (INT_NUM_IM3_IRL0 + 19)
|
||||
/* GPTC Timer/Counter 3A Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC3A (INT_NUM_IM3_IRL0 + 20)
|
||||
/* GPTC Timer/Counter 3B Interrupt */
|
||||
#define FALCON_IRQ_GPTC_TC3B (INT_NUM_IM3_IRL0 + 21)
|
||||
/* DFEV0, Channel 1 Transmit Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_2TX (INT_NUM_IM3_IRL0 + 26)
|
||||
/* DFEV0, Channel 1 Receive Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_2RX (INT_NUM_IM3_IRL0 + 27)
|
||||
/* DFEV0, Channel 1 General Purpose Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_2GP (INT_NUM_IM3_IRL0 + 28)
|
||||
/* DFEV0, Channel 0 Transmit Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_1TX (INT_NUM_IM3_IRL0 + 29)
|
||||
/* DFEV0, Channel 0 Receive Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_1RX (INT_NUM_IM3_IRL0 + 30)
|
||||
/* DFEV0, Channel 0 General Purpose Interrupt */
|
||||
#define FALCON_IRQ_DFEV0_1GP (INT_NUM_IM3_IRL0 + 31)
|
||||
|
||||
/* ICTRLL 0 Error */
|
||||
#define FALCON_IRQ_ICTRLL0_ERR (INT_NUM_IM4_IRL0 + 0)
|
||||
/* ICTRLL 1 Error */
|
||||
#define FALCON_IRQ_ICTRLL1_ERR (INT_NUM_IM4_IRL0 + 1)
|
||||
/* ICTRLL 2 Error */
|
||||
#define FALCON_IRQ_ICTRLL2_ERR (INT_NUM_IM4_IRL0 + 2)
|
||||
/* ICTRLL 3 Error */
|
||||
#define FALCON_IRQ_ICTRLL3_ERR (INT_NUM_IM4_IRL0 + 3)
|
||||
/* OCTRLL 0 Error */
|
||||
#define FALCON_IRQ_OCTRLL0_ERR (INT_NUM_IM4_IRL0 + 4)
|
||||
/* OCTRLL 1 Error */
|
||||
#define FALCON_IRQ_OCTRLL1_ERR (INT_NUM_IM4_IRL0 + 5)
|
||||
/* OCTRLL 2 Error */
|
||||
#define FALCON_IRQ_OCTRLL2_ERR (INT_NUM_IM4_IRL0 + 6)
|
||||
/* OCTRLL 3 Error */
|
||||
#define FALCON_IRQ_OCTRLL3_ERR (INT_NUM_IM4_IRL0 + 7)
|
||||
/* ICTRLG Error */
|
||||
#define FALCON_IRQ_ICTRLG_ERR (INT_NUM_IM4_IRL0 + 8)
|
||||
/* OCTRLG Error */
|
||||
#define FALCON_IRQ_OCTRLG_ERR (INT_NUM_IM4_IRL0 + 9)
|
||||
/* IQM Error */
|
||||
#define FALCON_IRQ_IQM_ERR (INT_NUM_IM4_IRL0 + 10)
|
||||
/* FSQM Error */
|
||||
#define FALCON_IRQ_FSQM_ERR (INT_NUM_IM4_IRL0 + 11)
|
||||
/* TMU Error */
|
||||
#define FALCON_IRQ_TMU_ERR (INT_NUM_IM4_IRL0 + 12)
|
||||
/* MPS Status Interrupt #0 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR0 (INT_NUM_IM4_IRL0 + 14)
|
||||
/* MPS Status Interrupt #1 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR1 (INT_NUM_IM4_IRL0 + 15)
|
||||
/* MPS Status Interrupt #2 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR2 (INT_NUM_IM4_IRL0 + 16)
|
||||
/* MPS Status Interrupt #3 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR3 (INT_NUM_IM4_IRL0 + 17)
|
||||
/* MPS Status Interrupt #4 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR4 (INT_NUM_IM4_IRL0 + 18)
|
||||
/* MPS Status Interrupt #5 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR5 (INT_NUM_IM4_IRL0 + 19)
|
||||
/* MPS Status Interrupt #6 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR6 (INT_NUM_IM4_IRL0 + 20)
|
||||
/* MPS Status Interrupt #7 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR7 (INT_NUM_IM4_IRL0 + 21)
|
||||
/* MPS Status Interrupt #8 (VPE1 to VPE0) */
|
||||
#define FALCON_IRQ_MPS_IR8 (INT_NUM_IM4_IRL0 + 22)
|
||||
/* VPE0 Exception Level Flag Interrupt */
|
||||
#define FALCON_IRQ_VPE0_EXL (INT_NUM_IM4_IRL0 + 29)
|
||||
/* VPE0 Error Level Flag Interrupt */
|
||||
#define FALCON_IRQ_VPE0_ERL (INT_NUM_IM4_IRL0 + 30)
|
||||
/* VPE0 Performance Monitoring Counter Interrupt */
|
||||
#define FALCON_IRQ_VPE0_PMCIR (INT_NUM_IM4_IRL0 + 31)
|
||||
|
||||
#endif /* _FALCON_IRQ__ */
|
|
@ -1,18 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
*/
|
||||
|
||||
#ifndef __FALCON_IRQ_H
|
||||
#define __FALCON_IRQ_H
|
||||
|
||||
#include <falcon_irq.h>
|
||||
|
||||
#define NR_IRQS 328
|
||||
|
||||
#include_next <irq.h>
|
||||
|
||||
#endif
|
|
@ -1,152 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#ifndef _LTQ_FALCON_H__
|
||||
#define _LTQ_FALCON_H__
|
||||
|
||||
#ifdef CONFIG_SOC_FALCON
|
||||
|
||||
#include <lantiq.h>
|
||||
|
||||
/* Chip IDs */
|
||||
#define SOC_ID_FALCON 0x01B8
|
||||
|
||||
/* SoC Types */
|
||||
#define SOC_TYPE_FALCON 0x01
|
||||
|
||||
/* ASC0/1 - serial port */
|
||||
#define LTQ_ASC0_BASE_ADDR 0x1E100C00
|
||||
#define LTQ_ASC1_BASE_ADDR 0x1E100B00
|
||||
#define LTQ_ASC_SIZE 0x100
|
||||
|
||||
#define LTQ_ASC_TIR(x) (INT_NUM_IM3_IRL0 + (x * 8))
|
||||
#define LTQ_ASC_RIR(x) (INT_NUM_IM3_IRL0 + (x * 8) + 1)
|
||||
#define LTQ_ASC_EIR(x) (INT_NUM_IM3_IRL0 + (x * 8) + 2)
|
||||
|
||||
/*
|
||||
* during early_printk no ioremap possible at this early stage
|
||||
* lets use KSEG1 instead
|
||||
*/
|
||||
#define LTQ_EARLY_ASC KSEG1ADDR(LTQ_ASC0_BASE_ADDR)
|
||||
|
||||
/* ICU - interrupt control unit */
|
||||
#define LTQ_ICU_BASE_ADDR 0x1F880200
|
||||
#define LTQ_ICU_SIZE 0x100
|
||||
|
||||
/* WDT */
|
||||
#define LTQ_WDT_BASE_ADDR 0x1F8803F0
|
||||
#define LTQ_WDT_SIZE 0x10
|
||||
|
||||
#define LTQ_RST_CAUSE_WDTRST 0x0002
|
||||
|
||||
/* EBU - external bus unit */
|
||||
#define LTQ_EBU_BASE_ADDR 0x18000000
|
||||
#define LTQ_EBU_SIZE 0x0100
|
||||
|
||||
#define LTQ_EBU_MODCON 0x000C
|
||||
|
||||
/* GPIO */
|
||||
#define LTQ_GPIO0_BASE_ADDR 0x1D810000
|
||||
#define LTQ_GPIO0_SIZE 0x0080
|
||||
#define LTQ_GPIO1_BASE_ADDR 0x1E800100
|
||||
#define LTQ_GPIO1_SIZE 0x0080
|
||||
#define LTQ_GPIO2_BASE_ADDR 0x1D810100
|
||||
#define LTQ_GPIO2_SIZE 0x0080
|
||||
#define LTQ_GPIO3_BASE_ADDR 0x1E800200
|
||||
#define LTQ_GPIO3_SIZE 0x0080
|
||||
#define LTQ_GPIO4_BASE_ADDR 0x1E800300
|
||||
#define LTQ_GPIO4_SIZE 0x0080
|
||||
#define LTQ_PADCTRL0_BASE_ADDR 0x1DB01000
|
||||
#define LTQ_PADCTRL0_SIZE 0x0100
|
||||
#define LTQ_PADCTRL1_BASE_ADDR 0x1E800400
|
||||
#define LTQ_PADCTRL1_SIZE 0x0100
|
||||
#define LTQ_PADCTRL2_BASE_ADDR 0x1DB02000
|
||||
#define LTQ_PADCTRL2_SIZE 0x0100
|
||||
#define LTQ_PADCTRL3_BASE_ADDR 0x1E800500
|
||||
#define LTQ_PADCTRL3_SIZE 0x0100
|
||||
#define LTQ_PADCTRL4_BASE_ADDR 0x1E800600
|
||||
#define LTQ_PADCTRL4_SIZE 0x0100
|
||||
|
||||
/* I2C */
|
||||
#define GPON_I2C_BASE 0x1E200000
|
||||
#define GPON_I2C_SIZE 0x00010000
|
||||
|
||||
/* CHIP ID */
|
||||
#define LTQ_STATUS_BASE_ADDR 0x1E802000
|
||||
|
||||
#define LTQ_FALCON_CHIPID ((u32 *)(KSEG1 + LTQ_STATUS_BASE_ADDR + 0x0c))
|
||||
#define LTQ_FALCON_CHIPTYPE ((u32 *)(KSEG1 + LTQ_STATUS_BASE_ADDR + 0x38))
|
||||
#define LTQ_FALCON_CHIPCONF ((u32 *)(KSEG1 + LTQ_STATUS_BASE_ADDR + 0x40))
|
||||
|
||||
/* SYSCTL - start/stop/restart/configure/... different parts of the Soc */
|
||||
#define LTQ_SYS1_BASE_ADDR 0x1EF00000
|
||||
#define LTQ_SYS1_SIZE 0x0100
|
||||
#define LTQ_STATUS_BASE_ADDR 0x1E802000
|
||||
#define LTQ_STATUS_SIZE 0x0080
|
||||
#define LTQ_SYS_ETH_BASE_ADDR 0x1DB00000
|
||||
#define LTQ_SYS_ETH_SIZE 0x0100
|
||||
#define LTQ_SYS_GPE_BASE_ADDR 0x1D700000
|
||||
#define LTQ_SYS_GPE_SIZE 0x0100
|
||||
|
||||
#define SYSCTL_SYS1 0
|
||||
#define SYSCTL_SYSETH 1
|
||||
#define SYSCTL_SYSGPE 2
|
||||
|
||||
/* Activation Status Register */
|
||||
#define ACTS_ASC1_ACT 0x00000800
|
||||
#define ACTS_I2C_ACT 0x00004000
|
||||
#define ACTS_P0 0x00010000
|
||||
#define ACTS_P1 0x00010000
|
||||
#define ACTS_P2 0x00020000
|
||||
#define ACTS_P3 0x00020000
|
||||
#define ACTS_P4 0x00040000
|
||||
#define ACTS_PADCTRL0 0x00100000
|
||||
#define ACTS_PADCTRL1 0x00100000
|
||||
#define ACTS_PADCTRL2 0x00200000
|
||||
#define ACTS_PADCTRL3 0x00200000
|
||||
#define ACTS_PADCTRL4 0x00400000
|
||||
#define ACTS_I2C_ACT 0x00004000
|
||||
|
||||
/* global register ranges */
|
||||
extern __iomem void *ltq_ebu_membase;
|
||||
extern __iomem void *ltq_sys1_membase;
|
||||
#define ltq_ebu_w32(x, y) ltq_w32((x), ltq_ebu_membase + (y))
|
||||
#define ltq_ebu_r32(x) ltq_r32(ltq_ebu_membase + (x))
|
||||
#define ltq_ebu_w32_mask(clear, set, reg) \
|
||||
ltq_ebu_w32((ltq_ebu_r32(reg) & ~(clear)) | (set), reg)
|
||||
|
||||
#define ltq_sys1_w32(x, y) ltq_w32((x), ltq_sys1_membase + (y))
|
||||
#define ltq_sys1_r32(x) ltq_r32(ltq_sys1_membase + (x))
|
||||
#define ltq_sys1_w32_mask(clear, set, reg) \
|
||||
ltq_sys1_w32((ltq_sys1_r32(reg) & ~(clear)) | (set), reg)
|
||||
|
||||
/* gpio wrapper to help configure the pin muxing */
|
||||
extern int ltq_gpio_mux_set(unsigned int pin, unsigned int mux);
|
||||
|
||||
/* to keep the irq code generic we need to define these to 0 as falcon
|
||||
has no EIU/EBU */
|
||||
#define LTQ_EIU_BASE_ADDR 0
|
||||
#define LTQ_EBU_PCC_ISTAT 0
|
||||
|
||||
static inline int ltq_is_ar9(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline int ltq_is_vr9(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline int ltq_is_falcon(void)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
#endif /* CONFIG_SOC_FALCON */
|
||||
#endif /* _LTQ_XWAY_H__ */
|
|
@ -1,155 +0,0 @@
|
|||
#ifndef __DANUBE_GPTU_DEV_H__2005_07_26__10_19__
|
||||
#define __DANUBE_GPTU_DEV_H__2005_07_26__10_19__
|
||||
|
||||
|
||||
/******************************************************************************
|
||||
Copyright (c) 2002, Infineon Technologies. All rights reserved.
|
||||
|
||||
No Warranty
|
||||
Because the program is licensed free of charge, there is no warranty for
|
||||
the program, to the extent permitted by applicable law. Except when
|
||||
otherwise stated in writing the copyright holders and/or other parties
|
||||
provide the program "as is" without warranty of any kind, either
|
||||
expressed or implied, including, but not limited to, the implied
|
||||
warranties of merchantability and fitness for a particular purpose. The
|
||||
entire risk as to the quality and performance of the program is with
|
||||
you. should the program prove defective, you assume the cost of all
|
||||
necessary servicing, repair or correction.
|
||||
|
||||
In no event unless required by applicable law or agreed to in writing
|
||||
will any copyright holder, or any other party who may modify and/or
|
||||
redistribute the program as permitted above, be liable to you for
|
||||
damages, including any general, special, incidental or consequential
|
||||
damages arising out of the use or inability to use the program
|
||||
(including but not limited to loss of data or data being rendered
|
||||
inaccurate or losses sustained by you or third parties or a failure of
|
||||
the program to operate with any other programs), even if such holder or
|
||||
other party has been advised of the possibility of such damages.
|
||||
******************************************************************************/
|
||||
|
||||
|
||||
/*
|
||||
* ####################################
|
||||
* Definition
|
||||
* ####################################
|
||||
*/
|
||||
|
||||
/*
|
||||
* Available Timer/Counter Index
|
||||
*/
|
||||
#define TIMER(n, X) (n * 2 + (X ? 1 : 0))
|
||||
#define TIMER_ANY 0x00
|
||||
#define TIMER1A TIMER(1, 0)
|
||||
#define TIMER1B TIMER(1, 1)
|
||||
#define TIMER2A TIMER(2, 0)
|
||||
#define TIMER2B TIMER(2, 1)
|
||||
#define TIMER3A TIMER(3, 0)
|
||||
#define TIMER3B TIMER(3, 1)
|
||||
|
||||
/*
|
||||
* Flag of Timer/Counter
|
||||
* These flags specify the way in which timer is configured.
|
||||
*/
|
||||
/* Bit size of timer/counter. */
|
||||
#define TIMER_FLAG_16BIT 0x0000
|
||||
#define TIMER_FLAG_32BIT 0x0001
|
||||
/* Switch between timer and counter. */
|
||||
#define TIMER_FLAG_TIMER 0x0000
|
||||
#define TIMER_FLAG_COUNTER 0x0002
|
||||
/* Stop or continue when overflowing/underflowing. */
|
||||
#define TIMER_FLAG_ONCE 0x0000
|
||||
#define TIMER_FLAG_CYCLIC 0x0004
|
||||
/* Count up or counter down. */
|
||||
#define TIMER_FLAG_UP 0x0000
|
||||
#define TIMER_FLAG_DOWN 0x0008
|
||||
/* Count on specific level or edge. */
|
||||
#define TIMER_FLAG_HIGH_LEVEL_SENSITIVE 0x0000
|
||||
#define TIMER_FLAG_LOW_LEVEL_SENSITIVE 0x0040
|
||||
#define TIMER_FLAG_RISE_EDGE 0x0010
|
||||
#define TIMER_FLAG_FALL_EDGE 0x0020
|
||||
#define TIMER_FLAG_ANY_EDGE 0x0030
|
||||
/* Signal is syncronous to module clock or not. */
|
||||
#define TIMER_FLAG_UNSYNC 0x0000
|
||||
#define TIMER_FLAG_SYNC 0x0080
|
||||
/* Different interrupt handle type. */
|
||||
#define TIMER_FLAG_NO_HANDLE 0x0000
|
||||
#if defined(__KERNEL__)
|
||||
#define TIMER_FLAG_CALLBACK_IN_IRQ 0x0100
|
||||
#endif // defined(__KERNEL__)
|
||||
#define TIMER_FLAG_SIGNAL 0x0300
|
||||
/* Internal clock source or external clock source */
|
||||
#define TIMER_FLAG_INT_SRC 0x0000
|
||||
#define TIMER_FLAG_EXT_SRC 0x1000
|
||||
|
||||
|
||||
/*
|
||||
* ioctl Command
|
||||
*/
|
||||
#define GPTU_REQUEST_TIMER 0x01 /* General method to setup timer/counter. */
|
||||
#define GPTU_FREE_TIMER 0x02 /* Free timer/counter. */
|
||||
#define GPTU_START_TIMER 0x03 /* Start or resume timer/counter. */
|
||||
#define GPTU_STOP_TIMER 0x04 /* Suspend timer/counter. */
|
||||
#define GPTU_GET_COUNT_VALUE 0x05 /* Get current count value. */
|
||||
#define GPTU_CALCULATE_DIVIDER 0x06 /* Calculate timer divider from given freq.*/
|
||||
#define GPTU_SET_TIMER 0x07 /* Simplified method to setup timer. */
|
||||
#define GPTU_SET_COUNTER 0x08 /* Simplified method to setup counter. */
|
||||
|
||||
/*
|
||||
* Data Type Used to Call ioctl
|
||||
*/
|
||||
struct gptu_ioctl_param {
|
||||
unsigned int timer; /* In command GPTU_REQUEST_TIMER, GPTU_SET_TIMER, and *
|
||||
* GPTU_SET_COUNTER, this field is ID of expected *
|
||||
* timer/counter. If it's zero, a timer/counter would *
|
||||
* be dynamically allocated and ID would be stored in *
|
||||
* this field. *
|
||||
* In command GPTU_GET_COUNT_VALUE, this field is *
|
||||
* ignored. *
|
||||
* In other command, this field is ID of timer/counter *
|
||||
* allocated. */
|
||||
unsigned int flag; /* In command GPTU_REQUEST_TIMER, GPTU_SET_TIMER, and *
|
||||
* GPTU_SET_COUNTER, this field contains flags to *
|
||||
* specify how to configure timer/counter. *
|
||||
* In command GPTU_START_TIMER, zero indicate start *
|
||||
* and non-zero indicate resume timer/counter. *
|
||||
* In other command, this field is ignored. */
|
||||
unsigned long value; /* In command GPTU_REQUEST_TIMER, this field contains *
|
||||
* init/reload value. *
|
||||
* In command GPTU_SET_TIMER, this field contains *
|
||||
* frequency (0.001Hz) of timer. *
|
||||
* In command GPTU_GET_COUNT_VALUE, current count *
|
||||
* value would be stored in this field. *
|
||||
* In command GPTU_CALCULATE_DIVIDER, this field *
|
||||
* contains frequency wanted, and after calculation, *
|
||||
* divider would be stored in this field to overwrite *
|
||||
* the frequency. *
|
||||
* In other command, this field is ignored. */
|
||||
int pid; /* In command GPTU_REQUEST_TIMER and GPTU_SET_TIMER, *
|
||||
* if signal is required, this field contains process *
|
||||
* ID to which signal would be sent. *
|
||||
* In other command, this field is ignored. */
|
||||
int sig; /* In command GPTU_REQUEST_TIMER and GPTU_SET_TIMER, *
|
||||
* if signal is required, this field contains signal *
|
||||
* number which would be sent. *
|
||||
* In other command, this field is ignored. */
|
||||
};
|
||||
|
||||
/*
|
||||
* ####################################
|
||||
* Data Type
|
||||
* ####################################
|
||||
*/
|
||||
typedef void (*timer_callback)(unsigned long arg);
|
||||
|
||||
extern int lq_request_timer(unsigned int, unsigned int, unsigned long, unsigned long, unsigned long);
|
||||
extern int lq_free_timer(unsigned int);
|
||||
extern int lq_start_timer(unsigned int, int);
|
||||
extern int lq_stop_timer(unsigned int);
|
||||
extern int lq_reset_counter_flags(u32 timer, u32 flags);
|
||||
extern int lq_get_count_value(unsigned int, unsigned long *);
|
||||
extern u32 lq_cal_divider(unsigned long);
|
||||
extern int lq_set_timer(unsigned int, unsigned int, int, int, unsigned int, unsigned long, unsigned long);
|
||||
extern int lq_set_counter(unsigned int timer, unsigned int flag,
|
||||
u32 reload, unsigned long arg1, unsigned long arg2);
|
||||
|
||||
#endif /* __DANUBE_GPTU_DEV_H__2005_07_26__10_19__ */
|
|
@ -1,56 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __BASE_REG_H
|
||||
#define __BASE_REG_H
|
||||
|
||||
#ifndef KSEG1
|
||||
#define KSEG1 0xA0000000
|
||||
#endif
|
||||
|
||||
#define LTQ_EBU_SEG1_BASE (KSEG1 + 0x10000000)
|
||||
#define LTQ_EBU_SEG2_BASE (KSEG1 + 0x11000000)
|
||||
#define LTQ_EBU_SEG3_BASE (KSEG1 + 0x12000000)
|
||||
#define LTQ_EBU_SEG4_BASE (KSEG1 + 0x13000000)
|
||||
|
||||
#define LTQ_ASC0_BASE (KSEG1 + 0x14100100)
|
||||
#define LTQ_ASC1_BASE (KSEG1 + 0x14100200)
|
||||
|
||||
#define LTQ_SSC0_BASE (0x14100300)
|
||||
#define LTQ_SSC1_BASE (0x14100400)
|
||||
|
||||
#define LTQ_PORT_P0_BASE (KSEG1 + 0x14100600)
|
||||
#define LTQ_PORT_P1_BASE (KSEG1 + 0x14108100)
|
||||
#define LTQ_PORT_P2_BASE (KSEG1 + 0x14100800)
|
||||
#define LTQ_PORT_P3_BASE (KSEG1 + 0x14100900)
|
||||
#define LTQ_PORT_P4_BASE (KSEG1 + 0x1E000400)
|
||||
|
||||
#define LTQ_EBU_BASE (KSEG1 + 0x14102000)
|
||||
#define LTQ_DMA_BASE (KSEG1 + 0x14104000)
|
||||
|
||||
#define LTQ_ICU0_IM3_IM2_BASE (KSEG1 + 0x1E016000)
|
||||
#define LTQ_ICU0_IM5_IM4_IM1_IM0_BASE (KSEG1 + 0x14106000)
|
||||
|
||||
#define LTQ_ES_BASE (KSEG1 + 0x18000000)
|
||||
|
||||
#define LTQ_SYS0_BASE (KSEG1 + 0x1C000000)
|
||||
#define LTQ_SYS1_BASE (KSEG1 + 0x1C000800)
|
||||
#define LTQ_SYS2_BASE (KSEG1 + 0x1E400000)
|
||||
|
||||
#define LTQ_L2_SPRAM_BASE (KSEG1 + 0x1F1E8000)
|
||||
|
||||
#define LTQ_SWINT_BASE (KSEG1 + 0x1E000100)
|
||||
#define LTQ_MBS_BASE (KSEG1 + 0x1E000200)
|
||||
|
||||
#define LTQ_STATUS_BASE (KSEG1 + 0x1E000500)
|
||||
|
||||
#endif
|
|
@ -1,37 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __BOOT_REG_H
|
||||
#define __BOOT_REG_H
|
||||
|
||||
#define LTQ_BOOT_CPU_OFFSET 0x20
|
||||
|
||||
#define LTQ_BOOT_RVEC(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x00)
|
||||
#define LTQ_BOOT_NVEC(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x04)
|
||||
#define LTQ_BOOT_EVEC(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x08)
|
||||
#define LTQ_BOOT_CP0_STATUS(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x0C)
|
||||
#define LTQ_BOOT_CP0_EPC(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x10)
|
||||
#define LTQ_BOOT_CP0_EEPC(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x14)
|
||||
#define LTQ_BOOT_SIZE(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x18) /* only for CP1 */
|
||||
#define LTQ_BOOT_RCU_SR(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x18) /* only for CP0 */
|
||||
#define LTQ_BOOT_CFG_STAT(cpu) (volatile u32*)(LTQ_L2_SPRAM_BASE + \
|
||||
(cpu * LTQ_BOOT_CPU_OFFSET) + 0x1C)
|
||||
|
||||
#endif
|
|
@ -1,308 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __DMA_REG_H
|
||||
#define __DMA_REG_H
|
||||
|
||||
#define dma_r32(reg) ltq_r32(&dma->reg)
|
||||
#define dma_w32(val, reg) ltq_w32(val, &dma->reg)
|
||||
#define dma_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &dma->reg)
|
||||
|
||||
/** DMA register structure */
|
||||
struct svip_reg_dma {
|
||||
volatile unsigned long clc; /* 0x00 */
|
||||
volatile unsigned long reserved0; /* 0x04 */
|
||||
volatile unsigned long id; /* 0x08 */
|
||||
volatile unsigned long reserved1; /* 0x0c */
|
||||
volatile unsigned long ctrl; /* 0x10 */
|
||||
volatile unsigned long cpoll; /* 0x14 */
|
||||
volatile unsigned long cs; /* 0x18 */
|
||||
volatile unsigned long cctrl; /* 0x1C */
|
||||
volatile unsigned long cdba; /* 0x20 */
|
||||
volatile unsigned long cdlen; /* 0x24 */
|
||||
volatile unsigned long cis; /* 0x28 */
|
||||
volatile unsigned long cie; /* 0x2C */
|
||||
volatile unsigned long cgbl; /* 0x30 */
|
||||
volatile unsigned long reserved2[3]; /* 0x34 */
|
||||
volatile unsigned long ps; /* 0x40 */
|
||||
volatile unsigned long pctrl; /* 0x44 */
|
||||
volatile unsigned long reserved3[43]; /* 0x48 */
|
||||
volatile unsigned long irnen; /* 0xF4 */
|
||||
volatile unsigned long irncr; /* 0xF8 */
|
||||
volatile unsigned long irnicr; /* 0xFC */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* CLC Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Fast Shut-Off Enable Bit (5) */
|
||||
#define DMA_CLC_FSOE (0x1 << 5)
|
||||
#define DMA_CLC_FSOE_VAL(val) (((val) & 0x1) << 5)
|
||||
#define DMA_CLC_FSOE_GET(val) ((((val) & DMA_CLC_FSOE) >> 5) & 0x1)
|
||||
#define DMA_CLC_FSOE_SET(reg,val) (reg) = ((reg & ~DMA_CLC_FSOE) | (((val) & 0x1) << 5))
|
||||
/* Suspend Bit Write Enable for OCDS (4) */
|
||||
#define DMA_CLC_SBWE (0x1 << 4)
|
||||
#define DMA_CLC_SBWE_VAL(val) (((val) & 0x1) << 4)
|
||||
#define DMA_CLC_SBWE_SET(reg,val) (reg) = (((reg & ~DMA_CLC_SBWE) | (val) & 1) << 4)
|
||||
/* External Request Disable (3) */
|
||||
#define DMA_CLC_EDIS (0x1 << 3)
|
||||
#define DMA_CLC_EDIS_VAL(val) (((val) & 0x1) << 3)
|
||||
#define DMA_CLC_EDIS_GET(val) ((((val) & DMA_CLC_EDIS) >> 3) & 0x1)
|
||||
#define DMA_CLC_EDIS_SET(reg,val) (reg) = ((reg & ~DMA_CLC_EDIS) | (((val) & 0x1) << 3))
|
||||
/* Suspend Enable Bit for OCDS (2) */
|
||||
#define DMA_CLC_SPEN (0x1 << 2)
|
||||
#define DMA_CLC_SPEN_VAL(val) (((val) & 0x1) << 2)
|
||||
#define DMA_CLC_SPEN_GET(val) ((((val) & DMA_CLC_SPEN) >> 2) & 0x1)
|
||||
#define DMA_CLC_SPEN_SET(reg,val) (reg) = ((reg & ~DMA_CLC_SPEN) | (((val) & 0x1) << 2))
|
||||
/* Disable Status Bit (1) */
|
||||
#define DMA_CLC_DISS (0x1 << 1)
|
||||
#define DMA_CLC_DISS_GET(val) ((((val) & DMA_CLC_DISS) >> 1) & 0x1)
|
||||
/* Disable Request Bit (0) */
|
||||
#define DMA_CLC_DISR (0x1)
|
||||
#define DMA_CLC_DISR_VAL(val) (((val) & 0x1) << 0)
|
||||
#define DMA_CLC_DISR_GET(val) ((((val) & DMA_CLC_DISR) >> 0) & 0x1)
|
||||
#define DMA_CLC_DISR_SET(reg,val) (reg) = ((reg & ~DMA_CLC_DISR) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* ID Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Number of Channels (25:20) */
|
||||
#define DMA_ID_CHNR (0x3f << 20)
|
||||
#define DMA_ID_CHNR_GET(val) ((((val) & DMA_ID_CHNR) >> 20) & 0x3f)
|
||||
/* Number of Ports (19:16) */
|
||||
#define DMA_ID_PRTNR (0xf << 16)
|
||||
#define DMA_ID_PRTNR_GET(val) ((((val) & DMA_ID_PRTNR) >> 16) & 0xf)
|
||||
/* Module ID (15:8) */
|
||||
#define DMA_ID_ID (0xff << 8)
|
||||
#define DMA_ID_ID_GET(val) ((((val) & DMA_ID_ID) >> 8) & 0xff)
|
||||
/* Revision (4:0) */
|
||||
#define DMA_ID_REV (0x1f)
|
||||
#define DMA_ID_REV_GET(val) ((((val) & DMA_ID_REV) >> 0) & 0x1f)
|
||||
|
||||
/*******************************************************************************
|
||||
* Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Global Software Reset (0) */
|
||||
#define DMA_CTRL_RST (0x1)
|
||||
#define DMA_CTRL_RST_GET(val) ((((val) & DMA_CTRL_RST) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Polling Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Enable (31) */
|
||||
#define DMA_CPOLL_EN (0x1 << 31)
|
||||
#define DMA_CPOLL_EN_VAL(val) (((val) & 0x1) << 31)
|
||||
#define DMA_CPOLL_EN_GET(val) ((((val) & DMA_CPOLL_EN) >> 31) & 0x1)
|
||||
#define DMA_CPOLL_EN_SET(reg,val) (reg) = ((reg & ~DMA_CPOLL_EN) | (((val) & 0x1) << 31))
|
||||
/* Counter (15:4) */
|
||||
#define DMA_CPOLL_CNT (0xfff << 4)
|
||||
#define DMA_CPOLL_CNT_VAL(val) (((val) & 0xfff) << 4)
|
||||
#define DMA_CPOLL_CNT_GET(val) ((((val) & DMA_CPOLL_CNT) >> 4) & 0xfff)
|
||||
#define DMA_CPOLL_CNT_SET(reg,val) (reg) = ((reg & ~DMA_CPOLL_CNT) | (((val) & 0xfff) << 4))
|
||||
|
||||
/*******************************************************************************
|
||||
* Global Buffer Length Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Global Buffer Length (15:0) */
|
||||
#define DMA_CGBL_GBL (0xffff)
|
||||
#define DMA_CGBL_GBL_VAL(val) (((val) & 0xffff) << 0)
|
||||
#define DMA_CGBL_GBL_GET(val) ((((val) & DMA_CGBL_GBL) >> 0) & 0xffff)
|
||||
#define DMA_CGBL_GBL_SET(reg,val) (reg) = ((reg & ~DMA_CGBL_GBL) | (((val) & 0xffff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Select Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel Selection (4:0) */
|
||||
#define DMA_CS_CS (0x1f)
|
||||
#define DMA_CS_CS_VAL(val) (((val) & 0x1f) << 0)
|
||||
#define DMA_CS_CS_GET(val) ((((val) & DMA_CS_CS) >> 0) & 0x1f)
|
||||
#define DMA_CS_CS_SET(reg,val) (reg) = ((reg & ~DMA_CS_CS) | (((val) & 0x1f) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Peripheral to Peripheral Copy (24) */
|
||||
#define DMA_CCTRL_P2PCPY (0x1 << 24)
|
||||
#define DMA_CCTRL_P2PCPY_VAL(val) (((val) & 0x1) << 24)
|
||||
#define DMA_CCTRL_P2PCPY_GET(val) ((((val) & DMA_CCTRL_P2PCPY) >> 24) & 0x1)
|
||||
#define DMA_CCTRL_P2PCPY_SET(reg,val) (reg) = ((reg & ~DMA_CCTRL_P2PCPY) | (((val) & 0x1) << 24))
|
||||
/* Channel Weight for Transmit Direction (17:16) */
|
||||
#define DMA_CCTRL_TXWGT (0x3 << 16)
|
||||
#define DMA_CCTRL_TXWGT_VAL(val) (((val) & 0x3) << 16)
|
||||
#define DMA_CCTRL_TXWGT_GET(val) ((((val) & DMA_CCTRL_TXWGT) >> 16) & 0x3)
|
||||
#define DMA_CCTRL_TXWGT_SET(reg,val) (reg) = ((reg & ~DMA_CCTRL_TXWGT) | (((val) & 0x3) << 16))
|
||||
/* Port Assignment (13:11) */
|
||||
#define DMA_CCTRL_PRTNR (0x7 << 11)
|
||||
#define DMA_CCTRL_PRTNR_GET(val) ((((val) & DMA_CCTRL_PRTNR) >> 11) & 0x7)
|
||||
/* Class (10:9) */
|
||||
#define DMA_CCTRL_CLASS (0x3 << 9)
|
||||
#define DMA_CCTRL_CLASS_VAL(val) (((val) & 0x3) << 9)
|
||||
#define DMA_CCTRL_CLASS_GET(val) ((((val) & DMA_CCTRL_CLASS) >> 9) & 0x3)
|
||||
#define DMA_CCTRL_CLASS_SET(reg,val) (reg) = ((reg & ~DMA_CCTRL_CLASS) | (((val) & 0x3) << 9))
|
||||
/* Direction (8) */
|
||||
#define DMA_CCTRL_DIR (0x1 << 8)
|
||||
#define DMA_CCTRL_DIR_GET(val) ((((val) & DMA_CCTRL_DIR) >> 8) & 0x1)
|
||||
/* Reset (1) */
|
||||
#define DMA_CCTRL_RST (0x1 << 1)
|
||||
#define DMA_CCTRL_RST_VAL(val) (((val) & 0x1) << 1)
|
||||
#define DMA_CCTRL_RST_GET(val) ((((val) & DMA_CCTRL_RST) >> 1) & 0x1)
|
||||
#define DMA_CCTRL_RST_SET(reg,val) (reg) = ((reg & ~DMA_CCTRL_RST) | (((val) & 0x1) << 1))
|
||||
/* Channel On or Off (0) */
|
||||
#define DMA_CCTRL_ON_OFF (0x1)
|
||||
#define DMA_CCTRL_ON_OFF_VAL(val) (((val) & 0x1) << 0)
|
||||
#define DMA_CCTRL_ON_OFF_GET(val) ((((val) & DMA_CCTRL_ON_OFF) >> 0) & 0x1)
|
||||
#define DMA_CCTRL_ON_OFF_SET(reg,val) (reg) = ((reg & ~DMA_CCTRL_ON_OFF) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Descriptor Base Address Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel Descriptor Base Address (29:3) */
|
||||
#define DMA_CDBA_CDBA (0x7ffffff << 3)
|
||||
#define DMA_CDBA_CDBA_VAL(val) (((val) & 0x7ffffff) << 3)
|
||||
#define DMA_CDBA_CDBA_GET(val) ((((val) & DMA_CDBA_CDBA) >> 3) & 0x7ffffff)
|
||||
#define DMA_CDBA_CDBA_SET(reg,val) (reg) = ((reg & ~DMA_CDBA_CDBA) | (((val) & 0x7ffffff) << 3))
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Descriptor Length Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel Descriptor Length (7:0) */
|
||||
#define DMA_CDLEN_CDLEN (0xff)
|
||||
#define DMA_CDLEN_CDLEN_VAL(val) (((val) & 0xff) << 0)
|
||||
#define DMA_CDLEN_CDLEN_GET(val) ((((val) & DMA_CDLEN_CDLEN) >> 0) & 0xff)
|
||||
#define DMA_CDLEN_CDLEN_SET(reg,val) (reg) = ((reg & ~DMA_CDLEN_CDLEN) | (((val) & 0xff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Interrupt Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* SAI Read Error Interrupt (5) */
|
||||
#define DMA_CIS_RDERR (0x1 << 5)
|
||||
#define DMA_CIS_RDERR_GET(val) ((((val) & DMA_CIS_RDERR) >> 5) & 0x1)
|
||||
/* Channel Off Interrupt (4) */
|
||||
#define DMA_CIS_CHOFF (0x1 << 4)
|
||||
#define DMA_CIS_CHOFF_GET(val) ((((val) & DMA_CIS_CHOFF) >> 4) & 0x1)
|
||||
/* Descriptor Complete Interrupt (3) */
|
||||
#define DMA_CIS_DESCPT (0x1 << 3)
|
||||
#define DMA_CIS_DESCPT_GET(val) ((((val) & DMA_CIS_DESCPT) >> 3) & 0x1)
|
||||
/* Descriptor Under-Run Interrupt (2) */
|
||||
#define DMA_CIS_DUR (0x1 << 2)
|
||||
#define DMA_CIS_DUR_GET(val) ((((val) & DMA_CIS_DUR) >> 2) & 0x1)
|
||||
/* End of Packet Interrupt (1) */
|
||||
#define DMA_CIS_EOP (0x1 << 1)
|
||||
#define DMA_CIS_EOP_GET(val) ((((val) & DMA_CIS_EOP) >> 1) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* Channel Interrupt Enable Register
|
||||
******************************************************************************/
|
||||
|
||||
/* SAI Read Error Interrupt (5) */
|
||||
#define DMA_CIE_RDERR (0x1 << 5)
|
||||
#define DMA_CIE_RDERR_GET(val) ((((val) & DMA_CIE_RDERR) >> 5) & 0x1)
|
||||
/* Channel Off Interrupt (4) */
|
||||
#define DMA_CIE_CHOFF (0x1 << 4)
|
||||
#define DMA_CIE_CHOFF_GET(val) ((((val) & DMA_CIE_CHOFF) >> 4) & 0x1)
|
||||
/* Descriptor Complete Interrupt Enable (3) */
|
||||
#define DMA_CIE_DESCPT (0x1 << 3)
|
||||
#define DMA_CIE_DESCPT_GET(val) ((((val) & DMA_CIE_DESCPT) >> 3) & 0x1)
|
||||
/* Descriptor Under Run Interrupt Enable (2) */
|
||||
#define DMA_CIE_DUR (0x1 << 2)
|
||||
#define DMA_CIE_DUR_GET(val) ((((val) & DMA_CIE_DUR) >> 2) & 0x1)
|
||||
/* End of Packet Interrupt Enable (1) */
|
||||
#define DMA_CIE_EOP (0x1 << 1)
|
||||
#define DMA_CIE_EOP_GET(val) ((((val) & DMA_CIE_EOP) >> 1) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* Port Select Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Port Selection (2:0) */
|
||||
#define DMA_PS_PS (0x7)
|
||||
#define DMA_PS_PS_VAL(val) (((val) & 0x7) << 0)
|
||||
#define DMA_PS_PS_GET(val) ((((val) & DMA_PS_PS) >> 0) & 0x7)
|
||||
#define DMA_PS_PS_SET(reg,val) (reg) = ((reg & ~DMA_PS_PS) | (((val) & 0x7) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Port Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* General Purpose Control (16) */
|
||||
#define DMA_PCTRL_GPC (0x1 << 16)
|
||||
#define DMA_PCTRL_GPC_VAL(val) (((val) & 0x1) << 16)
|
||||
#define DMA_PCTRL_GPC_GET(val) ((((val) & DMA_PCTRL_GPC) >> 16) & 0x1)
|
||||
#define DMA_PCTRL_GPC_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_GPC) | (((val) & 0x1) << 16))
|
||||
/* Port Weight for Transmit Direction (14:12) */
|
||||
#define DMA_PCTRL_TXWGT (0x7 << 12)
|
||||
#define DMA_PCTRL_TXWGT_VAL(val) (((val) & 0x7) << 12)
|
||||
#define DMA_PCTRL_TXWGT_GET(val) ((((val) & DMA_PCTRL_TXWGT) >> 12) & 0x7)
|
||||
#define DMA_PCTRL_TXWGT_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_TXWGT) | (((val) & 0x7) << 12))
|
||||
/* Endianness for Transmit Direction (11:10) */
|
||||
#define DMA_PCTRL_TXENDI (0x3 << 10)
|
||||
#define DMA_PCTRL_TXENDI_VAL(val) (((val) & 0x3) << 10)
|
||||
#define DMA_PCTRL_TXENDI_GET(val) ((((val) & DMA_PCTRL_TXENDI) >> 10) & 0x3)
|
||||
#define DMA_PCTRL_TXENDI_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_TXENDI) | (((val) & 0x3) << 10))
|
||||
/* Endianness for Receive Direction (9:8) */
|
||||
#define DMA_PCTRL_RXENDI (0x3 << 8)
|
||||
#define DMA_PCTRL_RXENDI_VAL(val) (((val) & 0x3) << 8)
|
||||
#define DMA_PCTRL_RXENDI_GET(val) ((((val) & DMA_PCTRL_RXENDI) >> 8) & 0x3)
|
||||
#define DMA_PCTRL_RXENDI_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_RXENDI) | (((val) & 0x3) << 8))
|
||||
/* Packet Drop Enable (6) */
|
||||
#define DMA_PCTRL_PDEN (0x1 << 6)
|
||||
#define DMA_PCTRL_PDEN_VAL(val) (((val) & 0x1) << 6)
|
||||
#define DMA_PCTRL_PDEN_GET(val) ((((val) & DMA_PCTRL_PDEN) >> 6) & 0x1)
|
||||
#define DMA_PCTRL_PDEN_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_PDEN) | (((val) & 0x1) << 6))
|
||||
/* Burst Length for Transmit Direction (5:4) */
|
||||
#define DMA_PCTRL_TXBL (0x3 << 4)
|
||||
#define DMA_PCTRL_TXBL_VAL(val) (((val) & 0x3) << 4)
|
||||
#define DMA_PCTRL_TXBL_GET(val) ((((val) & DMA_PCTRL_TXBL) >> 4) & 0x3)
|
||||
#define DMA_PCTRL_TXBL_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_TXBL) | (((val) & 0x3) << 4))
|
||||
/* Burst Length for Receive Direction (3:2) */
|
||||
#define DMA_PCTRL_RXBL (0x3 << 2)
|
||||
#define DMA_PCTRL_RXBL_VAL(val) (((val) & 0x3) << 2)
|
||||
#define DMA_PCTRL_RXBL_GET(val) ((((val) & DMA_PCTRL_RXBL) >> 2) & 0x3)
|
||||
#define DMA_PCTRL_RXBL_SET(reg,val) (reg) = ((reg & ~DMA_PCTRL_RXBL) | (((val) & 0x3) << 2))
|
||||
|
||||
/*******************************************************************************
|
||||
* DMA_IRNEN Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel x Interrupt Request Enable (23) */
|
||||
#define DMA_IRNEN_CH23 (0x1 << 23)
|
||||
#define DMA_IRNEN_CH23_VAL(val) (((val) & 0x1) << 23)
|
||||
#define DMA_IRNEN_CH23_GET(val) ((((val) & DMA_IRNEN_CH23) >> 23) & 0x1)
|
||||
#define DMA_IRNEN_CH23_SET(reg,val) (reg) = ((reg & ~DMA_IRNEN_CH23) | (((val) & 0x1) << 23))
|
||||
|
||||
/*******************************************************************************
|
||||
* DMA_IRNCR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel x Interrupt (23) */
|
||||
#define DMA_IRNCR_CH23 (0x1 << 23)
|
||||
#define DMA_IRNCR_CH23_GET(val) ((((val) & DMA_IRNCR_CH23) >> 23) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* DMA_IRNICR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Channel x Interrupt Request (23) */
|
||||
#define DMA_IRNICR_CH23 (0x1 << 23)
|
||||
#define DMA_IRNICR_CH23_GET(val) ((((val) & DMA_IRNICR_CH23) >> 23) & 0x1)
|
||||
|
||||
#endif
|
|
@ -1,615 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __EBU_REG_H
|
||||
#define __EBU_REG_H
|
||||
|
||||
#define ebu_r32(reg) ltq_r32(&ebu->reg)
|
||||
#define ebu_w32(val, reg) ltq_w32(val, &ebu->reg)
|
||||
#define ebu_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &ebu->reg)
|
||||
|
||||
/** EBU register structure */
|
||||
struct svip_reg_ebu {
|
||||
volatile unsigned long clc; /* 0x0000 */
|
||||
volatile unsigned long reserved0; /* 0x04 */
|
||||
volatile unsigned long id; /* 0x0008 */
|
||||
volatile unsigned long reserved1; /* 0x0c */
|
||||
volatile unsigned long con; /* 0x0010 */
|
||||
volatile unsigned long reserved2[3]; /* 0x14 */
|
||||
volatile unsigned long addr_sel_0; /* 0x0020 */
|
||||
volatile unsigned long addr_sel_1; /* 0x0024 */
|
||||
volatile unsigned long addr_sel_2; /* 0x0028 */
|
||||
volatile unsigned long addr_sel_3; /* 0x002c */
|
||||
volatile unsigned long reserved3[12]; /* 0x30 */
|
||||
volatile unsigned long con_0; /* 0x0060 */
|
||||
volatile unsigned long con_1; /* 0x0064 */
|
||||
volatile unsigned long con_2; /* 0x0068 */
|
||||
volatile unsigned long con_3; /* 0x006c */
|
||||
volatile unsigned long reserved4[4]; /* 0x70 */
|
||||
volatile unsigned long emu_addr; /* 0x0080 */
|
||||
volatile unsigned long emu_bc; /* 0x0084 */
|
||||
volatile unsigned long emu_con; /* 0x0088 */
|
||||
volatile unsigned long reserved5; /* 0x8c */
|
||||
volatile unsigned long pcc_con; /* 0x0090 */
|
||||
volatile unsigned long pcc_stat; /* 0x0094 */
|
||||
volatile unsigned long reserved6[2]; /* 0x98 */
|
||||
volatile unsigned long pcc_istat; /* 0x00A0 */
|
||||
volatile unsigned long pcc_ien; /* 0x00A4 */
|
||||
volatile unsigned long pcc_int_out; /* 0x00A8 */
|
||||
volatile unsigned long pcc_irs; /* 0x00AC */
|
||||
volatile unsigned long nand_con; /* 0x00B0 */
|
||||
volatile unsigned long nand_wait; /* 0x00B4 */
|
||||
volatile unsigned long nand_ecc0; /* 0x00B8 */
|
||||
volatile unsigned long nand_ecc_ac; /* 0x00BC */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* EBU
|
||||
******************************************************************************/
|
||||
#define LTQ_EBU_CLC ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0000))
|
||||
#define LTQ_EBU_ID ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0008))
|
||||
#define LTQ_EBU_CON ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0010))
|
||||
#define LTQ_EBU_ADDR_SEL_0 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0020))
|
||||
#define LTQ_EBU_ADDR_SEL_1 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0024))
|
||||
#define LTQ_EBU_ADDR_SEL_2 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0028))
|
||||
#define LTQ_EBU_ADDR_SEL_3 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x002c))
|
||||
#define LTQ_EBU_CON_0 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0060))
|
||||
#define LTQ_EBU_CON_1 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0064))
|
||||
#define LTQ_EBU_CON_2 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0068))
|
||||
#define LTQ_EBU_CON_3 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x006c))
|
||||
#define LTQ_EBU_EMU_BC ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0084))
|
||||
#define LTQ_EBU_PCC_CON ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0090))
|
||||
#define LTQ_EBU_PCC_STAT ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0094))
|
||||
#define LTQ_EBU_PCC_ISTAT ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00A0))
|
||||
#define LTQ_EBU_PCC_IEN ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00A4))
|
||||
#define LTQ_EBU_PCC_INT_OUT ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00A8))
|
||||
#define LTQ_EBU_PCC_IRS ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00AC))
|
||||
#define LTQ_EBU_NAND_CON ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00B0))
|
||||
#define LTQ_EBU_NAND_WAIT ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00B4))
|
||||
#define LTQ_EBU_NAND_ECC0 ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00B8))
|
||||
#define LTQ_EBU_NAND_ECC_AC ((volatile unsigned int*)(LTQ_EBU_BASE + 0x00BC))
|
||||
#define LTQ_EBU_EMU_ADDR ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0080))
|
||||
#define LTQ_EBU_EMU_CON ((volatile unsigned int*)(LTQ_EBU_BASE + 0x0088))
|
||||
|
||||
/*******************************************************************************
|
||||
* EBU Clock Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* EBU Disable Status Bit (1) */
|
||||
#define LTQ_EBU_CLC_DISS (0x1 << 1)
|
||||
#define LTQ_EBU_CLC_DISS_GET(val) ((((val) & LTQ_EBU_CLC_DISS) >> 1) & 0x1)
|
||||
/* Used for Enable/disable Control of the EBU (0) */
|
||||
#define LTQ_EBU_CLC_DISR (0x1)
|
||||
#define LTQ_EBU_CLC_DISR_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_CLC_DISR_GET(val) ((((val) & LTQ_EBU_CLC_DISR) >> 0) & 0x1)
|
||||
#define LTQ_EBU_CLC_DISR_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CLC_DISR) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* EBU Identification Register (Internal)
|
||||
******************************************************************************/
|
||||
|
||||
/* Module Number (31:8) */
|
||||
#define LTQ_EBU_ID_MODNUM (0xffffff << 8)
|
||||
#define LTQ_EBU_ID_MODNUM_GET(val) ((((val) & LTQ_EBU_ID_MODNUM) >> 8) & 0xffffff)
|
||||
/* Revision Number (7:0) */
|
||||
#define LTQ_EBU_ID_REVNUM (0xff)
|
||||
#define LTQ_EBU_ID_REVNUM_GET(val) ((((val) & LTQ_EBU_ID_REVNUM) >> 0) & 0xff)
|
||||
|
||||
/*******************************************************************************
|
||||
* External Bus Unit Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Driver Turn-Around Control, Chip Select Triggered (22:20) */
|
||||
#define LTQ_EBU_CON_DTACS (0x7 << 20)
|
||||
#define LTQ_EBU_CON_DTACS_VAL(val) (((val) & 0x7) << 20)
|
||||
#define LTQ_EBU_CON_DTACS_GET(val) ((((val) & LTQ_EBU_CON_DTACS) >> 20) & 0x7)
|
||||
#define LTQ_EBU_CON_DTACS_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_DTACS) | (((val) & 0x7) << 20))
|
||||
/* Driver Turn-Around Control, Read-write Triggered (18:16) */
|
||||
#define LTQ_EBU_CON_DTARW (0x7 << 16)
|
||||
#define LTQ_EBU_CON_DTARW_VAL(val) (((val) & 0x7) << 16)
|
||||
#define LTQ_EBU_CON_DTARW_GET(val) ((((val) & LTQ_EBU_CON_DTARW) >> 16) & 0x7)
|
||||
#define LTQ_EBU_CON_DTARW_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_DTARW) | (((val) & 0x7) << 16))
|
||||
/* Time-Out Control (15:8) */
|
||||
#define LTQ_EBU_CON_TOUTC (0xff << 8)
|
||||
#define LTQ_EBU_CON_TOUTC_VAL(val) (((val) & 0xff) << 8)
|
||||
#define LTQ_EBU_CON_TOUTC_GET(val) ((((val) & LTQ_EBU_CON_TOUTC) >> 8) & 0xff)
|
||||
#define LTQ_EBU_CON_TOUTC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_TOUTC) | (((val) & 0xff) << 8))
|
||||
/* Arbitration Mode (7:6) */
|
||||
#define LTQ_EBU_CON_ARBMODE (0x3 << 6)
|
||||
#define LTQ_EBU_CON_ARBMODE_VAL(val) (((val) & 0x3) << 6)
|
||||
#define LTQ_EBU_CON_ARBMODE_GET(val) ((((val) & LTQ_EBU_CON_ARBMODE) >> 6) & 0x3)
|
||||
#define LTQ_EBU_CON_ARBMODE_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_ARBMODE) | (((val) & 0x3) << 6))
|
||||
/* Arbitration Synchronization (5) */
|
||||
#define LTQ_EBU_CON_ARBSYNC (0x1 << 5)
|
||||
#define LTQ_EBU_CON_ARBSYNC_VAL(val) (((val) & 0x1) << 5)
|
||||
#define LTQ_EBU_CON_ARBSYNC_GET(val) ((((val) & LTQ_EBU_CON_ARBSYNC) >> 5) & 0x1)
|
||||
#define LTQ_EBU_CON_ARBSYNC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_ARBSYNC) | (((val) & 0x1) << 5))
|
||||
|
||||
/*******************************************************************************
|
||||
* Address Select Registers
|
||||
******************************************************************************/
|
||||
|
||||
/* Memory Region Base Address (31:12) */
|
||||
#define LTQ_EBU_ADDR_SEL_0_BASE (0xfffff << 12)
|
||||
#define LTQ_EBU_ADDR_SEL_0_BASE_VAL(val) (((val) & 0xfffff) << 12)
|
||||
#define LTQ_EBU_ADDR_SEL_0_BASE_GET(val) ((((val) & LTQ_EBU_ADDR_SEL_0_BASE) >> 12) & 0xfffff)
|
||||
#define LTQ_EBU_ADDR_SEL_0_BASE_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_ADDR_SEL_0_BASE) | (((val) & 0xfffff) << 12))
|
||||
/* Memory Region Address Mask (7:4) */
|
||||
#define LTQ_EBU_ADDR_SEL_0_MASK (0xf << 4)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MASK_VAL(val) (((val) & 0xf) << 4)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MASK_GET(val) ((((val) & LTQ_EBU_ADDR_SEL_0_MASK) >> 4) & 0xf)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MASK_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_ADDR_SEL_0_MASK) | (((val) & 0xf) << 4))
|
||||
/* Memory Region Mirror Enable Control (1) */
|
||||
#define LTQ_EBU_ADDR_SEL_0_MRME (0x1 << 1)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MRME_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MRME_GET(val) ((((val) & LTQ_EBU_ADDR_SEL_0_MRME) >> 1) & 0x1)
|
||||
#define LTQ_EBU_ADDR_SEL_0_MRME_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_ADDR_SEL_0_MRME) | (((val) & 0x1) << 1))
|
||||
/* Memory Region Enable Control (0) */
|
||||
#define LTQ_EBU_ADDR_SEL_0_REGEN (0x1)
|
||||
#define LTQ_EBU_ADDR_SEL_0_REGEN_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_ADDR_SEL_0_REGEN_GET(val) ((((val) & LTQ_EBU_ADDR_SEL_0_REGEN) >> 0) & 0x1)
|
||||
#define LTQ_EBU_ADDR_SEL_0_REGEN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_ADDR_SEL_0_REGEN) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Bus Configuration Registers
|
||||
******************************************************************************/
|
||||
|
||||
/* Memory Region Write Protection (31) */
|
||||
#define LTQ_EBU_CON_0_WRDIS (0x1 << 31)
|
||||
#define LTQ_EBU_CON_0_WRDIS_VAL(val) (((val) & 0x1) << 31)
|
||||
#define LTQ_EBU_CON_0_WRDIS_GET(val) ((((val) & LTQ_EBU_CON_0_WRDIS) >> 31) & 0x1)
|
||||
#define LTQ_EBU_CON_0_WRDIS_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_WRDIS) | (((val) & 0x1) << 31))
|
||||
/* Address Swapping (30) */
|
||||
#define LTQ_EBU_CON_0_ADSWP (0x1 << 30)
|
||||
#define LTQ_EBU_CON_0_ADSWP_VAL(val) (((val) & 0x1) << 30)
|
||||
#define LTQ_EBU_CON_0_ADSWP_GET(val) ((((val) & LTQ_EBU_CON_0_ADSWP) >> 30) & 0x1)
|
||||
#define LTQ_EBU_CON_0_ADSWP_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_ADSWP) | (((val) & 0x1) << 30))
|
||||
/* Address Generation Control (26:24) */
|
||||
#define LTQ_EBU_CON_0_AGEN (0x7 << 24)
|
||||
#define LTQ_EBU_CON_0_AGEN_VAL(val) (((val) & 0x7) << 24)
|
||||
#define LTQ_EBU_CON_0_AGEN_GET(val) ((((val) & LTQ_EBU_CON_0_AGEN) >> 24) & 0x7)
|
||||
#define LTQ_EBU_CON_0_AGEN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_AGEN) | (((val) & 0x7) << 24))
|
||||
/* Extended Address Setup Control (22) */
|
||||
#define LTQ_EBU_CON_0_SETUP (0x1 << 22)
|
||||
#define LTQ_EBU_CON_0_SETUP_VAL(val) (((val) & 0x1) << 22)
|
||||
#define LTQ_EBU_CON_0_SETUP_GET(val) ((((val) & LTQ_EBU_CON_0_SETUP) >> 22) & 0x1)
|
||||
#define LTQ_EBU_CON_0_SETUP_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_SETUP) | (((val) & 0x1) << 22))
|
||||
/* Variable Wait-State Insertion Control (21:20) */
|
||||
#define LTQ_EBU_CON_0_WAIT (0x3 << 20)
|
||||
#define LTQ_EBU_CON_0_WAIT_VAL(val) (((val) & 0x3) << 20)
|
||||
#define LTQ_EBU_CON_0_WAIT_GET(val) ((((val) & LTQ_EBU_CON_0_WAIT) >> 20) & 0x3)
|
||||
#define LTQ_EBU_CON_0_WAIT_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_WAIT) | (((val) & 0x3) << 20))
|
||||
/* Active WAIT Level Control (19) */
|
||||
#define LTQ_EBU_CON_0_WINV (0x1 << 19)
|
||||
#define LTQ_EBU_CON_0_WINV_VAL(val) (((val) & 0x1) << 19)
|
||||
#define LTQ_EBU_CON_0_WINV_GET(val) ((((val) & LTQ_EBU_CON_0_WINV) >> 19) & 0x1)
|
||||
#define LTQ_EBU_CON_0_WINV_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_WINV) | (((val) & 0x1) << 19))
|
||||
/* External Device Data Width Control (17:16) */
|
||||
#define LTQ_EBU_CON_0_PW (0x3 << 16)
|
||||
#define LTQ_EBU_CON_0_PW_VAL(val) (((val) & 0x3) << 16)
|
||||
#define LTQ_EBU_CON_0_PW_GET(val) ((((val) & LTQ_EBU_CON_0_PW) >> 16) & 0x3)
|
||||
#define LTQ_EBU_CON_0_PW_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_PW) | (((val) & 0x3) << 16))
|
||||
/* Address Latch Enable ALE Duration Control (15:14) */
|
||||
#define LTQ_EBU_CON_0_ALEC (0x3 << 14)
|
||||
#define LTQ_EBU_CON_0_ALEC_VAL(val) (((val) & 0x3) << 14)
|
||||
#define LTQ_EBU_CON_0_ALEC_GET(val) ((((val) & LTQ_EBU_CON_0_ALEC) >> 14) & 0x3)
|
||||
#define LTQ_EBU_CON_0_ALEC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_ALEC) | (((val) & 0x3) << 14))
|
||||
/* Byte Control Signal Timing Mode Control (13:12) */
|
||||
#define LTQ_EBU_CON_0_BCGEN (0x3 << 12)
|
||||
#define LTQ_EBU_CON_0_BCGEN_VAL(val) (((val) & 0x3) << 12)
|
||||
#define LTQ_EBU_CON_0_BCGEN_GET(val) ((((val) & LTQ_EBU_CON_0_BCGEN) >> 12) & 0x3)
|
||||
#define LTQ_EBU_CON_0_BCGEN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_BCGEN) | (((val) & 0x3) << 12))
|
||||
/* Write Access Wait-State Control (10:8) */
|
||||
#define LTQ_EBU_CON_0_WAITWRC (0x7 << 8)
|
||||
#define LTQ_EBU_CON_0_WAITWRC_VAL(val) (((val) & 0x7) << 8)
|
||||
#define LTQ_EBU_CON_0_WAITWRC_GET(val) ((((val) & LTQ_EBU_CON_0_WAITWRC) >> 8) & 0x7)
|
||||
#define LTQ_EBU_CON_0_WAITWRC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_WAITWRC) | (((val) & 0x7) << 8))
|
||||
/* Read Access Wait-State Control (7:6) */
|
||||
#define LTQ_EBU_CON_0_WAITRDC (0x3 << 6)
|
||||
#define LTQ_EBU_CON_0_WAITRDC_VAL(val) (((val) & 0x3) << 6)
|
||||
#define LTQ_EBU_CON_0_WAITRDC_GET(val) ((((val) & LTQ_EBU_CON_0_WAITRDC) >> 6) & 0x3)
|
||||
#define LTQ_EBU_CON_0_WAITRDC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_WAITRDC) | (((val) & 0x3) << 6))
|
||||
/* Hold/Pause Cycle Control (5:4) */
|
||||
#define LTQ_EBU_CON_0_HOLDC (0x3 << 4)
|
||||
#define LTQ_EBU_CON_0_HOLDC_VAL(val) (((val) & 0x3) << 4)
|
||||
#define LTQ_EBU_CON_0_HOLDC_GET(val) ((((val) & LTQ_EBU_CON_0_HOLDC) >> 4) & 0x3)
|
||||
#define LTQ_EBU_CON_0_HOLDC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_HOLDC) | (((val) & 0x3) << 4))
|
||||
/* Recovery Cycle Control (3:2) */
|
||||
#define LTQ_EBU_CON_0_RECOVC (0x3 << 2)
|
||||
#define LTQ_EBU_CON_0_RECOVC_VAL(val) (((val) & 0x3) << 2)
|
||||
#define LTQ_EBU_CON_0_RECOVC_GET(val) ((((val) & LTQ_EBU_CON_0_RECOVC) >> 2) & 0x3)
|
||||
#define LTQ_EBU_CON_0_RECOVC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_RECOVC) | (((val) & 0x3) << 2))
|
||||
/* Wait Cycle Multiplier Control (1:0) */
|
||||
#define LTQ_EBU_CON_0_CMULT (0x3)
|
||||
#define LTQ_EBU_CON_0_CMULT_VAL(val) (((val) & 0x3) << 0)
|
||||
#define LTQ_EBU_CON_0_CMULT_GET(val) ((((val) & LTQ_EBU_CON_0_CMULT) >> 0) & 0x3)
|
||||
#define LTQ_EBU_CON_0_CMULT_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_CON_0_CMULT) | (((val) & 0x3) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* External Bus Unit Emulator Bus Configuration Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Write Protection (31) */
|
||||
#define LTQ_EBU_EMU_BC_WRITE (0x1 << 31)
|
||||
#define LTQ_EBU_EMU_BC_WRITE_VAL(val) (((val) & 0x1) << 31)
|
||||
#define LTQ_EBU_EMU_BC_WRITE_GET(val) ((((val) & LTQ_EBU_EMU_BC_WRITE) >> 31) & 0x1)
|
||||
#define LTQ_EBU_EMU_BC_WRITE_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_WRITE) | (((val) & 0x1) << 31))
|
||||
/* Address Generation Control (26:24) */
|
||||
#define LTQ_EBU_EMU_BC_AGEN (0x7 << 24)
|
||||
#define LTQ_EBU_EMU_BC_AGEN_VAL(val) (((val) & 0x7) << 24)
|
||||
#define LTQ_EBU_EMU_BC_AGEN_GET(val) ((((val) & LTQ_EBU_EMU_BC_AGEN) >> 24) & 0x7)
|
||||
#define LTQ_EBU_EMU_BC_AGEN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_AGEN) | (((val) & 0x7) << 24))
|
||||
/* Extended Address Setup Control (22) */
|
||||
#define LTQ_EBU_EMU_BC_SETUP (0x1 << 22)
|
||||
#define LTQ_EBU_EMU_BC_SETUP_VAL(val) (((val) & 0x1) << 22)
|
||||
#define LTQ_EBU_EMU_BC_SETUP_GET(val) ((((val) & LTQ_EBU_EMU_BC_SETUP) >> 22) & 0x1)
|
||||
#define LTQ_EBU_EMU_BC_SETUP_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_SETUP) | (((val) & 0x1) << 22))
|
||||
/* Variable Waitstate Insertion Control (21:20) */
|
||||
#define LTQ_EBU_EMU_BC_WAIT (0x3 << 20)
|
||||
#define LTQ_EBU_EMU_BC_WAIT_VAL(val) (((val) & 0x3) << 20)
|
||||
#define LTQ_EBU_EMU_BC_WAIT_GET(val) ((((val) & LTQ_EBU_EMU_BC_WAIT) >> 20) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_WAIT_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_WAIT) | (((val) & 0x3) << 20))
|
||||
/* Active WAIT Level Control (19) */
|
||||
#define LTQ_EBU_EMU_BC_WINV (0x1 << 19)
|
||||
#define LTQ_EBU_EMU_BC_WINV_VAL(val) (((val) & 0x1) << 19)
|
||||
#define LTQ_EBU_EMU_BC_WINV_GET(val) ((((val) & LTQ_EBU_EMU_BC_WINV) >> 19) & 0x1)
|
||||
#define LTQ_EBU_EMU_BC_WINV_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_WINV) | (((val) & 0x1) << 19))
|
||||
/* External Device Data Width Control (17:16) */
|
||||
#define LTQ_EBU_EMU_BC_PORTW (0x3 << 16)
|
||||
#define LTQ_EBU_EMU_BC_PORTW_VAL(val) (((val) & 0x3) << 16)
|
||||
#define LTQ_EBU_EMU_BC_PORTW_GET(val) ((((val) & LTQ_EBU_EMU_BC_PORTW) >> 16) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_PORTW_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_PORTW) | (((val) & 0x3) << 16))
|
||||
/* Address Latch Enable Function (15:14) */
|
||||
#define LTQ_EBU_EMU_BC_ALEC (0x3 << 14)
|
||||
#define LTQ_EBU_EMU_BC_ALEC_VAL(val) (((val) & 0x3) << 14)
|
||||
#define LTQ_EBU_EMU_BC_ALEC_GET(val) ((((val) & LTQ_EBU_EMU_BC_ALEC) >> 14) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_ALEC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_ALEC) | (((val) & 0x3) << 14))
|
||||
/* Byte Control Signal Timing Mode (13:12) */
|
||||
#define LTQ_EBU_EMU_BC_BCGEN (0x3 << 12)
|
||||
#define LTQ_EBU_EMU_BC_BCGEN_VAL(val) (((val) & 0x3) << 12)
|
||||
#define LTQ_EBU_EMU_BC_BCGEN_GET(val) ((((val) & LTQ_EBU_EMU_BC_BCGEN) >> 12) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_BCGEN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_BCGEN) | (((val) & 0x3) << 12))
|
||||
/* Write Access Waitstate Control (10:8) */
|
||||
#define LTQ_EBU_EMU_BC_WAITWRC (0x7 << 8)
|
||||
#define LTQ_EBU_EMU_BC_WAITWRC_VAL(val) (((val) & 0x7) << 8)
|
||||
#define LTQ_EBU_EMU_BC_WAITWRC_GET(val) ((((val) & LTQ_EBU_EMU_BC_WAITWRC) >> 8) & 0x7)
|
||||
#define LTQ_EBU_EMU_BC_WAITWRC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_WAITWRC) | (((val) & 0x7) << 8))
|
||||
/* Read Access Waitstate Control (7:6) */
|
||||
#define LTQ_EBU_EMU_BC_WAITRDC (0x3 << 6)
|
||||
#define LTQ_EBU_EMU_BC_WAITRDC_VAL(val) (((val) & 0x3) << 6)
|
||||
#define LTQ_EBU_EMU_BC_WAITRDC_GET(val) ((((val) & LTQ_EBU_EMU_BC_WAITRDC) >> 6) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_WAITRDC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_WAITRDC) | (((val) & 0x3) << 6))
|
||||
/* Hold/Pause Cycle Control (5:4) */
|
||||
#define LTQ_EBU_EMU_BC_HOLDC (0x3 << 4)
|
||||
#define LTQ_EBU_EMU_BC_HOLDC_VAL(val) (((val) & 0x3) << 4)
|
||||
#define LTQ_EBU_EMU_BC_HOLDC_GET(val) ((((val) & LTQ_EBU_EMU_BC_HOLDC) >> 4) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_HOLDC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_HOLDC) | (((val) & 0x3) << 4))
|
||||
/* Recovery Cycles Control (3:2) */
|
||||
#define LTQ_EBU_EMU_BC_RECOVC (0x3 << 2)
|
||||
#define LTQ_EBU_EMU_BC_RECOVC_VAL(val) (((val) & 0x3) << 2)
|
||||
#define LTQ_EBU_EMU_BC_RECOVC_GET(val) ((((val) & LTQ_EBU_EMU_BC_RECOVC) >> 2) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_RECOVC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_RECOVC) | (((val) & 0x3) << 2))
|
||||
/* Cycle Multiplier Control (1:0) */
|
||||
#define LTQ_EBU_EMU_BC_CMULT (0x3)
|
||||
#define LTQ_EBU_EMU_BC_CMULT_VAL(val) (((val) & 0x3) << 0)
|
||||
#define LTQ_EBU_EMU_BC_CMULT_GET(val) ((((val) & LTQ_EBU_EMU_BC_CMULT) >> 0) & 0x3)
|
||||
#define LTQ_EBU_EMU_BC_CMULT_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_BC_CMULT) | (((val) & 0x3) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PC-Card Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* External Interrupt Input IREQ (3:1) */
|
||||
#define LTQ_EBU_PCC_CON_IREQ (0x7 << 1)
|
||||
#define LTQ_EBU_PCC_CON_IREQ_VAL(val) (((val) & 0x7) << 1)
|
||||
#define LTQ_EBU_PCC_CON_IREQ_GET(val) ((((val) & LTQ_EBU_PCC_CON_IREQ) >> 1) & 0x7)
|
||||
#define LTQ_EBU_PCC_CON_IREQ_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_CON_IREQ) | (((val) & 0x7) << 1))
|
||||
/* PC Card ON (0) */
|
||||
#define LTQ_EBU_PCC_CON_ON (0x1)
|
||||
#define LTQ_EBU_PCC_CON_ON_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_PCC_CON_ON_GET(val) ((((val) & LTQ_EBU_PCC_CON_ON) >> 0) & 0x1)
|
||||
#define LTQ_EBU_PCC_CON_ON_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_CON_ON) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PCC Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Interrupt Request (6) */
|
||||
#define LTQ_EBU_PCC_STAT_IRQ (0x1 << 6)
|
||||
#define LTQ_EBU_PCC_STAT_IRQ_GET(val) ((((val) & LTQ_EBU_PCC_STAT_IRQ) >> 6) & 0x1)
|
||||
/* PC-Card Overcurrent (5) */
|
||||
#define LTQ_EBU_PCC_STAT_OC (0x1 << 5)
|
||||
#define LTQ_EBU_PCC_STAT_OC_GET(val) ((((val) & LTQ_EBU_PCC_STAT_OC) >> 5) & 0x1)
|
||||
/* PC-Card Socket Power On (4) */
|
||||
#define LTQ_EBU_PCC_STAT_SPON (0x1 << 4)
|
||||
#define LTQ_EBU_PCC_STAT_SPON_GET(val) ((((val) & LTQ_EBU_PCC_STAT_SPON) >> 4) & 0x1)
|
||||
/* Card Detect Status (1:0) */
|
||||
#define LTQ_EBU_PCC_STAT_CD (0x3)
|
||||
#define LTQ_EBU_PCC_STAT_CD_GET(val) ((((val) & LTQ_EBU_PCC_STAT_CD) >> 0) & 0x3)
|
||||
|
||||
/*******************************************************************************
|
||||
* PCC Interrupt Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Interrupt Request Active Interrupt (4) */
|
||||
#define LTQ_EBU_PCC_ISTAT_IREQ (0x1 << 4)
|
||||
#define LTQ_EBU_PCC_ISTAT_IREQ_VAL(val) (((val) & 0x1) << 4)
|
||||
#define LTQ_EBU_PCC_ISTAT_IREQ_GET(val) ((((val) & LTQ_EBU_PCC_ISTAT_IREQ) >> 4) & 0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_IREQ_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_ISTAT_IREQ) | (((val) & 0x1) << 4))
|
||||
/* Over Current Status Change Interrupt (3) */
|
||||
#define LTQ_EBU_PCC_ISTAT_OC (0x1 << 3)
|
||||
#define LTQ_EBU_PCC_ISTAT_OC_VAL(val) (((val) & 0x1) << 3)
|
||||
#define LTQ_EBU_PCC_ISTAT_OC_GET(val) ((((val) & LTQ_EBU_PCC_ISTAT_OC) >> 3) & 0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_OC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_ISTAT_OC) | (((val) & 0x1) << 3))
|
||||
/* Socket Power on Status Change Interrupt (2) */
|
||||
#define LTQ_EBU_PCC_ISTAT_SPON (0x1 << 2)
|
||||
#define LTQ_EBU_PCC_ISTAT_SPON_VAL(val) (((val) & 0x1) << 2)
|
||||
#define LTQ_EBU_PCC_ISTAT_SPON_GET(val) ((((val) & LTQ_EBU_PCC_ISTAT_SPON) >> 2) & 0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_SPON_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_ISTAT_SPON) | (((val) & 0x1) << 2))
|
||||
/* Voltage Sense Status Change Interrupt (1) */
|
||||
#define LTQ_EBU_PCC_ISTAT_VS (0x1 << 1)
|
||||
#define LTQ_EBU_PCC_ISTAT_VS_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_PCC_ISTAT_VS_GET(val) ((((val) & LTQ_EBU_PCC_ISTAT_VS) >> 1) & 0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_VS_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_ISTAT_VS) | (((val) & 0x1) << 1))
|
||||
/* Card Detect Status Change Interrupt (0) */
|
||||
#define LTQ_EBU_PCC_ISTAT_CD (0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_CD_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_PCC_ISTAT_CD_GET(val) ((((val) & LTQ_EBU_PCC_ISTAT_CD) >> 0) & 0x1)
|
||||
#define LTQ_EBU_PCC_ISTAT_CD_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_ISTAT_CD) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PCC Interrupt Enable Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Enable of Interrupt Request IR (4) */
|
||||
#define LTQ_EBU_PCC_IEN_IR (0x1 << 4)
|
||||
#define LTQ_EBU_PCC_IEN_IR_VAL(val) (((val) & 0x1) << 4)
|
||||
#define LTQ_EBU_PCC_IEN_IR_GET(val) ((((val) & LTQ_EBU_PCC_IEN_IR) >> 4) & 0x1)
|
||||
#define LTQ_EBU_PCC_IEN_IR_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_IEN_IR) | (((val) & 0x1) << 4))
|
||||
/* Enable of Interrupt Request OC event (3) */
|
||||
#define LTQ_EBU_PCC_IEN_OC (0x1 << 3)
|
||||
#define LTQ_EBU_PCC_IEN_OC_VAL(val) (((val) & 0x1) << 3)
|
||||
#define LTQ_EBU_PCC_IEN_OC_GET(val) ((((val) & LTQ_EBU_PCC_IEN_OC) >> 3) & 0x1)
|
||||
#define LTQ_EBU_PCC_IEN_OC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_IEN_OC) | (((val) & 0x1) << 3))
|
||||
/* Enable of Interrupt Request Socket Power On (2) */
|
||||
#define LTQ_EBU_PCC_IEN_PWRON (0x1 << 2)
|
||||
#define LTQ_EBU_PCC_IEN_PWRON_VAL(val) (((val) & 0x1) << 2)
|
||||
#define LTQ_EBU_PCC_IEN_PWRON_GET(val) ((((val) & LTQ_EBU_PCC_IEN_PWRON) >> 2) & 0x1)
|
||||
#define LTQ_EBU_PCC_IEN_PWRON_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_IEN_PWRON) | (((val) & 0x1) << 2))
|
||||
/* Enable of Interrupt Request Voltage Sense (1) */
|
||||
#define LTQ_EBU_PCC_IEN_VS (0x1 << 1)
|
||||
#define LTQ_EBU_PCC_IEN_VS_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_PCC_IEN_VS_GET(val) ((((val) & LTQ_EBU_PCC_IEN_VS) >> 1) & 0x1)
|
||||
#define LTQ_EBU_PCC_IEN_VS_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_IEN_VS) | (((val) & 0x1) << 1))
|
||||
/* Enable of Interrupt Request Card Detect (0) */
|
||||
#define LTQ_EBU_PCC_IEN_CD (0x1)
|
||||
#define LTQ_EBU_PCC_IEN_CD_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_PCC_IEN_CD_GET(val) ((((val) & LTQ_EBU_PCC_IEN_CD) >> 0) & 0x1)
|
||||
#define LTQ_EBU_PCC_IEN_CD_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_PCC_IEN_CD) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PCC Interrupt Output Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Status of Interrupt Request IR (4) */
|
||||
#define LTQ_EBU_PCC_INT_OUT_IR (0x1 << 4)
|
||||
#define LTQ_EBU_PCC_INT_OUT_IR_GET(val) ((((val) & LTQ_EBU_PCC_INT_OUT_IR) >> 4) & 0x1)
|
||||
/* Status of Interrupt Request OC (3) */
|
||||
#define LTQ_EBU_PCC_INT_OUT_OC (0x1 << 3)
|
||||
#define LTQ_EBU_PCC_INT_OUT_OC_GET(val) ((((val) & LTQ_EBU_PCC_INT_OUT_OC) >> 3) & 0x1)
|
||||
/* Status of Interrupt Request Socket Power On (2) */
|
||||
#define LTQ_EBU_PCC_INT_OUT_PWRON (0x1 << 2)
|
||||
#define LTQ_EBU_PCC_INT_OUT_PWRON_GET(val) ((((val) & LTQ_EBU_PCC_INT_OUT_PWRON) >> 2) & 0x1)
|
||||
/* Status of Interrupt Request Voltage Sense (1) */
|
||||
#define LTQ_EBU_PCC_INT_OUT_VS (0x1 << 1)
|
||||
#define LTQ_EBU_PCC_INT_OUT_VS_GET(val) ((((val) & LTQ_EBU_PCC_INT_OUT_VS) >> 1) & 0x1)
|
||||
/* Status of Interrupt Request Card Detect (0) */
|
||||
#define LTQ_EBU_PCC_INT_OUT_CD (0x1)
|
||||
#define LTQ_EBU_PCC_INT_OUT_CD_GET(val) ((((val) & LTQ_EBU_PCC_INT_OUT_CD) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* PCC Interrupt Request Set Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Set Interrupt Request IR (4) */
|
||||
#define LTQ_EBU_PCC_IRS_IR (0x1 << 4)
|
||||
#define LTQ_EBU_PCC_IRS_IR_VAL(val) (((val) & 0x1) << 4)
|
||||
#define LTQ_EBU_PCC_IRS_IR_SET(reg,val) (reg) = (((reg & ~LTQ_EBU_PCC_IRS_IR) | (val) & 1) << 4)
|
||||
/* Set Interrupt Request OC (3) */
|
||||
#define LTQ_EBU_PCC_IRS_OC (0x1 << 3)
|
||||
#define LTQ_EBU_PCC_IRS_OC_VAL(val) (((val) & 0x1) << 3)
|
||||
#define LTQ_EBU_PCC_IRS_OC_SET(reg,val) (reg) = (((reg & ~LTQ_EBU_PCC_IRS_OC) | (val) & 1) << 3)
|
||||
/* Set Interrupt Request Socket Power On (2) */
|
||||
#define LTQ_EBU_PCC_IRS_PWRON (0x1 << 2)
|
||||
#define LTQ_EBU_PCC_IRS_PWRON_VAL(val) (((val) & 0x1) << 2)
|
||||
#define LTQ_EBU_PCC_IRS_PWRON_SET(reg,val) (reg) = (((reg & ~LTQ_EBU_PCC_IRS_PWRON) | (val) & 1) << 2)
|
||||
/* Set Interrupt Request Voltage Sense (1) */
|
||||
#define LTQ_EBU_PCC_IRS_VS (0x1 << 1)
|
||||
#define LTQ_EBU_PCC_IRS_VS_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_PCC_IRS_VS_SET(reg,val) (reg) = (((reg & ~LTQ_EBU_PCC_IRS_VS) | (val) & 1) << 1)
|
||||
/* Set Interrupt Request Card Detect (0) */
|
||||
#define LTQ_EBU_PCC_IRS_CD (0x1)
|
||||
#define LTQ_EBU_PCC_IRS_CD_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_PCC_IRS_CD_SET(reg,val) (reg) = (((reg & ~LTQ_EBU_PCC_IRS_CD) | (val) & 1) << 0)
|
||||
|
||||
/*******************************************************************************
|
||||
* NAND Flash Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* ECC Enabling (31) */
|
||||
#define LTQ_EBU_NAND_CON_ECC_ON (0x1 << 31)
|
||||
#define LTQ_EBU_NAND_CON_ECC_ON_VAL(val) (((val) & 0x1) << 31)
|
||||
#define LTQ_EBU_NAND_CON_ECC_ON_GET(val) ((((val) & LTQ_EBU_NAND_CON_ECC_ON) >> 31) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_ECC_ON_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_ECC_ON) | (((val) & 0x1) << 31))
|
||||
/* Latch enable (23:18) */
|
||||
#define LTQ_EBU_NAND_CON_LAT_EN (0x3f << 18)
|
||||
#define LTQ_EBU_NAND_CON_LAT_EN_VAL(val) (((val) & 0x3f) << 18)
|
||||
#define LTQ_EBU_NAND_CON_LAT_EN_GET(val) ((((val) & LTQ_EBU_NAND_CON_LAT_EN) >> 18) & 0x3f)
|
||||
#define LTQ_EBU_NAND_CON_LAT_EN_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_LAT_EN) | (((val) & 0x3f) << 18))
|
||||
/* Output ChipSelect# Selection (11:10) */
|
||||
#define LTQ_EBU_NAND_CON_OUT_CS_S (0x3 << 10)
|
||||
#define LTQ_EBU_NAND_CON_OUT_CS_S_VAL(val) (((val) & 0x3) << 10)
|
||||
#define LTQ_EBU_NAND_CON_OUT_CS_S_GET(val) ((((val) & LTQ_EBU_NAND_CON_OUT_CS_S) >> 10) & 0x3)
|
||||
#define LTQ_EBU_NAND_CON_OUT_CS_S_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_OUT_CS_S) | (((val) & 0x3) << 10))
|
||||
/* Input ChipSelect# Selection (9:8) */
|
||||
#define LTQ_EBU_NAND_CON_IN_CS_S (0x3 << 8)
|
||||
#define LTQ_EBU_NAND_CON_IN_CS_S_VAL(val) (((val) & 0x3) << 8)
|
||||
#define LTQ_EBU_NAND_CON_IN_CS_S_GET(val) ((((val) & LTQ_EBU_NAND_CON_IN_CS_S) >> 8) & 0x3)
|
||||
#define LTQ_EBU_NAND_CON_IN_CS_S_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_IN_CS_S) | (((val) & 0x3) << 8))
|
||||
/* Set PRE (7) */
|
||||
#define LTQ_EBU_NAND_CON_PRE_P (0x1 << 7)
|
||||
#define LTQ_EBU_NAND_CON_PRE_P_VAL(val) (((val) & 0x1) << 7)
|
||||
#define LTQ_EBU_NAND_CON_PRE_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_PRE_P) >> 7) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_PRE_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_PRE_P) | (((val) & 0x1) << 7))
|
||||
/* Set WP Active Polarity (6) */
|
||||
#define LTQ_EBU_NAND_CON_WP_P (0x1 << 6)
|
||||
#define LTQ_EBU_NAND_CON_WP_P_VAL(val) (((val) & 0x1) << 6)
|
||||
#define LTQ_EBU_NAND_CON_WP_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_WP_P) >> 6) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_WP_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_WP_P) | (((val) & 0x1) << 6))
|
||||
/* Set SE Active Polarity (5) */
|
||||
#define LTQ_EBU_NAND_CON_SE_P (0x1 << 5)
|
||||
#define LTQ_EBU_NAND_CON_SE_P_VAL(val) (((val) & 0x1) << 5)
|
||||
#define LTQ_EBU_NAND_CON_SE_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_SE_P) >> 5) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_SE_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_SE_P) | (((val) & 0x1) << 5))
|
||||
/* Set CS Active Polarity (4) */
|
||||
#define LTQ_EBU_NAND_CON_CS_P (0x1 << 4)
|
||||
#define LTQ_EBU_NAND_CON_CS_P_VAL(val) (((val) & 0x1) << 4)
|
||||
#define LTQ_EBU_NAND_CON_CS_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_CS_P) >> 4) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_CS_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_CS_P) | (((val) & 0x1) << 4))
|
||||
/* Set CLE Active Polarity (3) */
|
||||
#define LTQ_EBU_NAND_CON_CLE_P (0x1 << 3)
|
||||
#define LTQ_EBU_NAND_CON_CLE_P_VAL(val) (((val) & 0x1) << 3)
|
||||
#define LTQ_EBU_NAND_CON_CLE_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_CLE_P) >> 3) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_CLE_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_CLE_P) | (((val) & 0x1) << 3))
|
||||
/* Set ALE Active Polarity (2) */
|
||||
#define LTQ_EBU_NAND_CON_ALE_P (0x1 << 2)
|
||||
#define LTQ_EBU_NAND_CON_ALE_P_VAL(val) (((val) & 0x1) << 2)
|
||||
#define LTQ_EBU_NAND_CON_ALE_P_GET(val) ((((val) & LTQ_EBU_NAND_CON_ALE_P) >> 2) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_ALE_P_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_ALE_P) | (((val) & 0x1) << 2))
|
||||
/* NAND CS Mux with EBU CS Enable (1) */
|
||||
#define LTQ_EBU_NAND_CON_CSMUX_E (0x1 << 1)
|
||||
#define LTQ_EBU_NAND_CON_CSMUX_E_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_NAND_CON_CSMUX_E_GET(val) ((((val) & LTQ_EBU_NAND_CON_CSMUX_E) >> 1) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_CSMUX_E_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_CSMUX_E) | (((val) & 0x1) << 1))
|
||||
/* NAND FLASH Mode Support (0) */
|
||||
#define LTQ_EBU_NAND_CON_NANDMODE (0x1)
|
||||
#define LTQ_EBU_NAND_CON_NANDMODE_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_NAND_CON_NANDMODE_GET(val) ((((val) & LTQ_EBU_NAND_CON_NANDMODE) >> 0) & 0x1)
|
||||
#define LTQ_EBU_NAND_CON_NANDMODE_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_CON_NANDMODE) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* NAND Flash State Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Reserved (31:3) */
|
||||
#define LTQ_EBU_NAND_WAIT_RES (0x1fffffff << 3)
|
||||
#define LTQ_EBU_NAND_WAIT_RES_GET(val) ((((val) & LTQ_EBU_NAND_WAIT_RES) >> 3) & 0x1fffffff)
|
||||
/* NAND Write Complete (3) */
|
||||
#define LTQ_EBU_NAND_WAIT_WR_C (0x1 << 3)
|
||||
#define LTQ_EBU_NAND_WAIT_WR_C_GET(val) ((((val) & LTQ_EBU_NAND_WAIT_WR_C) >> 3) & 0x1)
|
||||
/* Record the RD Edge (rising ) (2) */
|
||||
#define LTQ_EBU_NAND_WAIT_RD_EDGE (0x1 << 2)
|
||||
#define LTQ_EBU_NAND_WAIT_RD_EDGE_GET(val) ((((val) & LTQ_EBU_NAND_WAIT_RD_EDGE) >> 2) & 0x1)
|
||||
/* Record the BY# Edge (falling) (1) */
|
||||
#define LTQ_EBU_NAND_WAIT_BY_EDGE (0x1 << 1)
|
||||
#define LTQ_EBU_NAND_WAIT_BY_EDGE_GET(val) ((((val) & LTQ_EBU_NAND_WAIT_BY_EDGE) >> 1) & 0x1)
|
||||
/* Rd/BY# value (0) */
|
||||
#define LTQ_EBU_NAND_WAIT_RDBY_VALUE (0x1)
|
||||
#define LTQ_EBU_NAND_WAIT_RDBY_VALUE_GET(val) ((((val) & LTQ_EBU_NAND_WAIT_RDBY_VALUE) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* NAND ECC Result Register 0
|
||||
******************************************************************************/
|
||||
|
||||
/* Reserved (31:24) */
|
||||
#define LTQ_EBU_NAND_ECC0_RES (0xff << 24)
|
||||
#define LTQ_EBU_NAND_ECC0_RES_GET(val) ((((val) & LTQ_EBU_NAND_ECC0_RES) >> 24) & 0xff)
|
||||
/* ECC value (23:16) */
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B2 (0xff << 16)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B2_VAL(val) (((val) & 0xff) << 16)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B2_GET(val) ((((val) & LTQ_EBU_NAND_ECC0_ECC_B2) >> 16) & 0xff)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B2_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_ECC0_ECC_B2) | (((val) & 0xff) << 16))
|
||||
/* ECC value (15:8) */
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B1 (0xff << 8)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B1_VAL(val) (((val) & 0xff) << 8)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B1_GET(val) ((((val) & LTQ_EBU_NAND_ECC0_ECC_B1) >> 8) & 0xff)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B1_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_ECC0_ECC_B1) | (((val) & 0xff) << 8))
|
||||
/* ECC value (7:0) */
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B0 (0xff)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B0_VAL(val) (((val) & 0xff) << 0)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B0_GET(val) ((((val) & LTQ_EBU_NAND_ECC0_ECC_B0) >> 0) & 0xff)
|
||||
#define LTQ_EBU_NAND_ECC0_ECC_B0_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_ECC0_ECC_B0) | (((val) & 0xff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* NAND ECC Address Counter Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Reserved (31:9) */
|
||||
#define LTQ_EBU_NAND_ECC_AC_RES (0x7fffff << 9)
|
||||
#define LTQ_EBU_NAND_ECC_AC_RES_GET(val) ((((val) & LTQ_EBU_NAND_ECC_AC_RES) >> 9) & 0x7fffff)
|
||||
/* ECC address counter (8:0) */
|
||||
#define LTQ_EBU_NAND_ECC_AC_ECC_AC (0x1ff)
|
||||
#define LTQ_EBU_NAND_ECC_AC_ECC_AC_VAL(val) (((val) & 0x1ff) << 0)
|
||||
#define LTQ_EBU_NAND_ECC_AC_ECC_AC_GET(val) ((((val) & LTQ_EBU_NAND_ECC_AC_ECC_AC) >> 0) & 0x1ff)
|
||||
#define LTQ_EBU_NAND_ECC_AC_ECC_AC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_NAND_ECC_AC_ECC_AC) | (((val) & 0x1ff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* Internal Address Emulation Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Memory Region Base Address (31:12) */
|
||||
#define LTQ_EBU_EMU_ADDR_BASE (0xfffff << 12)
|
||||
#define LTQ_EBU_EMU_ADDR_BASE_VAL(val) (((val) & 0xfffff) << 12)
|
||||
#define LTQ_EBU_EMU_ADDR_BASE_GET(val) ((((val) & LTQ_EBU_EMU_ADDR_BASE) >> 12) & 0xfffff)
|
||||
#define LTQ_EBU_EMU_ADDR_BASE_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_ADDR_BASE) | (((val) & 0xfffff) << 12))
|
||||
/* Memory Region Address Mask (7:4) */
|
||||
#define LTQ_EBU_EMU_ADDR_MASK (0xf << 4)
|
||||
#define LTQ_EBU_EMU_ADDR_MASK_VAL(val) (((val) & 0xf) << 4)
|
||||
#define LTQ_EBU_EMU_ADDR_MASK_GET(val) ((((val) & LTQ_EBU_EMU_ADDR_MASK) >> 4) & 0xf)
|
||||
#define LTQ_EBU_EMU_ADDR_MASK_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_ADDR_MASK) | (((val) & 0xf) << 4))
|
||||
/* Memory Region Mirror Segment B Control (1) */
|
||||
#define LTQ_EBU_EMU_ADDR_MRMB (0x1 << 1)
|
||||
#define LTQ_EBU_EMU_ADDR_MRMB_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_EMU_ADDR_MRMB_GET(val) ((((val) & LTQ_EBU_EMU_ADDR_MRMB) >> 1) & 0x1)
|
||||
#define LTQ_EBU_EMU_ADDR_MRMB_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_ADDR_MRMB) | (((val) & 0x1) << 1))
|
||||
/* Memory Region Enable Control (0) */
|
||||
#define LTQ_EBU_EMU_ADDR_MREC (0x1)
|
||||
#define LTQ_EBU_EMU_ADDR_MREC_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_EMU_ADDR_MREC_GET(val) ((((val) & LTQ_EBU_EMU_ADDR_MREC) >> 0) & 0x1)
|
||||
#define LTQ_EBU_EMU_ADDR_MREC_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_ADDR_MREC) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* nternal Emulator Configuration Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Overlay Memory Control Region 3 (3) */
|
||||
#define LTQ_EBU_EMU_CON_OVL3 (0x1 << 3)
|
||||
#define LTQ_EBU_EMU_CON_OVL3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define LTQ_EBU_EMU_CON_OVL3_GET(val) ((((val) & LTQ_EBU_EMU_CON_OVL3) >> 3) & 0x1)
|
||||
#define LTQ_EBU_EMU_CON_OVL3_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_CON_OVL3) | (((val) & 0x1) << 3))
|
||||
/* Overlay Memory Control Region 2 (2) */
|
||||
#define LTQ_EBU_EMU_CON_OVL2 (0x1 << 2)
|
||||
#define LTQ_EBU_EMU_CON_OVL2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define LTQ_EBU_EMU_CON_OVL2_GET(val) ((((val) & LTQ_EBU_EMU_CON_OVL2) >> 2) & 0x1)
|
||||
#define LTQ_EBU_EMU_CON_OVL2_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_CON_OVL2) | (((val) & 0x1) << 2))
|
||||
/* Overlay Memory Control Region 1 (1) */
|
||||
#define LTQ_EBU_EMU_CON_OVL1 (0x1 << 1)
|
||||
#define LTQ_EBU_EMU_CON_OVL1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define LTQ_EBU_EMU_CON_OVL1_GET(val) ((((val) & LTQ_EBU_EMU_CON_OVL1) >> 1) & 0x1)
|
||||
#define LTQ_EBU_EMU_CON_OVL1_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_CON_OVL1) | (((val) & 0x1) << 1))
|
||||
/* Overlay Memory Control Region 0 (0) */
|
||||
#define LTQ_EBU_EMU_CON_OVL0 (0x1)
|
||||
#define LTQ_EBU_EMU_CON_OVL0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define LTQ_EBU_EMU_CON_OVL0_GET(val) ((((val) & LTQ_EBU_EMU_CON_OVL0) >> 0) & 0x1)
|
||||
#define LTQ_EBU_EMU_CON_OVL0_SET(reg,val) (reg) = ((reg & ~LTQ_EBU_EMU_CON_OVL0) | (((val) & 0x1) << 0))
|
||||
|
||||
#endif /* __LTQ_EBU_H */
|
File diff suppressed because it is too large
Load Diff
|
@ -1,36 +0,0 @@
|
|||
/*
|
||||
* arch/mips/include/asm/mach-lantiq/svip/irq.h
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Copyright (C) 2010 Lantiq
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __IRQ_H
|
||||
#define __IRQ_H
|
||||
|
||||
#include <svip_irq.h>
|
||||
|
||||
#define NR_IRQS 264
|
||||
|
||||
#include_next <irq.h>
|
||||
|
||||
/* Functions for EXINT handling */
|
||||
extern int ifx_enable_external_int(u32 exint, u32 mode);
|
||||
extern int ifx_disable_external_int(u32 exint);
|
||||
extern int ifx_external_int_level(u32 exint);
|
||||
|
||||
#endif
|
|
@ -1,71 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#ifndef _LTQ_SVIP_H__
|
||||
#define _LTQ_SVIP_H__
|
||||
|
||||
#ifdef CONFIG_SOC_SVIP
|
||||
|
||||
#include <lantiq.h>
|
||||
|
||||
/* Chip IDs */
|
||||
#define SOC_ID_SVIP 0x169
|
||||
|
||||
/* SoC Types */
|
||||
#define SOC_TYPE_SVIP 0x01
|
||||
|
||||
/* ASC0/1 - serial port */
|
||||
#define LTQ_ASC0_BASE_ADDR 0x14100100
|
||||
#define LTQ_ASC1_BASE_ADDR 0x14100200
|
||||
#define LTQ_ASC_SIZE 0x100
|
||||
#define LTQ_EARLY_ASC KSEG1ADDR(LTQ_ASC0_BASE_ADDR)
|
||||
|
||||
#define LTQ_ASC_TIR(x) (INT_NUM_IM0_IRL0 + (x * 8))
|
||||
#define LTQ_ASC_RIR(x) (INT_NUM_IM0_IRL0 + (x * 8) + 2)
|
||||
#define LTQ_ASC_EIR(x) (INT_NUM_IM0_IRL0 + (x * 8) + 3)
|
||||
|
||||
/* ICU - interrupt control unit */
|
||||
#define LTQ_ICU_BASE_ADDR 0x14106000
|
||||
#define LTQ_ICU_BASE_ADDR1 0x14106028
|
||||
#define LTQ_ICU_BASE_ADDR2 0x1E016000
|
||||
#define LTQ_ICU_BASE_ADDR3 0x1E016028
|
||||
#define LTQ_ICU_BASE_ADDR4 0x14106050
|
||||
#define LTQ_ICU_BASE_ADDR5 0x14106078
|
||||
#define LTQ_ICU_SIZE 0x100
|
||||
|
||||
/* WDT */
|
||||
#define LTQ_WDT_BASE_ADDR 0x1F8803F0
|
||||
#define LTQ_WDT_SIZE 0x10
|
||||
|
||||
/* Status */
|
||||
#define LTQ_STATUS_BASE_ADDR (KSEG1 + 0x1E000500)
|
||||
#define LTQ_STATUS_CHIPID ((u32 *)(LTQ_STATUS_BASE_ADDR + 0x000C))
|
||||
|
||||
#define LTQ_EIU_BASE_ADDR 0
|
||||
|
||||
#define ltq_ebu_w32(x, y) ltq_w32((x), ltq_ebu_membase + (y))
|
||||
#define ltq_ebu_r32(x) ltq_r32(ltq_ebu_membase + (x))
|
||||
|
||||
extern __iomem void *ltq_ebu_membase;
|
||||
|
||||
extern void ltq_gpio_configure(int port, int pin, bool dirin, bool puen,
|
||||
bool altsel0, bool altsel1);
|
||||
extern int ltq_port_get_dir(unsigned int port, unsigned int pin);
|
||||
extern int ltq_port_get_puden(unsigned int port, unsigned int pin);
|
||||
extern int ltq_port_get_altsel0(unsigned int port, unsigned int pin);
|
||||
extern int ltq_port_get_altsel1(unsigned int port, unsigned int pin);
|
||||
|
||||
#define ltq_is_ar9() 0
|
||||
#define ltq_is_vr9() 0
|
||||
#define ltq_is_falcon() 0
|
||||
|
||||
#define BS_FLASH 0
|
||||
#define LTQ_RST_CAUSE_WDTRST 0x2
|
||||
|
||||
#endif /* CONFIG_SOC_SVIP */
|
||||
#endif /* _LTQ_SVIP_H__ */
|
|
@ -1,242 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __MPS_REG_H
|
||||
#define __MPS_REG_H
|
||||
|
||||
#define mbs_r32(reg) ltq_r32(&mbs->reg)
|
||||
#define mbs_w32(val, reg) ltq_w32(val, &mbs->reg)
|
||||
#define mbs_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &mbs->reg)
|
||||
|
||||
/** MBS register structure */
|
||||
struct svip_reg_mbs {
|
||||
unsigned long reserved0[4];
|
||||
unsigned long mbsr0; /* 0x0010 */
|
||||
unsigned long mbsr1; /* 0x0014 */
|
||||
unsigned long mbsr2; /* 0x0018 */
|
||||
unsigned long mbsr3; /* 0x001c */
|
||||
unsigned long mbsr4; /* 0x0020 */
|
||||
unsigned long mbsr5; /* 0x0024 */
|
||||
unsigned long mbsr6; /* 0x0028 */
|
||||
unsigned long mbsr7; /* 0x002c */
|
||||
unsigned long mbsr8; /* 0x0030 */
|
||||
unsigned long mbsr9; /* 0x0034 */
|
||||
unsigned long mbsr10; /* 0x0038 */
|
||||
unsigned long mbsr11; /* 0x003c */
|
||||
unsigned long mbsr12; /* 0x0040 */
|
||||
unsigned long mbsr13; /* 0x0044 */
|
||||
unsigned long mbsr14; /* 0x0048 */
|
||||
unsigned long mbsr15; /* 0x004c */
|
||||
unsigned long mbsr16; /* 0x0050 */
|
||||
unsigned long mbsr17; /* 0x0054 */
|
||||
unsigned long mbsr18; /* 0x0058 */
|
||||
unsigned long mbsr19; /* 0x005c */
|
||||
unsigned long mbsr20; /* 0x0060 */
|
||||
unsigned long mbsr21; /* 0x0064 */
|
||||
unsigned long mbsr22; /* 0x0068 */
|
||||
unsigned long mbsr23; /* 0x006c */
|
||||
unsigned long mbsr24; /* 0x0070 */
|
||||
unsigned long mbsr25; /* 0x0074 */
|
||||
unsigned long mbsr26; /* 0x0078 */
|
||||
unsigned long mbsr27; /* 0x007c */
|
||||
unsigned long mbsr28; /* 0x0080 */
|
||||
};
|
||||
|
||||
/** MPS register structure */
|
||||
struct svip_reg_mps {
|
||||
volatile unsigned long mps_swirn0set; /* 0x0000 */
|
||||
volatile unsigned long mps_swirn0en; /* 0x0004 */
|
||||
volatile unsigned long mps_swirn0cr; /* 0x0008 */
|
||||
volatile unsigned long mps_swirn0icr; /* 0x000C */
|
||||
volatile unsigned long mps_swirn1set; /* 0x0010 */
|
||||
volatile unsigned long mps_swirn1en; /* 0x0014 */
|
||||
volatile unsigned long mps_swirn1cr; /* 0x0018 */
|
||||
volatile unsigned long mps_swirn1icr; /* 0x001C */
|
||||
volatile unsigned long mps_swirn2set; /* 0x0020 */
|
||||
volatile unsigned long mps_swirn2en; /* 0x0024 */
|
||||
volatile unsigned long mps_swirn2cr; /* 0x0028 */
|
||||
volatile unsigned long mps_swirn2icr; /* 0x002C */
|
||||
volatile unsigned long mps_swirn3set; /* 0x0030 */
|
||||
volatile unsigned long mps_swirn3en; /* 0x0034 */
|
||||
volatile unsigned long mps_swirn3cr; /* 0x0038 */
|
||||
volatile unsigned long mps_swirn3icr; /* 0x003C */
|
||||
volatile unsigned long mps_swirn4set; /* 0x0040 */
|
||||
volatile unsigned long mps_swirn4en; /* 0x0044 */
|
||||
volatile unsigned long mps_swirn4cr; /* 0x0048 */
|
||||
volatile unsigned long mps_swirn4icr; /* 0x004C */
|
||||
volatile unsigned long mps_swirn5set; /* 0x0050 */
|
||||
volatile unsigned long mps_swirn5en; /* 0x0054 */
|
||||
volatile unsigned long mps_swirn5cr; /* 0x0058 */
|
||||
volatile unsigned long mps_swirn5icr; /* 0x005C */
|
||||
volatile unsigned long mps_swirn6set; /* 0x0060 */
|
||||
volatile unsigned long mps_swirn6en; /* 0x0064 */
|
||||
volatile unsigned long mps_swirn6cr; /* 0x0068 */
|
||||
volatile unsigned long mps_swirn6icr; /* 0x006C */
|
||||
volatile unsigned long mps_swirn7set; /* 0x0070 */
|
||||
volatile unsigned long mps_swirn7en; /* 0x0074 */
|
||||
volatile unsigned long mps_swirn7cr; /* 0x0078 */
|
||||
volatile unsigned long mps_swirn7icr; /* 0x007C */
|
||||
volatile unsigned long mps_swirn8set; /* 0x0080 */
|
||||
volatile unsigned long mps_swirn8en; /* 0x0084 */
|
||||
volatile unsigned long mps_swirn8cr; /* 0x0088 */
|
||||
volatile unsigned long mps_swirn8icr; /* 0x008C */
|
||||
};
|
||||
|
||||
/* Software Interrupt */
|
||||
#define IFX_MPS_SWIRN0SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0000))
|
||||
#define IFX_MPS_SWIRN0EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0004))
|
||||
#define IFX_MPS_SWIRN0CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0008))
|
||||
#define IFX_MPS_SWIRN0ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x000C))
|
||||
#define IFX_MPS_SWIRN1SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0010))
|
||||
#define IFX_MPS_SWIRN1EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0014))
|
||||
#define IFX_MPS_SWIRN1CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0018))
|
||||
#define IFX_MPS_SWIRN1ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x001C))
|
||||
#define IFX_MPS_SWIRN2SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0020))
|
||||
#define IFX_MPS_SWIRN2EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0024))
|
||||
#define IFX_MPS_SWIRN2CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0028))
|
||||
#define IFX_MPS_SWIRN2ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x002C))
|
||||
#define IFX_MPS_SWIRN3SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0030))
|
||||
#define IFX_MPS_SWIRN3EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0034))
|
||||
#define IFX_MPS_SWIRN3CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0038))
|
||||
#define IFX_MPS_SWIRN3ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x003C))
|
||||
#define IFX_MPS_SWIRN4SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0040))
|
||||
#define IFX_MPS_SWIRN4EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0044))
|
||||
#define IFX_MPS_SWIRN4CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0048))
|
||||
#define IFX_MPS_SWIRN4ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x004C))
|
||||
#define IFX_MPS_SWIRN5SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0050))
|
||||
#define IFX_MPS_SWIRN5EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0054))
|
||||
#define IFX_MPS_SWIRN5CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0058))
|
||||
#define IFX_MPS_SWIRN5ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x005C))
|
||||
#define IFX_MPS_SWIRN6SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0060))
|
||||
#define IFX_MPS_SWIRN6EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0064))
|
||||
#define IFX_MPS_SWIRN6CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0068))
|
||||
#define IFX_MPS_SWIRN6ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x006C))
|
||||
#define IFX_MPS_SWIRN7SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0070))
|
||||
#define IFX_MPS_SWIRN7EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0074))
|
||||
#define IFX_MPS_SWIRN7CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0078))
|
||||
#define IFX_MPS_SWIRN7ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x007C))
|
||||
#define IFX_MPS_SWIRN8SET ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0080))
|
||||
#define IFX_MPS_SWIRN8EN ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0084))
|
||||
#define IFX_MPS_SWIRN8ICR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x008C))
|
||||
#define IFX_MPS_SWIRN8CR ((volatile unsigned int*)(LTQ_SWINT_BASE + 0x0088))
|
||||
|
||||
/*******************************************************************************
|
||||
* MPS_SWIRNSET Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Software Interrupt Request IR5 (5) */
|
||||
#define IFX_MPS_SWIRNSET_IR5 (0x1 << 5)
|
||||
#define IFX_MPS_SWIRNSET_IR5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define IFX_MPS_SWIRNSET_IR5_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR5) | (val) & 1) << 5)
|
||||
/* Software Interrupt Request IR4 (4) */
|
||||
#define IFX_MPS_SWIRNSET_IR4 (0x1 << 4)
|
||||
#define IFX_MPS_SWIRNSET_IR4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define IFX_MPS_SWIRNSET_IR4_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR4) | (val) & 1) << 4)
|
||||
/* Software Interrupt Request IR3 (3) */
|
||||
#define IFX_MPS_SWIRNSET_IR3 (0x1 << 3)
|
||||
#define IFX_MPS_SWIRNSET_IR3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define IFX_MPS_SWIRNSET_IR3_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR3) | (val) & 1) << 3)
|
||||
/* Software Interrupt Request IR2 (2) */
|
||||
#define IFX_MPS_SWIRNSET_IR2 (0x1 << 2)
|
||||
#define IFX_MPS_SWIRNSET_IR2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define IFX_MPS_SWIRNSET_IR2_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR2) | (val) & 1) << 2)
|
||||
/* Software Interrupt Request IR1 (1) */
|
||||
#define IFX_MPS_SWIRNSET_IR1 (0x1 << 1)
|
||||
#define IFX_MPS_SWIRNSET_IR1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define IFX_MPS_SWIRNSET_IR1_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR1) | (val) & 1) << 1)
|
||||
/* Software Interrupt Request IR0 (0) */
|
||||
#define IFX_MPS_SWIRNSET_IR0 (0x1)
|
||||
#define IFX_MPS_SWIRNSET_IR0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define IFX_MPS_SWIRNSET_IR0_SET(reg,val) (reg) = (((reg & ~IFX_MPS_SWIRNSET_IR0) | (val) & 1) << 0)
|
||||
|
||||
/*******************************************************************************
|
||||
* MPS_SWIRNEN Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Software Interrupt Request IR5 (5) */
|
||||
#define IFX_MPS_SWIRNEN_IR5 (0x1 << 5)
|
||||
#define IFX_MPS_SWIRNEN_IR5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define IFX_MPS_SWIRNEN_IR5_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR5) >> 5) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR5_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR5) | (((val) & 0x1) << 5))
|
||||
/* Software Interrupt Request IR4 (4) */
|
||||
#define IFX_MPS_SWIRNEN_IR4 (0x1 << 4)
|
||||
#define IFX_MPS_SWIRNEN_IR4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define IFX_MPS_SWIRNEN_IR4_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR4) >> 4) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR4_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR4) | (((val) & 0x1) << 4))
|
||||
/* Software Interrupt Request IR3 (3) */
|
||||
#define IFX_MPS_SWIRNEN_IR3 (0x1 << 3)
|
||||
#define IFX_MPS_SWIRNEN_IR3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define IFX_MPS_SWIRNEN_IR3_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR3) >> 3) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR3_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR3) | (((val) & 0x1) << 3))
|
||||
/* Software Interrupt Request IR2 (2) */
|
||||
#define IFX_MPS_SWIRNEN_IR2 (0x1 << 2)
|
||||
#define IFX_MPS_SWIRNEN_IR2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define IFX_MPS_SWIRNEN_IR2_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR2) >> 2) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR2_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR2) | (((val) & 0x1) << 2))
|
||||
/* Software Interrupt Request IR1 (1) */
|
||||
#define IFX_MPS_SWIRNEN_IR1 (0x1 << 1)
|
||||
#define IFX_MPS_SWIRNEN_IR1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define IFX_MPS_SWIRNEN_IR1_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR1) >> 1) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR1_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR1) | (((val) & 0x1) << 1))
|
||||
/* Software Interrupt Request IR0 (0) */
|
||||
#define IFX_MPS_SWIRNEN_IR0 (0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define IFX_MPS_SWIRNEN_IR0_GET(val) ((((val) & IFX_MPS_SWIRNEN_IR0) >> 0) & 0x1)
|
||||
#define IFX_MPS_SWIRNEN_IR0_SET(reg,val) (reg) = ((reg & ~IFX_MPS_SWIRNEN_IR0) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* MPS_SWIRNICR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Software Interrupt Request IR5 (5) */
|
||||
#define IFX_MPS_SWIRNICR_IR5 (0x1 << 5)
|
||||
#define IFX_MPS_SWIRNICR_IR5_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR5) >> 5) & 0x1)
|
||||
/* Software Interrupt Request IR4 (4) */
|
||||
#define IFX_MPS_SWIRNICR_IR4 (0x1 << 4)
|
||||
#define IFX_MPS_SWIRNICR_IR4_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR4) >> 4) & 0x1)
|
||||
/* Software Interrupt Request IR3 (3) */
|
||||
#define IFX_MPS_SWIRNICR_IR3 (0x1 << 3)
|
||||
#define IFX_MPS_SWIRNICR_IR3_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR3) >> 3) & 0x1)
|
||||
/* Software Interrupt Request IR2 (2) */
|
||||
#define IFX_MPS_SWIRNICR_IR2 (0x1 << 2)
|
||||
#define IFX_MPS_SWIRNICR_IR2_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR2) >> 2) & 0x1)
|
||||
/* Software Interrupt Request IR1 (1) */
|
||||
#define IFX_MPS_SWIRNICR_IR1 (0x1 << 1)
|
||||
#define IFX_MPS_SWIRNICR_IR1_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR1) >> 1) & 0x1)
|
||||
/* Software Interrupt Request IR0 (0) */
|
||||
#define IFX_MPS_SWIRNICR_IR0 (0x1)
|
||||
#define IFX_MPS_SWIRNICR_IR0_GET(val) ((((val) & IFX_MPS_SWIRNICR_IR0) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* MPS_SWIRNCR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Software Interrupt Request IR5 (5) */
|
||||
#define IFX_MPS_SWIRNCR_IR5 (0x1 << 5)
|
||||
#define IFX_MPS_SWIRNCR_IR5_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR5) >> 5) & 0x1)
|
||||
/* Software Interrupt Request IR4 (4) */
|
||||
#define IFX_MPS_SWIRNCR_IR4 (0x1 << 4)
|
||||
#define IFX_MPS_SWIRNCR_IR4_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR4) >> 4) & 0x1)
|
||||
/* Software Interrupt Request IR3 (3) */
|
||||
#define IFX_MPS_SWIRNCR_IR3 (0x1 << 3)
|
||||
#define IFX_MPS_SWIRNCR_IR3_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR3) >> 3) & 0x1)
|
||||
/* Software Interrupt Request IR2 (2) */
|
||||
#define IFX_MPS_SWIRNCR_IR2 (0x1 << 2)
|
||||
#define IFX_MPS_SWIRNCR_IR2_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR2) >> 2) & 0x1)
|
||||
/* Software Interrupt Request IR1 (1) */
|
||||
#define IFX_MPS_SWIRNCR_IR1 (0x1 << 1)
|
||||
#define IFX_MPS_SWIRNCR_IR1_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR1) >> 1) & 0x1)
|
||||
/* Software Interrupt Request IR0 (0) */
|
||||
#define IFX_MPS_SWIRNCR_IR0 (0x1)
|
||||
#define IFX_MPS_SWIRNCR_IR0_GET(val) ((((val) & IFX_MPS_SWIRNCR_IR0) >> 0) & 0x1)
|
||||
|
||||
#endif
|
File diff suppressed because it is too large
Load Diff
|
@ -1,624 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __SSC_REG_H
|
||||
#define __SSC_REG_H
|
||||
|
||||
/** SSC register structure */
|
||||
struct svip_reg_ssc {
|
||||
volatile unsigned long clc; /* 0x00 */
|
||||
volatile unsigned long pisel; /* 0x04 */
|
||||
volatile unsigned long id; /* 0x08 */
|
||||
volatile unsigned long reserved0; /* 0x0c */
|
||||
volatile unsigned long mcon; /* 0x10 */
|
||||
volatile unsigned long state; /* 0x14 */
|
||||
volatile unsigned long whbstate; /* 0x18 */
|
||||
volatile unsigned long reserved1; /* 0x1c */
|
||||
volatile unsigned long tb; /* 0x20 */
|
||||
volatile unsigned long rb; /* 0x24 */
|
||||
volatile unsigned long reserved2[2]; /* 0x28 */
|
||||
volatile unsigned long rxfcon; /* 0x30 */
|
||||
volatile unsigned long txfcon; /* 0x34 */
|
||||
volatile unsigned long fstat; /* 0x38 */
|
||||
volatile unsigned long reserved3; /* 0x3c */
|
||||
volatile unsigned long br; /* 0x40 */
|
||||
volatile unsigned long brstat; /* 0x44 */
|
||||
volatile unsigned long reserved4[6]; /* 0x48 */
|
||||
volatile unsigned long sfcon; /* 0x60 */
|
||||
volatile unsigned long sfstat; /* 0x64 */
|
||||
volatile unsigned long reserved5[2]; /* 0x68 */
|
||||
volatile unsigned long gpocon; /* 0x70 */
|
||||
volatile unsigned long gpostat; /* 0x74 */
|
||||
volatile unsigned long whbgpostat; /* 0x78 */
|
||||
volatile unsigned long reserved6; /* 0x7c */
|
||||
volatile unsigned long rxreq; /* 0x80 */
|
||||
volatile unsigned long rxcnt; /* 0x84 */
|
||||
volatile unsigned long reserved7[25]; /* 0x88 */
|
||||
volatile unsigned long dma_con; /* 0xEC */
|
||||
volatile unsigned long reserved8; /* 0xf0 */
|
||||
volatile unsigned long irnen; /* 0xF4 */
|
||||
volatile unsigned long irncr; /* 0xF8 */
|
||||
volatile unsigned long irnicr; /* 0xFC */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* CLC Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Clock Divider for Sleep Mode (23:16) */
|
||||
#define SSC_CLC_SMC (0xff << 16)
|
||||
#define SSC_CLC_SMC_VAL(val) (((val) & 0xff) << 16)
|
||||
#define SSC_CLC_SMC_GET(val) ((((val) & SSC_CLC_SMC) >> 16) & 0xff)
|
||||
#define SSC_CLC_SMC_SET(reg,val) (reg) = ((reg & ~SSC_CLC_SMC) | (((val) & 0xff) << 16))
|
||||
/* Clock Divider for Normal Run Mode (15:8) */
|
||||
#define SSC_CLC_RMC (0xff << 8)
|
||||
#define SSC_CLC_RMC_VAL(val) (((val) & 0xff) << 8)
|
||||
#define SSC_CLC_RMC_GET(val) ((((val) & SSC_CLC_RMC) >> 8) & 0xff)
|
||||
#define SSC_CLC_RMC_SET(reg,val) (reg) = ((reg & ~SSC_CLC_RMC) | (((val) & 0xff) << 8))
|
||||
/* Fast Shut-Off Enable Bit (5) */
|
||||
#define SSC_CLC_FSOE (0x1 << 5)
|
||||
#define SSC_CLC_FSOE_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SSC_CLC_FSOE_GET(val) ((((val) & SSC_CLC_FSOE) >> 5) & 0x1)
|
||||
#define SSC_CLC_FSOE_SET(reg,val) (reg) = ((reg & ~SSC_CLC_FSOE) | (((val) & 0x1) << 5))
|
||||
/* Suspend Bit Write Enable for OCDS (4) */
|
||||
#define SSC_CLC_SBWE (0x1 << 4)
|
||||
#define SSC_CLC_SBWE_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SSC_CLC_SBWE_SET(reg,val) (reg) = (((reg & ~SSC_CLC_SBWE) | (val) & 1) << 4)
|
||||
/* External Request Disable (3) */
|
||||
#define SSC_CLC_EDIS (0x1 << 3)
|
||||
#define SSC_CLC_EDIS_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SSC_CLC_EDIS_GET(val) ((((val) & SSC_CLC_EDIS) >> 3) & 0x1)
|
||||
#define SSC_CLC_EDIS_SET(reg,val) (reg) = ((reg & ~SSC_CLC_EDIS) | (((val) & 0x1) << 3))
|
||||
/* Suspend Enable Bit for OCDS (2) */
|
||||
#define SSC_CLC_SPEN (0x1 << 2)
|
||||
#define SSC_CLC_SPEN_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_CLC_SPEN_GET(val) ((((val) & SSC_CLC_SPEN) >> 2) & 0x1)
|
||||
#define SSC_CLC_SPEN_SET(reg,val) (reg) = ((reg & ~SSC_CLC_SPEN) | (((val) & 0x1) << 2))
|
||||
/* Disable Status Bit (1) */
|
||||
#define SSC_CLC_DISS (0x1 << 1)
|
||||
#define SSC_CLC_DISS_GET(val) ((((val) & SSC_CLC_DISS) >> 1) & 0x1)
|
||||
/* Disable Request Bit (0) */
|
||||
#define SSC_CLC_DISR (0x1)
|
||||
#define SSC_CLC_DISR_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_CLC_DISR_GET(val) ((((val) & SSC_CLC_DISR) >> 0) & 0x1)
|
||||
#define SSC_CLC_DISR_SET(reg,val) (reg) = ((reg & ~SSC_CLC_DISR) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* ID Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Transmit FIFO Size (29:24) */
|
||||
#define SSC_ID_TXFS (0x3f << 24)
|
||||
#define SSC_ID_TXFS_GET(val) ((((val) & SSC_ID_TXFS) >> 24) & 0x3f)
|
||||
/* Receive FIFO Size (21:16) */
|
||||
#define SSC_ID_RXFS (0x3f << 16)
|
||||
#define SSC_ID_RXFS_GET(val) ((((val) & SSC_ID_RXFS) >> 16) & 0x3f)
|
||||
/* Module ID (15:8) */
|
||||
#define SSC_ID_ID (0xff << 8)
|
||||
#define SSC_ID_ID_GET(val) ((((val) & SSC_ID_ID) >> 8) & 0xff)
|
||||
/* Configuration (5) */
|
||||
#define SSC_ID_CFG (0x1 << 5)
|
||||
#define SSC_ID_CFG_GET(val) ((((val) & SSC_ID_CFG) >> 5) & 0x1)
|
||||
/* Revision (4:0) */
|
||||
#define SSC_ID_REV (0x1f)
|
||||
#define SSC_ID_REV_GET(val) ((((val) & SSC_ID_REV) >> 0) & 0x1f)
|
||||
|
||||
/*******************************************************************************
|
||||
* MCON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Echo Mode (24) */
|
||||
#define SSC_MCON_EM (0x1 << 24)
|
||||
#define SSC_MCON_EM_VAL(val) (((val) & 0x1) << 24)
|
||||
#define SSC_MCON_EM_GET(val) ((((val) & SSC_MCON_EM) >> 24) & 0x1)
|
||||
#define SSC_MCON_EM_SET(reg,val) (reg) = ((reg & ~SSC_MCON_EM) | (((val) & 0x1) << 24))
|
||||
/* Idle Bit Value (23) */
|
||||
#define SSC_MCON_IDLE (0x1 << 23)
|
||||
#define SSC_MCON_IDLE_VAL(val) (((val) & 0x1) << 23)
|
||||
#define SSC_MCON_IDLE_GET(val) ((((val) & SSC_MCON_IDLE) >> 23) & 0x1)
|
||||
#define SSC_MCON_IDLE_SET(reg,val) (reg) = ((reg & ~SSC_MCON_IDLE) | (((val) & 0x1) << 23))
|
||||
/* Enable Byte Valid Control (22) */
|
||||
#define SSC_MCON_ENBV (0x1 << 22)
|
||||
#define SSC_MCON_ENBV_VAL(val) (((val) & 0x1) << 22)
|
||||
#define SSC_MCON_ENBV_GET(val) ((((val) & SSC_MCON_ENBV) >> 22) & 0x1)
|
||||
#define SSC_MCON_ENBV_SET(reg,val) (reg) = ((reg & ~SSC_MCON_ENBV) | (((val) & 0x1) << 22))
|
||||
/* Data Width Selection (20:16) */
|
||||
#define SSC_MCON_BM (0x1f << 16)
|
||||
#define SSC_MCON_BM_VAL(val) (((val) & 0x1f) << 16)
|
||||
#define SSC_MCON_BM_GET(val) ((((val) & SSC_MCON_BM) >> 16) & 0x1f)
|
||||
#define SSC_MCON_BM_SET(reg,val) (reg) = ((reg & ~SSC_MCON_BM) | (((val) & 0x1f) << 16))
|
||||
/* Receive Underflow Error Enable (12) */
|
||||
#define SSC_MCON_RUEN (0x1 << 12)
|
||||
#define SSC_MCON_RUEN_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SSC_MCON_RUEN_GET(val) ((((val) & SSC_MCON_RUEN) >> 12) & 0x1)
|
||||
#define SSC_MCON_RUEN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_RUEN) | (((val) & 0x1) << 12))
|
||||
/* Transmit Underflow Error Enable (11) */
|
||||
#define SSC_MCON_TUEN (0x1 << 11)
|
||||
#define SSC_MCON_TUEN_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SSC_MCON_TUEN_GET(val) ((((val) & SSC_MCON_TUEN) >> 11) & 0x1)
|
||||
#define SSC_MCON_TUEN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_TUEN) | (((val) & 0x1) << 11))
|
||||
/* Abort Error Enable (10) */
|
||||
#define SSC_MCON_AEN (0x1 << 10)
|
||||
#define SSC_MCON_AEN_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SSC_MCON_AEN_GET(val) ((((val) & SSC_MCON_AEN) >> 10) & 0x1)
|
||||
#define SSC_MCON_AEN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_AEN) | (((val) & 0x1) << 10))
|
||||
/* Receive Overflow Error Enable (9) */
|
||||
#define SSC_MCON_REN (0x1 << 9)
|
||||
#define SSC_MCON_REN_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SSC_MCON_REN_GET(val) ((((val) & SSC_MCON_REN) >> 9) & 0x1)
|
||||
#define SSC_MCON_REN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_REN) | (((val) & 0x1) << 9))
|
||||
/* Transmit Overflow Error Enable (8) */
|
||||
#define SSC_MCON_TEN (0x1 << 8)
|
||||
#define SSC_MCON_TEN_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SSC_MCON_TEN_GET(val) ((((val) & SSC_MCON_TEN) >> 8) & 0x1)
|
||||
#define SSC_MCON_TEN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_TEN) | (((val) & 0x1) << 8))
|
||||
/* Loop Back Control (7) */
|
||||
#define SSC_MCON_LB (0x1 << 7)
|
||||
#define SSC_MCON_LB_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SSC_MCON_LB_GET(val) ((((val) & SSC_MCON_LB) >> 7) & 0x1)
|
||||
#define SSC_MCON_LB_SET(reg,val) (reg) = ((reg & ~SSC_MCON_LB) | (((val) & 0x1) << 7))
|
||||
/* Clock Polarity Control (6) */
|
||||
#define SSC_MCON_PO (0x1 << 6)
|
||||
#define SSC_MCON_PO_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SSC_MCON_PO_GET(val) ((((val) & SSC_MCON_PO) >> 6) & 0x1)
|
||||
#define SSC_MCON_PO_SET(reg,val) (reg) = ((reg & ~SSC_MCON_PO) | (((val) & 0x1) << 6))
|
||||
/* Clock Phase Control (5) */
|
||||
#define SSC_MCON_PH (0x1 << 5)
|
||||
#define SSC_MCON_PH_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SSC_MCON_PH_GET(val) ((((val) & SSC_MCON_PH) >> 5) & 0x1)
|
||||
#define SSC_MCON_PH_SET(reg,val) (reg) = ((reg & ~SSC_MCON_PH) | (((val) & 0x1) << 5))
|
||||
/* Heading Control (4) */
|
||||
#define SSC_MCON_HB (0x1 << 4)
|
||||
#define SSC_MCON_HB_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SSC_MCON_HB_GET(val) ((((val) & SSC_MCON_HB) >> 4) & 0x1)
|
||||
#define SSC_MCON_HB_SET(reg,val) (reg) = ((reg & ~SSC_MCON_HB) | (((val) & 0x1) << 4))
|
||||
/* Chip Select Enable (3) */
|
||||
#define SSC_MCON_CSBEN (0x1 << 3)
|
||||
#define SSC_MCON_CSBEN_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SSC_MCON_CSBEN_GET(val) ((((val) & SSC_MCON_CSBEN) >> 3) & 0x1)
|
||||
#define SSC_MCON_CSBEN_SET(reg,val) (reg) = ((reg & ~SSC_MCON_CSBEN) | (((val) & 0x1) << 3))
|
||||
/* Chip Select Invert (2) */
|
||||
#define SSC_MCON_CSBINV (0x1 << 2)
|
||||
#define SSC_MCON_CSBINV_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_MCON_CSBINV_GET(val) ((((val) & SSC_MCON_CSBINV) >> 2) & 0x1)
|
||||
#define SSC_MCON_CSBINV_SET(reg,val) (reg) = ((reg & ~SSC_MCON_CSBINV) | (((val) & 0x1) << 2))
|
||||
/* Receive Off (1) */
|
||||
#define SSC_MCON_RXOFF (0x1 << 1)
|
||||
#define SSC_MCON_RXOFF_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_MCON_RXOFF_GET(val) ((((val) & SSC_MCON_RXOFF) >> 1) & 0x1)
|
||||
#define SSC_MCON_RXOFF_SET(reg,val) (reg) = ((reg & ~SSC_MCON_RXOFF) | (((val) & 0x1) << 1))
|
||||
/* Transmit Off (0) */
|
||||
#define SSC_MCON_TXOFF (0x1)
|
||||
#define SSC_MCON_TXOFF_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_MCON_TXOFF_GET(val) ((((val) & SSC_MCON_TXOFF) >> 0) & 0x1)
|
||||
#define SSC_MCON_TXOFF_SET(reg,val) (reg) = ((reg & ~SSC_MCON_TXOFF) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* STATE Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive End-of-Message (31) */
|
||||
#define SSC_STATE_RXEOM (0x1 << 31)
|
||||
#define SSC_STATE_RXEOM_GET(val) ((((val) & SSC_STATE_RXEOM) >> 31) & 0x1)
|
||||
/* Receive Byte Valid (30:28) */
|
||||
#define SSC_STATE_RXBV (0x7 << 28)
|
||||
#define SSC_STATE_RXBV_GET(val) ((((val) & SSC_STATE_RXBV) >> 28) & 0x7)
|
||||
/* Transmit End-of-Message (27) */
|
||||
#define SSC_STATE_TXEOM (0x1 << 27)
|
||||
#define SSC_STATE_TXEOM_GET(val) ((((val) & SSC_STATE_TXEOM) >> 27) & 0x1)
|
||||
/* Transmit Byte Valid (26:24) */
|
||||
#define SSC_STATE_TXBV (0x7 << 24)
|
||||
#define SSC_STATE_TXBV_GET(val) ((((val) & SSC_STATE_TXBV) >> 24) & 0x7)
|
||||
/* Bit Count Field (20:16) */
|
||||
#define SSC_STATE_BC (0x1f << 16)
|
||||
#define SSC_STATE_BC_GET(val) ((((val) & SSC_STATE_BC) >> 16) & 0x1f)
|
||||
/* Busy Flag (13) */
|
||||
#define SSC_STATE_BSY (0x1 << 13)
|
||||
#define SSC_STATE_BSY_GET(val) ((((val) & SSC_STATE_BSY) >> 13) & 0x1)
|
||||
/* Receive Underflow Error Flag (12) */
|
||||
#define SSC_STATE_RUE (0x1 << 12)
|
||||
#define SSC_STATE_RUE_GET(val) ((((val) & SSC_STATE_RUE) >> 12) & 0x1)
|
||||
/* Transmit Underflow Error Flag (11) */
|
||||
#define SSC_STATE_TUE (0x1 << 11)
|
||||
#define SSC_STATE_TUE_GET(val) ((((val) & SSC_STATE_TUE) >> 11) & 0x1)
|
||||
/* Abort Error Flag (10) */
|
||||
#define SSC_STATE_AE (0x1 << 10)
|
||||
#define SSC_STATE_AE_GET(val) ((((val) & SSC_STATE_AE) >> 10) & 0x1)
|
||||
/* Receive Error Flag (9) */
|
||||
#define SSC_STATE_RE (0x1 << 9)
|
||||
#define SSC_STATE_RE_GET(val) ((((val) & SSC_STATE_RE) >> 9) & 0x1)
|
||||
/* Transmit Error Flag (8) */
|
||||
#define SSC_STATE_TE (0x1 << 8)
|
||||
#define SSC_STATE_TE_GET(val) ((((val) & SSC_STATE_TE) >> 8) & 0x1)
|
||||
/* Mode Error Flag (7) */
|
||||
#define SSC_STATE_ME (0x1 << 7)
|
||||
#define SSC_STATE_ME_GET(val) ((((val) & SSC_STATE_ME) >> 7) & 0x1)
|
||||
/* Slave Selected (2) */
|
||||
#define SSC_STATE_SSEL (0x1 << 2)
|
||||
#define SSC_STATE_SSEL_GET(val) ((((val) & SSC_STATE_SSEL) >> 2) & 0x1)
|
||||
/* Master Select Bit (1) */
|
||||
#define SSC_STATE_MS (0x1 << 1)
|
||||
#define SSC_STATE_MS_GET(val) ((((val) & SSC_STATE_MS) >> 1) & 0x1)
|
||||
/* Enable Bit (0) */
|
||||
#define SSC_STATE_EN (0x1)
|
||||
#define SSC_STATE_EN_GET(val) ((((val) & SSC_STATE_EN) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* WHBSTATE Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Set Transmit Underflow Error Flag Bit (15) */
|
||||
#define SSC_WHBSTATE_SETTUE (0x1 << 15)
|
||||
#define SSC_WHBSTATE_SETTUE_VAL(val) (((val) & 0x1) << 15)
|
||||
#define SSC_WHBSTATE_SETTUE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETTUE) | (val) & 1) << 15)
|
||||
/* Set Abort Error Flag Bit (14) */
|
||||
#define SSC_WHBSTATE_SETAE (0x1 << 14)
|
||||
#define SSC_WHBSTATE_SETAE_VAL(val) (((val) & 0x1) << 14)
|
||||
#define SSC_WHBSTATE_SETAE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETAE) | (val) & 1) << 14)
|
||||
/* Set Receive Error Flag Bit (13) */
|
||||
#define SSC_WHBSTATE_SETRE (0x1 << 13)
|
||||
#define SSC_WHBSTATE_SETRE_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SSC_WHBSTATE_SETRE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETRE) | (val) & 1) << 13)
|
||||
/* Set Transmit Error Flag Bit (12) */
|
||||
#define SSC_WHBSTATE_SETTE (0x1 << 12)
|
||||
#define SSC_WHBSTATE_SETTE_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SSC_WHBSTATE_SETTE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETTE) | (val) & 1) << 12)
|
||||
/* Clear Transmit Underflow Error Flag Bit (11) */
|
||||
#define SSC_WHBSTATE_CLRTUE (0x1 << 11)
|
||||
#define SSC_WHBSTATE_CLRTUE_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SSC_WHBSTATE_CLRTUE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRTUE) | (val) & 1) << 11)
|
||||
/* Clear Abort Error Flag Bit (10) */
|
||||
#define SSC_WHBSTATE_CLRAE (0x1 << 10)
|
||||
#define SSC_WHBSTATE_CLRAE_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SSC_WHBSTATE_CLRAE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRAE) | (val) & 1) << 10)
|
||||
/* Clear Receive Error Flag Bit (9) */
|
||||
#define SSC_WHBSTATE_CLRRE (0x1 << 9)
|
||||
#define SSC_WHBSTATE_CLRRE_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SSC_WHBSTATE_CLRRE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRRE) | (val) & 1) << 9)
|
||||
/* Clear Transmit Error Flag Bit (8) */
|
||||
#define SSC_WHBSTATE_CLRTE (0x1 << 8)
|
||||
#define SSC_WHBSTATE_CLRTE_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SSC_WHBSTATE_CLRTE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRTE) | (val) & 1) << 8)
|
||||
/* Set Mode Error Flag Bit (7) */
|
||||
#define SSC_WHBSTATE_SETME (0x1 << 7)
|
||||
#define SSC_WHBSTATE_SETME_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SSC_WHBSTATE_SETME_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETME) | (val) & 1) << 7)
|
||||
/* Clear Mode Error Flag Bit (6) */
|
||||
#define SSC_WHBSTATE_CLRME (0x1 << 6)
|
||||
#define SSC_WHBSTATE_CLRME_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SSC_WHBSTATE_CLRME_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRME) | (val) & 1) << 6)
|
||||
/* Set Receive Underflow Error Bit (5) */
|
||||
#define SSC_WHBSTATE_SETRUE (0x1 << 5)
|
||||
#define SSC_WHBSTATE_SETRUE_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SSC_WHBSTATE_SETRUE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETRUE) | (val) & 1) << 5)
|
||||
/* Clear Receive Underflow Error Bit (4) */
|
||||
#define SSC_WHBSTATE_CLRRUE (0x1 << 4)
|
||||
#define SSC_WHBSTATE_CLRRUE_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SSC_WHBSTATE_CLRRUE_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRRUE) | (val) & 1) << 4)
|
||||
/* Set Master Select Bit (3) */
|
||||
#define SSC_WHBSTATE_SETMS (0x1 << 3)
|
||||
#define SSC_WHBSTATE_SETMS_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SSC_WHBSTATE_SETMS_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETMS) | (val) & 1) << 3)
|
||||
/* Clear Master Select Bit (2) */
|
||||
#define SSC_WHBSTATE_CLRMS (0x1 << 2)
|
||||
#define SSC_WHBSTATE_CLRMS_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_WHBSTATE_CLRMS_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLRMS) | (val) & 1) << 2)
|
||||
/* Set Enable Bit (1) */
|
||||
#define SSC_WHBSTATE_SETEN (0x1 << 1)
|
||||
#define SSC_WHBSTATE_SETEN_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_WHBSTATE_SETEN_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_SETEN) | (val) & 1) << 1)
|
||||
/* Clear Enable Bit (0) */
|
||||
#define SSC_WHBSTATE_CLREN (0x1)
|
||||
#define SSC_WHBSTATE_CLREN_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_WHBSTATE_CLREN_SET(reg,val) (reg) = (((reg & ~SSC_WHBSTATE_CLREN) | (val) & 1) << 0)
|
||||
|
||||
/*******************************************************************************
|
||||
* TB Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Transmit Data Register Value (31:0) */
|
||||
#define SSC_TB_TB_VAL (0xFFFFFFFFL)
|
||||
#define SSC_TB_TB_VAL_VAL(val) (((val) & 0xFFFFFFFFL) << 0)
|
||||
#define SSC_TB_TB_VAL_GET(val) ((((val) & SSC_TB_TB_VAL) >> 0) & 0xFFFFFFFFL)
|
||||
#define SSC_TB_TB_VAL_SET(reg,val) (reg) = ((reg & ~SSC_TB_TB_VAL) | (((val) & 0xFFFFFFFFL) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* RB Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive Data Register Value (31:0) */
|
||||
#define SSC_RB_RB_VAL (0xFFFFFFFFL)
|
||||
#define SSC_RB_RB_VAL_GET(val) ((((val) & SSC_RB_RB_VAL) >> 0) & 0xFFFFFFFFL)
|
||||
|
||||
/*******************************************************************************
|
||||
* FSTAT Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Transmit FIFO Filling Level (13:8) */
|
||||
#define SSC_FSTAT_TXFFL (0x3f << 8)
|
||||
#define SSC_FSTAT_TXFFL_GET(val) ((((val) & SSC_FSTAT_TXFFL) >> 8) & 0x3f)
|
||||
/* Receive FIFO Filling Level (5:0) */
|
||||
#define SSC_FSTAT_RXFFL (0x3f)
|
||||
#define SSC_FSTAT_RXFFL_GET(val) ((((val) & SSC_FSTAT_RXFFL) >> 0) & 0x3f)
|
||||
|
||||
/*******************************************************************************
|
||||
* PISEL Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Slave Mode Clock Input Select (2) */
|
||||
#define SSC_PISEL_CIS (0x1 << 2)
|
||||
#define SSC_PISEL_CIS_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_PISEL_CIS_GET(val) ((((val) & SSC_PISEL_CIS) >> 2) & 0x1)
|
||||
#define SSC_PISEL_CIS_SET(reg,val) (reg) = ((reg & ~SSC_PISEL_CIS) | (((val) & 0x1) << 2))
|
||||
/* Slave Mode Receiver Input Select (1) */
|
||||
#define SSC_PISEL_SIS (0x1 << 1)
|
||||
#define SSC_PISEL_SIS_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_PISEL_SIS_GET(val) ((((val) & SSC_PISEL_SIS) >> 1) & 0x1)
|
||||
#define SSC_PISEL_SIS_SET(reg,val) (reg) = ((reg & ~SSC_PISEL_SIS) | (((val) & 0x1) << 1))
|
||||
/* Master Mode Receiver Input Select (0) */
|
||||
#define SSC_PISEL_MIS (0x1)
|
||||
#define SSC_PISEL_MIS_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_PISEL_MIS_GET(val) ((((val) & SSC_PISEL_MIS) >> 0) & 0x1)
|
||||
#define SSC_PISEL_MIS_SET(reg,val) (reg) = ((reg & ~SSC_PISEL_MIS) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* RXFCON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive FIFO Interrupt Trigger Level (13:8) */
|
||||
#define SSC_RXFCON_RXFITL (0x3f << 8)
|
||||
#define SSC_RXFCON_RXFITL_VAL(val) (((val) & 0x3f) << 8)
|
||||
#define SSC_RXFCON_RXFITL_GET(val) ((((val) & SSC_RXFCON_RXFITL) >> 8) & 0x3f)
|
||||
#define SSC_RXFCON_RXFITL_SET(reg,val) (reg) = ((reg & ~SSC_RXFCON_RXFITL) | (((val) & 0x3f) << 8))
|
||||
/* Receive FIFO Flush (1) */
|
||||
#define SSC_RXFCON_RXFLU (0x1 << 1)
|
||||
#define SSC_RXFCON_RXFLU_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_RXFCON_RXFLU_SET(reg,val) (reg) = (((reg & ~SSC_RXFCON_RXFLU) | (val) & 1) << 1)
|
||||
/* Receive FIFO Enable (0) */
|
||||
#define SSC_RXFCON_RXFEN (0x1)
|
||||
#define SSC_RXFCON_RXFEN_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_RXFCON_RXFEN_GET(val) ((((val) & SSC_RXFCON_RXFEN) >> 0) & 0x1)
|
||||
#define SSC_RXFCON_RXFEN_SET(reg,val) (reg) = ((reg & ~SSC_RXFCON_RXFEN) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* TXFCON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Transmit FIFO Interrupt Trigger Level (13:8) */
|
||||
#define SSC_TXFCON_TXFITL (0x3f << 8)
|
||||
#define SSC_TXFCON_TXFITL_VAL(val) (((val) & 0x3f) << 8)
|
||||
#define SSC_TXFCON_TXFITL_GET(val) ((((val) & SSC_TXFCON_TXFITL) >> 8) & 0x3f)
|
||||
#define SSC_TXFCON_TXFITL_SET(reg,val) (reg) = ((reg & ~SSC_TXFCON_TXFITL) | (((val) & 0x3f) << 8))
|
||||
/* Transmit FIFO Flush (1) */
|
||||
#define SSC_TXFCON_TXFLU (0x1 << 1)
|
||||
#define SSC_TXFCON_TXFLU_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_TXFCON_TXFLU_SET(reg,val) (reg) = (((reg & ~SSC_TXFCON_TXFLU) | (val) & 1) << 1)
|
||||
/* Transmit FIFO Enable (0) */
|
||||
#define SSC_TXFCON_TXFEN (0x1)
|
||||
#define SSC_TXFCON_TXFEN_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_TXFCON_TXFEN_GET(val) ((((val) & SSC_TXFCON_TXFEN) >> 0) & 0x1)
|
||||
#define SSC_TXFCON_TXFEN_SET(reg,val) (reg) = ((reg & ~SSC_TXFCON_TXFEN) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* BR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Baudrate Timer Reload Register Value (15:0) */
|
||||
#define SSC_BR_BR_VAL (0xffff)
|
||||
#define SSC_BR_BR_VAL_VAL(val) (((val) & 0xffff) << 0)
|
||||
#define SSC_BR_BR_VAL_GET(val) ((((val) & SSC_BR_BR_VAL) >> 0) & 0xffff)
|
||||
#define SSC_BR_BR_VAL_SET(reg,val) (reg) = ((reg & ~SSC_BR_BR_VAL) | (((val) & 0xffff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* BRSTAT Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Baudrate Timer Register Value (15:0) */
|
||||
#define SSC_BRSTAT_BT_VAL (0xffff)
|
||||
#define SSC_BRSTAT_BT_VAL_GET(val) ((((val) & SSC_BRSTAT_BT_VAL) >> 0) & 0xffff)
|
||||
|
||||
/*******************************************************************************
|
||||
* SFCON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Pause Length (31:22) */
|
||||
#define SSC_SFCON_PLEN (0x3ff << 22)
|
||||
#define SSC_SFCON_PLEN_VAL(val) (((val) & 0x3ff) << 22)
|
||||
#define SSC_SFCON_PLEN_GET(val) ((((val) & SSC_SFCON_PLEN) >> 22) & 0x3ff)
|
||||
#define SSC_SFCON_PLEN_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_PLEN) | (((val) & 0x3ff) << 22))
|
||||
/* Stop After Pause (20) */
|
||||
#define SSC_SFCON_STOP (0x1 << 20)
|
||||
#define SSC_SFCON_STOP_VAL(val) (((val) & 0x1) << 20)
|
||||
#define SSC_SFCON_STOP_GET(val) ((((val) & SSC_SFCON_STOP) >> 20) & 0x1)
|
||||
#define SSC_SFCON_STOP_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_STOP) | (((val) & 0x1) << 20))
|
||||
/* Idle Clock Configuration (19:18) */
|
||||
#define SSC_SFCON_ICLK (0x3 << 18)
|
||||
#define SSC_SFCON_ICLK_VAL(val) (((val) & 0x3) << 18)
|
||||
#define SSC_SFCON_ICLK_GET(val) ((((val) & SSC_SFCON_ICLK) >> 18) & 0x3)
|
||||
#define SSC_SFCON_ICLK_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_ICLK) | (((val) & 0x3) << 18))
|
||||
/* Idle Data Configuration (17:16) */
|
||||
#define SSC_SFCON_IDAT (0x3 << 16)
|
||||
#define SSC_SFCON_IDAT_VAL(val) (((val) & 0x3) << 16)
|
||||
#define SSC_SFCON_IDAT_GET(val) ((((val) & SSC_SFCON_IDAT) >> 16) & 0x3)
|
||||
#define SSC_SFCON_IDAT_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_IDAT) | (((val) & 0x3) << 16))
|
||||
/* Data Length (15:4) */
|
||||
#define SSC_SFCON_DLEN (0xfff << 4)
|
||||
#define SSC_SFCON_DLEN_VAL(val) (((val) & 0xfff) << 4)
|
||||
#define SSC_SFCON_DLEN_GET(val) ((((val) & SSC_SFCON_DLEN) >> 4) & 0xfff)
|
||||
#define SSC_SFCON_DLEN_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_DLEN) | (((val) & 0xfff) << 4))
|
||||
/* Enable Interrupt After Pause (3) */
|
||||
#define SSC_SFCON_IAEN (0x1 << 3)
|
||||
#define SSC_SFCON_IAEN_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SSC_SFCON_IAEN_GET(val) ((((val) & SSC_SFCON_IAEN) >> 3) & 0x1)
|
||||
#define SSC_SFCON_IAEN_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_IAEN) | (((val) & 0x1) << 3))
|
||||
/* Enable Interrupt Before Pause (2) */
|
||||
#define SSC_SFCON_IBEN (0x1 << 2)
|
||||
#define SSC_SFCON_IBEN_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_SFCON_IBEN_GET(val) ((((val) & SSC_SFCON_IBEN) >> 2) & 0x1)
|
||||
#define SSC_SFCON_IBEN_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_IBEN) | (((val) & 0x1) << 2))
|
||||
/* Serial Frame Enable (0) */
|
||||
#define SSC_SFCON_SFEN (0x1)
|
||||
#define SSC_SFCON_SFEN_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_SFCON_SFEN_GET(val) ((((val) & SSC_SFCON_SFEN) >> 0) & 0x1)
|
||||
#define SSC_SFCON_SFEN_SET(reg,val) (reg) = ((reg & ~SSC_SFCON_SFEN) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* SFSTAT Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Pause Count (31:22) */
|
||||
#define SSC_SFSTAT_PCNT (0x3ff << 22)
|
||||
#define SSC_SFSTAT_PCNT_GET(val) ((((val) & SSC_SFSTAT_PCNT) >> 22) & 0x3ff)
|
||||
/* Data Bit Count (15:4) */
|
||||
#define SSC_SFSTAT_DCNT (0xfff << 4)
|
||||
#define SSC_SFSTAT_DCNT_GET(val) ((((val) & SSC_SFSTAT_DCNT) >> 4) & 0xfff)
|
||||
/* Pause Busy (1) */
|
||||
#define SSC_SFSTAT_PBSY (0x1 << 1)
|
||||
#define SSC_SFSTAT_PBSY_GET(val) ((((val) & SSC_SFSTAT_PBSY) >> 1) & 0x1)
|
||||
/* Data Busy (0) */
|
||||
#define SSC_SFSTAT_DBSY (0x1)
|
||||
#define SSC_SFSTAT_DBSY_GET(val) ((((val) & SSC_SFSTAT_DBSY) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* GPOCON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Output OUTn Is Chip Select (15:8) */
|
||||
#define SSC_GPOCON_ISCSBN (0xff << 8)
|
||||
#define SSC_GPOCON_ISCSBN_VAL(val) (((val) & 0xff) << 8)
|
||||
#define SSC_GPOCON_ISCSBN_GET(val) ((((val) & SSC_GPOCON_ISCSBN) >> 8) & 0xff)
|
||||
#define SSC_GPOCON_ISCSBN_SET(reg,val) (reg) = ((reg & ~SSC_GPOCON_ISCSBN) | (((val) & 0xff) << 8))
|
||||
/* Invert Output OUTn (7:0) */
|
||||
#define SSC_GPOCON_INVOUTN (0xff)
|
||||
#define SSC_GPOCON_INVOUTN_VAL(val) (((val) & 0xff) << 0)
|
||||
#define SSC_GPOCON_INVOUTN_GET(val) ((((val) & SSC_GPOCON_INVOUTN) >> 0) & 0xff)
|
||||
#define SSC_GPOCON_INVOUTN_SET(reg,val) (reg) = ((reg & ~SSC_GPOCON_INVOUTN) | (((val) & 0xff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* GPOSTAT Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Output Register Bit n (7:0) */
|
||||
#define SSC_GPOSTAT_OUTN (0xff)
|
||||
#define SSC_GPOSTAT_OUTN_GET(val) ((((val) & SSC_GPOSTAT_OUTN) >> 0) & 0xff)
|
||||
|
||||
/*******************************************************************************
|
||||
* WHBGPOSTAT
|
||||
******************************************************************************/
|
||||
|
||||
/* Set Output Register Bit n (15:8) */
|
||||
#define SSC_WHBGPOSTAT_SETOUTN (0xff << 8)
|
||||
#define SSC_WHBGPOSTAT_SETOUTN_VAL(val) (((val) & 0xff) << 8)
|
||||
#define SSC_WHBGPOSTAT_SETOUTN_SET(reg,val) (reg) = (((reg & ~SSC_WHBGPOSTAT_SETOUTN) | (val) & 1) << 8)
|
||||
/* Clear Output Register Bit n (7:0) */
|
||||
#define SSC_WHBGPOSTAT_CLROUTN (0xff)
|
||||
#define SSC_WHBGPOSTAT_CLROUTN_VAL(val) (((val) & 0xff) << 0)
|
||||
#define SSC_WHBGPOSTAT_CLROUTN_SET(reg,val) (reg) = (((reg & ~SSC_WHBGPOSTAT_CLROUTN) | (val) & 1) << 0)
|
||||
|
||||
/*******************************************************************************
|
||||
* RXREQ Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive Count Value (15:0) */
|
||||
#define SSC_RXREQ_RXCNT (0xffff)
|
||||
#define SSC_RXREQ_RXCNT_VAL(val) (((val) & 0xffff) << 0)
|
||||
#define SSC_RXREQ_RXCNT_GET(val) ((((val) & SSC_RXREQ_RXCNT) >> 0) & 0xffff)
|
||||
#define SSC_RXREQ_RXCNT_SET(reg,val) (reg) = ((reg & ~SSC_RXREQ_RXCNT) | (((val) & 0xffff) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* RXCNT Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive To Do Value (15:0) */
|
||||
#define SSC_RXCNT_TODO (0xffff)
|
||||
#define SSC_RXCNT_TODO_GET(val) ((((val) & SSC_RXCNT_TODO) >> 0) & 0xffff)
|
||||
|
||||
/*******************************************************************************
|
||||
* DMA_CON Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Receive Class (3:2) */
|
||||
#define SSC_DMA_CON_RXCLS (0x3 << 2)
|
||||
#define SSC_DMA_CON_RXCLS_VAL(val) (((val) & 0x3) << 2)
|
||||
#define SSC_DMA_CON_RXCLS_GET(val) ((((val) & SSC_DMA_CON_RXCLS) >> 2) & 0x3)
|
||||
#define SSC_DMA_CON_RXCLS_SET(reg,val) (reg) = ((reg & ~SSC_DMA_CON_RXCLS) | (((val) & 0x3) << 2))
|
||||
/* Transmit Path On (1) */
|
||||
#define SSC_DMA_CON_TXON (0x1 << 1)
|
||||
#define SSC_DMA_CON_TXON_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_DMA_CON_TXON_GET(val) ((((val) & SSC_DMA_CON_TXON) >> 1) & 0x1)
|
||||
#define SSC_DMA_CON_TXON_SET(reg,val) (reg) = ((reg & ~SSC_DMA_CON_TXON) | (((val) & 0x1) << 1))
|
||||
/* Receive Path On (0) */
|
||||
#define SSC_DMA_CON_RXON (0x1)
|
||||
#define SSC_DMA_CON_RXON_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_DMA_CON_RXON_GET(val) ((((val) & SSC_DMA_CON_RXON) >> 0) & 0x1)
|
||||
#define SSC_DMA_CON_RXON_SET(reg,val) (reg) = ((reg & ~SSC_DMA_CON_RXON) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* IRNEN Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Frame End Interrupt Request Enable (3) */
|
||||
#define SSC_IRNEN_F (0x1 << 3)
|
||||
#define SSC_IRNEN_F_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SSC_IRNEN_F_GET(val) ((((val) & SSC_IRNEN_F) >> 3) & 0x1)
|
||||
#define SSC_IRNEN_F_SET(reg,val) (reg) = ((reg & ~SSC_IRNEN_F) | (((val) & 0x1) << 3))
|
||||
/* Error Interrupt Request Enable (2) */
|
||||
#define SSC_IRNEN_E (0x1 << 2)
|
||||
#define SSC_IRNEN_E_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SSC_IRNEN_E_GET(val) ((((val) & SSC_IRNEN_E) >> 2) & 0x1)
|
||||
#define SSC_IRNEN_E_SET(reg,val) (reg) = ((reg & ~SSC_IRNEN_E) | (((val) & 0x1) << 2))
|
||||
/* Receive Interrupt Request Enable (1) */
|
||||
#define SSC_IRNEN_R (0x1 << 1)
|
||||
#define SSC_IRNEN_R_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SSC_IRNEN_R_GET(val) ((((val) & SSC_IRNEN_R) >> 1) & 0x1)
|
||||
#define SSC_IRNEN_R_SET(reg,val) (reg) = ((reg & ~SSC_IRNEN_R) | (((val) & 0x1) << 1))
|
||||
/* Transmit Interrupt Request Enable (0) */
|
||||
#define SSC_IRNEN_T (0x1)
|
||||
#define SSC_IRNEN_T_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SSC_IRNEN_T_GET(val) ((((val) & SSC_IRNEN_T) >> 0) & 0x1)
|
||||
#define SSC_IRNEN_T_SET(reg,val) (reg) = ((reg & ~SSC_IRNEN_T) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* IRNICR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Frame End Interrupt Request (3) */
|
||||
#define SSC_IRNICR_F (0x1 << 3)
|
||||
#define SSC_IRNICR_F_GET(val) ((((val) & SSC_IRNICR_F) >> 3) & 0x1)
|
||||
/* Error Interrupt Request (2) */
|
||||
#define SSC_IRNICR_E (0x1 << 2)
|
||||
#define SSC_IRNICR_E_GET(val) ((((val) & SSC_IRNICR_E) >> 2) & 0x1)
|
||||
/* Receive Interrupt Request (1) */
|
||||
#define SSC_IRNICR_R (0x1 << 1)
|
||||
#define SSC_IRNICR_R_GET(val) ((((val) & SSC_IRNICR_R) >> 1) & 0x1)
|
||||
/* Transmit Interrupt Request (0) */
|
||||
#define SSC_IRNICR_T (0x1)
|
||||
#define SSC_IRNICR_T_GET(val) ((((val) & SSC_IRNICR_T) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* IRNCR Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Frame End Interrupt Request (3) */
|
||||
#define SSC_IRNCR_F (0x1 << 3)
|
||||
#define SSC_IRNCR_F_GET(val) ((((val) & SSC_IRNCR_F) >> 3) & 0x1)
|
||||
/* Error Interrupt Request (2) */
|
||||
#define SSC_IRNCR_E (0x1 << 2)
|
||||
#define SSC_IRNCR_E_GET(val) ((((val) & SSC_IRNCR_E) >> 2) & 0x1)
|
||||
/* Receive Interrupt Request (1) */
|
||||
#define SSC_IRNCR_R (0x1 << 1)
|
||||
#define SSC_IRNCR_R_GET(val) ((((val) & SSC_IRNCR_R) >> 1) & 0x1)
|
||||
/* Transmit Interrupt Request (0) */
|
||||
#define SSC_IRNCR_T (0x1)
|
||||
#define SSC_IRNCR_T_GET(val) ((((val) & SSC_IRNCR_T) >> 0) & 0x1)
|
||||
|
||||
#endif /* __SSC_H */
|
|
@ -1,130 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __STATUS_REG_H
|
||||
#define __STATUS_REG_H
|
||||
|
||||
#define status_r32(reg) ltq_r32(&status->reg)
|
||||
#define status_w32(val, reg) ltq_w32(val, &status->reg)
|
||||
#define status_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &status->reg)
|
||||
|
||||
/** STATUS register structure */
|
||||
struct svip_reg_status {
|
||||
unsigned long fuse_deu; /* 0x0000 */
|
||||
unsigned long fuse_cpu; /* 0x0004 */
|
||||
unsigned long fuse_pll; /* 0x0008 */
|
||||
unsigned long chipid; /* 0x000C */
|
||||
unsigned long config; /* 0x0010 */
|
||||
unsigned long chip_loc; /* 0x0014 */
|
||||
unsigned long fuse_spare; /* 0x0018 */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* Fuse for DEU Settings
|
||||
******************************************************************************/
|
||||
|
||||
/* Fuse for Enabling the TRNG (6) */
|
||||
#define STATUS_FUSE_DEU_TRNG (0x1 << 6)
|
||||
#define STATUS_FUSE_DEU_TRNG_GET(val) ((((val) & STATUS_FUSE_DEU_TRNG) >> 6) & 0x1)
|
||||
/* Fuse for Enabling the DES Submodule (5) */
|
||||
#define STATUS_FUSE_DEU_DES (0x1 << 5)
|
||||
#define STATUS_FUSE_DEU_DES_GET(val) ((((val) & STATUS_FUSE_DEU_DES) >> 5) & 0x1)
|
||||
/* Fuse for Enabling the 3DES Submodule (4) */
|
||||
#define STATUS_FUSE_DEU_3DES (0x1 << 4)
|
||||
#define STATUS_FUSE_DEU_3DES_GET(val) ((((val) & STATUS_FUSE_DEU_3DES) >> 4) & 0x1)
|
||||
/* Fuse for Enabling the AES Submodule (3) */
|
||||
#define STATUS_FUSE_DEU_AES (0x1 << 3)
|
||||
#define STATUS_FUSE_DEU_AES_GET(val) ((((val) & STATUS_FUSE_DEU_AES) >> 3) & 0x1)
|
||||
/* Fuse for Enabling the HASH Submodule (2) */
|
||||
#define STATUS_FUSE_DEU_HASH (0x1 << 2)
|
||||
#define STATUS_FUSE_DEU_HASH_GET(val) ((((val) & STATUS_FUSE_DEU_HASH) >> 2) & 0x1)
|
||||
/* Fuse for Enabling the ARC4 Submodule (1) */
|
||||
#define STATUS_FUSE_DEU_ARC4 (0x1 << 1)
|
||||
#define STATUS_FUSE_DEU_ARC4_GET(val) ((((val) & STATUS_FUSE_DEU_ARC4) >> 1) & 0x1)
|
||||
/* Fuse for Enabling the DEU Module (0) */
|
||||
#define STATUS_FUSE_DEU_DEU (0x1)
|
||||
#define STATUS_FUSE_DEU_DEU_GET(val) ((((val) & STATUS_FUSE_DEU_DEU) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* Fuse for CPU Settings
|
||||
******************************************************************************/
|
||||
|
||||
/* Fuse for Enabling CPU5 (5) */
|
||||
#define STATUS_FUSE_CPU_CPU5 (0x1 << 5)
|
||||
#define STATUS_FUSE_CPU_CPU5_GET(val) ((((val) & STATUS_FUSE_CPU_CPU5) >> 5) & 0x1)
|
||||
/* Fuse for Enabling the CPU4 (4) */
|
||||
#define STATUS_FUSE_CPU_CPU4 (0x1 << 4)
|
||||
#define STATUS_FUSE_CPU_CPU4_GET(val) ((((val) & STATUS_FUSE_CPU_CPU4) >> 4) & 0x1)
|
||||
/* Fuse for Enabling the CPU3 (3) */
|
||||
#define STATUS_FUSE_CPU_CPU3 (0x1 << 3)
|
||||
#define STATUS_FUSE_CPU_CPU3_GET(val) ((((val) & STATUS_FUSE_CPU_CPU3) >> 3) & 0x1)
|
||||
/* Fuse for Enabling the CPU2 (2) */
|
||||
#define STATUS_FUSE_CPU_CPU2 (0x1 << 2)
|
||||
#define STATUS_FUSE_CPU_CPU2_GET(val) ((((val) & STATUS_FUSE_CPU_CPU2) >> 2) & 0x1)
|
||||
/* Fuse for Enabling the CPU1 (1) */
|
||||
#define STATUS_FUSE_CPU_CPU1 (0x1 << 1)
|
||||
#define STATUS_FUSE_CPU_CPU1_GET(val) ((((val) & STATUS_FUSE_CPU_CPU1) >> 1) & 0x1)
|
||||
/* Fuse for Enabling the CPU0 (0) */
|
||||
#define STATUS_FUSE_CPU_CPU0 (0x1)
|
||||
#define STATUS_FUSE_CPU_CPU0_GET(val) ((((val) & STATUS_FUSE_CPU_CPU0) >> 0) & 0x1)
|
||||
|
||||
/*******************************************************************************
|
||||
* Fuse for PLL Settings
|
||||
******************************************************************************/
|
||||
|
||||
/* Fuse for Enabling PLL (7:0) */
|
||||
#define STATUS_FUSE_PLL_PLL (0xff)
|
||||
#define STATUS_FUSE_PLL_PLL_GET(val) ((((val) & STATUS_FUSE_PLL_PLL) >> 0) & 0xff)
|
||||
|
||||
/*******************************************************************************
|
||||
* Chip Identification Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Chip Version Number (31:28) */
|
||||
#define STATUS_CHIPID_VERSION (0xf << 28)
|
||||
#define STATUS_CHIPID_VERSION_GET(val) ((((val) & STATUS_CHIPID_VERSION) >> 28) & 0xf)
|
||||
/* Part Number (27:12) */
|
||||
#define STATUS_CHIPID_PART_NUMBER (0xffff << 12)
|
||||
#define STATUS_CHIPID_PART_NUMBER_GET(val) ((((val) & STATUS_CHIPID_PART_NUMBER) >> 12) & 0xffff)
|
||||
/* Manufacturer ID (11:1) */
|
||||
#define STATUS_CHIPID_MANID (0x7ff << 1)
|
||||
#define STATUS_CHIPID_MANID_GET(val) ((((val) & STATUS_CHIPID_MANID) >> 1) & 0x7ff)
|
||||
|
||||
/*******************************************************************************
|
||||
* Chip Configuration Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Number of Analog Channels (8:5) */
|
||||
#define STATUS_CONFIG_ANA_CHAN (0xf << 5)
|
||||
#define STATUS_CONFIG_ANA_CHAN_GET(val) ((((val) & STATUS_CONFIG_ANA_CHAN) >> 5) & 0xf)
|
||||
/* Clock Mode (4) */
|
||||
#define STATUS_CONFIG_CLK_MODE (0x1 << 1)
|
||||
#define STATUS_CONFIG_CLK_MODE_GET(val) ((((val) & STATUS_CONFIG_CLK_MODE) >> 4) & 0x1)
|
||||
/* Subversion Number (3:0) */
|
||||
#define STATUS_CONFIG_SUB_VERS (0xF)
|
||||
#define STATUS_CONFIG_SUB_VERS_GET(val) ((((val) & STATUS_SUBVER_SUB_VERS) >> 0) & 0xF)
|
||||
|
||||
/*******************************************************************************
|
||||
* Chip Location Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Chip Lot ID (31:16) */
|
||||
#define STATUS_CHIP_LOC_CHIP_LOT (0xffff << 16)
|
||||
#define STATUS_CHIP_LOC_CHIP_LOT_GET(val) ((((val) & STATUS_CHIP_LOC_CHIP_LOT) >> 16) & 0xffff)
|
||||
/* Chip X Coordinate (15:8) */
|
||||
#define STATUS_CHIP_LOC_CHIP_X (0xff << 8)
|
||||
#define STATUS_CHIP_LOC_CHIP_X_GET(val) ((((val) & STATUS_CHIP_LOC_CHIP_X) >> 8) & 0xff)
|
||||
/* Chip Y Coordinate (7:0) */
|
||||
#define STATUS_CHIP_LOC_CHIP_Y (0xff)
|
||||
#define STATUS_CHIP_LOC_CHIP_Y_GET(val) ((((val) & STATUS_CHIP_LOC_CHIP_Y) >> 0) & 0xff)
|
||||
|
||||
#endif
|
|
@ -1,245 +0,0 @@
|
|||
/************************************************************************
|
||||
*
|
||||
* Copyright (c) 2007
|
||||
* Infineon Technologies AG
|
||||
* St. Martin Strasse 53; 81669 Muenchen; Germany
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version
|
||||
* 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
************************************************************************/
|
||||
|
||||
#ifndef __SVIP_DMA_H
|
||||
#define __SVIP_DMA_H
|
||||
|
||||
#define LTQ_DMA_CH_ON 1
|
||||
#define LTQ_DMA_CH_OFF 0
|
||||
#define LTQ_DMA_CH_DEFAULT_WEIGHT 100;
|
||||
|
||||
#define DMA_OWN 1
|
||||
#define CPU_OWN 0
|
||||
#define DMA_MAJOR 250
|
||||
|
||||
/* Descriptors */
|
||||
#define DMA_DESC_OWN_CPU 0x0
|
||||
#define DMA_DESC_OWN_DMA 0x80000000
|
||||
#define DMA_DESC_CPT_SET 0x40000000
|
||||
#define DMA_DESC_SOP_SET 0x20000000
|
||||
#define DMA_DESC_EOP_SET 0x10000000
|
||||
|
||||
struct rx_desc {
|
||||
union {
|
||||
struct {
|
||||
#ifdef CONFIG_CPU_LITTLE_ENDIAN
|
||||
volatile u32 data_length:16;
|
||||
volatile u32 reserve2:7;
|
||||
volatile u32 byte_offset:2;
|
||||
volatile u32 reserve1:3;
|
||||
volatile u32 eop:1;
|
||||
volatile u32 sop:1;
|
||||
volatile u32 c:1;
|
||||
volatile u32 own:1;
|
||||
#else
|
||||
volatile u32 own:1;
|
||||
volatile u32 c:1;
|
||||
volatile u32 sop:1;
|
||||
volatile u32 eop:1;
|
||||
volatile u32 reserve1:3;
|
||||
volatile u32 byte_offset:2;
|
||||
volatile u32 reserve2:7;
|
||||
volatile u32 data_length:16;
|
||||
#endif
|
||||
} field;
|
||||
|
||||
volatile u32 word;
|
||||
} status;
|
||||
|
||||
volatile u32 data_pointer;
|
||||
};
|
||||
|
||||
struct tx_desc {
|
||||
union {
|
||||
struct {
|
||||
#ifdef CONFIG_CPU_LITTLE_ENDIAN
|
||||
volatile u32 data_length:16;
|
||||
volatile u32 reserved:7;
|
||||
volatile u32 byte_offset:5;
|
||||
volatile u32 eop:1;
|
||||
volatile u32 sop:1;
|
||||
volatile u32 c:1;
|
||||
volatile u32 own:1;
|
||||
#else
|
||||
volatile u32 own:1;
|
||||
volatile u32 c:1;
|
||||
volatile u32 sop:1;
|
||||
volatile u32 eop:1;
|
||||
volatile u32 byte_offset:5;
|
||||
volatile u32 reserved:7;
|
||||
volatile u32 data_length:16;
|
||||
#endif
|
||||
} field;
|
||||
|
||||
volatile u32 word;
|
||||
} status;
|
||||
|
||||
volatile u32 data_pointer;
|
||||
};
|
||||
|
||||
/* DMA pseudo interrupts notified to switch driver */
|
||||
#define RCV_INT 0x01
|
||||
#define TX_BUF_FULL_INT 0x02
|
||||
#define TRANSMIT_CPT_INT 0x04
|
||||
#define CHANNEL_CLOSED 0x10
|
||||
|
||||
/* Parameters for switch DMA device */
|
||||
#define DEFAULT_SW_CHANNEL_WEIGHT 3
|
||||
#define DEFAULT_SW_PORT_WEIGHT 7
|
||||
|
||||
#define DEFAULT_SW_TX_BURST_LEN 2 /* 2 words, 4 words, 8 words */
|
||||
#define DEFAULT_SW_RX_BURST_LEN 2 /* 2 words, 4 words, 8 words */
|
||||
|
||||
#define DEFAULT_SW_TX_CHANNEL_NUM 4
|
||||
#define DEFAULT_SW_RX_CHANNEL_NUM 4
|
||||
|
||||
#define DEFAULT_SW_TX_CHANNEL_DESCR_NUM 20
|
||||
#define DEFAULT_SW_RX_CHANNEL_DESCR_NUM 20
|
||||
|
||||
/* Parameters for SSC DMA device */
|
||||
#define DEFAULT_SSC_CHANNEL_WEIGHT 3
|
||||
#define DEFAULT_SSC_PORT_WEIGHT 7
|
||||
|
||||
#define DEFAULT_SSC_TX_CHANNEL_CLASS 3
|
||||
#define DEFAULT_SSC_RX_CHANNEL_CLASS 0
|
||||
|
||||
#define DEFAULT_SSC_TX_BURST_LEN 2 /* 2 words, 4 words, 8 words */
|
||||
#define DEFAULT_SSC_RX_BURST_LEN 2 /* 2 words, 4 words, 8 words */
|
||||
|
||||
#define DEFAULT_SSC0_TX_CHANNEL_NUM 1
|
||||
#define DEFAULT_SSC0_RX_CHANNEL_NUM 1
|
||||
#define DEFAULT_SSC1_TX_CHANNEL_NUM 1
|
||||
#define DEFAULT_SSC1_RX_CHANNEL_NUM 1
|
||||
|
||||
#define DEFAULT_SSC_TX_CHANNEL_DESCR_NUM 10
|
||||
#define DEFAULT_SSC_RX_CHANNEL_DESCR_NUM 10
|
||||
|
||||
/* Parameters for memory DMA device */
|
||||
#define DEFAULT_MEM_CHANNEL_WEIGHT 3
|
||||
#define DEFAULT_MEM_PORT_WEIGHT 7
|
||||
|
||||
#define DEFAULT_MEM_TX_BURST_LEN 4 /* 2 words, 4 words, 8 words */
|
||||
#define DEFAULT_MEM_RX_BURST_LEN 4 /* 2 words, 4 words, 8 words */
|
||||
|
||||
#define DEFAULT_MEM_TX_CHANNEL_NUM 1
|
||||
#define DEFAULT_MEM_RX_CHANNEL_NUM 1
|
||||
|
||||
#define DEFAULT_MEM_TX_CHANNEL_DESCR_NUM 2
|
||||
#define DEFAULT_MEM_RX_CHANNEL_DESCR_NUM 2
|
||||
|
||||
/* Parameters for DEU DMA device */
|
||||
#define DEFAULT_DEU_CHANNEL_WEIGHT 1
|
||||
#define DEFAULT_DEU_PORT_WEIGHT 1
|
||||
|
||||
#define DEFAULT_DEU_TX_BURST_LEN 4 /* 2 words, 4 words, 8 words */
|
||||
#define DEFAULT_DEU_RX_BURST_LEN 4 /* 2 words, 4 words, 8 words */
|
||||
|
||||
#define DEFAULT_DEU_TX_CHANNEL_DESCR_NUM 20
|
||||
#define DEFAULT_DEU_RX_CHANNEL_DESCR_NUM 20
|
||||
|
||||
#define DMA_DESCR_NUM 30 /* number of descriptors per channel */
|
||||
|
||||
enum dma_dir_t {
|
||||
DIR_RX = 0,
|
||||
DIR_TX = 1,
|
||||
};
|
||||
|
||||
struct dma_device_info;
|
||||
|
||||
struct dma_channel_info {
|
||||
/*Pointer to the peripheral device who is using this channel*/
|
||||
/*const*/ struct dma_device_info *dma_dev;
|
||||
/*direction*/
|
||||
const enum dma_dir_t dir; /*RX or TX*/
|
||||
/*class for this channel for QoS*/
|
||||
int pri;
|
||||
/*irq number*/
|
||||
const int irq;
|
||||
/*relative channel number*/
|
||||
const int rel_chan_no;
|
||||
/*absolute channel number*/
|
||||
int abs_chan_no;
|
||||
|
||||
/*specify byte_offset*/
|
||||
int byte_offset;
|
||||
int tx_weight;
|
||||
|
||||
/*descriptor parameter*/
|
||||
int desc_base;
|
||||
int desc_len;
|
||||
int curr_desc;
|
||||
int prev_desc;/*only used if it is a tx channel*/
|
||||
|
||||
/*weight setting for WFQ algorithm*/
|
||||
int weight;
|
||||
int default_weight;
|
||||
|
||||
int packet_size;
|
||||
|
||||
/*status of this channel*/
|
||||
int control; /*on or off*/
|
||||
int xfer_cnt;
|
||||
int dur; /*descriptor underrun*/
|
||||
|
||||
/**optional information for the upper layer devices*/
|
||||
void *opt[DMA_DESCR_NUM];
|
||||
|
||||
/*channel operations*/
|
||||
int (*open)(struct dma_channel_info *ch);
|
||||
int (*close)(struct dma_channel_info *ch);
|
||||
int (*reset)(struct dma_channel_info *ch);
|
||||
void (*enable_irq)(struct dma_channel_info *ch);
|
||||
void (*disable_irq)(struct dma_channel_info *ch);
|
||||
};
|
||||
|
||||
|
||||
struct dma_device_info {
|
||||
/*device name of this peripheral*/
|
||||
const char device_name[16];
|
||||
const int max_rx_chan_num;
|
||||
const int max_tx_chan_num;
|
||||
int drop_enable;
|
||||
|
||||
int reserved;
|
||||
|
||||
int tx_burst_len;
|
||||
int rx_burst_len;
|
||||
int tx_weight;
|
||||
|
||||
int current_tx_chan;
|
||||
int current_rx_chan;
|
||||
int num_tx_chan;
|
||||
int num_rx_chan;
|
||||
int tx_endianness_mode;
|
||||
int rx_endianness_mode;
|
||||
struct dma_channel_info *tx_chan[4];
|
||||
struct dma_channel_info *rx_chan[4];
|
||||
|
||||
/*functions, optional*/
|
||||
u8 *(*buffer_alloc)(int len,int *offset, void **opt);
|
||||
void (*buffer_free)(u8 *dataptr, void *opt);
|
||||
int (*intr_handler)(struct dma_device_info *dma_dev, int status);
|
||||
|
||||
/* used by peripheral driver only */
|
||||
void *priv;
|
||||
};
|
||||
|
||||
struct dma_device_info *dma_device_reserve(char *dev_name);
|
||||
int dma_device_release(struct dma_device_info *dma_dev);
|
||||
int dma_device_register(struct dma_device_info *dma_dev);
|
||||
int dma_device_unregister(struct dma_device_info *dma_dev);
|
||||
int dma_device_read(struct dma_device_info *dma_dev, u8 **dataptr, void **opt);
|
||||
int dma_device_write(struct dma_device_info *dma_dev, u8 *dataptr,
|
||||
int len, void *opt);
|
||||
|
||||
#endif
|
|
@ -1,35 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Copyright (C) 2010 Lantiq
|
||||
*/
|
||||
#ifndef __SVIP_IRQ_H
|
||||
#define __SVIP_IRQ_H
|
||||
|
||||
#define IM_NUM 6
|
||||
|
||||
#define INT_NUM_IRQ0 8
|
||||
#define INT_NUM_IM0_IRL0 (INT_NUM_IRQ0 + 0)
|
||||
#define INT_NUM_IM1_IRL0 (INT_NUM_IM0_IRL0 + 32)
|
||||
#define INT_NUM_IM2_IRL0 (INT_NUM_IM1_IRL0 + 32)
|
||||
#define INT_NUM_IM3_IRL0 (INT_NUM_IM2_IRL0 + 32)
|
||||
#define INT_NUM_IM4_IRL0 (INT_NUM_IM3_IRL0 + 32)
|
||||
#define INT_NUM_EXTRA_START (INT_NUM_IM4_IRL0 + 32)
|
||||
#define INT_NUM_IM_OFFSET (INT_NUM_IM1_IRL0 - INT_NUM_IM0_IRL0)
|
||||
|
||||
#define INT_NUM_IM5_IRL0 (INT_NUM_IRQ0 + 160)
|
||||
#define MIPS_CPU_TIMER_IRQ (INT_NUM_IM5_IRL0 + 2)
|
||||
|
||||
#endif
|
|
@ -1,467 +0,0 @@
|
|||
/************************************************************************
|
||||
*
|
||||
* Copyright (c) 2007
|
||||
* Infineon Technologies AG
|
||||
* St. Martin Strasse 53; 81669 Muenchen; Germany
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version
|
||||
* 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
************************************************************************/
|
||||
|
||||
#ifndef __SVIP_MUX_H
|
||||
#define __SVIP_MUX_H
|
||||
|
||||
#define LTQ_MUX_P0_PINS 20
|
||||
#define LTQ_MUX_P1_PINS 20
|
||||
#define LTQ_MUX_P2_PINS 19
|
||||
#define LTQ_MUX_P3_PINS 20
|
||||
#define LTQ_MUX_P4_PINS 24
|
||||
|
||||
struct ltq_mux_pin {
|
||||
int dirin;
|
||||
int puen;
|
||||
int altsel0;
|
||||
int altsel1;
|
||||
};
|
||||
|
||||
struct ltq_mux_settings {
|
||||
const struct ltq_mux_pin *mux_p0;
|
||||
const struct ltq_mux_pin *mux_p1;
|
||||
const struct ltq_mux_pin *mux_p2;
|
||||
const struct ltq_mux_pin *mux_p3;
|
||||
const struct ltq_mux_pin *mux_p4;
|
||||
};
|
||||
|
||||
#define LTQ_MUX_P0_19_EXINT16 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_19 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_18_EJ_BRKIN { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_18 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_18_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_17_EXINT10 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_17 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_17_ASC1_RXD { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_16_EXINT9 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_16 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_16_ASC1_TXD { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_15_EXINT8 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_15 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_15_ASC0_RXD { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_14_EXINT7 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_14 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_14_ASC0_TXD { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_13_SSC0_CS7 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_13_EXINT6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_13 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_13_SSC1_CS7 { 0, 0, 0, 1 }
|
||||
#define LTQ_MUX_P0_13_SSC1_INT { 0, 0, 1, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_12_SSC0_CS6 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_12_EXINT5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_12 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_12_SSC1_CS6 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_11_SSC0_CS5 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_11_EXINT4 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_11 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_11_SSC1_CS5 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_10_SSC0_CS4 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_10_EXINT3 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_10 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_10_SSC1_CS4 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_9_SSC0_CS3 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_9_EXINT2 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_9 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_9_SSC1_CS3 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_8_SSC0_CS2 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_8_EXINT1 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_8 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_8_SSC1_CS2 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_7_SSC0_CS1 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_7_EXINT0 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_7 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_7_SSC1_CS1 { 0, 0, 0, 1 }
|
||||
#define LTQ_MUX_P0_7_SSC1_CS0 { 1, 0, 0, 1 }
|
||||
#define LTQ_MUX_P0_7_SSC2_CS0 { 1, 0, 1, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_6_SSC0_CS0 { 0, 1, 0, 0 }
|
||||
#define LTQ_MUX_P0_6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_6_IN { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_6_SSC1_CS0 { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_5_SSC1_SCLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_5_IN { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_5_SSC2_CLK { 1, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_4_SSC1_MRST { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_4 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_4_IN { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_4_SSC2_MRST { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_3_SSC1_MTSR { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_3 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_3_IN { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_3_SSC2_MTSR { 0, 0, 0, 1 }
|
||||
|
||||
#define LTQ_MUX_P0_2_SSC0_SCLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_2 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_2_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_1_SSC0_MRST { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_1 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_1_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P0_0_SSC0_MTSR { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P0_0 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P0_0_IN { 1, 0, 1, 0 }
|
||||
|
||||
|
||||
#define LTQ_MUX_P1_19_PCM3_TC1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_19_EXINT15 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_19 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_18_PCM3_FSC { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_18_EXINT11 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_18 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_17_PCM3_PCL { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_17_EXINT12 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_17 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_16_PCM3_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_16_EXINT13 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_16 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_15_PCM3_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_15_EXINT14 { 1, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_15 { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_14_PCM2_TC1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_14 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_14_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_13_PCM2_FSC { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_13 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_13_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_12_PCM2_PCL { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_12 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_12_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_11_PCM2_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_11 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_11_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_10_PCM2_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_10 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_10_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_9_PCM1_TC1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_9 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_9_IN { 0, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_8_PCM1_FSC { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_8 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_8_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_7_PCM1_PCL { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_7 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_7_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_6_PCM1_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_6_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_5_PCM1_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_5_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_4_PCM0_TC1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_4 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_4_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_3_PCM0_FSC { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_3 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_3_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_2_PCM0_PCL { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_2 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_2_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_1_PCM0_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_1 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_1_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P1_0_PCM0_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P1_0 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P1_0_IN { 1, 0, 1, 0 }
|
||||
|
||||
|
||||
#define LTQ_MUX_P2_18_EBU_BC1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_18 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_18_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_17_EBU_BC0 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_17 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_17_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_16_EBU_RDBY { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_16 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_16_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_15_EBU_WAIT { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_15 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_15_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_14_EBU_ALE { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_14 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_14_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_13_EBU_WR { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_13 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_13_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_12_EBU_RD { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_12 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_12_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_11_EBU_A11 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_11 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_11_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_10_EBU_A10 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_10 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_10_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_9_EBU_A9 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_9 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_9_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_8_EBU_A8 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_8 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_8_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_7_EBU_A7 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_7 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_7_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_6_EBU_A6 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_6_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_5_EBU_A5 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_5_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_4_EBU_A4 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_4 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_4_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_3_EBU_A3 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_3 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_3_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_2_EBU_A2 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_2 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_2_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_1_EBU_A1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_1 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_1_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P2_0_EBU_A0 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P2_0 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P2_0_IN { 1, 0, 1, 0 }
|
||||
|
||||
|
||||
#define LTQ_MUX_P3_19_EBU_CS3 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_19 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_19_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_18_EBU_CS2 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_18 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_18_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_17_EBU_CS1 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_17 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_17_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_16_EBU_CS0 { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_16 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_16_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_15_EBU_AD15 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_15 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_15_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_14_EBU_AD14 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_14 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_14_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_13_EBU_AD13 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_13 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_13_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_12_EBU_AD12 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_12 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_12_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_11_EBU_AD11 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_11 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_11_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_10_EBU_AD10 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_10 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_10_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_9_EBU_AD9 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_9 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_9_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_8_EBU_AD8 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_8 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_8_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_7_EBU_AD7 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_7 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_7_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_6_EBU_AD6 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_6_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_5_EBU_AD5 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_5_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_4_EBU_AD4 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_4 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_4_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_3_EBU_AD3 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_3 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_3_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_2_EBU_AD2 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_2 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_2_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_1_EBU_AD1 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_1 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_1_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P3_0_EBU_AD0 { 1, 0, 0, 0 }
|
||||
#define LTQ_MUX_P3_0 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P3_0_IN { 1, 0, 1, 0 }
|
||||
|
||||
|
||||
#define LTQ_MUX_P4_23_SSLIC7_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_23 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_23_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_22_SSLIC7_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_22 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_22_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_21_SSLIC7_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_21 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_21_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_20_SSLIC6_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_20 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_20_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_19_SSLIC6_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_19 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_19_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_18_SSLIC6_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_18 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_18_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_17_SSLIC5_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_17 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_17_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_16_SSLIC5_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_16 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_16_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_15_SSLIC5_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_15 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_15_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_14_SSLIC4_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_14 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_14_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_13_SSLIC4_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_13 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_13_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_12_SSLIC4_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_12 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_12_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_11_SSLIC3_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_11 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_11_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_10_SSLIC3_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_10 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_10_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_9_SSLIC3_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_9 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_9_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_8_SSLIC2_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_8 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_8_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_7_SSLIC2_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_7 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_7_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_6_SSLIC2_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_6 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_6_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_5_SSLIC1_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_5 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_5_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_4_SSLIC1_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_4 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_4_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_3_SSLIC1_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_3 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_3_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_2_SSLIC0_CLK { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_2 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_2_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_1_SSLIC0_RX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_1 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_1_IN { 1, 0, 1, 0 }
|
||||
|
||||
#define LTQ_MUX_P4_0_SSLIC0_TX { 0, 0, 0, 0 }
|
||||
#define LTQ_MUX_P4_0 { 0, 0, 1, 0 }
|
||||
#define LTQ_MUX_P4_0_IN { 1, 0, 1, 0 }
|
||||
|
||||
#endif
|
|
@ -1,23 +0,0 @@
|
|||
/************************************************************************
|
||||
*
|
||||
* Copyright (c) 2007
|
||||
* Infineon Technologies AG
|
||||
* St. Martin Strasse 53; 81669 Muenchen; Germany
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version
|
||||
* 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
************************************************************************/
|
||||
|
||||
#ifndef __SVIP_PMS_H
|
||||
#define __SVIP_PMS_H
|
||||
|
||||
void svip_sys1_clk_enable(u32 mask);
|
||||
int svip_sys1_clk_is_enabled(u32 mask);
|
||||
|
||||
void svip_sys2_clk_enable(u32 mask);
|
||||
int svip_sys2_clk_is_enabled(u32 mask);
|
||||
|
||||
#endif
|
|
@ -1,165 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __SYS0_REG_H
|
||||
#define __SYS0_REG_H
|
||||
|
||||
#define sys0_r32(reg) ltq_r32(&sys0->reg)
|
||||
#define sys0_w32(val, reg) ltq_w32(val, &sys0->reg)
|
||||
#define sys0_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &sys0->reg)
|
||||
|
||||
/** SYS0 register structure */
|
||||
struct svip_reg_sys0 {
|
||||
unsigned long sr; /* 0x0000 */
|
||||
unsigned long bcr; /* 0x0004 */
|
||||
unsigned long pll1cr; /* 0x0008 */
|
||||
unsigned long pll2cr; /* 0x000c */
|
||||
unsigned long tscr; /* 0x0010 */
|
||||
unsigned long phyclkr; /* 0x0014 */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS0 Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Endian select pin (31) */
|
||||
#define SYS0_SR_ESEL (0x1 << 31)
|
||||
#define SYS0_SR_ESEL_GET(val) ((((val) & SYS0_SR_ESEL) >> 31) & 0x1)
|
||||
/* Boot mode pins (27:24) */
|
||||
#define SYS0_SR_BMODE (0xf << 24)
|
||||
#define SYS0_SR_BMODE_GET(val) ((((val) & SYS0_SR_BMODE) >> 24) & 0xf)
|
||||
/* PLL2 Lock (18) */
|
||||
#define SYS0_SR_PLL2LOCK (0x1 << 18)
|
||||
#define SYS0_SR_PLL2LOCK_GET(val) ((((val) & SYS0_SR_PLL2LOCK) >> 18) & 0x1)
|
||||
/* PLL1 Lock (17) */
|
||||
#define SYS0_SR_PLL1LOCK (0x1 << 17)
|
||||
#define SYS0_SR_PLL1LOCK_GET(val) ((((val) & SYS0_SR_PLL1LOCK) >> 17) & 0x1)
|
||||
/* Discrete Timing Oscillator Lock (16) */
|
||||
#define SYS0_SR_DTOLOCK (0x1 << 16)
|
||||
#define SYS0_SR_DTOLOCK_GET(val) ((((val) & SYS0_SR_DTOLOCK) >> 16) & 0x1)
|
||||
/* Hardware Reset Indication (1) */
|
||||
#define SYS0_SR_HRSTIN (0x1 << 1)
|
||||
#define SYS0_SR_HRSTIN_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS0_SR_HRSTIN_GET(val) ((((val) & SYS0_SR_HRSTIN) >> 1) & 0x1)
|
||||
#define SYS0_SR_HRSTIN_SET(reg,val) (reg) = ((reg & ~SYS0_SR_HRSTIN) | (((val) & 0x1) << 1))
|
||||
/* Power-on Reset Indication (0) */
|
||||
#define SYS0_SR_POR (0x1 << 0)
|
||||
#define SYS0_SR_POR_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS0_SR_POR_GET(val) ((((val) & SYS0_SR_POR) >> 0) & 0x1)
|
||||
#define SYS0_SR_POR_SET(reg,val) (reg) = ((reg & ~SYS0_SR_POR) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS0 Boot Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Configuration of Boot Source for CPU5 (25) */
|
||||
#define SYS0_BCR_BMODECPU5 (0x1 << 25)
|
||||
#define SYS0_BCR_BMODECPU5_VAL(val) (((val) & 0x1) << 25)
|
||||
#define SYS0_BCR_BMODECPU5_GET(val) ((((val) & SYS0_BCR_BMODECPU5) >> 25) & 0x1)
|
||||
#define SYS0_BCR_BMODECPU5_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU5) | (((val) & 0x1) << 25))
|
||||
/* Configuration of Boot Source for CPU4 (24) */
|
||||
#define SYS0_BCR_BMODECPU4 (0x1 << 24)
|
||||
#define SYS0_BCR_BMODECPU4_VAL(val) (((val) & 0x1) << 24)
|
||||
#define SYS0_BCR_BMODECPU4_GET(val) ((((val) & SYS0_BCR_BMODECPU4) >> 24) & 0x1)
|
||||
#define SYS0_BCR_BMODECPU4_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU4) | (((val) & 0x1) << 24))
|
||||
/* Configuration of Boot Source for CPU3 (23) */
|
||||
#define SYS0_BCR_BMODECPU3 (0x1 << 23)
|
||||
#define SYS0_BCR_BMODECPU3_VAL(val) (((val) & 0x1) << 23)
|
||||
#define SYS0_BCR_BMODECPU3_GET(val) ((((val) & SYS0_BCR_BMODECPU3) >> 23) & 0x1)
|
||||
#define SYS0_BCR_BMODECPU3_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU3) | (((val) & 0x1) << 23))
|
||||
/* Configuration of Boot Source for CPU2 (22) */
|
||||
#define SYS0_BCR_BMODECPU2 (0x1 << 22)
|
||||
#define SYS0_BCR_BMODECPU2_VAL(val) (((val) & 0x1) << 22)
|
||||
#define SYS0_BCR_BMODECPU2_GET(val) ((((val) & SYS0_BCR_BMODECPU2) >> 22) & 0x1)
|
||||
#define SYS0_BCR_BMODECPU2_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU2) | (((val) & 0x1) << 22))
|
||||
/* Configuration of Boot Source for CPU1 (21) */
|
||||
#define SYS0_BCR_BMODECPU1 (0x1 << 21)
|
||||
#define SYS0_BCR_BMODECPU1_VAL(val) (((val) & 0x1) << 21)
|
||||
#define SYS0_BCR_BMODECPU1_GET(val) ((((val) & SYS0_BCR_BMODECPU1) >> 21) & 0x1)
|
||||
#define SYS0_BCR_BMODECPU1_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU1) | (((val) & 0x1) << 21))
|
||||
/* Configuration of Boot Source for CPU0 (20:16) */
|
||||
#define SYS0_BCR_BMODECPU0 (0x1f << 16)
|
||||
#define SYS0_BCR_BMODECPU0_VAL(val) (((val) & 0x1f) << 16)
|
||||
#define SYS0_BCR_BMODECPU0_GET(val) ((((val) & SYS0_BCR_BMODECPU0) >> 16) & 0x1f)
|
||||
#define SYS0_BCR_BMODECPU0_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_BMODECPU0) | (((val) & 0x1f) << 16))
|
||||
/* Configuration of Endianess for CPU5 (5) */
|
||||
#define SYS0_BCR_ESELCPU5 (0x1 << 5)
|
||||
#define SYS0_BCR_ESELCPU5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS0_BCR_ESELCPU5_GET(val) ((((val) & SYS0_BCR_ESELCPU5) >> 5) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU5_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU5) | (((val) & 0x1) << 5))
|
||||
/* Configuration of Endianess for CPU4 (4) */
|
||||
#define SYS0_BCR_ESELCPU4 (0x1 << 4)
|
||||
#define SYS0_BCR_ESELCPU4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS0_BCR_ESELCPU4_GET(val) ((((val) & SYS0_BCR_ESELCPU4) >> 4) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU4_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU4) | (((val) & 0x1) << 4))
|
||||
/* Configuration of Endianess for CPU3 (3) */
|
||||
#define SYS0_BCR_ESELCPU3 (0x1 << 3)
|
||||
#define SYS0_BCR_ESELCPU3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS0_BCR_ESELCPU3_GET(val) ((((val) & SYS0_BCR_ESELCPU3) >> 3) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU3_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU3) | (((val) & 0x1) << 3))
|
||||
/* Configuration of Endianess for CPU2 (2) */
|
||||
#define SYS0_BCR_ESELCPU2 (0x1 << 2)
|
||||
#define SYS0_BCR_ESELCPU2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS0_BCR_ESELCPU2_GET(val) ((((val) & SYS0_BCR_ESELCPU2) >> 2) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU2_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU2) | (((val) & 0x1) << 2))
|
||||
/* Configuration of Endianess for CPU1 (1) */
|
||||
#define SYS0_BCR_ESELCPU1 (0x1 << 1)
|
||||
#define SYS0_BCR_ESELCPU1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS0_BCR_ESELCPU1_GET(val) ((((val) & SYS0_BCR_ESELCPU1) >> 1) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU1_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU1) | (((val) & 0x1) << 1))
|
||||
/* Configuration of Endianess for CPU0 (0) */
|
||||
#define SYS0_BCR_ESELCPU0 (0x1)
|
||||
#define SYS0_BCR_ESELCPU0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS0_BCR_ESELCPU0_GET(val) ((((val) & SYS0_BCR_ESELCPU0) >> 0) & 0x1)
|
||||
#define SYS0_BCR_ESELCPU0_SET(reg,val) (reg) = ((reg & ~SYS0_BCR_ESELCPU0) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PLL1 Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* PLL1 Bypass Enable (31) */
|
||||
#define SYS0_PLL1CR_OSCBYP (0x1 << 31)
|
||||
#define SYS0_PLL1CR_OSCBYP_VAL(val) (((val) & 0x1) << 31)
|
||||
#define SYS0_PLL1CR_OSCBYP_GET(val) ((((val) & SYS0_PLL1CR_OSCBYP) >> 31) & 0x1)
|
||||
#define SYS0_PLL1CR_OSCBYP_SET(reg,val) (reg) = ((reg & ~SYS0_PLL1CR_OSCBYP) | (((val) & 0x1) << 31))
|
||||
/* PLL1 Divider Value (1:0) */
|
||||
#define SYS0_PLL1CR_PLLDIV (0x3)
|
||||
#define SYS0_PLL1CR_PLLDIV_VAL(val) (((val) & 0x3) << 0)
|
||||
#define SYS0_PLL1CR_PLLDIV_GET(val) ((((val) & SYS0_PLL1CR_PLLDIV) >> 0) & 0x3)
|
||||
#define SYS0_PLL1CR_PLLDIV_SET(reg,val) (reg) = ((reg & ~SYS0_PLL1CR_PLLDIV) | (((val) & 0x3) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* PLL2 Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* PLL2 clear deepsleep (31) */
|
||||
#define SYS0_PLL2CR_CLRDS (0x1 << 31)
|
||||
#define SYS0_PLL2CR_CLRDS_VAL(val) (((val) & 0x1) << 31)
|
||||
#define SYS0_PLL2CR_CLRDS_GET(val) ((((val) & SYS0_PLL2CR_CLRDS) >> 31) & 0x1)
|
||||
#define SYS0_PLL2CR_CLRDS_SET(reg,val) (reg) = ((reg & ~SYS0_PLL2CR_CLRDS) | (((val) & 0x1) << 31))
|
||||
/* PLL2 set deepsleep (30) */
|
||||
#define SYS0_PLL2CR_SETDS (0x1 << 30)
|
||||
#define SYS0_PLL2CR_SETDS_VAL(val) (((val) & 0x1) << 30)
|
||||
#define SYS0_PLL2CR_SETDS_GET(val) ((((val) & SYS0_PLL2CR_SETDS) >> 30) & 0x1)
|
||||
#define SYS0_PLL2CR_SETDS_SET(reg,val) (reg) = ((reg & ~SYS0_PLL2CR_SETDS) | (((val) & 0x1) << 30))
|
||||
/* PLL2 Fractional division enable (16) */
|
||||
#define SYS0_PLL2CR_FRACTEN (0x1 << 16)
|
||||
#define SYS0_PLL2CR_FRACTEN_VAL(val) (((val) & 0x1) << 16)
|
||||
#define SYS0_PLL2CR_FRACTEN_GET(val) ((((val) & SYS0_PLL2CR_FRACTEN) >> 16) & 0x1)
|
||||
#define SYS0_PLL2CR_FRACTEN_SET(reg,val) (reg) = ((reg & ~SYS0_PLL2CR_FRACTEN) | (((val) & 0x1) << 16))
|
||||
/* PLL2 Fractional division value (9:0) */
|
||||
#define SYS0_FRACTVAL (0x3f)
|
||||
#define SYS0_FRACTVAL_VAL(val) (((val) & 0x3f) << 0)
|
||||
#define SYS0_FRACTVAL_GET(val) ((((val) & SYS0_FRACTVAL) >> 0) & 0x3f)
|
||||
#define SYS0_FRACTVAL_SET(reg,val) (reg) = ((reg & ~SYS0_FRACTVAL) | (((val) & 0x3f) << 0))
|
||||
|
||||
#endif
|
|
@ -1,370 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __SYS1_REG_H
|
||||
#define __SYS1_REG_H
|
||||
|
||||
#define sys1_r32(reg) ltq_r32(&sys1->reg)
|
||||
#define sys1_w32(val, reg) ltq_w32(val, &sys1->reg)
|
||||
#define sys1_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &sys1->reg)
|
||||
|
||||
/** SYS1 register structure */
|
||||
struct svip_reg_sys1 {
|
||||
unsigned long clksr; /* 0x0000 */
|
||||
unsigned long clkenr; /* 0x0004 */
|
||||
unsigned long clkclr; /* 0x0008 */
|
||||
unsigned long reserved0[1];
|
||||
unsigned long l2ccr; /* 0x0010 */
|
||||
unsigned long fpicr; /* 0x0014 */
|
||||
unsigned long wdtcr; /* 0x0018 */
|
||||
unsigned long reserved1[1];
|
||||
unsigned long cpucr[6]; /* 0x0020 */
|
||||
unsigned long reserved2[2];
|
||||
unsigned long rsr; /* 0x0040 */
|
||||
unsigned long rreqr; /* 0x0044 */
|
||||
unsigned long rrlsr; /* 0x0048 */
|
||||
unsigned long rbtr; /* 0x004c */
|
||||
unsigned long irncr; /* 0x0050 */
|
||||
unsigned long irnicr; /* 0x0054 */
|
||||
unsigned long irnen; /* 0x0058 */
|
||||
unsigned long reserved3[1];
|
||||
unsigned long cpursr[6]; /* 0x0060 */
|
||||
unsigned long reserved4[2];
|
||||
unsigned long cpusrssr[6]; /* 0x0080 */
|
||||
unsigned long reserved5[2];
|
||||
unsigned long cpuwrssr[6]; /* 0x00a0 */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Clock Status Register
|
||||
******************************************************************************/
|
||||
/* (r) Clock Enable for L2C */
|
||||
#define SYS1_CLKSR_L2C (0x1 << 31)
|
||||
/* (r) Clock Enable for DDR2 */
|
||||
#define SYS1_CLKSR_DDR2 (0x1 << 30)
|
||||
/* (r) Clock Enable for SMI2 */
|
||||
#define SYS1_CLKSR_SMI2 (0x1 << 29)
|
||||
/* (r) Clock Enable for SMI1 */
|
||||
#define SYS1_CLKSR_SMI1 (0x1 << 28)
|
||||
/* (r) Clock Enable for SMI0 */
|
||||
#define SYS1_CLKSR_SMI0 (0x1 << 27)
|
||||
/* (r) Clock Enable for FMI0 */
|
||||
#define SYS1_CLKSR_FMI0 (0x1 << 26)
|
||||
/* (r) Clock Enable for PORT0 */
|
||||
#define SYS1_CLKSR_PORT0 (0x1 << 0)
|
||||
/* (r) Clock Enable for PCM3 */
|
||||
#define SYS1_CLKSR_PCM3 (0x1 << 19)
|
||||
/* (r) Clock Enable for PCM2 */
|
||||
#define SYS1_CLKSR_PCM2 (0x1 << 18)
|
||||
/* (r) Clock Enable for PCM1 */
|
||||
#define SYS1_CLKSR_PCM1 (0x1 << 17)
|
||||
/* (r) Clock Enable for PCM0 */
|
||||
#define SYS1_CLKSR_PCM0 (0x1 << 16)
|
||||
/* (r) Clock Enable for ASC1 */
|
||||
#define SYS1_CLKSR_ASC1 (0x1 << 15)
|
||||
/* (r) Clock Enable for ASC0 */
|
||||
#define SYS1_CLKSR_ASC0 (0x1 << 14)
|
||||
/* (r) Clock Enable for SSC2 */
|
||||
#define SYS1_CLKSR_SSC2 (0x1 << 13)
|
||||
/* (r) Clock Enable for SSC1 */
|
||||
#define SYS1_CLKSR_SSC1 (0x1 << 12)
|
||||
/* (r) Clock Enable for SSC0 */
|
||||
#define SYS1_CLKSR_SSC0 (0x1 << 11)
|
||||
/* (r) Clock Enable for GPTC */
|
||||
#define SYS1_CLKSR_GPTC (0x1 << 10)
|
||||
/* (r) Clock Enable for DMA */
|
||||
#define SYS1_CLKSR_DMA (0x1 << 9)
|
||||
/* (r) Clock Enable for FSCT */
|
||||
#define SYS1_CLKSR_FSCT (0x1 << 8)
|
||||
/* (r) Clock Enable for ETHSW */
|
||||
#define SYS1_CLKSR_ETHSW (0x1 << 7)
|
||||
/* (r) Clock Enable for EBU */
|
||||
#define SYS1_CLKSR_EBU (0x1 << 6)
|
||||
/* (r) Clock Enable for TRNG */
|
||||
#define SYS1_CLKSR_TRNG (0x1 << 5)
|
||||
/* (r) Clock Enable for DEU */
|
||||
#define SYS1_CLKSR_DEU (0x1 << 4)
|
||||
/* (r) Clock Enable for PORT3 */
|
||||
#define SYS1_CLKSR_PORT3 (0x1 << 3)
|
||||
/* (r) Clock Enable for PORT2 */
|
||||
#define SYS1_CLKSR_PORT2 (0x1 << 2)
|
||||
/* (r) Clock Enable for PORT1 */
|
||||
#define SYS1_CLKSR_PORT1 (0x1 << 1)
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Clock Enable Register
|
||||
******************************************************************************/
|
||||
/* (w) Clock Enable Request for L2C */
|
||||
#define SYS1_CLKENR_L2C (0x1 << 31)
|
||||
/* (w) Clock Enable Request for DDR2 */
|
||||
#define SYS1_CLKENR_DDR2 (0x1 << 30)
|
||||
/* (w) Clock Enable Request for SMI2 */
|
||||
#define SYS1_CLKENR_SMI2 (0x1 << 29)
|
||||
/* (w) Clock Enable Request for SMI1 */
|
||||
#define SYS1_CLKENR_SMI1 (0x1 << 28)
|
||||
/* (w) Clock Enable Request for SMI0 */
|
||||
#define SYS1_CLKENR_SMI0 (0x1 << 27)
|
||||
/* (w) Clock Enable Request for FMI0 */
|
||||
#define SYS1_CLKENR_FMI0 (0x1 << 26)
|
||||
/* (w) Clock Enable Request for PORT0 */
|
||||
#define SYS1_CLKENR_PORT0 (0x1 << 0)
|
||||
/* (w) Clock Enable Request for PCM3 */
|
||||
#define SYS1_CLKENR_PCM3 (0x1 << 19)
|
||||
/* (w) Clock Enable Request for PCM2 */
|
||||
#define SYS1_CLKENR_PCM2 (0x1 << 18)
|
||||
/* (w) Clock Enable Request for PCM1 */
|
||||
#define SYS1_CLKENR_PCM1 (0x1 << 17)
|
||||
/* (w) Clock Enable Request for PCM0 */
|
||||
#define SYS1_CLKENR_PCM0 (0x1 << 16)
|
||||
/* (w) Clock Enable Request for ASC1 */
|
||||
#define SYS1_CLKENR_ASC1 (0x1 << 15)
|
||||
/* (w) Clock Enable Request for ASC0 */
|
||||
#define SYS1_CLKENR_ASC0 (0x1 << 14)
|
||||
/* (w) Clock Enable Request for SSC2 */
|
||||
#define SYS1_CLKENR_SSC2 (0x1 << 13)
|
||||
/* (w) Clock Enable Request for SSC1 */
|
||||
#define SYS1_CLKENR_SSC1 (0x1 << 12)
|
||||
/* (w) Clock Enable Request for SSC0 */
|
||||
#define SYS1_CLKENR_SSC0 (0x1 << 11)
|
||||
/* (w) Clock Enable Request for GPTC */
|
||||
#define SYS1_CLKENR_GPTC (0x1 << 10)
|
||||
/* (w) Clock Enable Request for DMA */
|
||||
#define SYS1_CLKENR_DMA (0x1 << 9)
|
||||
/* (w) Clock Enable Request for FSCT */
|
||||
#define SYS1_CLKENR_FSCT (0x1 << 8)
|
||||
/* (w) Clock Enable Request for ETHSW */
|
||||
#define SYS1_CLKENR_ETHSW (0x1 << 7)
|
||||
/* (w) Clock Enable Request for EBU */
|
||||
#define SYS1_CLKENR_EBU (0x1 << 6)
|
||||
/* (w) Clock Enable Request for TRNG */
|
||||
#define SYS1_CLKENR_TRNG (0x1 << 5)
|
||||
/* (w) Clock Enable Request for DEU */
|
||||
#define SYS1_CLKENR_DEU (0x1 << 4)
|
||||
/* (w) Clock Enable Request for PORT3 */
|
||||
#define SYS1_CLKENR_PORT3 (0x1 << 3)
|
||||
/* (w) Clock Enable Request for PORT2 */
|
||||
#define SYS1_CLKENR_PORT2 (0x1 << 2)
|
||||
/* (w) Clock Enable Request for PORT1 */
|
||||
#define SYS1_CLKENR_PORT1 (0x1 << 1)
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Clock Clear Register
|
||||
******************************************************************************/
|
||||
/* (w) Clock Disable Request for L2C */
|
||||
#define SYS1_CLKCLR_L2C (0x1 << 31)
|
||||
/* (w) Clock Disable Request for DDR2 */
|
||||
#define SYS1_CLKCLR_DDR2 (0x1 << 30)
|
||||
/* (w) Clock Disable Request for SMI2 */
|
||||
#define SYS1_CLKCLR_SMI2 (0x1 << 29)
|
||||
/* (w) Clock Disable Request for SMI1 */
|
||||
#define SYS1_CLKCLR_SMI1 (0x1 << 28)
|
||||
/* (w) Clock Disable Request for SMI0 */
|
||||
#define SYS1_CLKCLR_SMI0 (0x1 << 27)
|
||||
/* (w) Clock Disable Request for FMI0 */
|
||||
#define SYS1_CLKCLR_FMI0 (0x1 << 26)
|
||||
/* (w) Clock Disable Request for PORT0 */
|
||||
#define SYS1_CLKCLR_PORT0 (0x1 << 0)
|
||||
/* (w) Clock Disable Request for PCM3 */
|
||||
#define SYS1_CLKCLR_PCM3 (0x1 << 19)
|
||||
/* (w) Clock Disable Request for PCM2 */
|
||||
#define SYS1_CLKCLR_PCM2 (0x1 << 18)
|
||||
/* (w) Clock Disable Request for PCM1 */
|
||||
#define SYS1_CLKCLR_PCM1 (0x1 << 17)
|
||||
/* (w) Clock Disable Request for PCM0 */
|
||||
#define SYS1_CLKCLR_PCM0 (0x1 << 16)
|
||||
/* (w) Clock Disable Request for ASC1 */
|
||||
#define SYS1_CLKCLR_ASC1 (0x1 << 15)
|
||||
/* (w) Clock Disable Request for ASC0 */
|
||||
#define SYS1_CLKCLR_ASC0 (0x1 << 14)
|
||||
/* (w) Clock Disable Request for SSC2 */
|
||||
#define SYS1_CLKCLR_SSC2 (0x1 << 13)
|
||||
/* (w) Clock Disable Request for SSC1 */
|
||||
#define SYS1_CLKCLR_SSC1 (0x1 << 12)
|
||||
/* (w) Clock Disable Request for SSC0 */
|
||||
#define SYS1_CLKCLR_SSC0 (0x1 << 11)
|
||||
/* (w) Clock Disable Request for GPTC */
|
||||
#define SYS1_CLKCLR_GPTC (0x1 << 10)
|
||||
/* (w) Clock Disable Request for DMA */
|
||||
#define SYS1_CLKCLR_DMA (0x1 << 9)
|
||||
/* (w) Clock Disable Request for FSCT */
|
||||
#define SYS1_CLKCLR_FSCT (0x1 << 8)
|
||||
/* (w) Clock Disable Request for ETHSW */
|
||||
#define SYS1_CLKCLR_ETHSW (0x1 << 7)
|
||||
/* (w) Clock Disable Request for EBU */
|
||||
#define SYS1_CLKCLR_EBU (0x1 << 6)
|
||||
/* (w) Clock Disable Request for TRNG */
|
||||
#define SYS1_CLKCLR_TRNG (0x1 << 5)
|
||||
/* (w) Clock Disable Request for DEU */
|
||||
#define SYS1_CLKCLR_DEU (0x1 << 4)
|
||||
/* (w) Clock Disable Request for PORT3 */
|
||||
#define SYS1_CLKCLR_PORT3 (0x1 << 3)
|
||||
/* (w) Clock Disable Request for PORT2 */
|
||||
#define SYS1_CLKCLR_PORT2 (0x1 << 2)
|
||||
/* (w) Clock Disable Request for PORT1 */
|
||||
#define SYS1_CLKCLR_PORT1 (0x1 << 1)
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 FPI Control Register
|
||||
******************************************************************************/
|
||||
|
||||
/* FPI Bus Clock divider (0) */
|
||||
#define SYS1_FPICR_FPIDIV (0x1)
|
||||
#define SYS1_FPICR_FPIDIV_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS1_FPICR_FPIDIV_GET(val) ((((val) & SYS1_FPICR_FPIDIV) >> 0) & 0x1)
|
||||
#define SYS1_FPICR_FPIDIV_SET(reg,val) (reg) = ((reg & ~SYS1_FPICR_FPIDIV) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Clock Control Register for CPUn
|
||||
******************************************************************************/
|
||||
|
||||
/* Enable bit for clock of CPUn (1) */
|
||||
#define SYS1_CPUCR_CPUCLKEN (0x1 << 1)
|
||||
#define SYS1_CPUCR_CPUCLKEN_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS1_CPUCR_CPUCLKEN_GET(val) ((((val) & SYS1_CPUCR_CPUCLKEN) >> 1) & 0x1)
|
||||
#define SYS1_CPUCR_CPUCLKEN_SET(reg,val) (reg) = ((reg & ~SYS1_CPUCR_CPUCLKEN) | (((val) & 0x1) << 1))
|
||||
/* Divider factor for clock of CPUn (0) */
|
||||
#define SYS1_CPUCR_CPUDIV (0x1)
|
||||
#define SYS1_CPUCR_CPUDIV_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS1_CPUCR_CPUDIV_GET(val) ((((val) & SYS1_CPUCR_CPUDIV) >> 0) & 0x1)
|
||||
#define SYS1_CPUCR_CPUDIV_SET(reg,val) (reg) = ((reg & ~SYS1_CPUCR_CPUDIV) | (((val) & 0x1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Reset Request Register
|
||||
******************************************************************************/
|
||||
|
||||
/* HRSTOUT Reset Request (18) */
|
||||
#define SYS1_RREQ_HRSTOUT (0x1 << 18)
|
||||
#define SYS1_RREQ_HRSTOUT_VAL(val) (((val) & 0x1) << 18)
|
||||
#define SYS1_RREQ_HRSTOUT_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_HRSTOUT) | (((val) & 1) << 18))
|
||||
/* FBS0 Reset Request (17) */
|
||||
#define SYS1_RREQ_FBS0 (0x1 << 17)
|
||||
#define SYS1_RREQ_FBS0_VAL(val) (((val) & 0x1) << 17)
|
||||
#define SYS1_RREQ_FBS0_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_FBS0) | (((val) & 1) << 17))
|
||||
/* SUBSYS Reset Request (16) */
|
||||
#define SYS1_RREQ_SUBSYS (0x1 << 16)
|
||||
#define SYS1_RREQ_SUBSYS_VAL(val) (((val) & 0x1) << 16)
|
||||
#define SYS1_RREQ_SUBSYS_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_SUBSYS) | (((val) & 1) << 16))
|
||||
/* Watchdog5 Reset Request (13) */
|
||||
#define SYS1_RREQ_WDT5 (0x1 << 13)
|
||||
#define SYS1_RREQ_WDT5_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SYS1_RREQ_WDT5_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT5) | (((val) & 1) << 13))
|
||||
/* Watchdog4 Reset Request (12) */
|
||||
#define SYS1_RREQ_WDT4 (0x1 << 12)
|
||||
#define SYS1_RREQ_WDT4_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SYS1_RREQ_WDT4_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT4) | (((val) & 1) << 12))
|
||||
/* Watchdog3 Reset Request (11) */
|
||||
#define SYS1_RREQ_WDT3 (0x1 << 11)
|
||||
#define SYS1_RREQ_WDT3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS1_RREQ_WDT3_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT3) | (((val) & 1) << 11))
|
||||
/* Watchdog2 Reset Request (10) */
|
||||
#define SYS1_RREQ_WDT2 (0x1 << 10)
|
||||
#define SYS1_RREQ_WDT2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS1_RREQ_WDT2_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT2) | (((val) & 1) << 10))
|
||||
/* Watchdog1 Reset Request (9) */
|
||||
#define SYS1_RREQ_WDT1 (0x1 << 9)
|
||||
#define SYS1_RREQ_WDT1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS1_RREQ_WDT1_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT1) | (((val) & 1) << 9))
|
||||
/* Watchdog0 Reset Request (8) */
|
||||
#define SYS1_RREQ_WDT0 (0x1 << 8)
|
||||
#define SYS1_RREQ_WDT0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS1_RREQ_WDT0_SET(reg,val) (reg) = (((reg & ~SYS1_RREQ_WDT0) | (((val) & 1) << 8))
|
||||
/* CPU5 Reset Request (5) */
|
||||
#define SYS1_RREQ_CPU5 (0x1 << 5)
|
||||
#define SYS1_RREQ_CPU5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS1_RREQ_CPU5_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU5) | (((val) & 1) << 5))
|
||||
/* CPU4 Reset Request (4) */
|
||||
#define SYS1_RREQ_CPU4 (0x1 << 4)
|
||||
#define SYS1_RREQ_CPU4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS1_RREQ_CPU4_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU4) | (((val) & 1) << 4))
|
||||
/* CPU3 Reset Request (3) */
|
||||
#define SYS1_RREQ_CPU3 (0x1 << 3)
|
||||
#define SYS1_RREQ_CPU3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS1_RREQ_CPU3_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU3) | (((val) & 1) << 3))
|
||||
/* CPU2 Reset Request (2) */
|
||||
#define SYS1_RREQ_CPU2 (0x1 << 2)
|
||||
#define SYS1_RREQ_CPU2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS1_RREQ_CPU2_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU2) | (((val) & 1) << 2))
|
||||
/* CPU1 Reset Request (1) */
|
||||
#define SYS1_RREQ_CPU1 (0x1 << 1)
|
||||
#define SYS1_RREQ_CPU1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS1_RREQ_CPU1_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU1) | (((val) & 1) << 1))
|
||||
/* CPU0 Reset Request (0) */
|
||||
#define SYS1_RREQ_CPU0 (0x1)
|
||||
#define SYS1_RREQ_CPU0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS1_RREQ_CPU0_SET(reg,val) (reg) = ((reg & ~SYS1_RREQ_CPU0) | (((val) & 1) << 0))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS1 Reset Release Register
|
||||
******************************************************************************/
|
||||
|
||||
/* HRSTOUT Reset Release (18) */
|
||||
#define SYS1_RRLSR_HRSTOUT (0x1 << 18)
|
||||
#define SYS1_RRLSR_HRSTOUT_VAL(val) (((val) & 0x1) << 18)
|
||||
#define SYS1_RRLSR_HRSTOUT_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_HRSTOUT) | (((val) & 1) << 18))
|
||||
/* FBS0 Reset Release (17) */
|
||||
#define SYS1_RRLSR_FBS0 (0x1 << 17)
|
||||
#define SYS1_RRLSR_FBS0_VAL(val) (((val) & 0x1) << 17)
|
||||
#define SYS1_RRLSR_FBS0_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_FBS0) | (((val) & 1) << 17))
|
||||
/* SUBSYS Reset Release (16) */
|
||||
#define SYS1_RRLSR_SUBSYS (0x1 << 16)
|
||||
#define SYS1_RRLSR_SUBSYS_VAL(val) (((val) & 0x1) << 16)
|
||||
#define SYS1_RRLSR_SUBSYS_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_SUBSYS) | (((val) & 1) << 16))
|
||||
/* Watchdog5 Reset Release (13) */
|
||||
#define SYS1_RRLSR_WDT5 (0x1 << 13)
|
||||
#define SYS1_RRLSR_WDT5_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SYS1_RRLSR_WDT5_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT5) | (((val) & 1) << 13))
|
||||
/* Watchdog4 Reset Release (12) */
|
||||
#define SYS1_RRLSR_WDT4 (0x1 << 12)
|
||||
#define SYS1_RRLSR_WDT4_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SYS1_RRLSR_WDT4_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT4) | (((val) & 1) << 12))
|
||||
/* Watchdog3 Reset Release (11) */
|
||||
#define SYS1_RRLSR_WDT3 (0x1 << 11)
|
||||
#define SYS1_RRLSR_WDT3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS1_RRLSR_WDT3_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT3) | (((val) & 1) << 11))
|
||||
/* Watchdog2 Reset Release (10) */
|
||||
#define SYS1_RRLSR_WDT2 (0x1 << 10)
|
||||
#define SYS1_RRLSR_WDT2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS1_RRLSR_WDT2_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT2) | (((val) & 1) << 10))
|
||||
/* Watchdog1 Reset Release (9) */
|
||||
#define SYS1_RRLSR_WDT1 (0x1 << 9)
|
||||
#define SYS1_RRLSR_WDT1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS1_RRLSR_WDT1_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT1) | (((val) & 1) << 9))
|
||||
/* Watchdog0 Reset Release (8) */
|
||||
#define SYS1_RRLSR_WDT0 (0x1 << 8)
|
||||
#define SYS1_RRLSR_WDT0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS1_RRLSR_WDT0_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_WDT0) | (((val) & 1) << 8))
|
||||
/* CPU5 Reset Release (5) */
|
||||
#define SYS1_RRLSR_CPU5 (0x1 << 5)
|
||||
#define SYS1_RRLSR_CPU5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS1_RRLSR_CPU5_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU5) | (((val) & 1) << 5))
|
||||
/* CPU4 Reset Release (4) */
|
||||
#define SYS1_RRLSR_CPU4 (0x1 << 4)
|
||||
#define SYS1_RRLSR_CPU4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS1_RRLSR_CPU4_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU4) | (((val) & 1) << 4))
|
||||
/* CPU3 Reset Release (3) */
|
||||
#define SYS1_RRLSR_CPU3 (0x1 << 3)
|
||||
#define SYS1_RRLSR_CPU3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS1_RRLSR_CPU3_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU3) | (((val) & 1) << 3))
|
||||
/* CPU2 Reset Release (2) */
|
||||
#define SYS1_RRLSR_CPU2 (0x1 << 2)
|
||||
#define SYS1_RRLSR_CPU2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS1_RRLSR_CPU2_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU2) | (((val) & 1) << 2))
|
||||
/* CPU1 Reset Release (1) */
|
||||
#define SYS1_RRLSR_CPU1 (0x1 << 1)
|
||||
#define SYS1_RRLSR_CPU1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS1_RRLSR_CPU1_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU1) | (((val) & 1) << 1))
|
||||
/* CPU0 Reset Release (0) */
|
||||
#define SYS1_RRLSR_CPU0 (0x1)
|
||||
#define SYS1_RRLSR_CPU0_VAL(val) (((val) & 0x1) << 0)
|
||||
#define SYS1_RRLSR_CPU0_SET(reg,val) (reg) = ((reg & ~SYS1_RRLSR_CPU0) | (((val) & 1) << 0))
|
||||
|
||||
#endif
|
|
@ -1,494 +0,0 @@
|
|||
/******************************************************************************
|
||||
|
||||
Copyright (c) 2007
|
||||
Infineon Technologies AG
|
||||
St. Martin Strasse 53; 81669 Munich, Germany
|
||||
|
||||
Any use of this Software is subject to the conclusion of a respective
|
||||
License Agreement. Without such a License Agreement no rights to the
|
||||
Software are granted.
|
||||
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __SYS2_REG_H
|
||||
#define __SYS2_REG_H
|
||||
|
||||
#define sys2_r32(reg) ltq_r32(&sys2->reg)
|
||||
#define sys2_w32(val, reg) ltq_w32(val, &sys2->reg)
|
||||
#define sys2_w32_mask(clear, set, reg) ltq_w32_mask(clear, set, &sys2->reg)
|
||||
|
||||
/** SYS2 register structure */
|
||||
struct svip_reg_sys2 {
|
||||
volatile unsigned long clksr; /* 0x0000 */
|
||||
volatile unsigned long clkenr; /* 0x0004 */
|
||||
volatile unsigned long clkclr; /* 0x0008 */
|
||||
volatile unsigned long reserved0[1];
|
||||
volatile unsigned long rsr; /* 0x0010 */
|
||||
volatile unsigned long rreqr; /* 0x0014 */
|
||||
volatile unsigned long rrlsr; /* 0x0018 */
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS2 Clock Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Clock Enable for PORT4 */
|
||||
#define SYS2_CLKSR_PORT4 (0x1 << 27)
|
||||
#define SYS2_CLKSR_PORT4_VAL(val) (((val) & 0x1) << 27)
|
||||
#define SYS2_CLKSR_PORT4_GET(val) (((val) & SYS2_CLKSR_PORT4) >> 27)
|
||||
/* Clock Enable for HWSYNC */
|
||||
#define SYS2_CLKSR_HWSYNC (0x1 << 26)
|
||||
#define SYS2_CLKSR_HWSYNC_VAL(val) (((val) &
|
||||
#define SYS2_CLKSR_HWSYNC_GET(val) (((val) & SYS2_CLKSR_HWSYNC) >> 26)
|
||||
/* Clock Enable for MBS */
|
||||
#define SYS2_CLKSR_MBS (0x1 << 25)
|
||||
#define SYS2_CLKSR_MBS_VAL(val) (((val) & 0x1) << 25)
|
||||
#define SYS2_CLKSR_MBS_GET(val) (((val) & SYS2_CLKSR_MBS) >> 25)
|
||||
/* Clock Enable for SWINT */
|
||||
#define SYS2_CLKSR_SWINT (0x1 << 24)
|
||||
#define SYS2_CLKSR_SWINT_VAL(val) (((val) & 0x1) << 24)
|
||||
#define SYS2_CLKSR_SWINT_GET(val) (((val) & SYS2_CLKSR_SWINT) >> 24)
|
||||
/* Clock Enable for HWACC3 */
|
||||
#define SYS2_CLKSR_HWACC3 (0x1 << 19)
|
||||
#define SYS2_CLKSR_HWACC3_VAL(val) (((val) &
|
||||
#define SYS2_CLKSR_HWACC3_GET(val) (((val) & SYS2_CLKSR_HWACC3) >> 19)
|
||||
/* Clock Enable for HWACC2 */
|
||||
#define SYS2_CLKSR_HWACC2 (0x1 << 18)
|
||||
#define SYS2_CLKSR_HWACC2_VAL(val) (((val) &
|
||||
#define SYS2_CLKSR_HWACC2_GET(val) (((val) & SYS2_CLKSR_HWACC2) >> 18)
|
||||
/* Clock Enable for HWACC1 */
|
||||
#define SYS2_CLKSR_HWACC1 (0x1 << 17)
|
||||
#define SYS2_CLKSR_HWACC1_VAL(val) (((val) &
|
||||
#define SYS2_CLKSR_HWACC1_GET(val) (((val) & SYS2_CLKSR_HWACC1) >> 17)
|
||||
/* Clock Enable for HWACC0 */
|
||||
#define SYS2_CLKSR_HWACC0 (0x1 << 16)
|
||||
#define SYS2_CLKSR_HWACC0_VAL(val) (((val) &
|
||||
#define SYS2_CLKSR_HWACC0_GET(val) (((val) & SYS2_CLKSR_HWACC0) >> 16)
|
||||
/* Clock Enable for SIF7 */
|
||||
#define SYS2_CLKSR_SIF7 (0x1 << 15)
|
||||
#define SYS2_CLKSR_SIF7_VAL(val) (((val) & 0x1) << 15)
|
||||
#define SYS2_CLKSR_SIF7_GET(val) (((val) & SYS2_CLKSR_SIF7) >> 15)
|
||||
/* Clock Enable for SIF6 */
|
||||
#define SYS2_CLKSR_SIF6 (0x1 << 14)
|
||||
#define SYS2_CLKSR_SIF6_VAL(val) (((val) & 0x1) << 14)
|
||||
#define SYS2_CLKSR_SIF6_GET(val) (((val) & SYS2_CLKSR_SIF6) >> 14)
|
||||
/* Clock Enable for SIF5 */
|
||||
#define SYS2_CLKSR_SIF5 (0x1 << 13)
|
||||
#define SYS2_CLKSR_SIF5_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SYS2_CLKSR_SIF5_GET(val) (((val) & SYS2_CLKSR_SIF5) >> 13)
|
||||
/* Clock Enable for SIF4 */
|
||||
#define SYS2_CLKSR_SIF4 (0x1 << 12)
|
||||
#define SYS2_CLKSR_SIF4_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SYS2_CLKSR_SIF4_GET(val) (((val) & SYS2_CLKSR_SIF4) >> 12)
|
||||
/* Clock Enable for SIF3 */
|
||||
#define SYS2_CLKSR_SIF3 (0x1 << 11)
|
||||
#define SYS2_CLKSR_SIF3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_CLKSR_SIF3_GET(val) (((val) & SYS2_CLKSR_SIF3) >> 11)
|
||||
/* Clock Enable for SIF2 */
|
||||
#define SYS2_CLKSR_SIF2 (0x1 << 10)
|
||||
#define SYS2_CLKSR_SIF2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_CLKSR_SIF2_GET(val) (((val) & SYS2_CLKSR_SIF2) >> 10)
|
||||
/* Clock Enable for SIF1 */
|
||||
#define SYS2_CLKSR_SIF1 (0x1 << 9)
|
||||
#define SYS2_CLKSR_SIF1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_CLKSR_SIF1_GET(val) (((val) & SYS2_CLKSR_SIF1) >> 9)
|
||||
/* Clock Enable for SIF0 */
|
||||
#define SYS2_CLKSR_SIF0 (0x1 << 8)
|
||||
#define SYS2_CLKSR_SIF0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_CLKSR_SIF0_GET(val) (((val) & SYS2_CLKSR_SIF0) >> 8)
|
||||
/* Clock Enable for DFEV7 */
|
||||
#define SYS2_CLKSR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_CLKSR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_CLKSR_DFEV7_GET(val) (((val) & SYS2_CLKSR_DFEV7) >> 7)
|
||||
/* Clock Enable for DFEV6 */
|
||||
#define SYS2_CLKSR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_CLKSR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_CLKSR_DFEV6_GET(val) (((val) & SYS2_CLKSR_DFEV6) >> 6)
|
||||
/* Clock Enable for DFEV5 */
|
||||
#define SYS2_CLKSR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_CLKSR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_CLKSR_DFEV5_GET(val) (((val) & SYS2_CLKSR_DFEV5) >> 5)
|
||||
/* Clock Enable for DFEV4 */
|
||||
#define SYS2_CLKSR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_CLKSR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_CLKSR_DFEV4_GET(val) (((val) & SYS2_CLKSR_DFEV4) >> 4)
|
||||
/* Clock Enable for DFEV3 */
|
||||
#define SYS2_CLKSR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_CLKSR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_CLKSR_DFEV3_GET(val) (((val) & SYS2_CLKSR_DFEV3) >> 3)
|
||||
/* Clock Enable for DFEV2 */
|
||||
#define SYS2_CLKSR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_CLKSR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_CLKSR_DFEV2_GET(val) (((val) & SYS2_CLKSR_DFEV2) >> 2)
|
||||
/* Clock Enable for DFEV1 */
|
||||
#define SYS2_CLKSR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_CLKSR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_CLKSR_DFEV1_GET(val) (((val) & SYS2_CLKSR_DFEV1) >> 1)
|
||||
/* Clock Enable for DFEV0 */
|
||||
#define SYS2_CLKSR_DFEV0 (0x1)
|
||||
#define SYS2_CLKSR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_CLKSR_DFEV0_GET(val) ((val) & SYS2_CLKSR_DFEV0)
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS2 Clock Enable Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Clock Enable Request for PORT4 */
|
||||
#define SYS2_CLKENR_PORT4 (0x1 << 27)
|
||||
#define SYS2_CLKENR_PORT4_VAL(val) (((val) & 0x1) << 27)
|
||||
#define SYS2_CLKENR_PORT4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_PORT4) | ((val & 0x1) << 27))
|
||||
/* Clock Enable Request for HWSYNC */
|
||||
#define SYS2_CLKENR_HWSYNC (0x1 << 26)
|
||||
#define SYS2_CLKENR_HWSYNC_VAL(val) (((val) & 0x1) << 26)
|
||||
#define SYS2_CLKENR_HWSYNC_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_HWSYNC) | ((val & 0x1) << 26))
|
||||
/* Clock Enable Request for MBS */
|
||||
#define SYS2_CLKENR_MBS (0x1 << 25)
|
||||
#define SYS2_CLKENR_MBS_VAL(val) (((val) & 0x1) << 25)
|
||||
#define SYS2_CLKENR_MBS_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_MBS) | ((val & 0x1) << 25))
|
||||
/* Clock Enable Request for SWINT */
|
||||
#define SYS2_CLKENR_SWINT (0x1 << 24)
|
||||
#define SYS2_CLKENR_SWINT_VAL(val) (((val) & 0x1) << 24)
|
||||
#define SYS2_CLKENR_SWINT_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SWINT) | ((val & 0x1) << 24))
|
||||
/* Clock Enable Request for HWACC3 */
|
||||
#define SYS2_CLKENR_HWACC3 (0x1 << 19)
|
||||
#define SYS2_CLKENR_HWACC3_VAL(val) (((val) & 0x1) << 19)
|
||||
#define SYS2_CLKENR_HWACC3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_HWACC3) | ((val & 0x1) << 19))
|
||||
/* Clock Enable Request for HWACC2 */
|
||||
#define SYS2_CLKENR_HWACC2 (0x1 << 18)
|
||||
#define SYS2_CLKENR_HWACC2_VAL(val) (((val) & 0x1) << 18)
|
||||
#define SYS2_CLKENR_HWACC2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_HWACC2) | ((val & 0x1) << 18))
|
||||
/* Clock Enable Request for HWACC1 */
|
||||
#define SYS2_CLKENR_HWACC1 (0x1 << 17)
|
||||
#define SYS2_CLKENR_HWACC1_VAL(val) (((val) & 0x1) << 17)
|
||||
#define SYS2_CLKENR_HWACC1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_HWACC1) | ((val & 0x1) << 17))
|
||||
/* Clock Enable Request for HWACC0 */
|
||||
#define SYS2_CLKENR_HWACC0 (0x1 << 16)
|
||||
#define SYS2_CLKENR_HWACC0_VAL(val) (((val) & 0x1) << 16)
|
||||
#define SYS2_CLKENR_HWACC0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_HWACC0) | ((val & 0x1) << 16))
|
||||
/* Clock Enable Request for SIF7 */
|
||||
#define SYS2_CLKENR_SIF7 (0x1 << 15)
|
||||
#define SYS2_CLKENR_SIF7_VAL(val) (((val) & 0x1) << 15)
|
||||
#define SYS2_CLKENR_SIF7_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF7) | ((val & 0x1) << 15))
|
||||
/* Clock Enable Request for SIF6 */
|
||||
#define SYS2_CLKENR_SIF6 (0x1 << 14)
|
||||
#define SYS2_CLKENR_SIF6_VAL(val) (((val) & 0x1) << 14)
|
||||
#define SYS2_CLKENR_SIF6_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF6) | ((val & 0x1) << 14))
|
||||
/* Clock Enable Request for SIF5 */
|
||||
#define SYS2_CLKENR_SIF5 (0x1 << 13)
|
||||
#define SYS2_CLKENR_SIF5_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SYS2_CLKENR_SIF5_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF5) | ((val & 0x1) << 13))
|
||||
/* Clock Enable Request for SIF4 */
|
||||
#define SYS2_CLKENR_SIF4 (0x1 << 12)
|
||||
#define SYS2_CLKENR_SIF4_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SYS2_CLKENR_SIF4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF4) | ((val & 0x1) << 12))
|
||||
/* Clock Enable Request for SIF3 */
|
||||
#define SYS2_CLKENR_SIF3 (0x1 << 11)
|
||||
#define SYS2_CLKENR_SIF3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_CLKENR_SIF3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF3) | ((val & 0x1) << 11))
|
||||
/* Clock Enable Request for SIF2 */
|
||||
#define SYS2_CLKENR_SIF2 (0x1 << 10)
|
||||
#define SYS2_CLKENR_SIF2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_CLKENR_SIF2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF2) | ((val & 0x1) << 10))
|
||||
/* Clock Enable Request for SIF1 */
|
||||
#define SYS2_CLKENR_SIF1 (0x1 << 9)
|
||||
#define SYS2_CLKENR_SIF1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_CLKENR_SIF1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF1) | ((val & 0x1) << 9))
|
||||
/* Clock Enable Request for SIF0 */
|
||||
#define SYS2_CLKENR_SIF0 (0x1 << 8)
|
||||
#define SYS2_CLKENR_SIF0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_CLKENR_SIF0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_SIF0) | ((val & 0x1) << 8))
|
||||
/* Clock Enable Request for DFEV7 */
|
||||
#define SYS2_CLKENR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_CLKENR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_CLKENR_DFEV7_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV7) | ((val & 0x1) << 7))
|
||||
/* Clock Enable Request for DFEV6 */
|
||||
#define SYS2_CLKENR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_CLKENR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_CLKENR_DFEV6_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV6) | ((val & 0x1) << 6))
|
||||
/* Clock Enable Request for DFEV5 */
|
||||
#define SYS2_CLKENR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_CLKENR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_CLKENR_DFEV5_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV5) | ((val & 0x1) << 5))
|
||||
/* Clock Enable Request for DFEV4 */
|
||||
#define SYS2_CLKENR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_CLKENR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_CLKENR_DFEV4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV4) | ((val & 0x1) << 4))
|
||||
/* Clock Enable Request for DFEV3 */
|
||||
#define SYS2_CLKENR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_CLKENR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_CLKENR_DFEV3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV3) | ((val & 0x1) << 3))
|
||||
/* Clock Enable Request for DFEV2 */
|
||||
#define SYS2_CLKENR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_CLKENR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_CLKENR_DFEV2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV2) | ((val & 0x1) << 2))
|
||||
/* Clock Enable Request for DFEV1 */
|
||||
#define SYS2_CLKENR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_CLKENR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_CLKENR_DFEV1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV1) | ((val & 0x1) << 1))
|
||||
/* Clock Enable Request for DFEV0 */
|
||||
#define SYS2_CLKENR_DFEV0 (0x1)
|
||||
#define SYS2_CLKENR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_CLKENR_DFEV0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKENR_DFEV0) | ((val & 0x1)))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS2 Clock Clear Register
|
||||
******************************************************************************/
|
||||
|
||||
/* Clock Disable Request for PORT4 */
|
||||
#define SYS2_CLKCLR_PORT4 (0x1 << 27)
|
||||
#define SYS2_CLKCLR_PORT4_VAL(val) (((val) & 0x1) << 27)
|
||||
#define SYS2_CLKCLR_PORT4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_PORT4) | ((val & 0x1) << 27))
|
||||
/* Clock Disable Request for HWSYNC */
|
||||
#define SYS2_CLKCLR_HWSYNC (0x1 << 26)
|
||||
#define SYS2_CLKCLR_HWSYNC_VAL(val) (((val) & 0x1) << 26)
|
||||
#define SYS2_CLKCLR_HWSYNC_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_HWSYNC) | ((val & 0x1) << 26))
|
||||
/* Clock Disable Request for MBS */
|
||||
#define SYS2_CLKCLR_MBS (0x1 << 25)
|
||||
#define SYS2_CLKCLR_MBS_VAL(val) (((val) & 0x1) << 25)
|
||||
#define SYS2_CLKCLR_MBS_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_MBS) | ((val & 0x1) << 25))
|
||||
/* Clock Disable Request for SWINT */
|
||||
#define SYS2_CLKCLR_SWINT (0x1 << 24)
|
||||
#define SYS2_CLKCLR_SWINT_VAL(val) (((val) & 0x1) << 24)
|
||||
#define SYS2_CLKCLR_SWINT_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SWINT) | ((val & 0x1) << 24))
|
||||
/* Clock Disable Request for HWACC3 */
|
||||
#define SYS2_CLKCLR_HWACC3 (0x1 << 19)
|
||||
#define SYS2_CLKCLR_HWACC3_VAL(val) (((val) & 0x1) << 19)
|
||||
#define SYS2_CLKCLR_HWACC3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_HWACC3) | ((val & 0x1) << 19))
|
||||
/* Clock Disable Request for HWACC2 */
|
||||
#define SYS2_CLKCLR_HWACC2 (0x1 << 18)
|
||||
#define SYS2_CLKCLR_HWACC2_VAL(val) (((val) & 0x1) << 18)
|
||||
#define SYS2_CLKCLR_HWACC2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_HWACC2) | ((val & 0x1) << 18))
|
||||
/* Clock Disable Request for HWACC1 */
|
||||
#define SYS2_CLKCLR_HWACC1 (0x1 << 17)
|
||||
#define SYS2_CLKCLR_HWACC1_VAL(val) (((val) & 0x1) << 17)
|
||||
#define SYS2_CLKCLR_HWACC1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_HWACC1) | ((val & 0x1) << 17))
|
||||
/* Clock Disable Request for HWACC0 */
|
||||
#define SYS2_CLKCLR_HWACC0 (0x1 << 16)
|
||||
#define SYS2_CLKCLR_HWACC0_VAL(val) (((val) & 0x1) << 16)
|
||||
#define SYS2_CLKCLR_HWACC0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_HWACC0) | ((val & 0x1) << 16))
|
||||
/* Clock Disable Request for SIF7 */
|
||||
#define SYS2_CLKCLR_SIF7 (0x1 << 15)
|
||||
#define SYS2_CLKCLR_SIF7_VAL(val) (((val) & 0x1) << 15)
|
||||
#define SYS2_CLKCLR_SIF7_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF7) | ((val & 0x1) << 15))
|
||||
/* Clock Disable Request for SIF6 */
|
||||
#define SYS2_CLKCLR_SIF6 (0x1 << 14)
|
||||
#define SYS2_CLKCLR_SIF6_VAL(val) (((val) & 0x1) << 14)
|
||||
#define SYS2_CLKCLR_SIF6_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF6) | ((val & 0x1) << 14))
|
||||
/* Clock Disable Request for SIF5 */
|
||||
#define SYS2_CLKCLR_SIF5 (0x1 << 13)
|
||||
#define SYS2_CLKCLR_SIF5_VAL(val) (((val) & 0x1) << 13)
|
||||
#define SYS2_CLKCLR_SIF5_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF5) | ((val & 0x1) << 13))
|
||||
/* Clock Disable Request for SIF4 */
|
||||
#define SYS2_CLKCLR_SIF4 (0x1 << 12)
|
||||
#define SYS2_CLKCLR_SIF4_VAL(val) (((val) & 0x1) << 12)
|
||||
#define SYS2_CLKCLR_SIF4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF4) | ((val & 0x1) << 12))
|
||||
/* Clock Disable Request for SIF3 */
|
||||
#define SYS2_CLKCLR_SIF3 (0x1 << 11)
|
||||
#define SYS2_CLKCLR_SIF3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_CLKCLR_SIF3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF3) | ((val & 0x1) << 11))
|
||||
/* Clock Disable Request for SIF2 */
|
||||
#define SYS2_CLKCLR_SIF2 (0x1 << 10)
|
||||
#define SYS2_CLKCLR_SIF2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_CLKCLR_SIF2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF2) | ((val & 0x1) << 10))
|
||||
/* Clock Disable Request for SIF1 */
|
||||
#define SYS2_CLKCLR_SIF1 (0x1 << 9)
|
||||
#define SYS2_CLKCLR_SIF1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_CLKCLR_SIF1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF1) | ((val & 0x1) << 9))
|
||||
/* Clock Disable Request for SIF0 */
|
||||
#define SYS2_CLKCLR_SIF0 (0x1 << 8)
|
||||
#define SYS2_CLKCLR_SIF0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_CLKCLR_SIF0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_SIF0) | ((val & 0x1) << 8))
|
||||
/* Clock Disable Request for DFEV7 */
|
||||
#define SYS2_CLKCLR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_CLKCLR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_CLKCLR_DFEV7_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV7) | ((val & 0x1) << 7))
|
||||
/* Clock Disable Request for DFEV6 */
|
||||
#define SYS2_CLKCLR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_CLKCLR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_CLKCLR_DFEV6_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV6) | ((val & 0x1) << 6))
|
||||
/* Clock Disable Request for DFEV5 */
|
||||
#define SYS2_CLKCLR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_CLKCLR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_CLKCLR_DFEV5_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV5) | ((val & 0x1) << 5))
|
||||
/* Clock Disable Request for DFEV4 */
|
||||
#define SYS2_CLKCLR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_CLKCLR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_CLKCLR_DFEV4_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV4) | ((val & 0x1) << 4))
|
||||
/* Clock Disable Request for DFEV3 */
|
||||
#define SYS2_CLKCLR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_CLKCLR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_CLKCLR_DFEV3_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV3) | ((val & 0x1) << 3))
|
||||
/* Clock Disable Request for DFEV2 */
|
||||
#define SYS2_CLKCLR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_CLKCLR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_CLKCLR_DFEV2_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV2) | ((val & 0x1) << 2))
|
||||
/* Clock Disable Request for DFEV1 */
|
||||
#define SYS2_CLKCLR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_CLKCLR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_CLKCLR_DFEV1_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV1) | ((val & 0x1) << 1))
|
||||
/* Clock Disable Request for DFEV0 */
|
||||
#define SYS2_CLKCLR_DFEV0 (0x1)
|
||||
#define SYS2_CLKCLR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_CLKCLR_DFEV0_SET (reg,val) (reg) = ((reg & ~SYS2_CLKCLR_DFEV0) | ((val & 0x1)))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS2 Reset Status Register
|
||||
******************************************************************************/
|
||||
|
||||
/* HWACC3 Reset */
|
||||
#define SYS2_RSR_HWACC3 (0x1 << 11)
|
||||
#define SYS2_RSR_HWACC3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_RSR_HWACC3_GET(val) (((val) & SYS2_RSR_HWACC3) >> 11)
|
||||
/* HWACC2 Reset */
|
||||
#define SYS2_RSR_HWACC2 (0x1 << 10)
|
||||
#define SYS2_RSR_HWACC2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_RSR_HWACC2_GET(val) (((val) & SYS2_RSR_HWACC2) >> 10)
|
||||
/* HWACC1 Reset */
|
||||
#define SYS2_RSR_HWACC1 (0x1 << 9)
|
||||
#define SYS2_RSR_HWACC1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_RSR_HWACC1_GET(val) (((val) & SYS2_RSR_HWACC1) >> 9)
|
||||
/* HWACC0 Reset */
|
||||
#define SYS2_RSR_HWACC0 (0x1 << 8)
|
||||
#define SYS2_RSR_HWACC0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_RSR_HWACC0_GET(val) (((val) & SYS2_RSR_HWACC0) >> 8)
|
||||
/* DFEV7 Reset */
|
||||
#define SYS2_RSR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_RSR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_RSR_DFEV7_GET(val) (((val) & SYS2_RSR_DFEV7) >> 7)
|
||||
/* DFEV6 Reset */
|
||||
#define SYS2_RSR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_RSR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_RSR_DFEV6_GET(val) (((val) & SYS2_RSR_DFEV6) >> 6)
|
||||
/* DFEV5 Reset */
|
||||
#define SYS2_RSR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_RSR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_RSR_DFEV5_GET(val) (((val) & SYS2_RSR_DFEV5) >> 5)
|
||||
/* DFEV4 Reset */
|
||||
#define SYS2_RSR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_RSR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_RSR_DFEV4_GET(val) (((val) & SYS2_RSR_DFEV4) >> 4)
|
||||
/* DFEV3 Reset */
|
||||
#define SYS2_RSR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_RSR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_RSR_DFEV3_GET(val) (((val) & SYS2_RSR_DFEV3) >> 3)
|
||||
/* DFEV2 Reset */
|
||||
#define SYS2_RSR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_RSR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_RSR_DFEV2_GET(val) (((val) & SYS2_RSR_DFEV2) >> 2)
|
||||
/* DFEV1 Reset */
|
||||
#define SYS2_RSR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_RSR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_RSR_DFEV1_GET(val) (((val) & SYS2_RSR_DFEV1) >> 1)
|
||||
/* DFEV0 Reset */
|
||||
#define SYS2_RSR_DFEV0 (0x1)
|
||||
#define SYS2_RSR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_RSR_DFEV0_GET(val) ((val) & SYS2_RSR_DFEV0)
|
||||
|
||||
/******************************************************************************
|
||||
* SYS2 Reset Request Register
|
||||
******************************************************************************/
|
||||
|
||||
/* HWACC3 Reset Request */
|
||||
#define SYS2_RREQR_HWACC3 (0x1 << 11)
|
||||
#define SYS2_RREQR_HWACC3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_RREQR_HWACC3_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_HWACC3) | ((val & 0x1) << 11))
|
||||
/* HWACC2 Reset Request */
|
||||
#define SYS2_RREQR_HWACC2 (0x1 << 10)
|
||||
#define SYS2_RREQR_HWACC2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_RREQR_HWACC2_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_HWACC2) | ((val & 0x1) << 10))
|
||||
/* HWACC1 Reset Request */
|
||||
#define SYS2_RREQR_HWACC1 (0x1 << 9)
|
||||
#define SYS2_RREQR_HWACC1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_RREQR_HWACC1_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_HWACC1) | ((val & 0x1) << 9))
|
||||
/* HWACC0 Reset Request */
|
||||
#define SYS2_RREQR_HWACC0 (0x1 << 8)
|
||||
#define SYS2_RREQR_HWACC0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_RREQR_HWACC0_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_HWACC0) | ((val & 0x1) << 8))
|
||||
/* DFEV7 Reset Request */
|
||||
#define SYS2_RREQR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_RREQR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_RREQR_DFEV7_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV7) | ((val & 0x1) << 7))
|
||||
/* DFEV6 Reset Request */
|
||||
#define SYS2_RREQR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_RREQR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_RREQR_DFEV6_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV6) | ((val & 0x1) << 6))
|
||||
/* DFEV5 Reset Request */
|
||||
#define SYS2_RREQR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_RREQR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_RREQR_DFEV5_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV5) | ((val & 0x1) << 5))
|
||||
/* DFEV4 Reset Request */
|
||||
#define SYS2_RREQR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_RREQR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_RREQR_DFEV4_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV4) | ((val & 0x1) << 4))
|
||||
/* DFEV3 Reset Request */
|
||||
#define SYS2_RREQR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_RREQR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_RREQR_DFEV3_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV3) | ((val & 0x1) << 3))
|
||||
/* DFEV2 Reset Request */
|
||||
#define SYS2_RREQR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_RREQR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_RREQR_DFEV2_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV2) | ((val & 0x1) << 2))
|
||||
/* DFEV1 Reset Request */
|
||||
#define SYS2_RREQR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_RREQR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_RREQR_DFEV1_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV1) | ((val & 0x1) << 1))
|
||||
/* DFEV0 Reset Request */
|
||||
#define SYS2_RREQR_DFEV0 (0x1)
|
||||
#define SYS2_RREQR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_RREQR_DFEV0_SET (reg,val) (reg) = ((reg & ~SYS2_RREQR_DFEV0) | ((val & 0x1)))
|
||||
|
||||
/*******************************************************************************
|
||||
* SYS2 Reset Release Register
|
||||
******************************************************************************/
|
||||
|
||||
/* HWACC3 Reset Release */
|
||||
#define SYS2_RRLSR_HWACC3 (0x1 << 11)
|
||||
#define SYS2_RRLSR_HWACC3_VAL(val) (((val) & 0x1) << 11)
|
||||
#define SYS2_RRLSR_HWACC3_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_HWACC3) | ((val & 0x1) << 11))
|
||||
/* HWACC2 Reset Release */
|
||||
#define SYS2_RRLSR_HWACC2 (0x1 << 10)
|
||||
#define SYS2_RRLSR_HWACC2_VAL(val) (((val) & 0x1) << 10)
|
||||
#define SYS2_RRLSR_HWACC2_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_HWACC2) | ((val & 0x1) << 10))
|
||||
/* HWACC1 Reset Release */
|
||||
#define SYS2_RRLSR_HWACC1 (0x1 << 9)
|
||||
#define SYS2_RRLSR_HWACC1_VAL(val) (((val) & 0x1) << 9)
|
||||
#define SYS2_RRLSR_HWACC1_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_HWACC1) | ((val & 0x1) << 9))
|
||||
/* HWACC0 Reset Release */
|
||||
#define SYS2_RRLSR_HWACC0 (0x1 << 8)
|
||||
#define SYS2_RRLSR_HWACC0_VAL(val) (((val) & 0x1) << 8)
|
||||
#define SYS2_RRLSR_HWACC0_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_HWACC0) | ((val & 0x1) << 8))
|
||||
/* DFEV7 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV7 (0x1 << 7)
|
||||
#define SYS2_RRLSR_DFEV7_VAL(val) (((val) & 0x1) << 7)
|
||||
#define SYS2_RRLSR_DFEV7_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV7) | ((val & 0x1) << 7))
|
||||
/* DFEV6 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV6 (0x1 << 6)
|
||||
#define SYS2_RRLSR_DFEV6_VAL(val) (((val) & 0x1) << 6)
|
||||
#define SYS2_RRLSR_DFEV6_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV6) | ((val & 0x1) << 6))
|
||||
/* DFEV5 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV5 (0x1 << 5)
|
||||
#define SYS2_RRLSR_DFEV5_VAL(val) (((val) & 0x1) << 5)
|
||||
#define SYS2_RRLSR_DFEV5_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV5) | ((val & 0x1) << 5))
|
||||
/* DFEV4 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV4 (0x1 << 4)
|
||||
#define SYS2_RRLSR_DFEV4_VAL(val) (((val) & 0x1) << 4)
|
||||
#define SYS2_RRLSR_DFEV4_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV4) | ((val & 0x1) << 4))
|
||||
/* DFEV3 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV3 (0x1 << 3)
|
||||
#define SYS2_RRLSR_DFEV3_VAL(val) (((val) & 0x1) << 3)
|
||||
#define SYS2_RRLSR_DFEV3_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV3) | ((val & 0x1) << 3))
|
||||
/* DFEV2 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV2 (0x1 << 2)
|
||||
#define SYS2_RRLSR_DFEV2_VAL(val) (((val) & 0x1) << 2)
|
||||
#define SYS2_RRLSR_DFEV2_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV2) | ((val & 0x1) << 2))
|
||||
/* DFEV1 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV1 (0x1 << 1)
|
||||
#define SYS2_RRLSR_DFEV1_VAL(val) (((val) & 0x1) << 1)
|
||||
#define SYS2_RRLSR_DFEV1_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV1) | ((val & 0x1) << 1))
|
||||
/* DFEV0 Reset Release */
|
||||
#define SYS2_RRLSR_DFEV0 (0x1)
|
||||
#define SYS2_RRLSR_DFEV0_VAL(val) (((val) & 0x1))
|
||||
#define SYS2_RRLSR_DFEV0_SET (reg,val) (reg) = ((reg & ~SYS2_RRLSR_DFEV0) | ((val & 0x1)))
|
||||
|
||||
#endif /* __SYS2_H */
|
||||
|
|
@ -1,58 +0,0 @@
|
|||
/*
|
||||
* Lantiq GPIO button support
|
||||
*
|
||||
* Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
|
||||
* Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
void __init ltq_register_gpio_keys_polled(int id,
|
||||
unsigned poll_interval,
|
||||
unsigned nbuttons,
|
||||
struct gpio_keys_button *buttons)
|
||||
{
|
||||
struct platform_device *pdev;
|
||||
struct gpio_keys_platform_data pdata;
|
||||
struct gpio_keys_button *p;
|
||||
int err;
|
||||
|
||||
p = kmalloc(nbuttons * sizeof(*p), GFP_KERNEL);
|
||||
if (!p)
|
||||
return;
|
||||
|
||||
memcpy(p, buttons, nbuttons * sizeof(*p));
|
||||
|
||||
pdev = platform_device_alloc("gpio-keys-polled", id);
|
||||
if (!pdev)
|
||||
goto err_free_buttons;
|
||||
|
||||
memset(&pdata, 0, sizeof(pdata));
|
||||
pdata.poll_interval = poll_interval;
|
||||
pdata.nbuttons = nbuttons;
|
||||
pdata.buttons = p;
|
||||
|
||||
err = platform_device_add_data(pdev, &pdata, sizeof(pdata));
|
||||
if (err)
|
||||
goto err_put_pdev;
|
||||
|
||||
err = platform_device_add(pdev);
|
||||
if (err)
|
||||
goto err_put_pdev;
|
||||
|
||||
return;
|
||||
|
||||
err_put_pdev:
|
||||
platform_device_put(pdev);
|
||||
|
||||
err_free_buttons:
|
||||
kfree(p);
|
||||
}
|
|
@ -1,57 +0,0 @@
|
|||
/*
|
||||
* Lantiq GPIO LED device support
|
||||
*
|
||||
* Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
|
||||
* Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
|
||||
*
|
||||
* Parts of this file are based on Atheros' 2.6.15 BSP
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include <dev-gpio-leds.h>
|
||||
|
||||
void __init ltq_add_device_gpio_leds(int id, unsigned num_leds,
|
||||
struct gpio_led *leds)
|
||||
{
|
||||
struct platform_device *pdev;
|
||||
struct gpio_led_platform_data pdata;
|
||||
struct gpio_led *p;
|
||||
int err;
|
||||
|
||||
p = kmalloc(num_leds * sizeof(*p), GFP_KERNEL);
|
||||
if (!p)
|
||||
return;
|
||||
|
||||
memcpy(p, leds, num_leds * sizeof(*p));
|
||||
|
||||
pdev = platform_device_alloc("leds-gpio", id);
|
||||
if (!pdev)
|
||||
goto err_free_leds;
|
||||
|
||||
memset(&pdata, 0, sizeof(pdata));
|
||||
pdata.num_leds = num_leds;
|
||||
pdata.leds = p;
|
||||
|
||||
err = platform_device_add_data(pdev, &pdata, sizeof(pdata));
|
||||
if (err)
|
||||
goto err_put_pdev;
|
||||
|
||||
err = platform_device_add(pdev);
|
||||
if (err)
|
||||
goto err_put_pdev;
|
||||
|
||||
return;
|
||||
|
||||
err_put_pdev:
|
||||
platform_device_put(pdev);
|
||||
|
||||
err_free_leds:
|
||||
kfree(p);
|
||||
}
|
|
@ -1,11 +0,0 @@
|
|||
if SOC_FALCON
|
||||
|
||||
menu "MIPS Machine"
|
||||
|
||||
config LANTIQ_MACH_EASY98000
|
||||
bool "Easy98000"
|
||||
default y
|
||||
|
||||
endmenu
|
||||
|
||||
endif
|
|
@ -1,2 +0,0 @@
|
|||
obj-y := prom.o reset.o sysctrl.o devices.o gpio.o
|
||||
obj-$(CONFIG_LANTIQ_MACH_EASY98000) += mach-easy98000.o
|
|
@ -1,213 +0,0 @@
|
|||
/*
|
||||
* EASY98000 CPLD Addon driver
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
*/
|
||||
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/version.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/errno.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/proc_fs.h>
|
||||
#include <linux/seq_file.h>
|
||||
|
||||
struct easy98000_reg_cpld {
|
||||
u16 cmdreg1; /* 0x1 */
|
||||
u16 cmdreg0; /* 0x0 */
|
||||
u16 idreg0; /* 0x3 */
|
||||
u16 resreg; /* 0x2 */
|
||||
u16 intreg; /* 0x5 */
|
||||
u16 idreg1; /* 0x4 */
|
||||
u16 ledreg; /* 0x7 */
|
||||
u16 pcmconconfig; /* 0x6 */
|
||||
u16 res0; /* 0x9 */
|
||||
u16 ethledreg; /* 0x8 */
|
||||
u16 res1[4]; /* 0xa-0xd */
|
||||
u16 cpld1v; /* 0xf */
|
||||
u16 cpld2v; /* 0xe */
|
||||
};
|
||||
static struct easy98000_reg_cpld * const cpld =
|
||||
(struct easy98000_reg_cpld *)(KSEG1 | 0x17c00000);
|
||||
#define cpld_r8(reg) (__raw_readw(&cpld->reg) & 0xFF)
|
||||
#define cpld_w8(val, reg) __raw_writew((val) & 0xFF, &cpld->reg)
|
||||
|
||||
int easy98000_addon_has_dm9000(void)
|
||||
{
|
||||
if ((cpld_r8(idreg0) & 0xF) == 1)
|
||||
return 1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_PROC_FS)
|
||||
typedef void (*cpld_dump) (struct seq_file *s);
|
||||
struct proc_entry {
|
||||
char *name;
|
||||
void *callback;
|
||||
};
|
||||
|
||||
static int cpld_proc_show ( struct seq_file *s, void *p )
|
||||
{
|
||||
cpld_dump dump = s->private;
|
||||
|
||||
if ( dump != NULL )
|
||||
dump(s);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cpld_proc_open ( struct inode *inode, struct file *file )
|
||||
{
|
||||
return single_open ( file, cpld_proc_show, PDE(inode)->data );
|
||||
}
|
||||
|
||||
static void cpld_versions_get ( struct seq_file *s )
|
||||
{
|
||||
seq_printf(s, "CPLD1: V%d\n", cpld_r8(cpld1v));
|
||||
seq_printf(s, "CPLD2: V%d\n", cpld_r8(cpld2v));
|
||||
}
|
||||
|
||||
static void cpld_ebu_module_get ( struct seq_file *s )
|
||||
{
|
||||
u8 addon_id;
|
||||
|
||||
addon_id = cpld_r8(idreg0) & 0xF;
|
||||
switch (addon_id) {
|
||||
case 0xF: /* nothing connected */
|
||||
break;
|
||||
case 1:
|
||||
seq_printf(s, "Ethernet Controller module (dm9000)\n");
|
||||
break;
|
||||
default:
|
||||
seq_printf(s, "Unknown EBU module (EBU_ID=0x%02X)\n", addon_id);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void cpld_xmii_module_get ( struct seq_file *s )
|
||||
{
|
||||
u8 addon_id;
|
||||
char *mod = NULL;
|
||||
|
||||
addon_id = cpld_r8(idreg1) & 0xF;
|
||||
switch (addon_id) {
|
||||
case 0xF:
|
||||
mod = "no module";
|
||||
break;
|
||||
case 0x1:
|
||||
mod = "RGMII module";
|
||||
break;
|
||||
case 0x4:
|
||||
mod = "GMII MAC Mode (XWAY TANTOS-3G)";
|
||||
break;
|
||||
case 0x6:
|
||||
mod = "TMII MAC Mode (XWAY TANTOS-3G)";
|
||||
break;
|
||||
case 0x8:
|
||||
mod = "GMII PHY module";
|
||||
break;
|
||||
case 0x9:
|
||||
mod = "MII PHY module";
|
||||
break;
|
||||
case 0xA:
|
||||
mod = "RMII PHY module";
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
if (mod)
|
||||
seq_printf(s, "%s\n", mod);
|
||||
else
|
||||
seq_printf(s, "unknown xMII module (xMII_ID=0x%02X)\n", addon_id);
|
||||
}
|
||||
|
||||
static struct proc_entry proc_entries[] = {
|
||||
{"versions", cpld_versions_get},
|
||||
{"ebu", cpld_ebu_module_get},
|
||||
{"xmii", cpld_xmii_module_get},
|
||||
};
|
||||
|
||||
static struct file_operations ops = {
|
||||
.owner = THIS_MODULE,
|
||||
.open = cpld_proc_open,
|
||||
.read = seq_read,
|
||||
.llseek = seq_lseek,
|
||||
.release = single_release,
|
||||
};
|
||||
|
||||
static void cpld_proc_entry_create(struct proc_dir_entry *parent_node,
|
||||
struct proc_entry *proc_entry)
|
||||
{
|
||||
proc_create_data ( proc_entry->name, (S_IFREG | S_IRUGO), parent_node,
|
||||
&ops, proc_entry->callback);
|
||||
}
|
||||
|
||||
static int cpld_proc_install(void)
|
||||
{
|
||||
struct proc_dir_entry *driver_proc_node;
|
||||
|
||||
driver_proc_node = proc_mkdir("cpld", NULL);
|
||||
if (driver_proc_node != NULL) {
|
||||
int i;
|
||||
for (i = 0; i < ARRAY_SIZE(proc_entries); i++)
|
||||
cpld_proc_entry_create(driver_proc_node,
|
||||
&proc_entries[i]);
|
||||
} else {
|
||||
printk("cannot create proc entry");
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#else
|
||||
static inline int cpld_proc_install(void) {}
|
||||
#endif
|
||||
|
||||
static int easy98000_addon_probe(struct platform_device *pdev)
|
||||
{
|
||||
return cpld_proc_install();
|
||||
}
|
||||
|
||||
static int easy98000_addon_remove(struct platform_device *pdev)
|
||||
{
|
||||
#if defined(CONFIG_PROC_FS)
|
||||
char buf[64];
|
||||
int i;
|
||||
|
||||
for (i = 0; i < sizeof(proc_entries) / sizeof(proc_entries[0]); i++) {
|
||||
sprintf(buf, "cpld/%s", proc_entries[i].name);
|
||||
remove_proc_entry(buf, 0);
|
||||
}
|
||||
remove_proc_entry("cpld", 0);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver easy98000_addon_driver = {
|
||||
.probe = easy98000_addon_probe,
|
||||
.remove = __devexit_p(easy98000_addon_remove),
|
||||
.driver = {
|
||||
.name = "easy98000_addon",
|
||||
.owner = THIS_MODULE,
|
||||
},
|
||||
};
|
||||
|
||||
int __init easy98000_addon_init(void)
|
||||
{
|
||||
return platform_driver_register(&easy98000_addon_driver);
|
||||
}
|
||||
|
||||
void __exit easy98000_addon_exit(void)
|
||||
{
|
||||
platform_driver_unregister(&easy98000_addon_driver);
|
||||
}
|
||||
|
||||
module_init(easy98000_addon_init);
|
||||
module_exit(easy98000_addon_exit);
|
|
@ -1,161 +0,0 @@
|
|||
/*
|
||||
* EASY98000 CPLD LED driver
|
||||
*
|
||||
* Copyright (C) 2010 Ralph Hempel <ralph.hempel@lantiq.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
*/
|
||||
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/version.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/errno.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/slab.h>
|
||||
|
||||
#include "dev-leds-easy98000-cpld.h"
|
||||
|
||||
const char *led_name[8] = {
|
||||
"ge0_act",
|
||||
"ge0_link",
|
||||
"ge1_act",
|
||||
"ge1_link",
|
||||
"fe2_act",
|
||||
"fe2_link",
|
||||
"fe3_act",
|
||||
"fe3_link"
|
||||
};
|
||||
|
||||
#define cpld_base7 ((u16 *)(KSEG1 | 0x17c0000c))
|
||||
#define cpld_base8 ((u16 *)(KSEG1 | 0x17c00012))
|
||||
|
||||
#define ltq_r16(reg) __raw_readw(reg)
|
||||
#define ltq_w16(val, reg) __raw_writew(val, reg)
|
||||
|
||||
struct cpld_led_dev {
|
||||
struct led_classdev cdev;
|
||||
u8 mask;
|
||||
u16 *base;
|
||||
};
|
||||
|
||||
struct cpld_led_drvdata {
|
||||
struct cpld_led_dev *led_devs;
|
||||
int num_leds;
|
||||
};
|
||||
|
||||
void led_set(u8 mask, u16 *base)
|
||||
{
|
||||
ltq_w16(ltq_r16(base) | mask, base);
|
||||
}
|
||||
|
||||
void led_clear(u8 mask, u16 *base)
|
||||
{
|
||||
ltq_w16(ltq_r16(base) & (~mask), base);
|
||||
}
|
||||
|
||||
void led_blink_clear(u8 mask, u16 *base)
|
||||
{
|
||||
led_clear(mask, base);
|
||||
}
|
||||
|
||||
static void led_brightness(struct led_classdev *led_cdev,
|
||||
enum led_brightness value)
|
||||
{
|
||||
struct cpld_led_dev *led_dev =
|
||||
container_of(led_cdev, struct cpld_led_dev, cdev);
|
||||
|
||||
if (value)
|
||||
led_set(led_dev->mask, led_dev->base);
|
||||
else
|
||||
led_clear(led_dev->mask, led_dev->base);
|
||||
}
|
||||
|
||||
static int led_probe(struct platform_device *pdev)
|
||||
{
|
||||
int i;
|
||||
char name[32];
|
||||
struct cpld_led_drvdata *drvdata;
|
||||
int ret = 0;
|
||||
|
||||
drvdata = kzalloc(sizeof(struct cpld_led_drvdata) +
|
||||
sizeof(struct cpld_led_dev) * MAX_LED,
|
||||
GFP_KERNEL);
|
||||
if (!drvdata)
|
||||
return -ENOMEM;
|
||||
|
||||
drvdata->led_devs = (struct cpld_led_dev *) &drvdata[1];
|
||||
|
||||
for (i = 0; i < MAX_LED; i++) {
|
||||
struct cpld_led_dev *led_dev = &drvdata->led_devs[i];
|
||||
led_dev->cdev.brightness_set = led_brightness;
|
||||
led_dev->cdev.default_trigger = NULL;
|
||||
led_dev->mask = 1 << (i % 8);
|
||||
if(i < 8) {
|
||||
sprintf(name, "easy98000-cpld:%s", led_name[i]);
|
||||
led_dev->base = cpld_base8;
|
||||
} else {
|
||||
sprintf(name, "easy98000-cpld:red:%d", i-8);
|
||||
led_dev->base = cpld_base7;
|
||||
}
|
||||
led_dev->cdev.name = name;
|
||||
ret = led_classdev_register(&pdev->dev, &led_dev->cdev);
|
||||
if (ret)
|
||||
goto err;
|
||||
}
|
||||
platform_set_drvdata(pdev, drvdata);
|
||||
return 0;
|
||||
|
||||
err:
|
||||
printk("led_probe: 3\n");
|
||||
for (i = i - 1; i >= 0; i--)
|
||||
led_classdev_unregister(&drvdata->led_devs[i].cdev);
|
||||
|
||||
kfree(drvdata);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int led_remove(struct platform_device *pdev)
|
||||
{
|
||||
int i;
|
||||
struct cpld_led_drvdata *drvdata = platform_get_drvdata(pdev);
|
||||
for (i = 0; i < MAX_LED; i++)
|
||||
led_classdev_unregister(&drvdata->led_devs[i].cdev);
|
||||
kfree(drvdata);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver led_driver = {
|
||||
.probe = led_probe,
|
||||
.remove = __devexit_p(led_remove),
|
||||
.driver = {
|
||||
.name = LED_NAME,
|
||||
.owner = THIS_MODULE,
|
||||
},
|
||||
};
|
||||
|
||||
int __init easy98000_cpld_led_init(void)
|
||||
{
|
||||
pr_info(LED_DESC ", Version " LED_VERSION
|
||||
" (c) Copyright 2011, Lantiq Deutschland GmbH\n");
|
||||
return platform_driver_register(&led_driver);
|
||||
}
|
||||
|
||||
void __exit easy98000_cpld_led_exit(void)
|
||||
{
|
||||
platform_driver_unregister(&led_driver);
|
||||
}
|
||||
|
||||
module_init(easy98000_cpld_led_init);
|
||||
module_exit(easy98000_cpld_led_exit);
|
||||
|
||||
MODULE_DESCRIPTION(LED_NAME);
|
||||
MODULE_DESCRIPTION(LED_DESC);
|
||||
MODULE_AUTHOR("Ralph Hempel <ralph.hempel@lantiq.com>");
|
||||
MODULE_LICENSE("GPL v2");
|
||||
|
|
@ -1,20 +0,0 @@
|
|||
/*
|
||||
* EASY98000 CPLD LED driver
|
||||
*
|
||||
* Copyright (C) 2010 Ralph Hempel <ralph.hempel@lantiq.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
*/
|
||||
#ifndef _INCLUDE_EASY98000_CPLD_LED_H_
|
||||
#define _INCLUDE_EASY98000_CPLD_LED_H_
|
||||
|
||||
#define LED_NAME "easy98000_cpld_led"
|
||||
#define LED_DESC "EASY98000 LED driver"
|
||||
#define LED_VERSION "1.0.0"
|
||||
|
||||
#define MAX_LED 16
|
||||
|
||||
#endif /* _INCLUDE_EASY98000_CPLD_LED_H_ */
|
|
@ -1,152 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/nand.h>
|
||||
#include <linux/gpio.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
/* nand flash */
|
||||
/* address lines used for NAND control signals */
|
||||
#define NAND_ADDR_ALE 0x10000
|
||||
#define NAND_ADDR_CLE 0x20000
|
||||
/* Ready/Busy Status */
|
||||
#define MODCON_STS 0x0002
|
||||
/* Ready/Busy Status Edge */
|
||||
#define MODCON_STSEDGE 0x0004
|
||||
|
||||
static const char *part_probes[] = { "cmdlinepart", NULL };
|
||||
|
||||
static int
|
||||
falcon_nand_ready(struct mtd_info *mtd)
|
||||
{
|
||||
u32 modcon = ltq_ebu_r32(LTQ_EBU_MODCON);
|
||||
|
||||
return (((modcon & (MODCON_STS | MODCON_STSEDGE)) ==
|
||||
(MODCON_STS | MODCON_STSEDGE)));
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_hwcontrol(struct mtd_info *mtd, int cmd, unsigned int ctrl)
|
||||
{
|
||||
struct nand_chip *this = mtd->priv;
|
||||
unsigned long nandaddr = (unsigned long) this->IO_ADDR_W;
|
||||
|
||||
if (ctrl & NAND_CTRL_CHANGE) {
|
||||
nandaddr &= ~(NAND_ADDR_ALE | NAND_ADDR_CLE);
|
||||
|
||||
if (ctrl & NAND_CLE)
|
||||
nandaddr |= NAND_ADDR_CLE;
|
||||
if (ctrl & NAND_ALE)
|
||||
nandaddr |= NAND_ADDR_ALE;
|
||||
|
||||
this->IO_ADDR_W = (void __iomem *) nandaddr;
|
||||
}
|
||||
|
||||
if (cmd != NAND_CMD_NONE)
|
||||
writeb(cmd, this->IO_ADDR_W);
|
||||
}
|
||||
|
||||
static struct platform_nand_data falcon_flash_nand_data = {
|
||||
.chip = {
|
||||
.nr_chips = 1,
|
||||
.chip_delay = 25,
|
||||
.part_probe_types = part_probes,
|
||||
},
|
||||
.ctrl = {
|
||||
.cmd_ctrl = falcon_hwcontrol,
|
||||
.dev_ready = falcon_nand_ready,
|
||||
}
|
||||
};
|
||||
|
||||
static struct resource ltq_nand_res =
|
||||
MEM_RES("nand", LTQ_FLASH_START, LTQ_FLASH_MAX);
|
||||
|
||||
static struct platform_device ltq_flash_nand = {
|
||||
.name = "gen_nand",
|
||||
.id = -1,
|
||||
.num_resources = 1,
|
||||
.resource = <q_nand_res,
|
||||
.dev = {
|
||||
.platform_data = &falcon_flash_nand_data,
|
||||
},
|
||||
};
|
||||
|
||||
void __init
|
||||
falcon_register_nand(void)
|
||||
{
|
||||
platform_device_register(<q_flash_nand);
|
||||
}
|
||||
|
||||
/* gpio */
|
||||
#define DECLARE_GPIO_RES(port) \
|
||||
static struct resource falcon_gpio ## port ## _res[] = { \
|
||||
MEM_RES("gpio"#port, LTQ_GPIO ## port ## _BASE_ADDR, \
|
||||
LTQ_GPIO ## port ## _SIZE), \
|
||||
MEM_RES("padctrl"#port, LTQ_PADCTRL ## port ## _BASE_ADDR, \
|
||||
LTQ_PADCTRL ## port ## _SIZE), \
|
||||
IRQ_RES("gpio_mux"#port, FALCON_IRQ_GPIO_P ## port) \
|
||||
}
|
||||
DECLARE_GPIO_RES(0);
|
||||
DECLARE_GPIO_RES(1);
|
||||
DECLARE_GPIO_RES(2);
|
||||
DECLARE_GPIO_RES(3);
|
||||
DECLARE_GPIO_RES(4);
|
||||
|
||||
void __init
|
||||
falcon_register_gpio(void)
|
||||
{
|
||||
platform_device_register_simple("falcon_gpio", 0,
|
||||
falcon_gpio0_res, ARRAY_SIZE(falcon_gpio0_res));
|
||||
platform_device_register_simple("falcon_gpio", 1,
|
||||
falcon_gpio1_res, ARRAY_SIZE(falcon_gpio1_res));
|
||||
platform_device_register_simple("falcon_gpio", 2,
|
||||
falcon_gpio2_res, ARRAY_SIZE(falcon_gpio2_res));
|
||||
}
|
||||
|
||||
void __init
|
||||
falcon_register_gpio_extra(void)
|
||||
{
|
||||
platform_device_register_simple("falcon_gpio", 3,
|
||||
falcon_gpio3_res, ARRAY_SIZE(falcon_gpio3_res));
|
||||
platform_device_register_simple("falcon_gpio", 4,
|
||||
falcon_gpio4_res, ARRAY_SIZE(falcon_gpio4_res));
|
||||
}
|
||||
|
||||
/* spi flash */
|
||||
static struct platform_device ltq_spi = {
|
||||
.name = "falcon_spi",
|
||||
.num_resources = 0,
|
||||
};
|
||||
|
||||
void __init
|
||||
falcon_register_spi_flash(struct spi_board_info *data)
|
||||
{
|
||||
spi_register_board_info(data, 1);
|
||||
platform_device_register(<q_spi);
|
||||
}
|
||||
|
||||
/* i2c */
|
||||
static struct resource falcon_i2c_resources[] = {
|
||||
MEM_RES("i2c", GPON_I2C_BASE, GPON_I2C_SIZE),
|
||||
IRQ_RES(i2c_lb, FALCON_IRQ_I2C_LBREQ),
|
||||
IRQ_RES(i2c_b, FALCON_IRQ_I2C_BREQ),
|
||||
IRQ_RES(i2c_err, FALCON_IRQ_I2C_I2C_ERR),
|
||||
IRQ_RES(i2c_p, FALCON_IRQ_I2C_I2C_P),
|
||||
};
|
||||
|
||||
void __init
|
||||
falcon_register_i2c(void)
|
||||
{
|
||||
platform_device_register_simple("i2c-falcon", 0,
|
||||
falcon_i2c_resources, ARRAY_SIZE(falcon_i2c_resources));
|
||||
}
|
|
@ -1,25 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#ifndef _FALCON_DEVICES_H__
|
||||
#define _FALCON_DEVICES_H__
|
||||
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
|
||||
#include "../devices.h"
|
||||
|
||||
extern void falcon_register_nand(void);
|
||||
extern void falcon_register_gpio(void);
|
||||
extern void falcon_register_gpio_extra(void);
|
||||
extern void falcon_register_spi_flash(struct spi_board_info *data);
|
||||
extern void falcon_register_i2c(void);
|
||||
|
||||
#endif
|
|
@ -1,409 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/export.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
/* Multiplexer Control Register */
|
||||
#define LTQ_PADC_MUX(x) (x * 0x4)
|
||||
/* Pad Control Availability Register */
|
||||
#define LTQ_PADC_AVAIL 0x000000F0
|
||||
|
||||
/* Data Output Register */
|
||||
#define LTQ_GPIO_OUT 0x00000000
|
||||
/* Data Input Register */
|
||||
#define LTQ_GPIO_IN 0x00000004
|
||||
/* Direction Register */
|
||||
#define LTQ_GPIO_DIR 0x00000008
|
||||
/* External Interrupt Control Register 0 */
|
||||
#define LTQ_GPIO_EXINTCR0 0x00000018
|
||||
/* External Interrupt Control Register 1 */
|
||||
#define LTQ_GPIO_EXINTCR1 0x0000001C
|
||||
/* IRN Capture Register */
|
||||
#define LTQ_GPIO_IRNCR 0x00000020
|
||||
/* IRN Interrupt Configuration Register */
|
||||
#define LTQ_GPIO_IRNCFG 0x0000002C
|
||||
/* IRN Interrupt Enable Set Register */
|
||||
#define LTQ_GPIO_IRNRNSET 0x00000030
|
||||
/* IRN Interrupt Enable Clear Register */
|
||||
#define LTQ_GPIO_IRNENCLR 0x00000034
|
||||
/* Output Set Register */
|
||||
#define LTQ_GPIO_OUTSET 0x00000040
|
||||
/* Output Cler Register */
|
||||
#define LTQ_GPIO_OUTCLR 0x00000044
|
||||
/* Direction Clear Register */
|
||||
#define LTQ_GPIO_DIRSET 0x00000048
|
||||
/* Direction Set Register */
|
||||
#define LTQ_GPIO_DIRCLR 0x0000004C
|
||||
|
||||
/* turn a gpio_chip into a falcon_gpio_port */
|
||||
#define ctop(c) container_of(c, struct falcon_gpio_port, gpio_chip)
|
||||
/* turn a irq_data into a falcon_gpio_port */
|
||||
#define itop(i) ((struct falcon_gpio_port *) irq_get_chip_data(i->irq))
|
||||
|
||||
#define ltq_pad_r32(p, reg) ltq_r32(p->pad + reg)
|
||||
#define ltq_pad_w32(p, val, reg) ltq_w32(val, p->pad + reg)
|
||||
#define ltq_pad_w32_mask(c, clear, set, reg) \
|
||||
ltq_pad_w32(c, (ltq_pad_r32(c, reg) & ~(clear)) | (set), reg)
|
||||
|
||||
#define ltq_port_r32(p, reg) ltq_r32(p->port + reg)
|
||||
#define ltq_port_w32(p, val, reg) ltq_w32(val, p->port + reg)
|
||||
#define ltq_port_w32_mask(p, clear, set, reg) \
|
||||
ltq_port_w32(p, (ltq_port_r32(p, reg) & ~(clear)) | (set), reg)
|
||||
|
||||
#define MAX_PORTS 5
|
||||
#define PINS_PER_PORT 32
|
||||
|
||||
struct falcon_gpio_port {
|
||||
struct gpio_chip gpio_chip;
|
||||
void __iomem *pad;
|
||||
void __iomem *port;
|
||||
unsigned int irq_base;
|
||||
unsigned int chained_irq;
|
||||
struct clk *clk;
|
||||
};
|
||||
|
||||
static struct falcon_gpio_port ltq_gpio_port[MAX_PORTS];
|
||||
|
||||
int gpio_to_irq(unsigned int gpio)
|
||||
{
|
||||
return __gpio_to_irq(gpio);
|
||||
}
|
||||
EXPORT_SYMBOL(gpio_to_irq);
|
||||
|
||||
int ltq_gpio_mux_set(unsigned int pin, unsigned int mux)
|
||||
{
|
||||
int port = pin / 100;
|
||||
int offset = pin % 100;
|
||||
struct falcon_gpio_port *gpio_port;
|
||||
|
||||
if ((offset >= PINS_PER_PORT) || (port >= MAX_PORTS))
|
||||
return -EINVAL;
|
||||
|
||||
gpio_port = <q_gpio_port[port];
|
||||
ltq_pad_w32(gpio_port, mux & 0x3, LTQ_PADC_MUX(offset));
|
||||
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_gpio_mux_set);
|
||||
|
||||
int ltq_gpio_request(struct device *dev, unsigned int pin, unsigned int mux,
|
||||
unsigned int dir, const char *name)
|
||||
{
|
||||
int port = pin / 100;
|
||||
int offset = pin % 100;
|
||||
|
||||
if (offset >= PINS_PER_PORT || port >= MAX_PORTS)
|
||||
return -EINVAL;
|
||||
|
||||
if (devm_gpio_request(dev, pin, name)) {
|
||||
pr_err("failed to setup lantiq gpio: %s\n", name);
|
||||
return -EBUSY;
|
||||
}
|
||||
|
||||
if (dir)
|
||||
gpio_direction_output(pin, 1);
|
||||
else
|
||||
gpio_direction_input(pin);
|
||||
|
||||
return ltq_gpio_mux_set(pin, mux);
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_gpio_request);
|
||||
|
||||
static int
|
||||
falcon_gpio_direction_input(struct gpio_chip *chip, unsigned int offset)
|
||||
{
|
||||
ltq_port_w32(ctop(chip), 1 << offset, LTQ_GPIO_DIRCLR);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_set(struct gpio_chip *chip, unsigned int offset, int value)
|
||||
{
|
||||
if (value)
|
||||
ltq_port_w32(ctop(chip), 1 << offset, LTQ_GPIO_OUTSET);
|
||||
else
|
||||
ltq_port_w32(ctop(chip), 1 << offset, LTQ_GPIO_OUTCLR);
|
||||
}
|
||||
|
||||
static int
|
||||
falcon_gpio_direction_output(struct gpio_chip *chip,
|
||||
unsigned int offset, int value)
|
||||
{
|
||||
falcon_gpio_set(chip, offset, value);
|
||||
ltq_port_w32(ctop(chip), 1 << offset, LTQ_GPIO_DIRSET);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
falcon_gpio_get(struct gpio_chip *chip, unsigned int offset)
|
||||
{
|
||||
if ((ltq_port_r32(ctop(chip), LTQ_GPIO_DIR) >> offset) & 1)
|
||||
return (ltq_port_r32(ctop(chip), LTQ_GPIO_OUT) >> offset) & 1;
|
||||
else
|
||||
return (ltq_port_r32(ctop(chip), LTQ_GPIO_IN) >> offset) & 1;
|
||||
}
|
||||
|
||||
static int
|
||||
falcon_gpio_request(struct gpio_chip *chip, unsigned offset)
|
||||
{
|
||||
if ((ltq_pad_r32(ctop(chip), LTQ_PADC_AVAIL) >> offset) & 1) {
|
||||
if (ltq_pad_r32(ctop(chip), LTQ_PADC_MUX(offset)) > 1)
|
||||
return -EBUSY;
|
||||
/* switch on gpio function */
|
||||
ltq_pad_w32(ctop(chip), 1, LTQ_PADC_MUX(offset));
|
||||
return 0;
|
||||
}
|
||||
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_free(struct gpio_chip *chip, unsigned offset)
|
||||
{
|
||||
if ((ltq_pad_r32(ctop(chip), LTQ_PADC_AVAIL) >> offset) & 1) {
|
||||
if (ltq_pad_r32(ctop(chip), LTQ_PADC_MUX(offset)) > 1)
|
||||
return;
|
||||
/* switch off gpio function */
|
||||
ltq_pad_w32(ctop(chip), 0, LTQ_PADC_MUX(offset));
|
||||
}
|
||||
}
|
||||
|
||||
static int
|
||||
falcon_gpio_to_irq(struct gpio_chip *chip, unsigned offset)
|
||||
{
|
||||
return ctop(chip)->irq_base + offset;
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_disable_irq(struct irq_data *d)
|
||||
{
|
||||
unsigned int offset = d->irq - itop(d)->irq_base;
|
||||
|
||||
ltq_port_w32(itop(d), 1 << offset, LTQ_GPIO_IRNENCLR);
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_enable_irq(struct irq_data *d)
|
||||
{
|
||||
unsigned int offset = d->irq - itop(d)->irq_base;
|
||||
|
||||
if (!ltq_pad_r32(itop(d), LTQ_PADC_MUX(offset)) < 1)
|
||||
/* switch on gpio function */
|
||||
ltq_pad_w32(itop(d), 1, LTQ_PADC_MUX(offset));
|
||||
|
||||
ltq_port_w32(itop(d), 1 << offset, LTQ_GPIO_IRNRNSET);
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_ack_irq(struct irq_data *d)
|
||||
{
|
||||
unsigned int offset = d->irq - itop(d)->irq_base;
|
||||
|
||||
ltq_port_w32(itop(d), 1 << offset, LTQ_GPIO_IRNCR);
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_mask_and_ack_irq(struct irq_data *d)
|
||||
{
|
||||
unsigned int offset = d->irq - itop(d)->irq_base;
|
||||
|
||||
ltq_port_w32(itop(d), 1 << offset, LTQ_GPIO_IRNENCLR);
|
||||
ltq_port_w32(itop(d), 1 << offset, LTQ_GPIO_IRNCR);
|
||||
}
|
||||
|
||||
static struct irq_chip falcon_gpio_irq_chip;
|
||||
static int
|
||||
falcon_gpio_irq_type(struct irq_data *d, unsigned int type)
|
||||
{
|
||||
unsigned int offset = d->irq - itop(d)->irq_base;
|
||||
unsigned int mask = 1 << offset;
|
||||
|
||||
if ((type & IRQ_TYPE_SENSE_MASK) == IRQ_TYPE_NONE)
|
||||
return 0;
|
||||
|
||||
if ((type & (IRQ_TYPE_LEVEL_HIGH | IRQ_TYPE_LEVEL_LOW)) != 0) {
|
||||
/* level triggered */
|
||||
ltq_port_w32_mask(itop(d), 0, mask, LTQ_GPIO_IRNCFG);
|
||||
irq_set_chip_and_handler_name(d->irq,
|
||||
&falcon_gpio_irq_chip, handle_level_irq, "mux");
|
||||
} else {
|
||||
/* edge triggered */
|
||||
ltq_port_w32_mask(itop(d), mask, 0, LTQ_GPIO_IRNCFG);
|
||||
irq_set_chip_and_handler_name(d->irq,
|
||||
&falcon_gpio_irq_chip, handle_simple_irq, "mux");
|
||||
}
|
||||
|
||||
if ((type & IRQ_TYPE_EDGE_BOTH) == IRQ_TYPE_EDGE_BOTH) {
|
||||
ltq_port_w32_mask(itop(d), mask, 0, LTQ_GPIO_EXINTCR0);
|
||||
ltq_port_w32_mask(itop(d), 0, mask, LTQ_GPIO_EXINTCR1);
|
||||
} else {
|
||||
if ((type & (IRQ_TYPE_EDGE_RISING | IRQ_TYPE_LEVEL_HIGH)) != 0)
|
||||
/* positive logic: rising edge, high level */
|
||||
ltq_port_w32_mask(itop(d), mask, 0, LTQ_GPIO_EXINTCR0);
|
||||
else
|
||||
/* negative logic: falling edge, low level */
|
||||
ltq_port_w32_mask(itop(d), 0, mask, LTQ_GPIO_EXINTCR0);
|
||||
ltq_port_w32_mask(itop(d), mask, 0, LTQ_GPIO_EXINTCR1);
|
||||
}
|
||||
|
||||
return gpio_direction_input(itop(d)->gpio_chip.base + offset);
|
||||
}
|
||||
|
||||
static void
|
||||
falcon_gpio_irq_handler(unsigned int irq, struct irq_desc *desc)
|
||||
{
|
||||
struct falcon_gpio_port *gpio_port = irq_desc_get_handler_data(desc);
|
||||
unsigned long irncr;
|
||||
int offset;
|
||||
|
||||
/* acknowledge interrupt */
|
||||
irncr = ltq_port_r32(gpio_port, LTQ_GPIO_IRNCR);
|
||||
ltq_port_w32(gpio_port, irncr, LTQ_GPIO_IRNCR);
|
||||
|
||||
desc->irq_data.chip->irq_ack(&desc->irq_data);
|
||||
|
||||
for_each_set_bit(offset, &irncr, gpio_port->gpio_chip.ngpio)
|
||||
generic_handle_irq(gpio_port->irq_base + offset);
|
||||
}
|
||||
|
||||
static struct irq_chip falcon_gpio_irq_chip = {
|
||||
.name = "gpio_irq_mux",
|
||||
.irq_mask = falcon_gpio_disable_irq,
|
||||
.irq_unmask = falcon_gpio_enable_irq,
|
||||
.irq_ack = falcon_gpio_ack_irq,
|
||||
.irq_mask_ack = falcon_gpio_mask_and_ack_irq,
|
||||
.irq_set_type = falcon_gpio_irq_type,
|
||||
};
|
||||
|
||||
static struct irqaction gpio_cascade = {
|
||||
.handler = no_action,
|
||||
.flags = IRQF_DISABLED,
|
||||
.name = "gpio_cascade",
|
||||
};
|
||||
|
||||
static int
|
||||
falcon_gpio_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct falcon_gpio_port *gpio_port;
|
||||
int ret, i;
|
||||
struct resource *gpiores, *padres;
|
||||
int irq;
|
||||
|
||||
if (pdev->id >= MAX_PORTS)
|
||||
return -ENODEV;
|
||||
|
||||
gpiores = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||
padres = platform_get_resource(pdev, IORESOURCE_MEM, 1);
|
||||
irq = platform_get_irq(pdev, 0);
|
||||
if (!gpiores || !padres)
|
||||
return -ENODEV;
|
||||
|
||||
gpio_port = <q_gpio_port[pdev->id];
|
||||
gpio_port->gpio_chip.label = "falcon-gpio";
|
||||
gpio_port->gpio_chip.direction_input = falcon_gpio_direction_input;
|
||||
gpio_port->gpio_chip.direction_output = falcon_gpio_direction_output;
|
||||
gpio_port->gpio_chip.get = falcon_gpio_get;
|
||||
gpio_port->gpio_chip.set = falcon_gpio_set;
|
||||
gpio_port->gpio_chip.request = falcon_gpio_request;
|
||||
gpio_port->gpio_chip.free = falcon_gpio_free;
|
||||
gpio_port->gpio_chip.base = 100 * pdev->id;
|
||||
gpio_port->gpio_chip.ngpio = 32;
|
||||
gpio_port->gpio_chip.dev = &pdev->dev;
|
||||
|
||||
gpio_port->port = ltq_remap_resource(gpiores);
|
||||
gpio_port->pad = ltq_remap_resource(padres);
|
||||
|
||||
if (!gpio_port->port || !gpio_port->pad) {
|
||||
dev_err(&pdev->dev, "Could not map io ranges\n");
|
||||
ret = -ENOMEM;
|
||||
goto err;
|
||||
}
|
||||
|
||||
gpio_port->clk = clk_get(&pdev->dev, NULL);
|
||||
if (IS_ERR(gpio_port->clk)) {
|
||||
dev_err(&pdev->dev, "Could not get clock\n");
|
||||
ret = PTR_ERR(gpio_port->clk);;
|
||||
goto err;
|
||||
}
|
||||
clk_enable(gpio_port->clk);
|
||||
|
||||
if (irq > 0) {
|
||||
/* irq_chip support */
|
||||
gpio_port->gpio_chip.to_irq = falcon_gpio_to_irq;
|
||||
gpio_port->irq_base = INT_NUM_EXTRA_START + (32 * pdev->id);
|
||||
|
||||
for (i = 0; i < 32; i++) {
|
||||
irq_set_chip_and_handler_name(gpio_port->irq_base + i,
|
||||
&falcon_gpio_irq_chip, handle_simple_irq,
|
||||
"mux");
|
||||
irq_set_chip_data(gpio_port->irq_base + i, gpio_port);
|
||||
/* set to negative logic (falling edge, low level) */
|
||||
ltq_port_w32_mask(gpio_port, 0, 1 << i,
|
||||
LTQ_GPIO_EXINTCR0);
|
||||
}
|
||||
|
||||
gpio_port->chained_irq = irq;
|
||||
setup_irq(irq, &gpio_cascade);
|
||||
irq_set_handler_data(irq, gpio_port);
|
||||
irq_set_chained_handler(irq, falcon_gpio_irq_handler);
|
||||
}
|
||||
|
||||
ret = gpiochip_add(&gpio_port->gpio_chip);
|
||||
if (ret < 0) {
|
||||
dev_err(&pdev->dev, "Could not register gpiochip %d, %d\n",
|
||||
pdev->id, ret);
|
||||
goto err;
|
||||
}
|
||||
platform_set_drvdata(pdev, gpio_port);
|
||||
return ret;
|
||||
|
||||
err:
|
||||
dev_err(&pdev->dev, "Error in gpio_probe %d, %d\n", pdev->id, ret);
|
||||
if (gpiores)
|
||||
release_resource(gpiores);
|
||||
if (padres)
|
||||
release_resource(padres);
|
||||
|
||||
if (gpio_port->port)
|
||||
iounmap(gpio_port->port);
|
||||
if (gpio_port->pad)
|
||||
iounmap(gpio_port->pad);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static struct platform_driver falcon_gpio_driver = {
|
||||
.probe = falcon_gpio_probe,
|
||||
.driver = {
|
||||
.name = "falcon_gpio",
|
||||
.owner = THIS_MODULE,
|
||||
},
|
||||
};
|
||||
|
||||
int __init
|
||||
falcon_gpio_init(void)
|
||||
{
|
||||
int ret;
|
||||
|
||||
pr_info("FALC(tm) ON GPIO Driver, (C) 2011 Lantiq Deutschland Gmbh\n");
|
||||
ret = platform_driver_register(&falcon_gpio_driver);
|
||||
if (ret)
|
||||
pr_err("falcon_gpio: Error registering platform driver!");
|
||||
return ret;
|
||||
}
|
||||
|
||||
postcore_initcall(falcon_gpio_init);
|
|
@ -1,94 +0,0 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/i2c-gpio.h>
|
||||
|
||||
#include <dev-gpio-leds.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
|
||||
#define BOARD_95C3AM1_GPIO_LED_0 10
|
||||
#define BOARD_95C3AM1_GPIO_LED_1 11
|
||||
#define BOARD_95C3AM1_GPIO_LED_2 12
|
||||
#define BOARD_95C3AM1_GPIO_LED_3 13
|
||||
|
||||
static struct mtd_partition board_95C3AM1_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x40000,
|
||||
.size = 0x40000, /* 2 sectors for redundant env. */
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x80000,
|
||||
.size = 0xF80000, /* map only 16 MiB */
|
||||
},
|
||||
};
|
||||
|
||||
static struct flash_platform_data board_95C3AM1_flash_platform_data = {
|
||||
.name = "sflash",
|
||||
.parts = board_95C3AM1_partitions,
|
||||
.nr_parts = ARRAY_SIZE(board_95C3AM1_partitions)
|
||||
};
|
||||
|
||||
static struct spi_board_info board_95C3AM1_flash_data __initdata = {
|
||||
.modalias = "m25p80",
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
.max_speed_hz = 10 * 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.platform_data = &board_95C3AM1_flash_platform_data
|
||||
};
|
||||
|
||||
static struct gpio_led board_95C3AM1_gpio_leds[] __initdata = {
|
||||
{
|
||||
.name = "power",
|
||||
.gpio = BOARD_95C3AM1_GPIO_LED_0,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "optical",
|
||||
.gpio = BOARD_95C3AM1_GPIO_LED_1,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "lan",
|
||||
.gpio = BOARD_95C3AM1_GPIO_LED_2,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "update",
|
||||
.gpio = BOARD_95C3AM1_GPIO_LED_3,
|
||||
.active_low = 0,
|
||||
}
|
||||
};
|
||||
|
||||
static struct i2c_gpio_platform_data board_95C3AM1_i2c_gpio_data = {
|
||||
.sda_pin = 107,
|
||||
.scl_pin = 108,
|
||||
};
|
||||
|
||||
static struct platform_device board_95C3AM1_i2c_gpio_device = {
|
||||
.name = "i2c-gpio",
|
||||
.id = 0,
|
||||
.dev = {
|
||||
.platform_data = &board_95C3AM1_i2c_gpio_data,
|
||||
}
|
||||
};
|
||||
|
||||
static void __init board_95C3AM1_init(void)
|
||||
{
|
||||
falcon_register_i2c();
|
||||
falcon_register_spi_flash(&board_95C3AM1_flash_data);
|
||||
platform_device_register(&board_95C3AM1_i2c_gpio_device);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(board_95C3AM1_gpio_leds),
|
||||
board_95C3AM1_gpio_leds);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_95C3AM1,
|
||||
"95C3AM1",
|
||||
"95C3AM1 Board",
|
||||
board_95C3AM1_init);
|
|
@ -1,138 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/spi_gpio.h>
|
||||
#include <linux/spi/eeprom.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
static struct mtd_partition easy98000_nor_partitions[] = {
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x40000,
|
||||
.size = 0x40000, /* 2 sectors for redundant env. */
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x80000,
|
||||
.size = 0xF80000, /* map only 16 MiB */
|
||||
},
|
||||
};
|
||||
|
||||
struct physmap_flash_data easy98000_nor_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(easy98000_nor_partitions),
|
||||
.parts = easy98000_nor_partitions,
|
||||
};
|
||||
|
||||
static struct flash_platform_data easy98000_spi_flash_platform_data = {
|
||||
.name = "sflash",
|
||||
.parts = easy98000_nor_partitions,
|
||||
.nr_parts = ARRAY_SIZE(easy98000_nor_partitions)
|
||||
};
|
||||
|
||||
static struct spi_board_info easy98000_spi_flash_data __initdata = {
|
||||
.modalias = "m25p80",
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
.max_speed_hz = 10 * 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.platform_data = &easy98000_spi_flash_platform_data
|
||||
};
|
||||
|
||||
/* setup gpio based spi bus/device for access to the eeprom on the board */
|
||||
#define SPI_GPIO_MRST 102
|
||||
#define SPI_GPIO_MTSR 103
|
||||
#define SPI_GPIO_CLK 104
|
||||
#define SPI_GPIO_CS0 105
|
||||
#define SPI_GPIO_CS1 106
|
||||
#define SPI_GPIO_BUS_NUM 1
|
||||
|
||||
static struct spi_gpio_platform_data easy98000_spi_gpio_data = {
|
||||
.sck = SPI_GPIO_CLK,
|
||||
.mosi = SPI_GPIO_MTSR,
|
||||
.miso = SPI_GPIO_MRST,
|
||||
.num_chipselect = 2,
|
||||
};
|
||||
|
||||
static struct platform_device easy98000_spi_gpio_device = {
|
||||
.name = "spi_gpio",
|
||||
.id = SPI_GPIO_BUS_NUM,
|
||||
.dev.platform_data = &easy98000_spi_gpio_data,
|
||||
};
|
||||
|
||||
static struct spi_eeprom at25160n = {
|
||||
.byte_len = 16 * 1024 / 8,
|
||||
.name = "at25160n",
|
||||
.page_size = 32,
|
||||
.flags = EE_ADDR2,
|
||||
};
|
||||
|
||||
static struct spi_board_info easy98000_spi_gpio_devices __initdata = {
|
||||
.modalias = "at25",
|
||||
.bus_num = SPI_GPIO_BUS_NUM,
|
||||
.max_speed_hz = 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.chip_select = 1,
|
||||
.controller_data = (void *) SPI_GPIO_CS1,
|
||||
.platform_data = &at25160n,
|
||||
};
|
||||
|
||||
static void __init
|
||||
easy98000_init_common(void)
|
||||
{
|
||||
spi_register_board_info(&easy98000_spi_gpio_devices, 1);
|
||||
platform_device_register(&easy98000_spi_gpio_device);
|
||||
falcon_register_i2c();
|
||||
}
|
||||
|
||||
static void __init
|
||||
easy98000_init(void)
|
||||
{
|
||||
easy98000_init_common();
|
||||
ltq_register_nor(&easy98000_nor_flash_data);
|
||||
}
|
||||
|
||||
static void __init
|
||||
easy98000sf_init(void)
|
||||
{
|
||||
easy98000_init_common();
|
||||
falcon_register_spi_flash(&easy98000_spi_flash_data);
|
||||
}
|
||||
|
||||
static void __init
|
||||
easy98000nand_init(void)
|
||||
{
|
||||
easy98000_init_common();
|
||||
falcon_register_nand();
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98000,
|
||||
"EASY98000",
|
||||
"EASY98000 Eval Board",
|
||||
easy98000_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98000SF,
|
||||
"EASY98000SF",
|
||||
"EASY98000 Eval Board (Serial Flash)",
|
||||
easy98000sf_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98000NAND,
|
||||
"EASY98000NAND",
|
||||
"EASY98000 Eval Board (NAND Flash)",
|
||||
easy98000nand_init);
|
|
@ -1,118 +0,0 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
|
||||
#include <dev-gpio-leds.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
|
||||
#define EASY98020_GPIO_LED_0 9
|
||||
#define EASY98020_GPIO_LED_1 10
|
||||
#define EASY98020_GPIO_LED_2 11
|
||||
#define EASY98020_GPIO_LED_3 12
|
||||
#define EASY98020_GPIO_LED_GE0_ACT 110
|
||||
#define EASY98020_GPIO_LED_GE0_LINK 109
|
||||
#define EASY98020_GPIO_LED_GE1_ACT 106
|
||||
#define EASY98020_GPIO_LED_GE1_LINK 105
|
||||
|
||||
static struct mtd_partition easy98020_spi_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x40000,
|
||||
.size = 0x40000, /* 2 sectors for redundant env. */
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x80000,
|
||||
.size = 0xF80000, /* map only 16 MiB */
|
||||
},
|
||||
};
|
||||
|
||||
static struct flash_platform_data easy98020_spi_flash_platform_data = {
|
||||
.name = "sflash",
|
||||
.parts = easy98020_spi_partitions,
|
||||
.nr_parts = ARRAY_SIZE(easy98020_spi_partitions)
|
||||
};
|
||||
|
||||
static struct spi_board_info easy98020_spi_flash_data __initdata = {
|
||||
.modalias = "m25p80",
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
.max_speed_hz = 10 * 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.platform_data = &easy98020_spi_flash_platform_data
|
||||
};
|
||||
|
||||
static struct gpio_led easy98020_gpio_leds[] __initdata = {
|
||||
{
|
||||
.name = "easy98020:green:0",
|
||||
.gpio = EASY98020_GPIO_LED_0,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:green:1",
|
||||
.gpio = EASY98020_GPIO_LED_1,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:green:2",
|
||||
.gpio = EASY98020_GPIO_LED_2,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:green:3",
|
||||
.gpio = EASY98020_GPIO_LED_3,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:ge0_act",
|
||||
.gpio = EASY98020_GPIO_LED_GE0_ACT,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:ge0_link",
|
||||
.gpio = EASY98020_GPIO_LED_GE0_LINK,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:ge1_act",
|
||||
.gpio = EASY98020_GPIO_LED_GE1_ACT,
|
||||
.active_low = 0,
|
||||
}, {
|
||||
.name = "easy98020:ge1_link",
|
||||
.gpio = EASY98020_GPIO_LED_GE1_LINK,
|
||||
.active_low = 0,
|
||||
}
|
||||
};
|
||||
|
||||
static void __init easy98020_init(void)
|
||||
{
|
||||
falcon_register_i2c();
|
||||
falcon_register_spi_flash(&easy98020_spi_flash_data);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(easy98020_gpio_leds),
|
||||
easy98020_gpio_leds);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98020,
|
||||
"EASY98020",
|
||||
"EASY98020 Eval Board",
|
||||
easy98020_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98020_1LAN,
|
||||
"EASY98020_1LAN",
|
||||
"EASY98020 Eval Board (1 LAN port)",
|
||||
easy98020_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY98020_2LAN,
|
||||
"EASY98020_2LAN",
|
||||
"EASY98020 Eval Board (2 LAN ports)",
|
||||
easy98020_init);
|
|
@ -1,84 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
#include "../prom.h"
|
||||
|
||||
#define SOC_FALCON "Falcon"
|
||||
#define SOC_FALCON_D "Falcon-D"
|
||||
#define SOC_FALCON_V "Falcon-V"
|
||||
#define SOC_FALCON_M "Falcon-M"
|
||||
|
||||
#define PART_SHIFT 12
|
||||
#define PART_MASK 0x0FFFF000
|
||||
#define REV_SHIFT 28
|
||||
#define REV_MASK 0xF0000000
|
||||
#define SREV_SHIFT 22
|
||||
#define SREV_MASK 0x03C00000
|
||||
#define TYPE_SHIFT 26
|
||||
#define TYPE_MASK 0x3C000000
|
||||
|
||||
/* this parameter allows us enable/disable asc1 via commandline */
|
||||
static int register_asc1;
|
||||
static int __init
|
||||
ltq_parse_asc1(char *p)
|
||||
{
|
||||
register_asc1 = 1;
|
||||
return 0;
|
||||
}
|
||||
__setup("use_asc1", ltq_parse_asc1);
|
||||
|
||||
void __init
|
||||
ltq_soc_setup(void)
|
||||
{
|
||||
ltq_register_asc(0);
|
||||
ltq_register_wdt();
|
||||
falcon_register_gpio();
|
||||
if (register_asc1)
|
||||
ltq_register_asc(1);
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_soc_detect(struct ltq_soc_info *i)
|
||||
{
|
||||
u32 type;
|
||||
i->partnum = (ltq_r32(LTQ_FALCON_CHIPID) & PART_MASK) >> PART_SHIFT;
|
||||
i->rev = (ltq_r32(LTQ_FALCON_CHIPID) & REV_MASK) >> REV_SHIFT;
|
||||
i->srev = ((ltq_r32(LTQ_FALCON_CHIPCONF) & SREV_MASK) >> SREV_SHIFT);
|
||||
sprintf(i->rev_type, "%c%d%d", (i->srev & 0x4) ? ('B') : ('A'),
|
||||
i->rev & 0x7, (i->srev & 0x3) + 1);
|
||||
|
||||
switch (i->partnum) {
|
||||
case SOC_ID_FALCON:
|
||||
type = (ltq_r32(LTQ_FALCON_CHIPTYPE) & TYPE_MASK) >> TYPE_SHIFT;
|
||||
switch (type) {
|
||||
case 0:
|
||||
i->name = SOC_FALCON_D;
|
||||
break;
|
||||
case 1:
|
||||
i->name = SOC_FALCON_V;
|
||||
break;
|
||||
case 2:
|
||||
i->name = SOC_FALCON_M;
|
||||
break;
|
||||
default:
|
||||
i->name = SOC_FALCON;
|
||||
break;
|
||||
}
|
||||
i->type = SOC_TYPE_FALCON;
|
||||
break;
|
||||
|
||||
default:
|
||||
unreachable();
|
||||
break;
|
||||
}
|
||||
}
|
|
@ -1,87 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/pm.h>
|
||||
#include <asm/reboot.h>
|
||||
#include <linux/export.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
/* CPU0 Reset Source Register */
|
||||
#define LTQ_SYS1_CPU0RS 0x0040
|
||||
/* reset cause mask */
|
||||
#define LTQ_CPU0RS_MASK 0x0003
|
||||
|
||||
int
|
||||
ltq_reset_cause(void)
|
||||
{
|
||||
return ltq_sys1_r32(LTQ_SYS1_CPU0RS) & LTQ_CPU0RS_MASK;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(ltq_reset_cause);
|
||||
|
||||
#define BOOT_REG_BASE (KSEG1 | 0x1F200000)
|
||||
#define BOOT_PW1_REG (BOOT_REG_BASE | 0x20)
|
||||
#define BOOT_PW2_REG (BOOT_REG_BASE | 0x24)
|
||||
#define BOOT_PW1 0x4C545100
|
||||
#define BOOT_PW2 0x0051544C
|
||||
|
||||
#define WDT_REG_BASE (KSEG1 | 0x1F8803F0)
|
||||
#define WDT_PW1 0x00BE0000
|
||||
#define WDT_PW2 0x00DC0000
|
||||
|
||||
static void
|
||||
ltq_machine_restart(char *command)
|
||||
{
|
||||
pr_notice("System restart\n");
|
||||
local_irq_disable();
|
||||
|
||||
/* reboot magic */
|
||||
ltq_w32(BOOT_PW1, (void *)BOOT_PW1_REG); /* 'LTQ\0' */
|
||||
ltq_w32(BOOT_PW2, (void *)BOOT_PW2_REG); /* '\0QTL' */
|
||||
ltq_w32(0, (void *)BOOT_REG_BASE); /* reset Bootreg RVEC */
|
||||
|
||||
/* watchdog magic */
|
||||
ltq_w32(WDT_PW1, (void *)WDT_REG_BASE);
|
||||
ltq_w32(WDT_PW2 |
|
||||
(0x3 << 26) | /* PWL */
|
||||
(0x2 << 24) | /* CLKDIV */
|
||||
(0x1 << 31) | /* enable */
|
||||
(1), /* reload */
|
||||
(void *)WDT_REG_BASE);
|
||||
unreachable();
|
||||
}
|
||||
|
||||
static void
|
||||
ltq_machine_halt(void)
|
||||
{
|
||||
pr_notice("System halted.\n");
|
||||
local_irq_disable();
|
||||
unreachable();
|
||||
}
|
||||
|
||||
static void
|
||||
ltq_machine_power_off(void)
|
||||
{
|
||||
pr_notice("Please turn off the power now.\n");
|
||||
local_irq_disable();
|
||||
unreachable();
|
||||
}
|
||||
|
||||
static int __init
|
||||
mips_reboot_setup(void)
|
||||
{
|
||||
_machine_restart = ltq_machine_restart;
|
||||
_machine_halt = ltq_machine_halt;
|
||||
pm_power_off = ltq_machine_power_off;
|
||||
return 0;
|
||||
}
|
||||
|
||||
arch_initcall(mips_reboot_setup);
|
|
@ -1,211 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Thomas Langer <thomas.langer@lantiq.com>
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/ioport.h>
|
||||
#include <linux/export.h>
|
||||
#include <linux/clkdev.h>
|
||||
#include <asm/delay.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "devices.h"
|
||||
#include "../clk.h"
|
||||
|
||||
/* infrastructure control register */
|
||||
#define SYS1_INFRAC 0x00bc
|
||||
/* Configuration fuses for drivers and pll */
|
||||
#define STATUS_CONFIG 0x0040
|
||||
|
||||
/* GPE frequency selection */
|
||||
#define GPPC_OFFSET 24
|
||||
#define GPEFREQ_MASK 0x00000C0
|
||||
#define GPEFREQ_OFFSET 10
|
||||
/* Clock status register */
|
||||
#define LTQ_SYSCTL_CLKS 0x0000
|
||||
/* Clock enable register */
|
||||
#define LTQ_SYSCTL_CLKEN 0x0004
|
||||
/* Clock clear register */
|
||||
#define LTQ_SYSCTL_CLKCLR 0x0008
|
||||
/* Activation Status Register */
|
||||
#define LTQ_SYSCTL_ACTS 0x0020
|
||||
/* Activation Register */
|
||||
#define LTQ_SYSCTL_ACT 0x0024
|
||||
/* Deactivation Register */
|
||||
#define LTQ_SYSCTL_DEACT 0x0028
|
||||
/* reboot Register */
|
||||
#define LTQ_SYSCTL_RBT 0x002c
|
||||
/* CPU0 Clock Control Register */
|
||||
#define LTQ_SYS1_CPU0CC 0x0040
|
||||
/* clock divider bit */
|
||||
#define LTQ_CPU0CC_CPUDIV 0x0001
|
||||
|
||||
static struct resource ltq_sysctl_res[] = {
|
||||
MEM_RES("sys1", LTQ_SYS1_BASE_ADDR, LTQ_SYS1_SIZE),
|
||||
MEM_RES("syseth", LTQ_SYS_ETH_BASE_ADDR, LTQ_SYS_ETH_SIZE),
|
||||
MEM_RES("sysgpe", LTQ_SYS_GPE_BASE_ADDR, LTQ_SYS_GPE_SIZE),
|
||||
};
|
||||
|
||||
static struct resource ltq_status_res =
|
||||
MEM_RES("status", LTQ_STATUS_BASE_ADDR, LTQ_STATUS_SIZE);
|
||||
static struct resource ltq_ebu_res =
|
||||
MEM_RES("ebu", LTQ_EBU_BASE_ADDR, LTQ_EBU_SIZE);
|
||||
|
||||
static void __iomem *ltq_sysctl[3];
|
||||
static void __iomem *ltq_status_membase;
|
||||
void __iomem *ltq_sys1_membase;
|
||||
void __iomem *ltq_ebu_membase;
|
||||
|
||||
#define ltq_reg_w32(m, x, y) ltq_w32((x), ltq_sysctl[m] + (y))
|
||||
#define ltq_reg_r32(m, x) ltq_r32(ltq_sysctl[m] + (x))
|
||||
#define ltq_reg_w32_mask(m, clear, set, reg) \
|
||||
ltq_reg_w32(m, (ltq_reg_r32(m, reg) & ~(clear)) | (set), reg)
|
||||
|
||||
#define ltq_status_w32(x, y) ltq_w32((x), ltq_status_membase + (y))
|
||||
#define ltq_status_r32(x) ltq_r32(ltq_status_membase + (x))
|
||||
|
||||
static inline void
|
||||
ltq_sysctl_wait(struct clk *clk,
|
||||
unsigned int test, unsigned int reg)
|
||||
{
|
||||
int err = 1000000;
|
||||
|
||||
do {} while (--err && ((ltq_reg_r32(clk->module, reg)
|
||||
& clk->bits) != test));
|
||||
if (!err)
|
||||
pr_err("module de/activation failed %d %08X %08X %08X\n",
|
||||
clk->module, clk->bits, test,
|
||||
ltq_reg_r32(clk->module, reg) & clk->bits);
|
||||
}
|
||||
|
||||
static int
|
||||
ltq_sysctl_activate(struct clk *clk)
|
||||
{
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_CLKEN);
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_ACT);
|
||||
ltq_sysctl_wait(clk, clk->bits, LTQ_SYSCTL_ACTS);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
ltq_sysctl_deactivate(struct clk *clk)
|
||||
{
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_CLKCLR);
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_DEACT);
|
||||
ltq_sysctl_wait(clk, 0, LTQ_SYSCTL_ACTS);
|
||||
}
|
||||
|
||||
static int
|
||||
ltq_sysctl_clken(struct clk *clk)
|
||||
{
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_CLKEN);
|
||||
ltq_sysctl_wait(clk, clk->bits, LTQ_SYSCTL_CLKS);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
ltq_sysctl_clkdis(struct clk *clk)
|
||||
{
|
||||
ltq_reg_w32(clk->module, clk->bits, LTQ_SYSCTL_CLKCLR);
|
||||
ltq_sysctl_wait(clk, 0, LTQ_SYSCTL_CLKS);
|
||||
}
|
||||
|
||||
static void
|
||||
ltq_sysctl_reboot(struct clk *clk)
|
||||
{
|
||||
unsigned int act;
|
||||
unsigned int bits;
|
||||
|
||||
act = ltq_reg_r32(clk->module, LTQ_SYSCTL_ACT);
|
||||
bits = ~act & clk->bits;
|
||||
if (bits != 0) {
|
||||
ltq_reg_w32(clk->module, bits, LTQ_SYSCTL_CLKEN);
|
||||
ltq_reg_w32(clk->module, bits, LTQ_SYSCTL_ACT);
|
||||
ltq_sysctl_wait(clk, bits, LTQ_SYSCTL_ACTS);
|
||||
}
|
||||
ltq_reg_w32(clk->module, act & clk->bits, LTQ_SYSCTL_RBT);
|
||||
ltq_sysctl_wait(clk, clk->bits, LTQ_SYSCTL_ACTS);
|
||||
}
|
||||
|
||||
/* enable the ONU core */
|
||||
static void
|
||||
ltq_gpe_enable(void)
|
||||
{
|
||||
unsigned int freq;
|
||||
unsigned int status;
|
||||
|
||||
/* if if the clock is already enabled */
|
||||
status = ltq_reg_r32(SYSCTL_SYS1, SYS1_INFRAC);
|
||||
if (status & (1 << (GPPC_OFFSET + 1)))
|
||||
return;
|
||||
|
||||
if (ltq_status_r32(STATUS_CONFIG) == 0)
|
||||
freq = 1; /* use 625MHz on unfused chip */
|
||||
else
|
||||
freq = (ltq_status_r32(STATUS_CONFIG) &
|
||||
GPEFREQ_MASK) >>
|
||||
GPEFREQ_OFFSET;
|
||||
|
||||
/* apply new frequency */
|
||||
ltq_reg_w32_mask(SYSCTL_SYS1, 7 << (GPPC_OFFSET + 1),
|
||||
freq << (GPPC_OFFSET + 2) , SYS1_INFRAC);
|
||||
udelay(1);
|
||||
|
||||
/* enable new frequency */
|
||||
ltq_reg_w32_mask(SYSCTL_SYS1, 0, 1 << (GPPC_OFFSET + 1), SYS1_INFRAC);
|
||||
udelay(1);
|
||||
}
|
||||
|
||||
static inline void
|
||||
clkdev_add_sys(const char *dev, unsigned int module,
|
||||
unsigned int bits)
|
||||
{
|
||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||
|
||||
clk->cl.dev_id = dev;
|
||||
clk->cl.con_id = NULL;
|
||||
clk->cl.clk = clk;
|
||||
clk->module = module;
|
||||
clk->bits = bits;
|
||||
clk->activate = ltq_sysctl_activate;
|
||||
clk->deactivate = ltq_sysctl_deactivate;
|
||||
clk->enable = ltq_sysctl_clken;
|
||||
clk->disable = ltq_sysctl_clkdis;
|
||||
clk->reboot = ltq_sysctl_reboot;
|
||||
clkdev_add(&clk->cl);
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_soc_init(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < 3; i++)
|
||||
ltq_sysctl[i] = ltq_remap_resource(<q_sysctl_res[i]);
|
||||
|
||||
ltq_sys1_membase = ltq_sysctl[0];
|
||||
ltq_status_membase = ltq_remap_resource(<q_status_res);
|
||||
ltq_ebu_membase = ltq_remap_resource(<q_ebu_res);
|
||||
|
||||
ltq_gpe_enable();
|
||||
|
||||
/* get our 3 static rates for cpu, fpi and io clocks */
|
||||
if (ltq_sys1_r32(LTQ_SYS1_CPU0CC) & LTQ_CPU0CC_CPUDIV)
|
||||
clkdev_add_static(CLOCK_200M, CLOCK_100M, CLOCK_200M);
|
||||
else
|
||||
clkdev_add_static(CLOCK_400M, CLOCK_100M, CLOCK_200M);
|
||||
|
||||
/* add our clock domains */
|
||||
clkdev_add_sys("falcon_gpio.0", SYSCTL_SYSETH, ACTS_PADCTRL0 | ACTS_P0);
|
||||
clkdev_add_sys("falcon_gpio.1", SYSCTL_SYS1, ACTS_PADCTRL1 | ACTS_P1);
|
||||
clkdev_add_sys("falcon_gpio.2", SYSCTL_SYSETH, ACTS_PADCTRL2 | ACTS_P2);
|
||||
clkdev_add_sys("falcon_gpio.3", SYSCTL_SYS1, ACTS_PADCTRL3 | ACTS_P3);
|
||||
clkdev_add_sys("falcon_gpio.4", SYSCTL_SYS1, ACTS_PADCTRL4 | ACTS_P4);
|
||||
clkdev_add_sys("ltq_asc.1", SYSCTL_SYS1, ACTS_ASC1_ACT);
|
||||
clkdev_add_sys("i2c-falcon.0", SYSCTL_SYS1, ACTS_I2C_ACT);
|
||||
}
|
|
@ -1,16 +0,0 @@
|
|||
if SOC_SVIP
|
||||
|
||||
menu "Mips Machine"
|
||||
|
||||
config LANTIQ_MACH_EASY33016
|
||||
bool "Easy33016"
|
||||
default y
|
||||
|
||||
config LANTIQ_MACH_EASY336
|
||||
select SYS_SUPPORTS_LITTLE_ENDIAN
|
||||
bool "Easy336"
|
||||
default y
|
||||
|
||||
endmenu
|
||||
|
||||
endif
|
|
@ -1,3 +0,0 @@
|
|||
obj-y := devices.o prom.o reset.o clk-svip.o gpio.o dma.o switchip_setup.o pms.o mux.o
|
||||
obj-$(CONFIG_LANTIQ_MACH_EASY33016) += mach-easy33016.o
|
||||
obj-$(CONFIG_LANTIQ_MACH_EASY336) += mach-easy336.o
|
|
@ -1,100 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/io.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/time.h>
|
||||
|
||||
#include <asm/irq.h>
|
||||
#include <asm/div64.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <base_reg.h>
|
||||
#include <sys0_reg.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <status_reg.h>
|
||||
|
||||
static struct svip_reg_status *const status =
|
||||
(struct svip_reg_status *)LTQ_STATUS_BASE;
|
||||
static struct svip_reg_sys0 *const sys0 = (struct svip_reg_sys0 *)LTQ_SYS0_BASE;
|
||||
static struct svip_reg_sys1 *const sys1 = (struct svip_reg_sys1 *)LTQ_SYS1_BASE;
|
||||
|
||||
unsigned int ltq_svip_io_region_clock(void)
|
||||
{
|
||||
return 200000000; /* 200 MHz */
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_svip_io_region_clock);
|
||||
|
||||
unsigned int ltq_svip_cpu_hz(void)
|
||||
{
|
||||
/* Magic BootROM speed location... */
|
||||
if ((*(u32 *)0x9fc07ff0) == 1)
|
||||
return *(u32 *)0x9fc07ff4;
|
||||
|
||||
if (STATUS_CONFIG_CLK_MODE_GET(status_r32(config)) == 1) {
|
||||
/* xT16 */
|
||||
return 393216000;
|
||||
} else {
|
||||
switch (SYS0_PLL1CR_PLLDIV_GET(sys0_r32(pll1cr))) {
|
||||
case 3:
|
||||
return 475000000;
|
||||
case 2:
|
||||
return 450000000;
|
||||
case 1:
|
||||
return 425000000;
|
||||
default:
|
||||
return 400000000;
|
||||
}
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_svip_cpu_hz);
|
||||
|
||||
unsigned int ltq_svip_fpi_hz(void)
|
||||
{
|
||||
u32 fbs0_div[2] = {4, 8};
|
||||
u32 div;
|
||||
|
||||
div = SYS1_FPICR_FPIDIV_GET(sys1_r32(fpicr));
|
||||
return ltq_svip_cpu_hz()/fbs0_div[div];
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_svip_fpi_hz);
|
||||
|
||||
unsigned int ltq_get_ppl_hz(void)
|
||||
{
|
||||
/* Magic BootROM speed location... */
|
||||
if ((*(u32 *)0x9fc07ff0) == 1)
|
||||
return *(u32 *)0x9fc07ff4;
|
||||
|
||||
if (STATUS_CONFIG_CLK_MODE_GET(status_r32(config)) == 1) {
|
||||
/* xT16 */
|
||||
return 393216000;
|
||||
} else {
|
||||
switch (SYS0_PLL1CR_PLLDIV_GET(sys0_r32(pll1cr))) {
|
||||
case 3:
|
||||
return 475000000;
|
||||
case 2:
|
||||
return 450000000;
|
||||
case 1:
|
||||
return 425000000;
|
||||
default:
|
||||
return 400000000;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
unsigned int ltq_get_fbs0_hz(void)
|
||||
{
|
||||
u32 fbs0_div[2] = {4, 8};
|
||||
u32 div;
|
||||
|
||||
div = SYS1_FPICR_FPIDIV_GET(sys1_r32(fpicr));
|
||||
return ltq_get_ppl_hz()/fbs0_div[div];
|
||||
}
|
||||
EXPORT_SYMBOL(ltq_get_fbs0_hz);
|
|
@ -1,380 +0,0 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/string.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/time.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/mtd/nand.h>
|
||||
|
||||
#include <asm/bootinfo.h>
|
||||
#include <asm/irq.h>
|
||||
|
||||
#include <lantiq.h>
|
||||
|
||||
#include <base_reg.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <sys2_reg.h>
|
||||
#include <ebu_reg.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <svip_mux.h>
|
||||
#include <svip_pms.h>
|
||||
|
||||
/* ASC */
|
||||
void __init svip_register_asc(int port)
|
||||
{
|
||||
switch (port) {
|
||||
case 0:
|
||||
ltq_register_asc(0);
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_ASC0);
|
||||
break;
|
||||
case 1:
|
||||
ltq_register_asc(1);
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_ASC1);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
};
|
||||
}
|
||||
|
||||
/* Ethernet */
|
||||
static unsigned char svip_ethaddr[6] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
|
||||
|
||||
static struct platform_device ltq_mii = {
|
||||
.name = "ifxmips_mii0",
|
||||
.dev = {
|
||||
.platform_data = svip_ethaddr,
|
||||
},
|
||||
};
|
||||
|
||||
static int __init svip_set_ethaddr(char *str)
|
||||
{
|
||||
sscanf(str, "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx",
|
||||
&svip_ethaddr[0], &svip_ethaddr[1], &svip_ethaddr[2],
|
||||
&svip_ethaddr[3], &svip_ethaddr[4], &svip_ethaddr[5]);
|
||||
return 0;
|
||||
}
|
||||
__setup("ethaddr=", svip_set_ethaddr);
|
||||
|
||||
void __init svip_register_eth(void)
|
||||
{
|
||||
if (!is_valid_ether_addr(svip_ethaddr))
|
||||
random_ether_addr(svip_ethaddr);
|
||||
|
||||
platform_device_register(<q_mii);
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_ETHSW);
|
||||
}
|
||||
|
||||
/* Virtual Ethernet */
|
||||
static struct platform_device ltq_ve = {
|
||||
.name = "ifxmips_svip_ve",
|
||||
};
|
||||
|
||||
void __init svip_register_virtual_eth(void)
|
||||
{
|
||||
platform_device_register(<q_ve);
|
||||
}
|
||||
|
||||
/* SPI */
|
||||
static void __init ltq_register_ssc(int bus_num, unsigned long base, int irq_rx,
|
||||
int irq_tx, int irq_err, int irq_frm)
|
||||
{
|
||||
struct resource res[] = {
|
||||
{
|
||||
.name = "regs",
|
||||
.start = base,
|
||||
.end = base + 0x20 - 1,
|
||||
.flags = IORESOURCE_MEM,
|
||||
}, {
|
||||
.name = "rx",
|
||||
.start = irq_rx,
|
||||
.flags = IORESOURCE_IRQ,
|
||||
}, {
|
||||
.name = "tx",
|
||||
.start = irq_tx,
|
||||
.flags = IORESOURCE_IRQ,
|
||||
}, {
|
||||
.name = "err",
|
||||
.start = irq_err,
|
||||
.flags = IORESOURCE_IRQ,
|
||||
}, {
|
||||
.name = "frm",
|
||||
.start = irq_frm,
|
||||
.flags = IORESOURCE_IRQ,
|
||||
},
|
||||
};
|
||||
|
||||
platform_device_register_simple("ifx_ssc", bus_num, res,
|
||||
ARRAY_SIZE(res));
|
||||
}
|
||||
|
||||
static struct spi_board_info bdinfo[] __initdata = {
|
||||
{
|
||||
.modalias = "xt16",
|
||||
.mode = SPI_MODE_3,
|
||||
.irq = INT_NUM_IM5_IRL0 + 28,
|
||||
.max_speed_hz = 1000000,
|
||||
.bus_num = 0,
|
||||
.chip_select = 1,
|
||||
},
|
||||
{
|
||||
.modalias = "xt16",
|
||||
.mode = SPI_MODE_3,
|
||||
.irq = INT_NUM_IM5_IRL0 + 19,
|
||||
.max_speed_hz = 1000000,
|
||||
.bus_num = 0,
|
||||
.chip_select = 2,
|
||||
},
|
||||
{
|
||||
.modalias = "loop",
|
||||
.mode = SPI_MODE_0 | SPI_LOOP,
|
||||
.irq = -1,
|
||||
.max_speed_hz = 10000000,
|
||||
.bus_num = 0,
|
||||
.chip_select = 3,
|
||||
},
|
||||
};
|
||||
|
||||
void __init svip_register_spi(void)
|
||||
{
|
||||
|
||||
ltq_register_ssc(0, LTQ_SSC0_BASE, INT_NUM_IM1_IRL0 + 6,
|
||||
INT_NUM_IM1_IRL0 + 7, INT_NUM_IM1_IRL0 + 8,
|
||||
INT_NUM_IM1_IRL0 + 9);
|
||||
|
||||
ltq_register_ssc(1, LTQ_SSC1_BASE, INT_NUM_IM1_IRL0 + 10,
|
||||
INT_NUM_IM1_IRL0 + 11, INT_NUM_IM1_IRL0 + 12,
|
||||
INT_NUM_IM1_IRL0 + 13);
|
||||
|
||||
spi_register_board_info(bdinfo, ARRAY_SIZE(bdinfo));
|
||||
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_SSC0 | SYS1_CLKENR_SSC1);
|
||||
}
|
||||
|
||||
void __init svip_register_spi_flash(struct spi_board_info *bdinfo)
|
||||
{
|
||||
spi_register_board_info(bdinfo, 1);
|
||||
}
|
||||
|
||||
/* GPIO */
|
||||
static struct platform_device ltq_gpio = {
|
||||
.name = "ifxmips_gpio",
|
||||
};
|
||||
|
||||
void __init svip_register_gpio(void)
|
||||
{
|
||||
platform_device_register(<q_gpio);
|
||||
}
|
||||
|
||||
/* MUX */
|
||||
static struct ltq_mux_settings ltq_mux_settings;
|
||||
|
||||
static struct platform_device ltq_mux = {
|
||||
.name = "ltq_mux",
|
||||
.dev = {
|
||||
.platform_data = <q_mux_settings,
|
||||
}
|
||||
};
|
||||
|
||||
void __init svip_register_mux(const struct ltq_mux_pin mux_p0[LTQ_MUX_P0_PINS],
|
||||
const struct ltq_mux_pin mux_p1[LTQ_MUX_P1_PINS],
|
||||
const struct ltq_mux_pin mux_p2[LTQ_MUX_P2_PINS],
|
||||
const struct ltq_mux_pin mux_p3[LTQ_MUX_P3_PINS],
|
||||
const struct ltq_mux_pin mux_p4[LTQ_MUX_P4_PINS])
|
||||
{
|
||||
ltq_mux_settings.mux_p0 = mux_p0;
|
||||
ltq_mux_settings.mux_p1 = mux_p1;
|
||||
ltq_mux_settings.mux_p2 = mux_p2;
|
||||
ltq_mux_settings.mux_p3 = mux_p3;
|
||||
ltq_mux_settings.mux_p4 = mux_p4;
|
||||
|
||||
if (mux_p0)
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_PORT0);
|
||||
|
||||
if (mux_p1)
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_PORT1);
|
||||
|
||||
if (mux_p2)
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_PORT2);
|
||||
|
||||
if (mux_p3)
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_PORT3);
|
||||
|
||||
if (mux_p4)
|
||||
svip_sys2_clk_enable(SYS2_CLKENR_PORT4);
|
||||
|
||||
platform_device_register(<q_mux);
|
||||
}
|
||||
|
||||
/* NAND */
|
||||
#define NAND_ADDR_REGION_BASE (LTQ_EBU_SEG1_BASE)
|
||||
#define NAND_CLE_BIT (1 << 3)
|
||||
#define NAND_ALE_BIT (1 << 2)
|
||||
|
||||
static struct svip_reg_ebu *const ebu = (struct svip_reg_ebu *)LTQ_EBU_BASE;
|
||||
|
||||
static int svip_nand_probe(struct platform_device *pdev)
|
||||
{
|
||||
ebu_w32(LTQ_EBU_ADDR_SEL_0_BASE_VAL(CPHYSADDR(NAND_ADDR_REGION_BASE)
|
||||
>> 12)
|
||||
| LTQ_EBU_ADDR_SEL_0_MASK_VAL(15)
|
||||
| LTQ_EBU_ADDR_SEL_0_MRME_VAL(0)
|
||||
| LTQ_EBU_ADDR_SEL_0_REGEN_VAL(1),
|
||||
addr_sel_0);
|
||||
|
||||
ebu_w32(LTQ_EBU_CON_0_WRDIS_VAL(0)
|
||||
| LTQ_EBU_CON_0_ADSWP_VAL(1)
|
||||
| LTQ_EBU_CON_0_AGEN_VAL(0x00)
|
||||
| LTQ_EBU_CON_0_SETUP_VAL(1)
|
||||
| LTQ_EBU_CON_0_WAIT_VAL(0x00)
|
||||
| LTQ_EBU_CON_0_WINV_VAL(0)
|
||||
| LTQ_EBU_CON_0_PW_VAL(0x00)
|
||||
| LTQ_EBU_CON_0_ALEC_VAL(0)
|
||||
| LTQ_EBU_CON_0_BCGEN_VAL(0x01)
|
||||
| LTQ_EBU_CON_0_WAITWRC_VAL(1)
|
||||
| LTQ_EBU_CON_0_WAITRDC_VAL(1)
|
||||
| LTQ_EBU_CON_0_HOLDC_VAL(1)
|
||||
| LTQ_EBU_CON_0_RECOVC_VAL(0)
|
||||
| LTQ_EBU_CON_0_CMULT_VAL(0x01),
|
||||
con_0);
|
||||
|
||||
/*
|
||||
* ECC disabled
|
||||
* CLE, ALE and CS are pulse, all other signal are latches based
|
||||
* CLE and ALE are active high, PRE, WP, SE and CS/CE are active low
|
||||
* OUT_CS_S is disabled
|
||||
* NAND mode is disabled
|
||||
*/
|
||||
ebu_w32(LTQ_EBU_NAND_CON_ECC_ON_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_LAT_EN_VAL(0x38)
|
||||
| LTQ_EBU_NAND_CON_OUT_CS_S_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_IN_CS_S_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_PRE_P_VAL(1)
|
||||
| LTQ_EBU_NAND_CON_WP_P_VAL(1)
|
||||
| LTQ_EBU_NAND_CON_SE_P_VAL(1)
|
||||
| LTQ_EBU_NAND_CON_CS_P_VAL(1)
|
||||
| LTQ_EBU_NAND_CON_CLE_P_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_ALE_P_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_CSMUX_E_VAL(0)
|
||||
| LTQ_EBU_NAND_CON_NANDMODE_VAL(0),
|
||||
nand_con);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void svip_nand_hwcontrol(struct mtd_info *mtd, int cmd,
|
||||
unsigned int ctrl)
|
||||
{
|
||||
struct nand_chip *this = mtd->priv;
|
||||
|
||||
if (ctrl & NAND_CTRL_CHANGE) {
|
||||
unsigned long adr;
|
||||
/* Coming here means to change either the enable state or
|
||||
* the address for controlling ALE or CLE */
|
||||
|
||||
/* NAND_NCE: Select the chip by setting nCE to low.
|
||||
* This is done in CON register */
|
||||
if (ctrl & NAND_NCE)
|
||||
ebu_w32_mask(0, LTQ_EBU_NAND_CON_NANDMODE_VAL(1),
|
||||
nand_con);
|
||||
else
|
||||
ebu_w32_mask(LTQ_EBU_NAND_CON_NANDMODE_VAL(1),
|
||||
0, nand_con);
|
||||
|
||||
/* The addressing of CLE or ALE is done via different addresses.
|
||||
We are now changing the address depending on the given action
|
||||
SVIPs NAND_CLE_BIT = (1 << 3), NAND_CLE = 0x02
|
||||
NAND_ALE_BIT = (1 << 2) = NAND_ALE (0x04) */
|
||||
adr = (unsigned long)this->IO_ADDR_W;
|
||||
adr &= ~(NAND_CLE_BIT | NAND_ALE_BIT);
|
||||
adr |= (ctrl & NAND_CLE) << 2 | (ctrl & NAND_ALE);
|
||||
this->IO_ADDR_W = (void __iomem *)adr;
|
||||
}
|
||||
|
||||
if (cmd != NAND_CMD_NONE)
|
||||
writeb(cmd, this->IO_ADDR_W);
|
||||
}
|
||||
|
||||
static int svip_nand_ready(struct mtd_info *mtd)
|
||||
{
|
||||
return (ebu_r32(nand_wait) & 0x01) == 0x01;
|
||||
}
|
||||
|
||||
static inline void svip_nand_wait(void)
|
||||
{
|
||||
static const int nops = 150;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < nops; i++)
|
||||
asm("nop");
|
||||
}
|
||||
|
||||
static void svip_nand_write_buf(struct mtd_info *mtd,
|
||||
const u_char *buf, int len)
|
||||
{
|
||||
int i;
|
||||
struct nand_chip *this = mtd->priv;
|
||||
|
||||
for (i = 0; i < len; i++) {
|
||||
writeb(buf[i], this->IO_ADDR_W);
|
||||
svip_nand_wait();
|
||||
}
|
||||
}
|
||||
|
||||
static void svip_nand_read_buf(struct mtd_info *mtd, u_char *buf, int len)
|
||||
{
|
||||
int i;
|
||||
struct nand_chip *this = mtd->priv;
|
||||
|
||||
for (i = 0; i < len; i++) {
|
||||
buf[i] = readb(this->IO_ADDR_R);
|
||||
svip_nand_wait();
|
||||
}
|
||||
}
|
||||
|
||||
static const char *part_probes[] = { "cmdlinepart", NULL };
|
||||
|
||||
static struct platform_nand_data svip_flash_nand_data = {
|
||||
.chip = {
|
||||
.nr_chips = 1,
|
||||
.part_probe_types = part_probes,
|
||||
},
|
||||
.ctrl = {
|
||||
.probe = svip_nand_probe,
|
||||
.cmd_ctrl = svip_nand_hwcontrol,
|
||||
.dev_ready = svip_nand_ready,
|
||||
.write_buf = svip_nand_write_buf,
|
||||
.read_buf = svip_nand_read_buf,
|
||||
}
|
||||
};
|
||||
|
||||
static struct resource svip_nand_resources[] = {
|
||||
MEM_RES("nand", LTQ_FLASH_START, LTQ_FLASH_MAX),
|
||||
};
|
||||
|
||||
static struct platform_device svip_flash_nand = {
|
||||
.name = "gen_nand",
|
||||
.id = -1,
|
||||
.num_resources = ARRAY_SIZE(svip_nand_resources),
|
||||
.resource = svip_nand_resources,
|
||||
.dev = {
|
||||
.platform_data = &svip_flash_nand_data,
|
||||
},
|
||||
};
|
||||
|
||||
void __init svip_register_nand(void)
|
||||
{
|
||||
platform_device_register(&svip_flash_nand);
|
||||
}
|
|
@ -1,23 +0,0 @@
|
|||
#ifndef _SVIP_DEVICES_H__
|
||||
#define _SVIP_DEVICES_H__
|
||||
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
#include <svip_mux.h>
|
||||
#include "../devices.h"
|
||||
|
||||
extern void __init svip_register_asc(int port);
|
||||
extern void __init svip_register_eth(void);
|
||||
extern void __init svip_register_virtual_eth(void);
|
||||
extern void __init svip_register_spi(void);
|
||||
extern void __init svip_register_spi_flash(struct spi_board_info *bdinfo);
|
||||
extern void __init svip_register_gpio(void);
|
||||
extern void __init svip_register_mux(const struct ltq_mux_pin mux_p0[LTQ_MUX_P0_PINS],
|
||||
const struct ltq_mux_pin mux_p1[LTQ_MUX_P1_PINS],
|
||||
const struct ltq_mux_pin mux_p2[LTQ_MUX_P2_PINS],
|
||||
const struct ltq_mux_pin mux_p3[LTQ_MUX_P3_PINS],
|
||||
const struct ltq_mux_pin mux_p4[LTQ_MUX_P4_PINS]);
|
||||
extern void __init svip_register_nand(void);
|
||||
|
||||
#endif
|
File diff suppressed because it is too large
Load Diff
|
@ -1,553 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/ioport.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/errno.h>
|
||||
#include <linux/proc_fs.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/ioctl.h>
|
||||
#include <linux/timer.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/kobject.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/skbuff.h>
|
||||
#include <linux/netlink.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <net/sock.h>
|
||||
#include <linux/uaccess.h>
|
||||
#include <linux/version.h>
|
||||
#include <linux/semaphore.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <svip_mux.h>
|
||||
#include <base_reg.h>
|
||||
#include <port_reg.h>
|
||||
|
||||
#define DRV_NAME "ifxmips_gpio"
|
||||
|
||||
int gpio_to_irq(unsigned int gpio)
|
||||
{
|
||||
return -EINVAL;
|
||||
}
|
||||
EXPORT_SYMBOL(gpio_to_irq);
|
||||
|
||||
int irq_to_gpio(unsigned int gpio)
|
||||
{
|
||||
return -EINVAL;
|
||||
}
|
||||
EXPORT_SYMBOL(irq_to_gpio);
|
||||
|
||||
struct ltq_port_base {
|
||||
struct svip_reg_port *base;
|
||||
u32 pins;
|
||||
};
|
||||
|
||||
/* Base addresses for ports */
|
||||
static const struct ltq_port_base ltq_port_base[] = {
|
||||
{ (struct svip_reg_port *)LTQ_PORT_P0_BASE, 20 },
|
||||
{ (struct svip_reg_port *)LTQ_PORT_P1_BASE, 20 },
|
||||
{ (struct svip_reg_port *)LTQ_PORT_P2_BASE, 19 },
|
||||
{ (struct svip_reg_port *)LTQ_PORT_P3_BASE, 20 },
|
||||
{ (struct svip_reg_port *)LTQ_PORT_P4_BASE, 24 }
|
||||
};
|
||||
|
||||
#define MAX_PORTS ARRAY_SIZE(ltq_port_base)
|
||||
#define PINS_PER_PORT(port) (ltq_port_base[port].pins)
|
||||
|
||||
static inline
|
||||
void ltq_port_set_exintcr0(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->exintcr0) | (1 << pin),
|
||||
ltq_port_base[port].base->exintcr0);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_exintcr0(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->exintcr0) & ~(1 << pin),
|
||||
ltq_port_base[port].base->exintcr0);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_exintcr1(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->exintcr1) | (1 << pin),
|
||||
ltq_port_base[port].base->exintcr1);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_exintcr1(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->exintcr1) & ~(1 << pin),
|
||||
ltq_port_base[port].base->exintcr1);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_irncfg(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->irncfg) | (1 << pin),
|
||||
ltq_port_base[port].base->irncfg);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_irncfg(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->irncfg) & ~(1 << pin),
|
||||
ltq_port_base[port].base->irncfg);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_irnen(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(1 << pin, ltq_port_base[port].base->irnenset);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_irnen(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(1 << pin, ltq_port_base[port].base->irnenclr);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_dir_out(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->dir) | (1 << pin),
|
||||
ltq_port_base[port].base->dir);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_dir_in(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->dir) & ~(1 << pin),
|
||||
ltq_port_base[port].base->dir);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_output(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->out) | (1 << pin),
|
||||
ltq_port_base[port].base->out);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_output(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->out) & ~(1 << pin),
|
||||
ltq_port_base[port].base->out);
|
||||
}
|
||||
|
||||
static inline
|
||||
int ltq_port_get_input(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return -EINVAL;
|
||||
|
||||
return (port_r32(ltq_port_base[port].base->in) & (1 << pin)) == 0;
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_puen(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->puen) | (1 << pin),
|
||||
ltq_port_base[port].base->puen);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_puen(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->puen) & ~(1 << pin),
|
||||
ltq_port_base[port].base->puen);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_altsel0(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->altsel0) | (1 << pin),
|
||||
ltq_port_base[port].base->altsel0);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_altsel0(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->altsel0) & ~(1 << pin),
|
||||
ltq_port_base[port].base->altsel0);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_set_altsel1(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->altsel1) | (1 << pin),
|
||||
ltq_port_base[port].base->altsel1);
|
||||
}
|
||||
|
||||
static inline
|
||||
void ltq_port_clear_altsel1(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return;
|
||||
|
||||
port_w32(port_r32(ltq_port_base[port].base->altsel1) & ~(1 << pin),
|
||||
ltq_port_base[port].base->altsel1);
|
||||
}
|
||||
|
||||
void ltq_gpio_configure(int port, int pin, bool dirin, bool puen,
|
||||
bool altsel0, bool altsel1)
|
||||
{
|
||||
if (dirin)
|
||||
ltq_port_set_dir_in(port, pin);
|
||||
else
|
||||
ltq_port_set_dir_out(port, pin);
|
||||
|
||||
if (puen)
|
||||
ltq_port_set_puen(port, pin);
|
||||
else
|
||||
ltq_port_clear_puen(port, pin);
|
||||
|
||||
if (altsel0)
|
||||
ltq_port_set_altsel0(port, pin);
|
||||
else
|
||||
ltq_port_clear_altsel0(port, pin);
|
||||
|
||||
if (altsel1)
|
||||
ltq_port_set_altsel1(port, pin);
|
||||
else
|
||||
ltq_port_clear_altsel1(port, pin);
|
||||
}
|
||||
|
||||
int ltq_port_get_dir(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return -EINVAL;
|
||||
|
||||
return (port_r32(ltq_port_base[port].base->dir) & (1 << pin)) != 0;
|
||||
}
|
||||
|
||||
int ltq_port_get_puden(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return -EINVAL;
|
||||
|
||||
return (port_r32(ltq_port_base[port].base->puen) & (1 << pin)) != 0;
|
||||
}
|
||||
|
||||
int ltq_port_get_altsel0(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return -EINVAL;
|
||||
|
||||
return (port_r32(ltq_port_base[port].base->altsel0) & (1 << pin)) != 0;
|
||||
}
|
||||
|
||||
int ltq_port_get_altsel1(unsigned int port, unsigned int pin)
|
||||
{
|
||||
if (port >= MAX_PORTS || pin >= PINS_PER_PORT(port))
|
||||
return -EINVAL;
|
||||
|
||||
return (port_r32(ltq_port_base[port].base->altsel1) & (1 << pin)) != 0;
|
||||
}
|
||||
|
||||
struct ltq_gpio_port {
|
||||
struct gpio_chip gpio_chip;
|
||||
unsigned int irq_base;
|
||||
unsigned int chained_irq;
|
||||
};
|
||||
|
||||
static struct ltq_gpio_port ltq_gpio_port[MAX_PORTS];
|
||||
|
||||
static int gpio_exported;
|
||||
static int __init gpio_export_setup(char *str)
|
||||
{
|
||||
get_option(&str, &gpio_exported);
|
||||
return 1;
|
||||
}
|
||||
__setup("gpio_exported=", gpio_export_setup);
|
||||
|
||||
static inline unsigned int offset2port(unsigned int offset)
|
||||
{
|
||||
unsigned int i;
|
||||
unsigned int prev = 0;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(ltq_port_base); i++) {
|
||||
if (offset >= prev &&
|
||||
offset < prev + ltq_port_base[i].pins)
|
||||
return i;
|
||||
|
||||
prev = ltq_port_base[i].pins;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline unsigned int offset2pin(unsigned int offset)
|
||||
{
|
||||
unsigned int i;
|
||||
unsigned int prev = 0;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(ltq_port_base); i++) {
|
||||
if (offset >= prev &&
|
||||
offset < prev + ltq_port_base[i].pins)
|
||||
return offset - prev;
|
||||
|
||||
prev = ltq_port_base[i].pins;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ltq_gpio_direction_input(struct gpio_chip *chip, unsigned int offset)
|
||||
{
|
||||
ltq_port_set_dir_in(offset2port(offset), offset2pin(offset));
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ltq_gpio_direction_output(struct gpio_chip *chip,
|
||||
unsigned int offset, int value)
|
||||
{
|
||||
ltq_port_set_dir_out(offset2port(offset), offset2pin(offset));
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ltq_gpio_get(struct gpio_chip *chip, unsigned int offset)
|
||||
{
|
||||
return ltq_port_get_input(offset2port(offset), offset2pin(offset));
|
||||
}
|
||||
|
||||
static void ltq_gpio_set(struct gpio_chip *chip, unsigned int offset, int value)
|
||||
{
|
||||
if (value)
|
||||
ltq_port_set_output(offset2port(offset), offset2pin(offset));
|
||||
else
|
||||
ltq_port_clear_output(offset2port(offset), offset2pin(offset));
|
||||
}
|
||||
|
||||
static int svip_gpio_request(struct gpio_chip *chip, unsigned offset)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void ltq_gpio_free(struct gpio_chip *chip, unsigned offset)
|
||||
{
|
||||
}
|
||||
|
||||
static int ltq_gpio_probe(struct platform_device *pdev)
|
||||
{
|
||||
int ret = 0;
|
||||
struct ltq_gpio_port *gpio_port;
|
||||
|
||||
if (pdev->id >= MAX_PORTS)
|
||||
return -ENODEV;
|
||||
|
||||
gpio_port = <q_gpio_port[pdev->id];
|
||||
gpio_port->gpio_chip.label = "ltq-gpio";
|
||||
|
||||
gpio_port->gpio_chip.direction_input = ltq_gpio_direction_input;
|
||||
gpio_port->gpio_chip.direction_output = ltq_gpio_direction_output;
|
||||
gpio_port->gpio_chip.get = ltq_gpio_get;
|
||||
gpio_port->gpio_chip.set = ltq_gpio_set;
|
||||
gpio_port->gpio_chip.request = svip_gpio_request;
|
||||
gpio_port->gpio_chip.free = ltq_gpio_free;
|
||||
gpio_port->gpio_chip.base = 100 * pdev->id;
|
||||
gpio_port->gpio_chip.ngpio = 32;
|
||||
gpio_port->gpio_chip.dev = &pdev->dev;
|
||||
gpio_port->gpio_chip.exported = gpio_exported;
|
||||
|
||||
ret = gpiochip_add(&gpio_port->gpio_chip);
|
||||
if (ret < 0) {
|
||||
dev_err(&pdev->dev, "Could not register gpiochip %d, %d\n",
|
||||
pdev->id, ret);
|
||||
goto err;
|
||||
}
|
||||
platform_set_drvdata(pdev, gpio_port);
|
||||
|
||||
return 0;
|
||||
|
||||
err:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int ltq_gpio_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct ltq_gpio_port *gpio_port = platform_get_drvdata(pdev);
|
||||
int ret;
|
||||
|
||||
ret = gpiochip_remove(&gpio_port->gpio_chip);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static struct platform_driver ltq_gpio_driver = {
|
||||
.probe = ltq_gpio_probe,
|
||||
.remove = __devexit_p(ltq_gpio_remove),
|
||||
.driver = {
|
||||
.name = DRV_NAME,
|
||||
.owner = THIS_MODULE,
|
||||
},
|
||||
};
|
||||
|
||||
int __init ltq_gpio_init(void)
|
||||
{
|
||||
int ret = platform_driver_register(<q_gpio_driver);
|
||||
if (ret)
|
||||
printk(KERN_INFO DRV_NAME
|
||||
": Error registering platform driver!");
|
||||
return ret;
|
||||
}
|
||||
|
||||
postcore_initcall(ltq_gpio_init);
|
||||
|
||||
/**
|
||||
* Convert interrupt number to corresponding port/pin pair
|
||||
* Returns the port/pin pair serving the selected external interrupt;
|
||||
* needed since mapping not linear.
|
||||
*
|
||||
* \param exint External interrupt number
|
||||
* \param port Pointer for resulting port
|
||||
* \param pin Pointer for resutling pin
|
||||
* \return -EINVAL Invalid exint
|
||||
* \return 0 port/pin updated
|
||||
* \ingroup API
|
||||
*/
|
||||
static int ltq_exint2port(u32 exint, int *port, int *pin)
|
||||
{
|
||||
if ((exint >= 0) && (exint <= 10)) {
|
||||
*port = 0;
|
||||
*pin = exint + 7;
|
||||
} else if ((exint >= 11) && (exint <= 14)) {
|
||||
*port = 1;
|
||||
*pin = 18 - (exint - 11) ;
|
||||
} else if (exint == 15) {
|
||||
*port = 1;
|
||||
*pin = 19;
|
||||
} else if (exint == 16) {
|
||||
*port = 0;
|
||||
*pin = 19;
|
||||
} else {
|
||||
return -EINVAL;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Enable external interrupt.
|
||||
* This function enables an external interrupt and sets the given mode.
|
||||
* valid values for mode are:
|
||||
* - 0 = Interrupt generation disabled
|
||||
* - 1 = Interrupt on rising edge
|
||||
* - 2 = Interrupt on falling edge
|
||||
* - 3 = Interrupt on rising and falling edge
|
||||
* - 5 = Interrupt on high level detection
|
||||
* - 6 = Interrupt on low level detection
|
||||
*
|
||||
* \param exint - Number of external interrupt
|
||||
* \param mode - Trigger mode
|
||||
* \return 0 on success
|
||||
* \ingroup API
|
||||
*/
|
||||
int ifx_enable_external_int(u32 exint, u32 mode)
|
||||
{
|
||||
int port;
|
||||
int pin;
|
||||
|
||||
if ((mode < 0) || (mode > 6))
|
||||
return -EINVAL;
|
||||
|
||||
if (ltq_exint2port(exint, &port, &pin))
|
||||
return -EINVAL;
|
||||
|
||||
ltq_port_clear_exintcr0(port, pin);
|
||||
ltq_port_clear_exintcr1(port, pin);
|
||||
ltq_port_clear_irncfg(port, pin);
|
||||
|
||||
if (mode & 0x1)
|
||||
ltq_port_set_exintcr0(port, pin);
|
||||
if (mode & 0x2)
|
||||
ltq_port_set_exintcr1(port, pin);
|
||||
if (mode & 0x4)
|
||||
ltq_port_set_irncfg(port, pin);
|
||||
|
||||
ltq_port_set_irnen(port, pin);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(ifx_enable_external_int);
|
||||
|
||||
/**
|
||||
* Disable external interrupt.
|
||||
* This function disables an external interrupt and sets mode to 0x00.
|
||||
*
|
||||
* \param exint - Number of external interrupt
|
||||
* \return 0 on success
|
||||
* \ingroup API
|
||||
*/
|
||||
int ifx_disable_external_int(u32 exint)
|
||||
{
|
||||
int port;
|
||||
int pin;
|
||||
|
||||
if (ltq_exint2port(exint, &port, &pin))
|
||||
return -EINVAL;
|
||||
|
||||
ltq_port_clear_irnen(port, pin);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(ifx_disable_external_int);
|
|
@ -1,73 +0,0 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
#include "../machtypes.h"
|
||||
|
||||
#include <sys1_reg.h>
|
||||
#include <sys2_reg.h>
|
||||
#include <svip_pms.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
static const struct ltq_mux_pin mux_p0[LTQ_MUX_P0_PINS] = {
|
||||
LTQ_MUX_P0_0_SSC0_MTSR,
|
||||
LTQ_MUX_P0_1_SSC0_MRST,
|
||||
LTQ_MUX_P0_2_SSC0_SCLK,
|
||||
LTQ_MUX_P0_3_SSC1_MTSR,
|
||||
LTQ_MUX_P0_4_SSC1_MRST,
|
||||
LTQ_MUX_P0_5_SSC1_SCLK,
|
||||
LTQ_MUX_P0_6_SSC0_CS0,
|
||||
LTQ_MUX_P0_7_SSC0_CS1,
|
||||
LTQ_MUX_P0_8_SSC0_CS2,
|
||||
LTQ_MUX_P0_9,
|
||||
LTQ_MUX_P0_10,
|
||||
LTQ_MUX_P0_11_EXINT4,
|
||||
LTQ_MUX_P0_12,
|
||||
LTQ_MUX_P0_13,
|
||||
LTQ_MUX_P0_14_ASC0_TXD,
|
||||
LTQ_MUX_P0_15_ASC0_RXD,
|
||||
LTQ_MUX_P0_16_EXINT9,
|
||||
LTQ_MUX_P0_17_EXINT10,
|
||||
LTQ_MUX_P0_18_EJ_BRKIN,
|
||||
LTQ_MUX_P0_19_EXINT16
|
||||
};
|
||||
|
||||
static void __init easy33016_init(void)
|
||||
{
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_L2C |
|
||||
SYS1_CLKENR_DDR2 |
|
||||
SYS1_CLKENR_SMI2 |
|
||||
SYS1_CLKENR_SMI1 |
|
||||
SYS1_CLKENR_SMI0 |
|
||||
SYS1_CLKENR_FMI0 |
|
||||
SYS1_CLKENR_DMA |
|
||||
SYS1_CLKENR_SSC0 |
|
||||
SYS1_CLKENR_SSC1 |
|
||||
SYS1_CLKENR_EBU);
|
||||
|
||||
svip_sys2_clk_enable(SYS2_CLKENR_HWSYNC |
|
||||
SYS2_CLKENR_MBS |
|
||||
SYS2_CLKENR_SWINT);
|
||||
|
||||
svip_register_mux(mux_p0, NULL, NULL, NULL, NULL);
|
||||
svip_register_asc(0);
|
||||
svip_register_eth();
|
||||
svip_register_virtual_eth();
|
||||
ltq_register_wdt();
|
||||
svip_register_gpio();
|
||||
svip_register_spi();
|
||||
svip_register_nand();
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY33016,
|
||||
"EASY33016",
|
||||
"EASY33016",
|
||||
easy33016_init);
|
|
@ -1,221 +0,0 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
#include "../machtypes.h"
|
||||
|
||||
#include <sys1_reg.h>
|
||||
#include <sys2_reg.h>
|
||||
#include <svip_pms.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
static struct mtd_partition easy336_sflash_partitions[] = {
|
||||
{
|
||||
.name = "SPI flash",
|
||||
.size = MTDPART_SIZ_FULL,
|
||||
.offset = 0,
|
||||
},
|
||||
};
|
||||
|
||||
static struct flash_platform_data easy336_sflash_data = {
|
||||
.name = "m25p32",
|
||||
.parts = (void *)&easy336_sflash_partitions,
|
||||
.nr_parts = ARRAY_SIZE(easy336_sflash_partitions),
|
||||
.type = "m25p32",
|
||||
};
|
||||
|
||||
static struct spi_board_info bdinfo[] __initdata = {
|
||||
{
|
||||
.modalias = "m25p80",
|
||||
.platform_data = &easy336_sflash_data,
|
||||
.mode = SPI_MODE_0,
|
||||
.irq = -1,
|
||||
.max_speed_hz = 25000000,
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
}
|
||||
};
|
||||
|
||||
static struct mtd_partition easy336_partitions[] = {
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x40000,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x60000,
|
||||
.size = 0x1a0000,
|
||||
},
|
||||
{
|
||||
.name = "rootfs",
|
||||
.offset = 0x200000,
|
||||
.size = 0x500000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data easy336_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(easy336_partitions),
|
||||
.parts = easy336_partitions,
|
||||
};
|
||||
|
||||
static const struct ltq_mux_pin mux_p0[LTQ_MUX_P0_PINS] = {
|
||||
LTQ_MUX_P0_0_SSC0_MTSR,
|
||||
LTQ_MUX_P0_1_SSC0_MRST,
|
||||
LTQ_MUX_P0_2_SSC0_SCLK,
|
||||
LTQ_MUX_P0_3_SSC1_MTSR,
|
||||
LTQ_MUX_P0_4_SSC1_MRST,
|
||||
LTQ_MUX_P0_5_SSC1_SCLK,
|
||||
LTQ_MUX_P0_6_SSC0_CS0,
|
||||
LTQ_MUX_P0_7_SSC0_CS1,
|
||||
LTQ_MUX_P0_8_SSC0_CS2,
|
||||
LTQ_MUX_P0_9_SSC0_CS3,
|
||||
LTQ_MUX_P0_10_SSC0_CS4,
|
||||
LTQ_MUX_P0_11_SSC0_CS5,
|
||||
LTQ_MUX_P0_12_EXINT5,
|
||||
LTQ_MUX_P0_13_EXINT6,
|
||||
LTQ_MUX_P0_14_ASC0_TXD,
|
||||
LTQ_MUX_P0_15_ASC0_RXD,
|
||||
LTQ_MUX_P0_16_EXINT9,
|
||||
LTQ_MUX_P0_17_EXINT10,
|
||||
LTQ_MUX_P0_18_EJ_BRKIN,
|
||||
LTQ_MUX_P0_19_EXINT16
|
||||
};
|
||||
|
||||
static const struct ltq_mux_pin mux_p2[LTQ_MUX_P2_PINS] = {
|
||||
LTQ_MUX_P2_0_EBU_A0,
|
||||
LTQ_MUX_P2_1_EBU_A1,
|
||||
LTQ_MUX_P2_2_EBU_A2,
|
||||
LTQ_MUX_P2_3_EBU_A3,
|
||||
LTQ_MUX_P2_4_EBU_A4,
|
||||
LTQ_MUX_P2_5_EBU_A5,
|
||||
LTQ_MUX_P2_6_EBU_A6,
|
||||
LTQ_MUX_P2_7_EBU_A7,
|
||||
LTQ_MUX_P2_8_EBU_A8,
|
||||
LTQ_MUX_P2_9_EBU_A9,
|
||||
LTQ_MUX_P2_10_EBU_A10,
|
||||
LTQ_MUX_P2_11_EBU_A11,
|
||||
LTQ_MUX_P2_12_EBU_RD,
|
||||
LTQ_MUX_P2_13_EBU_WR,
|
||||
LTQ_MUX_P2_14_EBU_ALE,
|
||||
LTQ_MUX_P2_15_EBU_WAIT,
|
||||
LTQ_MUX_P2_16_EBU_RDBY,
|
||||
LTQ_MUX_P2_17_EBU_BC0,
|
||||
LTQ_MUX_P2_18_EBU_BC1
|
||||
};
|
||||
|
||||
static const struct ltq_mux_pin mux_p3[LTQ_MUX_P3_PINS] = {
|
||||
LTQ_MUX_P3_0_EBU_AD0,
|
||||
LTQ_MUX_P3_1_EBU_AD1,
|
||||
LTQ_MUX_P3_2_EBU_AD2,
|
||||
LTQ_MUX_P3_3_EBU_AD3,
|
||||
LTQ_MUX_P3_4_EBU_AD4,
|
||||
LTQ_MUX_P3_5_EBU_AD5,
|
||||
LTQ_MUX_P3_6_EBU_AD6,
|
||||
LTQ_MUX_P3_7_EBU_AD7,
|
||||
LTQ_MUX_P3_8_EBU_AD8,
|
||||
LTQ_MUX_P3_9_EBU_AD9,
|
||||
LTQ_MUX_P3_10_EBU_AD10,
|
||||
LTQ_MUX_P3_11_EBU_AD11,
|
||||
LTQ_MUX_P3_12_EBU_AD12,
|
||||
LTQ_MUX_P3_13_EBU_AD13,
|
||||
LTQ_MUX_P3_14_EBU_AD14,
|
||||
LTQ_MUX_P3_15_EBU_AD15,
|
||||
LTQ_MUX_P3_16_EBU_CS0,
|
||||
LTQ_MUX_P3_17_EBU_CS1,
|
||||
LTQ_MUX_P3_18_EBU_CS2,
|
||||
LTQ_MUX_P3_19_EBU_CS3
|
||||
};
|
||||
|
||||
static void __init easy336_init_common(void)
|
||||
{
|
||||
svip_sys1_clk_enable(SYS1_CLKENR_L2C |
|
||||
SYS1_CLKENR_DDR2 |
|
||||
SYS1_CLKENR_SMI2 |
|
||||
SYS1_CLKENR_SMI1 |
|
||||
SYS1_CLKENR_SMI0 |
|
||||
SYS1_CLKENR_FMI0 |
|
||||
SYS1_CLKENR_DMA |
|
||||
SYS1_CLKENR_GPTC |
|
||||
SYS1_CLKENR_EBU);
|
||||
|
||||
svip_sys2_clk_enable(SYS2_CLKENR_HWSYNC |
|
||||
SYS2_CLKENR_MBS |
|
||||
SYS2_CLKENR_SWINT |
|
||||
SYS2_CLKENR_HWACC3 |
|
||||
SYS2_CLKENR_HWACC2 |
|
||||
SYS2_CLKENR_HWACC1 |
|
||||
SYS2_CLKENR_HWACC0 |
|
||||
SYS2_CLKENR_SIF7 |
|
||||
SYS2_CLKENR_SIF6 |
|
||||
SYS2_CLKENR_SIF5 |
|
||||
SYS2_CLKENR_SIF4 |
|
||||
SYS2_CLKENR_SIF3 |
|
||||
SYS2_CLKENR_SIF2 |
|
||||
SYS2_CLKENR_SIF1 |
|
||||
SYS2_CLKENR_SIF0 |
|
||||
SYS2_CLKENR_DFEV7 |
|
||||
SYS2_CLKENR_DFEV6 |
|
||||
SYS2_CLKENR_DFEV5 |
|
||||
SYS2_CLKENR_DFEV4 |
|
||||
SYS2_CLKENR_DFEV3 |
|
||||
SYS2_CLKENR_DFEV2 |
|
||||
SYS2_CLKENR_DFEV1 |
|
||||
SYS2_CLKENR_DFEV0);
|
||||
|
||||
svip_register_mux(mux_p0, NULL, mux_p2, mux_p3, NULL);
|
||||
svip_register_asc(0);
|
||||
svip_register_eth();
|
||||
svip_register_virtual_eth();
|
||||
/* ltq_register_wdt(); - conflicts with lq_switch */
|
||||
svip_register_gpio();
|
||||
svip_register_spi();
|
||||
ltq_register_tapi();
|
||||
}
|
||||
|
||||
static void __init easy336_init(void)
|
||||
{
|
||||
easy336_init_common();
|
||||
ltq_register_nor(&easy336_flash_data);
|
||||
}
|
||||
|
||||
static void __init easy336sf_init(void)
|
||||
{
|
||||
easy336_init_common();
|
||||
svip_register_spi_flash(bdinfo);
|
||||
}
|
||||
|
||||
static void __init easy336nand_init(void)
|
||||
{
|
||||
easy336_init_common();
|
||||
svip_register_nand();
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY336,
|
||||
"EASY336",
|
||||
"EASY336",
|
||||
easy336_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY336SF,
|
||||
"EASY336SF",
|
||||
"EASY336 (Serial Flash)",
|
||||
easy336sf_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_EASY336NAND,
|
||||
"EASY336NAND",
|
||||
"EASY336 (NAND Flash)",
|
||||
easy336nand_init);
|
||||
|
|
@ -1,187 +0,0 @@
|
|||
/************************************************************************
|
||||
*
|
||||
* Copyright (c) 2007
|
||||
* Infineon Technologies AG
|
||||
* St. Martin Strasse 53; 81669 Muenchen; Germany
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version
|
||||
* 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
************************************************************************/
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/proc_fs.h>
|
||||
#include <linux/init.h>
|
||||
#include <asm/addrspace.h>
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <svip_mux.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <sys2_reg.h>
|
||||
#include <svip_pms.h>
|
||||
|
||||
#define DRV_NAME "ltq_mux"
|
||||
|
||||
static void ltq_mux_port_init(const int port,
|
||||
const struct ltq_mux_pin *pins,
|
||||
const int pin_max)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < pin_max; i++)
|
||||
ltq_gpio_configure(port,
|
||||
i,
|
||||
pins[i].dirin,
|
||||
pins[i].puen,
|
||||
pins[i].altsel0,
|
||||
pins[i].altsel1);
|
||||
}
|
||||
|
||||
static int ltq_mux_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct ltq_mux_settings *mux_settings = dev_get_platdata(&pdev->dev);
|
||||
|
||||
if (mux_settings->mux_p0)
|
||||
ltq_mux_port_init(0,
|
||||
mux_settings->mux_p0,
|
||||
LTQ_MUX_P0_PINS);
|
||||
|
||||
if (mux_settings->mux_p1)
|
||||
ltq_mux_port_init(1,
|
||||
mux_settings->mux_p1,
|
||||
LTQ_MUX_P1_PINS);
|
||||
|
||||
if (mux_settings->mux_p2)
|
||||
ltq_mux_port_init(2,
|
||||
mux_settings->mux_p2,
|
||||
LTQ_MUX_P2_PINS);
|
||||
|
||||
if (mux_settings->mux_p3)
|
||||
ltq_mux_port_init(3,
|
||||
mux_settings->mux_p3,
|
||||
LTQ_MUX_P3_PINS);
|
||||
|
||||
if (mux_settings->mux_p4)
|
||||
ltq_mux_port_init(4,
|
||||
mux_settings->mux_p4,
|
||||
LTQ_MUX_P4_PINS);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ltq_mux_read_procmem(char *buf, char **start, off_t offset,
|
||||
int count, int *eof, void *data)
|
||||
{
|
||||
int len = 0;
|
||||
int t = 0, i = 0;
|
||||
u32 port_clk[5] = {
|
||||
SYS1_CLKENR_PORT0,
|
||||
SYS1_CLKENR_PORT1,
|
||||
SYS1_CLKENR_PORT2,
|
||||
SYS1_CLKENR_PORT3,
|
||||
SYS2_CLKENR_PORT4,
|
||||
};
|
||||
|
||||
#define PROC_PRINT(fmt, args...) \
|
||||
do { \
|
||||
int c_len = 0; \
|
||||
c_len = snprintf(buf + len, count - len, fmt, ## args); \
|
||||
if (c_len <= 0) \
|
||||
goto out; \
|
||||
if (c_len >= (count - len)) { \
|
||||
len += (count - len); \
|
||||
goto out; \
|
||||
} \
|
||||
len += c_len; \
|
||||
if (offset > 0) { \
|
||||
if (len > offset) { \
|
||||
len -= offset; \
|
||||
memmove(buf, buf + offset, len); \
|
||||
offset = 0; \
|
||||
} else { \
|
||||
offset -= len; \
|
||||
len = 0; \
|
||||
} \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
PROC_PRINT("\nVINETIC-SVIP Multiplex Settings\n");
|
||||
PROC_PRINT(" 3 2 1 0\n");
|
||||
PROC_PRINT(" 10987654321098765432109876543210\n");
|
||||
PROC_PRINT(" --------------------------------\n");
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(port_clk); i++) {
|
||||
if (i < 4) {
|
||||
if (!svip_sys1_clk_is_enabled(port_clk[i]))
|
||||
continue;
|
||||
} else {
|
||||
if (!svip_sys2_clk_is_enabled(port_clk[i]))
|
||||
continue;
|
||||
}
|
||||
|
||||
PROC_PRINT("P%d.%-10s", i, "DIR:");
|
||||
|
||||
for (t = 31; t != -1; t--)
|
||||
PROC_PRINT("%d", ltq_port_get_dir(i, t) == 1 ? 1 : 0);
|
||||
PROC_PRINT("\n");
|
||||
|
||||
PROC_PRINT("P%d.%-10s", i, "PUEN:");
|
||||
for (t = 31; t != -1; t--)
|
||||
PROC_PRINT("%d", ltq_port_get_puden(i, t) == 1 ? 1 : 0);
|
||||
PROC_PRINT("\n");
|
||||
|
||||
PROC_PRINT("P%d.%-10s", i, "ALTSEL0:");
|
||||
for (t = 31; t != -1; t--)
|
||||
PROC_PRINT("%d",
|
||||
ltq_port_get_altsel0(i, t) == 1 ? 1 : 0);
|
||||
PROC_PRINT("\n");
|
||||
|
||||
PROC_PRINT("P%d.%-10s", i, "ALTSEL1:");
|
||||
for (t = 31; t != -1; t--)
|
||||
PROC_PRINT("%d",
|
||||
ltq_port_get_altsel1(i, t) == 1 ? 1 : 0);
|
||||
PROC_PRINT("\n\n");
|
||||
}
|
||||
|
||||
out:
|
||||
if (len < 0) {
|
||||
len = 0;
|
||||
*eof = 1;
|
||||
} else if (len < count) {
|
||||
*eof = 1;
|
||||
} else {
|
||||
len = count;
|
||||
}
|
||||
|
||||
*start = buf;
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
static struct platform_driver ltq_mux_driver = {
|
||||
.probe = ltq_mux_probe,
|
||||
.driver = {
|
||||
.name = DRV_NAME,
|
||||
.owner = THIS_MODULE,
|
||||
},
|
||||
};
|
||||
|
||||
int __init ltq_mux_init(void)
|
||||
{
|
||||
int ret = platform_driver_register(<q_mux_driver);
|
||||
if (ret) {
|
||||
printk(KERN_INFO DRV_NAME
|
||||
": Error registering platform driver!");
|
||||
return ret;
|
||||
}
|
||||
|
||||
return create_proc_read_entry("driver/ltq_mux", 0, NULL,
|
||||
ltq_mux_read_procmem, NULL) == NULL;
|
||||
}
|
||||
|
||||
module_init(ltq_mux_init);
|
|
@ -1,101 +0,0 @@
|
|||
/************************************************************************
|
||||
*
|
||||
* Copyright (c) 2007
|
||||
* Infineon Technologies AG
|
||||
* St. Martin Strasse 53; 81669 Muenchen; Germany
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version
|
||||
* 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
************************************************************************/
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/proc_fs.h>
|
||||
#include <linux/init.h>
|
||||
#include <asm/addrspace.h>
|
||||
|
||||
#include <base_reg.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <sys2_reg.h>
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
static struct svip_reg_sys1 *const sys1 = (struct svip_reg_sys1 *)LTQ_SYS1_BASE;
|
||||
static struct svip_reg_sys2 *const sys2 = (struct svip_reg_sys2 *)LTQ_SYS2_BASE;
|
||||
|
||||
void svip_sys1_clk_enable(u32 mask)
|
||||
{
|
||||
sys1_w32(sys1_r32(clksr) | mask, clkenr);
|
||||
asm("sync;");
|
||||
}
|
||||
EXPORT_SYMBOL(svip_sys1_clk_enable);
|
||||
|
||||
int svip_sys1_clk_is_enabled(u32 mask)
|
||||
{
|
||||
return (sys1_r32(clksr) & mask) != 0;
|
||||
}
|
||||
EXPORT_SYMBOL(svip_sys1_clk_is_enabled);
|
||||
|
||||
void svip_sys2_clk_enable(u32 mask)
|
||||
{
|
||||
sys2_w32(sys2_r32(clksr) | mask, clkenr);
|
||||
asm("sync;");
|
||||
}
|
||||
EXPORT_SYMBOL(svip_sys2_clk_enable);
|
||||
|
||||
int svip_sys2_clk_is_enabled(u32 mask)
|
||||
{
|
||||
return (sys2_r32(clksr) & mask) != 0;
|
||||
}
|
||||
EXPORT_SYMBOL(svip_sys2_clk_is_enabled);
|
||||
|
||||
int ltq_pms_read_procmem(char *buf, char **start, off_t offset,
|
||||
int count, int *eof, void *data)
|
||||
{
|
||||
long len = 0;
|
||||
int t = 0;
|
||||
u32 bit = 0;
|
||||
u32 reg_tmp, bits_tmp;
|
||||
|
||||
len = sprintf(buf, "\nSVIP PMS Settings\n");
|
||||
len = len + sprintf(buf + len,
|
||||
" 3 2 1 0\n");
|
||||
len = len + sprintf(buf + len,
|
||||
" 210987654321098765432109876543210\n");
|
||||
len = len + sprintf(buf + len,
|
||||
"---------------------------------------------\n");
|
||||
len = len + sprintf(buf + len,
|
||||
"SYS1_CLKSR: ");
|
||||
reg_tmp = sys1_r32(clksr);
|
||||
bit = 0x80000000;
|
||||
for (t = 31; t != -1; t--) {
|
||||
bits_tmp = (reg_tmp & bit) >> t;
|
||||
len = len + sprintf(buf + len, "%d", bits_tmp);
|
||||
bit = bit >> 1;
|
||||
}
|
||||
len = len + sprintf(buf + len, "\n\n");
|
||||
len = len + sprintf(buf + len, "SYS2_CLKSR: ");
|
||||
reg_tmp = sys2_r32(clksr);
|
||||
bit = 0x80000000;
|
||||
for (t = 31; t != -1; t--) {
|
||||
bits_tmp = (reg_tmp & bit) >> t;
|
||||
len = len + sprintf(buf + len, "%d", bits_tmp);
|
||||
bit = bit >> 1;
|
||||
}
|
||||
len = len + sprintf(buf + len, "\n\n");
|
||||
|
||||
*eof = 1;
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
int __init ltq_pms_init_proc(void)
|
||||
{
|
||||
return create_proc_read_entry("driver/ltq_pms", 0, NULL,
|
||||
ltq_pms_read_procmem, NULL) == NULL;
|
||||
}
|
||||
|
||||
module_init(ltq_pms_init_proc);
|
|
@ -1,73 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/module.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/time.h>
|
||||
#include <asm/bootinfo.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "../prom.h"
|
||||
#include "../clk.h"
|
||||
#include "../machtypes.h"
|
||||
|
||||
#include <base_reg.h>
|
||||
#include <ebu_reg.h>
|
||||
|
||||
#define SOC_SVIP "SVIP"
|
||||
|
||||
#define PART_SHIFT 12
|
||||
#define PART_MASK 0x0FFFF000
|
||||
#define REV_SHIFT 28
|
||||
#define REV_MASK 0xF0000000
|
||||
|
||||
static struct svip_reg_ebu *const ebu = (struct svip_reg_ebu *)LTQ_EBU_BASE;
|
||||
|
||||
void __init ltq_soc_init(void)
|
||||
{
|
||||
clkdev_add_static(ltq_svip_cpu_hz(), ltq_svip_fpi_hz(),
|
||||
ltq_svip_io_region_clock());
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_soc_setup(void)
|
||||
{
|
||||
if (mips_machtype == LANTIQ_MACH_EASY33016 ||
|
||||
mips_machtype == LANTIQ_MACH_EASY336) {
|
||||
ebu_w32(0x120000f1, addr_sel_2);
|
||||
ebu_w32(LTQ_EBU_CON_0_ADSWP |
|
||||
LTQ_EBU_CON_0_SETUP |
|
||||
LTQ_EBU_CON_0_BCGEN_VAL(0x02) |
|
||||
LTQ_EBU_CON_0_WAITWRC_VAL(7) |
|
||||
LTQ_EBU_CON_0_WAITRDC_VAL(3) |
|
||||
LTQ_EBU_CON_0_HOLDC_VAL(3) |
|
||||
LTQ_EBU_CON_0_RECOVC_VAL(3) |
|
||||
LTQ_EBU_CON_0_CMULT_VAL(3), con_2);
|
||||
}
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_soc_detect(struct ltq_soc_info *i)
|
||||
{
|
||||
i->partnum = (ltq_r32(LTQ_STATUS_CHIPID) & PART_MASK) >> PART_SHIFT;
|
||||
i->rev = (ltq_r32(LTQ_STATUS_CHIPID) & REV_MASK) >> REV_SHIFT;
|
||||
sprintf(i->rev_type, "1.%d", i->rev);
|
||||
switch (i->partnum) {
|
||||
case SOC_ID_SVIP:
|
||||
i->name = SOC_SVIP;
|
||||
i->type = SOC_TYPE_SVIP;
|
||||
break;
|
||||
|
||||
default:
|
||||
printk(KERN_ERR "unknown partnum : 0x%08X\n", i->partnum);
|
||||
while (1);
|
||||
break;
|
||||
}
|
||||
}
|
|
@ -1,95 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/ioport.h>
|
||||
#include <linux/pm.h>
|
||||
#include <linux/module.h>
|
||||
#include <asm/reboot.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include "../machtypes.h"
|
||||
#include <base_reg.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <boot_reg.h>
|
||||
#include <ebu_reg.h>
|
||||
|
||||
static struct svip_reg_sys1 *const sys1 = (struct svip_reg_sys1 *)LTQ_SYS1_BASE;
|
||||
static struct svip_reg_ebu *const ebu = (struct svip_reg_ebu *)LTQ_EBU_BASE;
|
||||
|
||||
#define CPLD_CMDREG3 ((volatile unsigned char*)(KSEG1 + 0x120000f3))
|
||||
extern void switchip_reset(void);
|
||||
|
||||
static void ltq_machine_restart(char *command)
|
||||
{
|
||||
printk(KERN_NOTICE "System restart\n");
|
||||
local_irq_disable();
|
||||
|
||||
if (mips_machtype == LANTIQ_MACH_EASY33016 ||
|
||||
mips_machtype == LANTIQ_MACH_EASY336) {
|
||||
/* We just use the CPLD function to reset the entire system as a
|
||||
workaround for the switch reset problem */
|
||||
local_irq_disable();
|
||||
ebu_w32(0x120000f1, addr_sel_2);
|
||||
ebu_w32(0x404027ff, con_2);
|
||||
|
||||
if (mips_machtype == LANTIQ_MACH_EASY336)
|
||||
/* set bit 0 to reset SVIP */
|
||||
*CPLD_CMDREG3 = (1<<0);
|
||||
else
|
||||
/* set bit 7 to reset SVIP, set bit 3 to reset xT */
|
||||
*CPLD_CMDREG3 = (1<<7) | (1<<3);
|
||||
} else {
|
||||
*LTQ_BOOT_RVEC(0) = 0;
|
||||
/* reset all except PER, SUBSYS and CPU0 */
|
||||
sys1_w32(0x00043F3E, rreqr);
|
||||
/* release WDT0 reset */
|
||||
sys1_w32(0x00000100, rrlsr);
|
||||
/* restore reset value for clock enables */
|
||||
sys1_w32(~0x0c000040, clkclr);
|
||||
/* reset SUBSYS (incl. DDR2) and CPU0 */
|
||||
sys1_w32(0x00030001, rbtr);
|
||||
}
|
||||
|
||||
for (;;)
|
||||
;
|
||||
}
|
||||
|
||||
static void ltq_machine_halt(void)
|
||||
{
|
||||
printk(KERN_NOTICE "System halted.\n");
|
||||
local_irq_disable();
|
||||
for (;;)
|
||||
;
|
||||
}
|
||||
|
||||
static void ltq_machine_power_off(void)
|
||||
{
|
||||
printk(KERN_NOTICE "Please turn off the power now.\n");
|
||||
local_irq_disable();
|
||||
for (;;)
|
||||
;
|
||||
}
|
||||
|
||||
/* This function is used by the watchdog driver */
|
||||
int ltq_reset_cause(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(ltq_reset_cause);
|
||||
|
||||
static int __init mips_reboot_setup(void)
|
||||
{
|
||||
_machine_restart = ltq_machine_restart;
|
||||
_machine_halt = ltq_machine_halt;
|
||||
pm_power_off = ltq_machine_power_off;
|
||||
return 0;
|
||||
}
|
||||
|
||||
arch_initcall(mips_reboot_setup);
|
|
@ -1,666 +0,0 @@
|
|||
/******************************************************************************
|
||||
Copyright (c) 2007, Infineon Technologies. All rights reserved.
|
||||
|
||||
No Warranty
|
||||
Because the program is licensed free of charge, there is no warranty for
|
||||
the program, to the extent permitted by applicable law. Except when
|
||||
otherwise stated in writing the copyright holders and/or other parties
|
||||
provide the program "as is" without warranty of any kind, either
|
||||
expressed or implied, including, but not limited to, the implied
|
||||
warranties of merchantability and fitness for a particular purpose. The
|
||||
entire risk as to the quality and performance of the program is with
|
||||
you. should the program prove defective, you assume the cost of all
|
||||
necessary servicing, repair or correction.
|
||||
|
||||
In no event unless required by applicable law or agreed to in writing
|
||||
will any copyright holder, or any other party who may modify and/or
|
||||
redistribute the program as permitted above, be liable to you for
|
||||
damages, including any general, special, incidental or consequential
|
||||
damages arising out of the use or inability to use the program
|
||||
(including but not limited to loss of data or data being rendered
|
||||
inaccurate or losses sustained by you or third parties or a failure of
|
||||
the program to operate with any other programs), even if such holder or
|
||||
other party has been advised of the possibility of such damages.
|
||||
******************************************************************************
|
||||
Module : switchip_setup.c
|
||||
Date : 2007-11-09
|
||||
Description : Basic setup of embedded ethernet switch "SwitchIP"
|
||||
Remarks: andreas.schmidt@infineon.com
|
||||
|
||||
*****************************************************************************/
|
||||
|
||||
/* TODO: get rid of #ifdef CONFIG_LANTIQ_MACH_EASY336 */
|
||||
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/version.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/time.h>
|
||||
|
||||
#include <base_reg.h>
|
||||
#include <es_reg.h>
|
||||
#include <sys1_reg.h>
|
||||
#include <dma_reg.h>
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
static struct svip_reg_sys1 *const sys1 = (struct svip_reg_sys1 *)LTQ_SYS1_BASE;
|
||||
static struct svip_reg_es *const es = (struct svip_reg_es *)LTQ_ES_BASE;
|
||||
|
||||
/* PHY Organizationally Unique Identifier (OUI) */
|
||||
#define PHY_OUI_PMC 0x00E004
|
||||
#define PHY_OUI_VITESSE 0x008083
|
||||
#define PHY_OUI_DEFAULT 0xFFFFFF
|
||||
|
||||
unsigned short switchip_phy_read(unsigned int phyaddr, unsigned int regaddr);
|
||||
void switchip_phy_write(unsigned int phyaddr, unsigned int regaddr,
|
||||
unsigned short data);
|
||||
|
||||
static int phy_address[2] = {0, 1};
|
||||
static u32 phy_oui;
|
||||
static void switchip_mdio_poll_init(void);
|
||||
static void _switchip_mdio_poll(struct work_struct *work);
|
||||
|
||||
/* struct workqueue_struct mdio_poll_task; */
|
||||
static struct workqueue_struct *mdio_poll_workqueue;
|
||||
DECLARE_DELAYED_WORK(mdio_poll_work, _switchip_mdio_poll);
|
||||
static int old_link_status[2] = {-1, -1};
|
||||
|
||||
/**
|
||||
* Autonegotiation check.
|
||||
* This funtion checks for link changes. If a link change has occured it will
|
||||
* update certain switch registers.
|
||||
*/
|
||||
static void _switchip_check_phy_status(int port)
|
||||
{
|
||||
int new_link_status;
|
||||
unsigned short reg1;
|
||||
|
||||
reg1 = switchip_phy_read(phy_address[port], 1);
|
||||
if ((reg1 == 0xFFFF) || (reg1 == 0x0000))
|
||||
return; /* no PHY connected */
|
||||
|
||||
new_link_status = reg1 & 4;
|
||||
if (old_link_status[port] ^ new_link_status) {
|
||||
/* link status change */
|
||||
if (!new_link_status) {
|
||||
if (port == 0)
|
||||
es_w32_mask(LTQ_ES_P0_CTL_REG_FLP, 0, p0_ctl);
|
||||
else
|
||||
es_w32_mask(LTQ_ES_P0_CTL_REG_FLP, 0, p1_ctl);
|
||||
|
||||
/* read again; link bit is latched low! */
|
||||
reg1 = switchip_phy_read(phy_address[port], 1);
|
||||
new_link_status = reg1 & 4;
|
||||
}
|
||||
|
||||
if (new_link_status) {
|
||||
unsigned short reg0, reg4, reg5, reg9, reg10;
|
||||
int phy_pause, phy_speed, phy_duplex;
|
||||
int aneg_enable, aneg_cmpt;
|
||||
|
||||
reg0 = switchip_phy_read(phy_address[port], 0);
|
||||
reg4 = switchip_phy_read(phy_address[port], 4);
|
||||
aneg_enable = reg0 & 0x1000;
|
||||
aneg_cmpt = reg1 & 0x20;
|
||||
|
||||
if (aneg_enable && aneg_cmpt) {
|
||||
reg5 = switchip_phy_read(phy_address[port], 5);
|
||||
switch (phy_oui) {
|
||||
#ifdef CONFIG_LANTIQ_MACH_EASY336
|
||||
case PHY_OUI_PMC:
|
||||
/* PMC Sierra supports 1Gigabit FD,
|
||||
* only. On successful
|
||||
* auto-negotiation, we are sure this
|
||||
* is what the LP can. */
|
||||
phy_pause = ((reg4 & reg5) & 0x0080) >> 7;
|
||||
phy_speed = 2;
|
||||
phy_duplex = 1;
|
||||
break;
|
||||
#endif
|
||||
case PHY_OUI_VITESSE:
|
||||
case PHY_OUI_DEFAULT:
|
||||
reg9 = switchip_phy_read(phy_address[port], 9);
|
||||
reg10 = switchip_phy_read(phy_address[port], 10);
|
||||
|
||||
/* Check if advertise and partner
|
||||
* agree on pause */
|
||||
phy_pause = ((reg4 & reg5) & 0x0400) >> 10;
|
||||
|
||||
/* Find the best mode both partners
|
||||
* support
|
||||
* Priority: 1GB-FD, 1GB-HD, 100MB-FD,
|
||||
* 100MB-HD, 10MB-FD, 10MB-HD */
|
||||
phy_speed = ((((reg9<<2) & reg10)
|
||||
& 0x0c00) >> 6) |
|
||||
(((reg4 & reg5) & 0x01e0) >> 5);
|
||||
|
||||
if (phy_speed >= 0x0020) {
|
||||
phy_speed = 2;
|
||||
phy_duplex = 1;
|
||||
} else if (phy_speed >= 0x0010) {
|
||||
phy_speed = 2;
|
||||
phy_duplex = 0;
|
||||
} else if (phy_speed >= 0x0008) {
|
||||
phy_speed = 1;
|
||||
phy_duplex = 1;
|
||||
} else if (phy_speed >= 0x0004) {
|
||||
phy_speed = 1;
|
||||
phy_duplex = 0;
|
||||
} else if (phy_speed >= 0x0002) {
|
||||
phy_speed = 0;
|
||||
phy_duplex = 1;
|
||||
} else {
|
||||
phy_speed = 0;
|
||||
phy_duplex = 0;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
phy_pause = (reg4 & 0x0400) >> 10;
|
||||
phy_speed = (reg0 & 0x40 ? 2 : (reg0 >> 13)&1);
|
||||
phy_duplex = (reg0 >> 8)&1;
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
/* parallel detection or fixed speed */
|
||||
phy_pause = (reg4 & 0x0400) >> 10;
|
||||
phy_speed = (reg0 & 0x40 ? 2 : (reg0 >> 13)&1);
|
||||
phy_duplex = (reg0 >> 8)&1;
|
||||
}
|
||||
|
||||
if (port == 0) {
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0SPD,
|
||||
LTQ_ES_RGMII_CTL_REG_P0SPD_VAL(phy_speed),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0DUP,
|
||||
LTQ_ES_RGMII_CTL_REG_P0DUP_VAL(phy_duplex),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0FCE,
|
||||
LTQ_ES_RGMII_CTL_REG_P0FCE_VAL(phy_pause),
|
||||
rgmii_ctl);
|
||||
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_FLP, p0_ctl);
|
||||
} else {
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1SPD,
|
||||
LTQ_ES_RGMII_CTL_REG_P1SPD_VAL(phy_speed),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1DUP,
|
||||
LTQ_ES_RGMII_CTL_REG_P1DUP_VAL(phy_duplex),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1FCE,
|
||||
LTQ_ES_RGMII_CTL_REG_P0FCE_VAL(phy_pause),
|
||||
rgmii_ctl);
|
||||
|
||||
es_w32_mask(1, LTQ_ES_P0_CTL_REG_FLP, p1_ctl);
|
||||
}
|
||||
}
|
||||
}
|
||||
old_link_status[port] = new_link_status;
|
||||
}
|
||||
|
||||
static void _switchip_mdio_poll(struct work_struct *work)
|
||||
{
|
||||
if (es_r32(sw_gctl0) & LTQ_ES_SW_GCTL0_REG_SE) {
|
||||
_switchip_check_phy_status(0);
|
||||
_switchip_check_phy_status(1);
|
||||
}
|
||||
|
||||
queue_delayed_work(mdio_poll_workqueue, &mdio_poll_work, HZ/2);
|
||||
}
|
||||
|
||||
static void switchip_mdio_poll_init(void)
|
||||
{
|
||||
mdio_poll_workqueue = create_workqueue("SVIP MDIP poll");
|
||||
INIT_DELAYED_WORK(&mdio_poll_work, _switchip_mdio_poll);
|
||||
|
||||
queue_delayed_work(mdio_poll_workqueue, &mdio_poll_work, HZ/2);
|
||||
|
||||
}
|
||||
|
||||
unsigned short switchip_phy_read(unsigned int phyaddr, unsigned int regaddr)
|
||||
{
|
||||
/* TODO: protect MDIO access with semaphore */
|
||||
es_w32(LTQ_ES_MDIO_CTL_REG_MBUSY
|
||||
| LTQ_ES_MDIO_CTL_REG_OP_VAL(2) /* read operation */
|
||||
| LTQ_ES_MDIO_CTL_REG_PHYAD_VAL(phyaddr)
|
||||
| LTQ_ES_MDIO_CTL_REG_REGAD_VAL(regaddr), mdio_ctl);
|
||||
while (es_r32(mdio_ctl) & LTQ_ES_MDIO_CTL_REG_MBUSY);
|
||||
|
||||
return es_r32(mdio_data) & 0xFFFF;
|
||||
}
|
||||
EXPORT_SYMBOL(switchip_phy_read);
|
||||
|
||||
void switchip_phy_write(unsigned int phyaddr, unsigned int regaddr,
|
||||
unsigned short data)
|
||||
{
|
||||
/* TODO: protect MDIO access with semaphore */
|
||||
es_w32(LTQ_ES_MDIO_CTL_REG_WD_VAL(data)
|
||||
| LTQ_ES_MDIO_CTL_REG_MBUSY
|
||||
| LTQ_ES_MDIO_CTL_REG_OP_VAL(1) /* write operation */
|
||||
| LTQ_ES_MDIO_CTL_REG_PHYAD_VAL(phyaddr)
|
||||
| LTQ_ES_MDIO_CTL_REG_REGAD_VAL(regaddr), mdio_ctl);
|
||||
while (es_r32(mdio_ctl) & LTQ_ES_MDIO_CTL_REG_MBUSY);
|
||||
|
||||
return;
|
||||
}
|
||||
EXPORT_SYMBOL(switchip_phy_write);
|
||||
|
||||
const static u32 switch_reset_offset_000[] = {
|
||||
/*b8000000:*/ 0xffffffff, 0x00000001, 0x00000001, 0x00000003,
|
||||
/*b8000010:*/ 0x04070001, 0x04070001, 0x04070001, 0xffffffff,
|
||||
/*b8000020:*/ 0x00001be8, 0x00001be8, 0x00001be8, 0xffffffff,
|
||||
/*b8000030:*/ 0x00000000, 0x00000000, 0x00080004, 0x00020001,
|
||||
/*b8000040:*/ 0x00000000, 0x00000000, 0x00080004, 0x00020001,
|
||||
/*b8000050:*/ 0x00000000, 0x00000000, 0x00080004, 0x00020001,
|
||||
/*b8000060:*/ 0x00000000, 0x00000000, 0x00081000, 0x001f7777,
|
||||
/*b8000070:*/ 0x00000000, 0x00000000, 0x0c00ac2b, 0x0000fa50,
|
||||
/*b8000080:*/ 0x00001000, 0x00001800, 0x00000000, 0x00000000,
|
||||
/*b8000090:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b80000a0:*/ 0x00000000, 0x00000050, 0x00000010, 0x00000000,
|
||||
/*b80000b0:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b80000c0:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b80000d0:*/ 0xffffffff, 0x00000000, 0x00000000
|
||||
};
|
||||
const static u32 switch_reset_offset_100[] = {
|
||||
/*b8000100:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000110:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000120:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000130:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000140:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000150:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000160:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000170:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000180:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b8000190:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b80001a0:*/ 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||
/*b80001b0:*/ 0x00000000, 0x00000000
|
||||
};
|
||||
|
||||
/*
|
||||
* Switch Reset.
|
||||
*/
|
||||
void switchip_reset(void)
|
||||
{
|
||||
volatile unsigned int *reg;
|
||||
volatile unsigned int rdreg;
|
||||
int i;
|
||||
|
||||
sys1_w32(SYS1_CLKENR_ETHSW, clkenr);
|
||||
asm("sync");
|
||||
|
||||
/* disable P0 */
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_SPS_VAL(1), p0_ctl);
|
||||
/* disable P1 */
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_SPS_VAL(1), p1_ctl);
|
||||
/* disable P2 */
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_SPS_VAL(1), p2_ctl);
|
||||
|
||||
/**************************************
|
||||
* BEGIN: Procedure to clear MAC table
|
||||
**************************************/
|
||||
for (i = 0; i < 3; i++) {
|
||||
int result;
|
||||
|
||||
/* check if access engine is available */
|
||||
while (es_r32(adr_tb_st2) & LTQ_ES_ADR_TB_ST2_REG_BUSY);
|
||||
|
||||
/* initialise to first address */
|
||||
es_w32(LTQ_ES_ADR_TB_CTL2_REG_CMD_VAL(3)
|
||||
| LTQ_ES_ADR_TB_CTL2_REG_AC_VAL(0), adr_tb_ctl2);
|
||||
|
||||
/* wait while busy */
|
||||
while (es_r32(adr_tb_st2) & LTQ_ES_ADR_TB_ST2_REG_BUSY);
|
||||
|
||||
/* setup the portmap */
|
||||
es_w32_mask(0, LTQ_ES_ADR_TB_CTL1_REG_PMAP_VAL(1 << i),
|
||||
adr_tb_ctl1);
|
||||
|
||||
do {
|
||||
/* search for addresses by port */
|
||||
es_w32(LTQ_ES_ADR_TB_CTL2_REG_CMD_VAL(2)
|
||||
| LTQ_ES_ADR_TB_CTL2_REG_AC_VAL(9), adr_tb_ctl2);
|
||||
|
||||
/* wait while busy */
|
||||
while (es_r32(adr_tb_st2) & LTQ_ES_ADR_TB_ST2_REG_BUSY);
|
||||
|
||||
result = LTQ_ES_ADR_TB_ST2_REG_RSLT_GET(es_r32(adr_tb_st2));
|
||||
if (result == 0x101) {
|
||||
printk(KERN_ERR "%s, cmd error\n", __func__);
|
||||
return;
|
||||
}
|
||||
/* if Command OK, address found... */
|
||||
if (result == 0) {
|
||||
unsigned char mac[6];
|
||||
|
||||
mac[5] = (es_r32(adr_tb_st0) >> 0) & 0xff;
|
||||
mac[4] = (es_r32(adr_tb_st0) >> 8) & 0xff;
|
||||
mac[3] = (es_r32(adr_tb_st0) >> 16) & 0xff;
|
||||
mac[2] = (es_r32(adr_tb_st0) >> 24) & 0xff;
|
||||
mac[1] = (es_r32(adr_tb_st1) >> 0) & 0xff;
|
||||
mac[0] = (es_r32(adr_tb_st1) >> 8) & 0xff;
|
||||
|
||||
/* setup address */
|
||||
es_w32((mac[5] << 0) |
|
||||
(mac[4] << 8) |
|
||||
(mac[3] << 16) |
|
||||
(mac[2] << 24), adr_tb_ctl0);
|
||||
es_w32(LTQ_ES_ADR_TB_CTL1_REG_PMAP_VAL(1<<i) |
|
||||
LTQ_ES_ADR_TB_CTL1_REG_FID_VAL(0) |
|
||||
(mac[0] << 8) |
|
||||
(mac[1] << 0), adr_tb_ctl1);
|
||||
/* erase address */
|
||||
|
||||
es_w32(LTQ_ES_ADR_TB_CTL2_REG_CMD_VAL(1) |
|
||||
LTQ_ES_ADR_TB_CTL2_REG_AC_VAL(15),
|
||||
adr_tb_ctl2);
|
||||
|
||||
/* wait, while busy */
|
||||
while (es_r32(adr_tb_st2) &
|
||||
LTQ_ES_ADR_TB_ST2_REG_BUSY);
|
||||
}
|
||||
} while (result == 0);
|
||||
}
|
||||
/**************************************
|
||||
* END: Procedure to clear MAC table
|
||||
**************************************/
|
||||
|
||||
/* reset RMON counters */
|
||||
es_w32(LTQ_ES_RMON_CTL_REG_BAS | LTQ_ES_RMON_CTL_REG_CAC_VAL(3),
|
||||
rmon_ctl);
|
||||
|
||||
/* bring all registers to reset state */
|
||||
reg = LTQ_ES_PS_REG;
|
||||
for (i = 0; i < ARRAY_SIZE(switch_reset_offset_000); i++) {
|
||||
if ((reg == LTQ_ES_PS_REG) ||
|
||||
(reg >= LTQ_ES_ADR_TB_CTL0_REG &&
|
||||
reg <= LTQ_ES_ADR_TB_ST2_REG))
|
||||
continue;
|
||||
|
||||
if (switch_reset_offset_000[i] != 0xFFFFFFFF) {
|
||||
/* write reset value to register */
|
||||
*reg = switch_reset_offset_000[i];
|
||||
/* read register value back */
|
||||
rdreg = *reg;
|
||||
if (reg == LTQ_ES_SW_GCTL1_REG)
|
||||
rdreg &= ~LTQ_ES_SW_GCTL1_REG_BISTDN;
|
||||
/* compare read value with written one */
|
||||
if (rdreg != switch_reset_offset_000[i]) {
|
||||
printk(KERN_ERR "%s,%d: reg %08x mismatch "
|
||||
"[has:%08x, expect:%08x]\n",
|
||||
__func__, __LINE__,
|
||||
(unsigned int)reg, rdreg,
|
||||
switch_reset_offset_000[i]);
|
||||
}
|
||||
}
|
||||
reg++;
|
||||
}
|
||||
|
||||
reg = LTQ_ES_VLAN_FLT0_REG;
|
||||
for (i = 0; i < ARRAY_SIZE(switch_reset_offset_100); i++) {
|
||||
*reg = switch_reset_offset_100[i];
|
||||
rdreg = *reg;
|
||||
if (rdreg != switch_reset_offset_100[i]) {
|
||||
printk(KERN_ERR "%s,%d: reg %08x mismatch "
|
||||
"[has:%08x, expect:%08x]\n", __func__, __LINE__,
|
||||
(unsigned int)reg, rdreg,
|
||||
switch_reset_offset_100[i]);
|
||||
}
|
||||
reg++;
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL(switchip_reset);
|
||||
|
||||
static u32 get_phy_oui(unsigned char phy_addr)
|
||||
{
|
||||
u32 oui;
|
||||
int i, bit, byte, shift, w;
|
||||
u16 reg_id[2];
|
||||
|
||||
/* read PHY identifier registers 1 and 2 */
|
||||
reg_id[0] = switchip_phy_read(phy_addr, 2);
|
||||
reg_id[1] = switchip_phy_read(phy_addr, 3);
|
||||
|
||||
oui = 0;
|
||||
w = 1;
|
||||
shift = 7;
|
||||
byte = 1;
|
||||
for (i = 0, bit = 10; i <= 21; i++, bit++) {
|
||||
oui |= ((reg_id[w] & (1<<bit)) ? 1 : 0) << shift;
|
||||
if (!(shift % 8)) {
|
||||
byte++;
|
||||
if (byte == 2)
|
||||
shift = 15;
|
||||
else
|
||||
shift = 21;
|
||||
} else {
|
||||
shift--;
|
||||
}
|
||||
if (w == 1 && bit == 15) {
|
||||
bit = -1;
|
||||
w = 0;
|
||||
}
|
||||
}
|
||||
return oui;
|
||||
}
|
||||
|
||||
/*
|
||||
* Switch Initialization.
|
||||
*/
|
||||
int switchip_init(void)
|
||||
{
|
||||
int eth_port, phy_present = 0;
|
||||
u16 reg, mode;
|
||||
|
||||
sys1_w32(SYS1_CLKENR_ETHSW, clkenr);
|
||||
asm("sync");
|
||||
|
||||
/* Enable Switch, if not already done so */
|
||||
if ((es_r32(sw_gctl0) & LTQ_ES_SW_GCTL0_REG_SE) == 0)
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL0_REG_SE, sw_gctl0);
|
||||
/* Wait for completion of MBIST */
|
||||
while (LTQ_ES_SW_GCTL1_REG_BISTDN_GET(es_r32(sw_gctl1)) == 0);
|
||||
|
||||
switchip_reset();
|
||||
|
||||
mode = LTQ_ES_RGMII_CTL_REG_IS_GET(es_r32(rgmii_ctl));
|
||||
eth_port = (mode == 2 ? 1 : 0);
|
||||
|
||||
/* Set the primary port(port toward backplane) as sniffer port,
|
||||
changing from P2 which is the reset setting */
|
||||
es_w32_mask(LTQ_ES_SW_GCTL0_REG_SNIFFPN,
|
||||
LTQ_ES_SW_GCTL0_REG_SNIFFPN_VAL(eth_port),
|
||||
sw_gctl0);
|
||||
|
||||
/* Point MDIO state machine to invalid PHY addresses 8 and 9 */
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL0_REG_PHYBA, sw_gctl0);
|
||||
|
||||
/* Add CRC for packets from DMA to PMAC.
|
||||
Remove CRC for packets from PMAC to DMA. */
|
||||
es_w32(LTQ_ES_PMAC_HD_CTL_RC | LTQ_ES_PMAC_HD_CTL_AC, pmac_hd_ctl);
|
||||
|
||||
phy_oui = get_phy_oui(0);
|
||||
switch (phy_oui) {
|
||||
#ifdef CONFIG_LANTIQ_MACH_EASY336
|
||||
case PHY_OUI_PMC:
|
||||
phy_address[0] = (mode == 2 ? -1 : 2);
|
||||
phy_address[1] = (mode == 2 ? 2 : -1);
|
||||
break;
|
||||
#endif
|
||||
case PHY_OUI_VITESSE:
|
||||
default:
|
||||
phy_oui = PHY_OUI_DEFAULT;
|
||||
phy_address[0] = (mode == 2 ? 1 : 0);
|
||||
phy_address[1] = (mode == 2 ? 0 : 1);
|
||||
break;
|
||||
}
|
||||
|
||||
/****** PORT 0 *****/
|
||||
reg = switchip_phy_read(phy_address[0], 1);
|
||||
if ((reg != 0x0000) && (reg != 0xffff)) {
|
||||
/* PHY connected? */
|
||||
phy_present |= 1;
|
||||
/* Set Rx- and TxDelay in case of RGMII */
|
||||
switch (mode) {
|
||||
case 0: /* *RGMII,RGMII */
|
||||
case 2: /* RGMII,*GMII */
|
||||
/* program clock delay in PHY, not in SVIP */
|
||||
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0RDLY, 0, rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0TDLY, 0, rgmii_ctl);
|
||||
if (phy_oui == PHY_OUI_VITESSE ||
|
||||
phy_oui == PHY_OUI_DEFAULT) {
|
||||
switchip_phy_write(phy_address[0], 31, 0x0001);
|
||||
switchip_phy_write(phy_address[0], 28, 0xA000);
|
||||
switchip_phy_write(phy_address[0], 31, 0x0000);
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
if (phy_oui == PHY_OUI_VITESSE ||
|
||||
phy_oui == PHY_OUI_DEFAULT) {
|
||||
/* Program PHY advertisements and
|
||||
* restart auto-negotiation */
|
||||
switchip_phy_write(phy_address[0], 4, 0x05E1);
|
||||
switchip_phy_write(phy_address[0], 9, 0x0300);
|
||||
switchip_phy_write(phy_address[0], 0, 0x3300);
|
||||
} else {
|
||||
reg = switchip_phy_read(phy_address[1], 0);
|
||||
reg |= 0x1000; /* auto-negotiation enable */
|
||||
switchip_phy_write(phy_address[1], 0, reg);
|
||||
reg |= 0x0200; /* auto-negotiation restart */
|
||||
switchip_phy_write(phy_address[1], 0, reg);
|
||||
}
|
||||
} else {
|
||||
/* Force SWITCH link with highest capability:
|
||||
* 100M FD for MII
|
||||
* 1G FD for GMII/RGMII
|
||||
*/
|
||||
switch (mode) {
|
||||
case 1: /* *MII,MII */
|
||||
case 3: /* *MII,RGMII */
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P0SPD_VAL(1),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P0DUP_VAL(1),
|
||||
rgmii_ctl);
|
||||
break;
|
||||
case 0: /* *RGMII,RGMII */
|
||||
case 2: /* RGMII,*GMII */
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P0SPD_VAL(2),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P0DUP_VAL(1),
|
||||
rgmii_ctl);
|
||||
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P0RDLY, 0, rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P0TDLY_VAL(2),
|
||||
rgmii_ctl);
|
||||
break;
|
||||
}
|
||||
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_FLP, p0_ctl);
|
||||
}
|
||||
|
||||
/****** PORT 1 *****/
|
||||
reg = switchip_phy_read(phy_address[1], 1);
|
||||
if ((reg != 0x0000) && (reg != 0xffff)) {
|
||||
/* PHY connected? */
|
||||
phy_present |= 2;
|
||||
/* Set Rx- and TxDelay in case of RGMII */
|
||||
switch (mode) {
|
||||
case 0: /* *RGMII,RGMII */
|
||||
case 3: /* *MII,RGMII */
|
||||
/* program clock delay in PHY, not in SVIP */
|
||||
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1RDLY, 0, rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1TDLY, 0, rgmii_ctl);
|
||||
if (phy_oui == PHY_OUI_VITESSE ||
|
||||
phy_oui == PHY_OUI_DEFAULT) {
|
||||
switchip_phy_write(phy_address[1], 31, 0x0001);
|
||||
switchip_phy_write(phy_address[1], 28, 0xA000);
|
||||
switchip_phy_write(phy_address[1], 31, 0x0000);
|
||||
}
|
||||
break;
|
||||
case 2: /* RGMII,*GMII */
|
||||
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1SPD_VAL(2),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1DUP, rgmii_ctl);
|
||||
#ifdef CONFIG_LANTIQ_MACH_EASY336
|
||||
if (phy_oui == PHY_OUI_PMC) {
|
||||
switchip_phy_write(phy_address[1], 24, 0x0510);
|
||||
switchip_phy_write(phy_address[1], 17, 0xA38C);
|
||||
switchip_phy_write(phy_address[1], 17, 0xA384);
|
||||
}
|
||||
#endif
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
/* Program PHY advertisements and restart auto-negotiation */
|
||||
if (phy_oui == PHY_OUI_VITESSE ||
|
||||
phy_oui == PHY_OUI_DEFAULT) {
|
||||
switchip_phy_write(phy_address[1], 4, 0x05E1);
|
||||
switchip_phy_write(phy_address[1], 9, 0x0300);
|
||||
switchip_phy_write(phy_address[1], 0, 0x3300);
|
||||
} else {
|
||||
reg = switchip_phy_read(phy_address[1], 0);
|
||||
reg |= 0x1000; /* auto-negotiation enable */
|
||||
switchip_phy_write(phy_address[1], 0, reg);
|
||||
reg |= 0x0200; /* auto-negotiation restart */
|
||||
switchip_phy_write(phy_address[1], 0, reg);
|
||||
}
|
||||
} else {
|
||||
/* Force SWITCH link with highest capability:
|
||||
* 100M FD for MII
|
||||
* 1G FD for GMII/RGMII
|
||||
*/
|
||||
switch (mode) {
|
||||
case 1: /* *MII,MII */
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1SPD_VAL(1),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1DUP, rgmii_ctl);
|
||||
break;
|
||||
case 0: /* *RGMII,RGMII */
|
||||
case 3: /* *MII,RGMII */
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1SPD_VAL(2),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1DUP, rgmii_ctl);
|
||||
es_w32_mask(LTQ_ES_RGMII_CTL_REG_P1RDLY, 0, rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1TDLY_VAL(2),
|
||||
rgmii_ctl);
|
||||
break;
|
||||
case 2: /* RGMII,*GMII */
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1SPD_VAL(2),
|
||||
rgmii_ctl);
|
||||
es_w32_mask(0, LTQ_ES_RGMII_CTL_REG_P1DUP, rgmii_ctl);
|
||||
break;
|
||||
}
|
||||
es_w32_mask(0, LTQ_ES_P0_CTL_REG_FLP, p0_ctl);
|
||||
}
|
||||
|
||||
/*
|
||||
* Allow unknown unicast/multicast and broadcasts
|
||||
* on all ports.
|
||||
*/
|
||||
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL1_REG_UP_VAL(7), sw_gctl1);
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL1_REG_BP_VAL(7), sw_gctl1);
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL1_REG_MP_VAL(7), sw_gctl1);
|
||||
es_w32_mask(0, LTQ_ES_SW_GCTL1_REG_RP_VAL(7), sw_gctl1);
|
||||
|
||||
/* Enable LAN port(s) */
|
||||
if (eth_port == 0)
|
||||
es_w32_mask(LTQ_ES_P0_CTL_REG_SPS, 0, p0_ctl);
|
||||
else
|
||||
es_w32_mask(LTQ_ES_P0_CTL_REG_SPS, 0, p1_ctl);
|
||||
/* Enable CPU Port (Forwarding State) */
|
||||
es_w32_mask(LTQ_ES_P0_CTL_REG_SPS, 0, p2_ctl);
|
||||
|
||||
if (phy_present)
|
||||
switchip_mdio_poll_init();
|
||||
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(switchip_init);
|
||||
|
||||
device_initcall(switchip_init);
|
|
@ -1,329 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/io.h>
|
||||
#include <linux/export.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/clk.h>
|
||||
|
||||
#include <asm/time.h>
|
||||
#include <asm/irq.h>
|
||||
#include <asm/div64.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "../clk.h"
|
||||
|
||||
static unsigned int ltq_ram_clocks[] = {
|
||||
CLOCK_167M, CLOCK_133M, CLOCK_111M, CLOCK_83M };
|
||||
#define DDR_HZ ltq_ram_clocks[ltq_cgu_r32(LTQ_CGU_SYS) & 0x3]
|
||||
|
||||
#define BASIC_FREQUENCY_1 35328000
|
||||
#define BASIC_FREQUENCY_2 36000000
|
||||
#define BASIS_REQUENCY_USB 12000000
|
||||
|
||||
#define GET_BITS(x, msb, lsb) \
|
||||
(((x) & ((1 << ((msb) + 1)) - 1)) >> (lsb))
|
||||
|
||||
/* legacy xway clock */
|
||||
#define LTQ_CGU_PLL0_CFG 0x0004
|
||||
#define LTQ_CGU_PLL1_CFG 0x0008
|
||||
#define LTQ_CGU_PLL2_CFG 0x000C
|
||||
#define LTQ_CGU_SYS 0x0010
|
||||
#define LTQ_CGU_UPDATE 0x0014
|
||||
#define LTQ_CGU_IF_CLK 0x0018
|
||||
#define LTQ_CGU_OSC_CON 0x001C
|
||||
#define LTQ_CGU_SMD 0x0020
|
||||
#define LTQ_CGU_CT1SR 0x0028
|
||||
#define LTQ_CGU_CT2SR 0x002C
|
||||
#define LTQ_CGU_PCMCR 0x0030
|
||||
#define LTQ_CGU_PCI_CR 0x0034
|
||||
#define LTQ_CGU_PD_PC 0x0038
|
||||
#define LTQ_CGU_FMR 0x003C
|
||||
|
||||
#define CGU_PLL0_PHASE_DIVIDER_ENABLE \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL0_CFG) & (1 << 31))
|
||||
#define CGU_PLL0_BYPASS \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL0_CFG) & (1 << 30))
|
||||
#define CGU_PLL0_CFG_DSMSEL \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL0_CFG) & (1 << 28))
|
||||
#define CGU_PLL0_CFG_FRAC_EN \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL0_CFG) & (1 << 27))
|
||||
#define CGU_PLL1_SRC \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL1_CFG) & (1 << 31))
|
||||
#define CGU_PLL2_PHASE_DIVIDER_ENABLE \
|
||||
(ltq_cgu_r32(LTQ_CGU_PLL2_CFG) & (1 << 20))
|
||||
#define CGU_SYS_FPI_SEL (1 << 6)
|
||||
#define CGU_SYS_DDR_SEL 0x3
|
||||
#define CGU_PLL0_SRC (1 << 29)
|
||||
|
||||
#define CGU_PLL0_CFG_PLLK GET_BITS(ltq_cgu_r32(LTQ_CGU_PLL0_CFG), 26, 17)
|
||||
#define CGU_PLL0_CFG_PLLN GET_BITS(ltq_cgu_r32(LTQ_CGU_PLL0_CFG), 12, 6)
|
||||
#define CGU_PLL0_CFG_PLLM GET_BITS(ltq_cgu_r32(LTQ_CGU_PLL0_CFG), 5, 2)
|
||||
#define CGU_PLL2_SRC GET_BITS(ltq_cgu_r32(LTQ_CGU_PLL2_CFG), 18, 17)
|
||||
#define CGU_PLL2_CFG_INPUT_DIV GET_BITS(ltq_cgu_r32(LTQ_CGU_PLL2_CFG), 16, 13)
|
||||
|
||||
/* vr9 clock */
|
||||
#define LTQ_CGU_SYS_VR9 0x0c
|
||||
#define LTQ_CGU_IF_CLK_VR9 0x24
|
||||
|
||||
|
||||
static unsigned int ltq_get_pll0_fdiv(void);
|
||||
|
||||
static inline unsigned int get_input_clock(int pll)
|
||||
{
|
||||
switch (pll) {
|
||||
case 0:
|
||||
if (ltq_cgu_r32(LTQ_CGU_PLL0_CFG) & CGU_PLL0_SRC)
|
||||
return BASIS_REQUENCY_USB;
|
||||
else if (CGU_PLL0_PHASE_DIVIDER_ENABLE)
|
||||
return BASIC_FREQUENCY_1;
|
||||
else
|
||||
return BASIC_FREQUENCY_2;
|
||||
case 1:
|
||||
if (CGU_PLL1_SRC)
|
||||
return BASIS_REQUENCY_USB;
|
||||
else if (CGU_PLL0_PHASE_DIVIDER_ENABLE)
|
||||
return BASIC_FREQUENCY_1;
|
||||
else
|
||||
return BASIC_FREQUENCY_2;
|
||||
case 2:
|
||||
switch (CGU_PLL2_SRC) {
|
||||
case 0:
|
||||
return ltq_get_pll0_fdiv();
|
||||
case 1:
|
||||
return CGU_PLL2_PHASE_DIVIDER_ENABLE ?
|
||||
BASIC_FREQUENCY_1 :
|
||||
BASIC_FREQUENCY_2;
|
||||
case 2:
|
||||
return BASIS_REQUENCY_USB;
|
||||
}
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
static inline unsigned int cal_dsm(int pll, unsigned int num, unsigned int den)
|
||||
{
|
||||
u64 res, clock = get_input_clock(pll);
|
||||
|
||||
res = num * clock;
|
||||
do_div(res, den);
|
||||
return res;
|
||||
}
|
||||
|
||||
static inline unsigned int mash_dsm(int pll, unsigned int M, unsigned int N,
|
||||
unsigned int K)
|
||||
{
|
||||
unsigned int num = ((N + 1) << 10) + K;
|
||||
unsigned int den = (M + 1) << 10;
|
||||
|
||||
return cal_dsm(pll, num, den);
|
||||
}
|
||||
|
||||
static inline unsigned int ssff_dsm_1(int pll, unsigned int M, unsigned int N,
|
||||
unsigned int K)
|
||||
{
|
||||
unsigned int num = ((N + 1) << 11) + K + 512;
|
||||
unsigned int den = (M + 1) << 11;
|
||||
|
||||
return cal_dsm(pll, num, den);
|
||||
}
|
||||
|
||||
static inline unsigned int ssff_dsm_2(int pll, unsigned int M, unsigned int N,
|
||||
unsigned int K)
|
||||
{
|
||||
unsigned int num = K >= 512 ?
|
||||
((N + 1) << 12) + K - 512 : ((N + 1) << 12) + K + 3584;
|
||||
unsigned int den = (M + 1) << 12;
|
||||
|
||||
return cal_dsm(pll, num, den);
|
||||
}
|
||||
|
||||
static inline unsigned int dsm(int pll, unsigned int M, unsigned int N,
|
||||
unsigned int K, unsigned int dsmsel, unsigned int phase_div_en)
|
||||
{
|
||||
if (!dsmsel)
|
||||
return mash_dsm(pll, M, N, K);
|
||||
else if (!phase_div_en)
|
||||
return mash_dsm(pll, M, N, K);
|
||||
else
|
||||
return ssff_dsm_2(pll, M, N, K);
|
||||
}
|
||||
|
||||
static inline unsigned int ltq_get_pll0_fosc(void)
|
||||
{
|
||||
if (CGU_PLL0_BYPASS)
|
||||
return get_input_clock(0);
|
||||
else
|
||||
return !CGU_PLL0_CFG_FRAC_EN
|
||||
? dsm(0, CGU_PLL0_CFG_PLLM, CGU_PLL0_CFG_PLLN, 0,
|
||||
CGU_PLL0_CFG_DSMSEL,
|
||||
CGU_PLL0_PHASE_DIVIDER_ENABLE)
|
||||
: dsm(0, CGU_PLL0_CFG_PLLM, CGU_PLL0_CFG_PLLN,
|
||||
CGU_PLL0_CFG_PLLK, CGU_PLL0_CFG_DSMSEL,
|
||||
CGU_PLL0_PHASE_DIVIDER_ENABLE);
|
||||
}
|
||||
|
||||
static unsigned int ltq_get_pll0_fdiv(void)
|
||||
{
|
||||
unsigned int div = CGU_PLL2_CFG_INPUT_DIV + 1;
|
||||
|
||||
return (ltq_get_pll0_fosc() + (div >> 1)) / div;
|
||||
}
|
||||
|
||||
unsigned long ltq_danube_io_region_clock(void)
|
||||
{
|
||||
unsigned int ret = ltq_get_pll0_fosc();
|
||||
|
||||
switch (ltq_cgu_r32(LTQ_CGU_SYS) & 0x3) {
|
||||
default:
|
||||
case 0:
|
||||
return (ret + 1) / 2;
|
||||
case 1:
|
||||
return (ret * 2 + 2) / 5;
|
||||
case 2:
|
||||
return (ret + 1) / 3;
|
||||
case 3:
|
||||
return (ret + 2) / 4;
|
||||
}
|
||||
}
|
||||
|
||||
unsigned long ltq_danube_fpi_bus_clock(int fpi)
|
||||
{
|
||||
unsigned long ret = ltq_danube_io_region_clock();
|
||||
|
||||
if ((fpi == 2) && (ltq_cgu_r32(LTQ_CGU_SYS) & CGU_SYS_FPI_SEL))
|
||||
ret >>= 1;
|
||||
return ret;
|
||||
}
|
||||
|
||||
unsigned long ltq_danube_fpi_hz(void)
|
||||
{
|
||||
unsigned long ddr_clock = DDR_HZ;
|
||||
|
||||
if (ltq_cgu_r32(LTQ_CGU_SYS) & 0x40)
|
||||
return ddr_clock >> 1;
|
||||
return ddr_clock;
|
||||
}
|
||||
|
||||
unsigned long ltq_danube_cpu_hz(void)
|
||||
{
|
||||
switch (ltq_cgu_r32(LTQ_CGU_SYS) & 0xc) {
|
||||
case 0:
|
||||
return CLOCK_333M;
|
||||
case 4:
|
||||
return DDR_HZ;
|
||||
case 8:
|
||||
return DDR_HZ << 1;
|
||||
default:
|
||||
return DDR_HZ >> 1;
|
||||
}
|
||||
}
|
||||
|
||||
unsigned long ltq_ar9_sys_hz(void)
|
||||
{
|
||||
if (((ltq_cgu_r32(LTQ_CGU_SYS) >> 3) & 0x3) == 0x2)
|
||||
return CLOCK_393M;
|
||||
return CLOCK_333M;
|
||||
}
|
||||
|
||||
unsigned long ltq_ar9_fpi_hz(void)
|
||||
{
|
||||
unsigned long sys = ltq_ar9_sys_hz();
|
||||
|
||||
if (ltq_cgu_r32(LTQ_CGU_SYS) & BIT(0))
|
||||
return sys;
|
||||
return sys >> 1;
|
||||
}
|
||||
|
||||
unsigned long ltq_ar9_cpu_hz(void)
|
||||
{
|
||||
if (ltq_cgu_r32(LTQ_CGU_SYS) & BIT(2))
|
||||
return ltq_ar9_fpi_hz();
|
||||
else
|
||||
return ltq_ar9_sys_hz();
|
||||
}
|
||||
|
||||
unsigned long ltq_vr9_cpu_hz(void)
|
||||
{
|
||||
unsigned int cpu_sel;
|
||||
unsigned long clk;
|
||||
|
||||
cpu_sel = (ltq_cgu_r32(LTQ_CGU_SYS_VR9) >> 4) & 0xf;
|
||||
|
||||
switch (cpu_sel) {
|
||||
case 0:
|
||||
clk = CLOCK_600M;
|
||||
break;
|
||||
case 1:
|
||||
clk = CLOCK_500M;
|
||||
break;
|
||||
case 2:
|
||||
clk = CLOCK_393M;
|
||||
break;
|
||||
case 3:
|
||||
clk = CLOCK_333M;
|
||||
break;
|
||||
case 5:
|
||||
case 6:
|
||||
clk = CLOCK_196_608M;
|
||||
break;
|
||||
case 7:
|
||||
clk = CLOCK_167M;
|
||||
break;
|
||||
case 4:
|
||||
case 8:
|
||||
case 9:
|
||||
clk = CLOCK_125M;
|
||||
break;
|
||||
default:
|
||||
clk = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
return clk;
|
||||
}
|
||||
|
||||
unsigned long ltq_vr9_fpi_hz(void)
|
||||
{
|
||||
unsigned int ocp_sel, cpu_clk;
|
||||
unsigned long clk;
|
||||
|
||||
cpu_clk = ltq_vr9_cpu_hz();
|
||||
ocp_sel = ltq_cgu_r32(LTQ_CGU_SYS_VR9) & 0x3;
|
||||
|
||||
switch (ocp_sel) {
|
||||
case 0:
|
||||
/* OCP ratio 1 */
|
||||
clk = cpu_clk;
|
||||
break;
|
||||
case 2:
|
||||
/* OCP ratio 2 */
|
||||
clk = cpu_clk / 2;
|
||||
break;
|
||||
case 3:
|
||||
/* OCP ratio 2.5 */
|
||||
clk = (cpu_clk * 2) / 5;
|
||||
break;
|
||||
case 4:
|
||||
/* OCP ratio 3 */
|
||||
clk = cpu_clk / 3;
|
||||
break;
|
||||
default:
|
||||
clk = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
return clk;
|
||||
}
|
||||
|
||||
unsigned long ltq_vr9_fpi_bus_clock(int fpi)
|
||||
{
|
||||
return ltq_vr9_fpi_hz();
|
||||
}
|
|
@ -1,70 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/string.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/time.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/leds.h>
|
||||
|
||||
#include <asm/bootinfo.h>
|
||||
#include <asm/irq.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_irq.h>
|
||||
#include <lantiq_platform.h>
|
||||
|
||||
#define LTQ_USB_IOMEM_BASE 0x1e101000
|
||||
#define LTQ_USB_IOMEM_SIZE 0x00001000
|
||||
|
||||
static struct resource resources[] =
|
||||
{
|
||||
[0] = {
|
||||
.name = "dwc_otg_membase",
|
||||
.start = LTQ_USB_IOMEM_BASE,
|
||||
.end = LTQ_USB_IOMEM_BASE + LTQ_USB_IOMEM_SIZE - 1,
|
||||
.flags = IORESOURCE_MEM,
|
||||
},
|
||||
[1] = {
|
||||
.name = "dwc_otg_irq",
|
||||
.flags = IORESOURCE_IRQ,
|
||||
},
|
||||
};
|
||||
|
||||
static u64 dwc_dmamask = (u32)0x1fffffff;
|
||||
|
||||
static struct platform_device platform_dev = {
|
||||
.name = "dwc_otg",
|
||||
.dev = {
|
||||
.dma_mask = &dwc_dmamask,
|
||||
},
|
||||
.resource = resources,
|
||||
.num_resources = ARRAY_SIZE(resources),
|
||||
};
|
||||
|
||||
int __init
|
||||
xway_register_dwc(int pin)
|
||||
{
|
||||
struct irq_data d;
|
||||
d.irq = resources[1].start;
|
||||
ltq_enable_irq(&d);
|
||||
resources[1].start = ltq_is_ase() ? LTQ_USB_ASE_INT : LTQ_USB_INT;
|
||||
platform_dev.dev.platform_data = (void*) pin;
|
||||
return platform_device_register(&platform_dev);
|
||||
}
|
|
@ -1,17 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#ifndef _LTQ_DEV_DWC_H__
|
||||
#define _LTQ_DEV_DWC_H__
|
||||
|
||||
#include <lantiq_platform.h>
|
||||
|
||||
extern void __init xway_register_dwc(int pin);
|
||||
|
||||
#endif
|
|
@ -1,45 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2012 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/string.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/reboot.h>
|
||||
#include <linux/time.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/leds.h>
|
||||
|
||||
#include <asm/bootinfo.h>
|
||||
#include <asm/irq.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_irq.h>
|
||||
#include <lantiq_platform.h>
|
||||
|
||||
static u64 dmamask = (u32)0x1fffffff;
|
||||
|
||||
static struct platform_device platform_dev = {
|
||||
.name = "ifxusb_hcd",
|
||||
.dev.dma_mask = &dmamask,
|
||||
};
|
||||
|
||||
int __init
|
||||
xway_register_hcd(int *pins)
|
||||
{
|
||||
platform_dev.dev.platform_data = pins;
|
||||
return platform_device_register(&platform_dev);
|
||||
}
|
|
@ -1,17 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Copyright (C) 2012 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#ifndef _LTQ_DEV_HCD_H__
|
||||
#define _LTQ_DEV_HCD_H__
|
||||
|
||||
#include <lantiq_platform.h>
|
||||
|
||||
extern void __init xway_register_hcd(int *pin);
|
||||
|
||||
#endif
|
|
@ -1,53 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
* Copyright (C) 2011 Andrej Vlašić <andrej.vlasic0@gmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/ath5k_platform.h>
|
||||
#include <linux/ath9k_platform.h>
|
||||
#include <linux/pci.h>
|
||||
|
||||
#include "dev-wifi-athxk.h"
|
||||
|
||||
extern int (*ltqpci_plat_dev_init)(struct pci_dev *dev);
|
||||
struct ath5k_platform_data ath5k_pdata;
|
||||
struct ath9k_platform_data ath9k_pdata = {
|
||||
.led_pin = -1,
|
||||
.endian_check = true,
|
||||
};
|
||||
|
||||
static int
|
||||
ath5k_pci_plat_dev_init(struct pci_dev *dev)
|
||||
{
|
||||
dev->dev.platform_data = &ath5k_pdata;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
ath9k_pci_plat_dev_init(struct pci_dev *dev)
|
||||
{
|
||||
dev->dev.platform_data = &ath9k_pdata;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_register_ath5k(u16 *eeprom_data, u8 *macaddr)
|
||||
{
|
||||
ath5k_pdata.eeprom_data = eeprom_data;
|
||||
ath5k_pdata.macaddr = macaddr;
|
||||
ltqpci_plat_dev_init = ath5k_pci_plat_dev_init;
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_register_ath9k(u16 *eeprom_data, u8 *macaddr)
|
||||
{
|
||||
memcpy(ath9k_pdata.eeprom_data, eeprom_data, sizeof(ath9k_pdata.eeprom_data));
|
||||
ath9k_pdata.macaddr = macaddr;
|
||||
ltqpci_plat_dev_init = ath9k_pci_plat_dev_init;
|
||||
}
|
|
@ -1,16 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
* Copyright (C) 2011 Andrej Vlašić <andrej.vlasic0@gmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#ifndef _DEV_WIFI_ATHXK_H__
|
||||
#define _DEV_WIFI_ATHXK_H__
|
||||
|
||||
extern void ltq_register_ath5k(u16 *eeprom_data, u8 *macaddr);
|
||||
extern void ltq_register_ath9k(u16 *eeprom_data, u8 *macaddr);
|
||||
|
||||
#endif
|
|
@ -1,32 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/rt2x00_platform.h>
|
||||
#include <linux/pci.h>
|
||||
|
||||
#include "dev-wifi-rt2x00.h"
|
||||
|
||||
extern int (*ltqpci_plat_dev_init)(struct pci_dev *dev);
|
||||
struct rt2x00_platform_data rt2x00_pdata;
|
||||
|
||||
static int
|
||||
rt2x00_pci_plat_dev_init(struct pci_dev *dev)
|
||||
{
|
||||
dev->dev.platform_data = &rt2x00_pdata;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void __init
|
||||
ltq_register_rt2x00(const char *firmware, const u8 *mac)
|
||||
{
|
||||
rt2x00_pdata.eeprom_file_name = kstrdup(firmware, GFP_KERNEL);
|
||||
rt2x00_pdata.mac_address = mac;
|
||||
ltqpci_plat_dev_init = rt2x00_pci_plat_dev_init;
|
||||
}
|
|
@ -1,14 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2011 John Crispin <blogic@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#ifndef _DEV_WIFI_RT2X00_H__
|
||||
#define _DEV_WIFI_RT2X00_H__
|
||||
|
||||
extern void ltq_register_rt2x00(const char *firmware, const u8 *mac);
|
||||
|
||||
#endif
|
|
@ -1,176 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2012 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/ioport.h>
|
||||
#include <linux/pm.h>
|
||||
#include <linux/export.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <asm/reboot.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include "../clk.h"
|
||||
|
||||
#include "../devices.h"
|
||||
|
||||
#define ltq_gptu_w32(x, y) ltq_w32((x), ltq_gptu_membase + (y))
|
||||
#define ltq_gptu_r32(x) ltq_r32(ltq_gptu_membase + (x))
|
||||
|
||||
|
||||
/* the magic ID byte of the core */
|
||||
#define GPTU_MAGIC 0x59
|
||||
/* clock control register */
|
||||
#define GPTU_CLC 0x00
|
||||
/* id register */
|
||||
#define GPTU_ID 0x08
|
||||
/* interrupt node enable */
|
||||
#define GPTU_IRNEN 0xf4
|
||||
/* interrupt control register */
|
||||
#define GPTU_IRCR 0xf8
|
||||
/* interrupt capture register */
|
||||
#define GPTU_IRNCR 0xfc
|
||||
/* there are 3 identical blocks of 2 timers. calculate register offsets */
|
||||
#define GPTU_SHIFT(x) (x % 2 ? 4 : 0)
|
||||
#define GPTU_BASE(x) (((x >> 1) * 0x20) + 0x10)
|
||||
/* timer control register */
|
||||
#define GPTU_CON(x) (GPTU_BASE(x) + GPTU_SHIFT(x) + 0x00)
|
||||
/* timer auto reload register */
|
||||
#define GPTU_RUN(x) (GPTU_BASE(x) + GPTU_SHIFT(x) + 0x08)
|
||||
/* timer manual reload register */
|
||||
#define GPTU_RLD(x) (GPTU_BASE(x) + GPTU_SHIFT(x) + 0x10)
|
||||
/* timer count register */
|
||||
#define GPTU_CNT(x) (GPTU_BASE(x) + GPTU_SHIFT(x) + 0x18)
|
||||
|
||||
/* GPTU_CON(x) */
|
||||
#define CON_CNT BIT(2)
|
||||
#define CON_EDGE_FALL BIT(7)
|
||||
#define CON_SYNC BIT(8)
|
||||
#define CON_CLK_INT BIT(10)
|
||||
|
||||
/* GPTU_RUN(x) */
|
||||
#define RUN_SEN BIT(0)
|
||||
#define RUN_RL BIT(2)
|
||||
|
||||
/* set clock to runmode */
|
||||
#define CLC_RMC BIT(8)
|
||||
/* bring core out of suspend */
|
||||
#define CLC_SUSPEND BIT(4)
|
||||
/* the disable bit */
|
||||
#define CLC_DISABLE BIT(0)
|
||||
|
||||
#define TIMER_INTERRUPT (INT_NUM_IM3_IRL0 + 22)
|
||||
|
||||
enum gptu_timer {
|
||||
TIMER1A = 0,
|
||||
TIMER1B,
|
||||
TIMER2A,
|
||||
TIMER2B,
|
||||
TIMER3A,
|
||||
TIMER3B
|
||||
};
|
||||
|
||||
static struct resource ltq_gptu_resource =
|
||||
MEM_RES("GPTU", LTQ_GPTU_BASE_ADDR, LTQ_GPTU_SIZE);
|
||||
|
||||
static void __iomem *ltq_gptu_membase;
|
||||
|
||||
static irqreturn_t timer_irq_handler(int irq, void *priv)
|
||||
{
|
||||
int timer = irq - TIMER_INTERRUPT;
|
||||
ltq_gptu_w32(1 << timer, GPTU_IRNCR);
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static void gptu_hwinit(void)
|
||||
{
|
||||
struct clk *clk = clk_get_sys("ltq_gptu", NULL);
|
||||
clk_enable(clk);
|
||||
ltq_gptu_w32(0x00, GPTU_IRNEN);
|
||||
ltq_gptu_w32(0xff, GPTU_IRNCR);
|
||||
ltq_gptu_w32(CLC_RMC | CLC_SUSPEND, GPTU_CLC);
|
||||
}
|
||||
|
||||
static void gptu_hwexit(void)
|
||||
{
|
||||
ltq_gptu_w32(0x00, GPTU_IRNEN);
|
||||
ltq_gptu_w32(0xff, GPTU_IRNCR);
|
||||
ltq_gptu_w32(CLC_DISABLE, GPTU_CLC);
|
||||
}
|
||||
|
||||
static int ltq_gptu_enable(struct clk *clk)
|
||||
{
|
||||
int ret = request_irq(TIMER_INTERRUPT + clk->bits, timer_irq_handler,
|
||||
IRQF_TIMER, "timer", NULL);
|
||||
if (ret) {
|
||||
pr_err("gptu: failed to request irq\n");
|
||||
return ret;
|
||||
}
|
||||
|
||||
ltq_gptu_w32(CON_CNT | CON_EDGE_FALL | CON_SYNC | CON_CLK_INT,
|
||||
GPTU_CON(clk->bits));
|
||||
ltq_gptu_w32(1, GPTU_RLD(clk->bits));
|
||||
ltq_gptu_w32(ltq_gptu_r32(GPTU_IRNEN) | clk->bits, GPTU_IRNEN);
|
||||
ltq_gptu_w32(RUN_SEN | RUN_RL, GPTU_RUN(clk->bits));
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void ltq_gptu_disable(struct clk *clk)
|
||||
{
|
||||
ltq_gptu_w32(0, GPTU_RUN(clk->bits));
|
||||
ltq_gptu_w32(0, GPTU_CON(clk->bits));
|
||||
ltq_gptu_w32(0, GPTU_RLD(clk->bits));
|
||||
ltq_gptu_w32(ltq_gptu_r32(GPTU_IRNEN) & ~clk->bits, GPTU_IRNEN);
|
||||
free_irq(TIMER_INTERRUPT + clk->bits, NULL);
|
||||
}
|
||||
|
||||
static inline void clkdev_add_gptu(const char *con, unsigned int timer)
|
||||
{
|
||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||
|
||||
clk->cl.dev_id = "ltq_gptu";
|
||||
clk->cl.con_id = con;
|
||||
clk->cl.clk = clk;
|
||||
clk->enable = ltq_gptu_enable;
|
||||
clk->disable = ltq_gptu_disable;
|
||||
clk->bits = timer;
|
||||
clkdev_add(&clk->cl);
|
||||
}
|
||||
|
||||
static int __init gptu_setup(void)
|
||||
{
|
||||
/* remap gptu register range */
|
||||
ltq_gptu_membase = ltq_remap_resource(<q_gptu_resource);
|
||||
if (!ltq_gptu_membase)
|
||||
panic("Failed to remap gptu memory");
|
||||
|
||||
/* power up the core */
|
||||
gptu_hwinit();
|
||||
|
||||
/* the gptu has a ID register */
|
||||
if (((ltq_gptu_r32(GPTU_ID) >> 8) & 0xff) != GPTU_MAGIC) {
|
||||
pr_err("gptu: failed to find magic\n");
|
||||
gptu_hwexit();
|
||||
return -ENAVAIL;
|
||||
}
|
||||
|
||||
/* register the clocks */
|
||||
clkdev_add_gptu("timer1a", TIMER1A);
|
||||
clkdev_add_gptu("timer1b", TIMER1B);
|
||||
clkdev_add_gptu("timer2a", TIMER2A);
|
||||
clkdev_add_gptu("timer2b", TIMER2B);
|
||||
clkdev_add_gptu("timer3a", TIMER3A);
|
||||
clkdev_add_gptu("timer3b", TIMER3B);
|
||||
|
||||
pr_info("gptu: 6 timers loaded\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
arch_initcall(gptu_setup);
|
|
@ -1,793 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/ath5k_platform.h>
|
||||
#include <linux/ath9k_platform.h>
|
||||
#include <linux/pci.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_platform.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "dev-wifi-rt2x00.h"
|
||||
#include "dev-wifi-athxk.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
#include "pci-ath-fixup.h"
|
||||
|
||||
static struct mtd_partition arv45xx_brnboot_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "brn-boot",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "config",
|
||||
.offset = 0x20000,
|
||||
.size = 0x30000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x50000,
|
||||
.size = 0x390000,
|
||||
},
|
||||
{
|
||||
.name = "reserved", /* 12-byte signature at 0x3efff4 :/ */
|
||||
.offset = 0x3e0000,
|
||||
.size = 0x010000,
|
||||
},
|
||||
{
|
||||
.name = "eeprom",
|
||||
.offset = 0x3f0000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct mtd_partition arv75xx_brnboot_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "brn-boot",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "config",
|
||||
.offset = 0x20000,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x440000,
|
||||
.size = 0x3a0000,
|
||||
},
|
||||
{
|
||||
.name = "reserved", /* 12-byte signature at 0x7efff4 :/ */
|
||||
.offset = 0x7e0000,
|
||||
.size = 0x010000,
|
||||
},
|
||||
{
|
||||
.name = "board_config",
|
||||
.offset = 0x7f0000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
};
|
||||
|
||||
/*
|
||||
* this is generic configuration for all arv based boards, note that it can be
|
||||
* rewriten in arv_load_nor()
|
||||
*/
|
||||
static struct mtd_partition arv_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x20000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x30000,
|
||||
.size = 0x3c0000,
|
||||
},
|
||||
{
|
||||
.name = "board_config",
|
||||
.offset = 0x3f0000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data arv45xx_brnboot_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(arv45xx_brnboot_partitions),
|
||||
.parts = arv45xx_brnboot_partitions,
|
||||
};
|
||||
|
||||
static struct physmap_flash_data arv75xx_brnboot_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(arv75xx_brnboot_partitions),
|
||||
.parts = arv75xx_brnboot_partitions,
|
||||
};
|
||||
|
||||
static struct physmap_flash_data arv_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(arv_partitions),
|
||||
.parts = arv_partitions,
|
||||
};
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_EXT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = {
|
||||
[14] = INT_NUM_IM0_IRL0 + 22,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RMII,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv4510pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:foo", .gpio = 4, .active_low = 1, },
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv4518pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:power", .gpio = 3, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:adsl", .gpio = 4, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:internet", .gpio = 5, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi", .gpio = 6, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:yellow:wps", .gpio = 7, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:fail", .gpio = 8, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:usb", .gpio = 19, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:voip", .gpio = 100, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:fxs1", .gpio = 101, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:fxs2", .gpio = 102, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:fxo", .gpio = 103, .active_low = 1, .default_trigger = "default-on" },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
arv4518pw_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "wifi",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 28,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 30,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "wps",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_2,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 29,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv4519pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:red:power", .gpio = 7, .active_low = 1, },
|
||||
{ .name = "soc:green:power", .gpio = 2, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi", .gpio = 6, .active_low = 1, },
|
||||
{ .name = "soc:green:adsl", .gpio = 4, .active_low = 1, },
|
||||
{ .name = "soc:green:internet", .gpio = 5, .active_low = 1, },
|
||||
{ .name = "soc:red:internet", .gpio = 8, .active_low = 1, },
|
||||
{ .name = "soc:green:voip", .gpio = 100, .active_low = 1, },
|
||||
{ .name = "soc:green:phone1", .gpio = 101, .active_low = 1, },
|
||||
{ .name = "soc:green:phone2", .gpio = 102, .active_low = 1, },
|
||||
{ .name = "soc:green:fxo", .gpio = 103, .active_low = 1, },
|
||||
{ .name = "soc:green:usb", .gpio = 19, .active_low = 1, },
|
||||
{ .name = "soc:orange:wps", .gpio = 104, .active_low = 1, },
|
||||
{ .name = "soc:green:wps", .gpio = 105, .active_low = 1, },
|
||||
{ .name = "soc:red:wps", .gpio = 106, .active_low = 1, },
|
||||
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
arv4519pw_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 30,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "wlan",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_2,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 28,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv4520pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:blue:power", .gpio = 3, .active_low = 1, },
|
||||
{ .name = "soc:blue:adsl", .gpio = 4, .active_low = 1, },
|
||||
{ .name = "soc:blue:internet", .gpio = 5, .active_low = 1, },
|
||||
{ .name = "soc:red:power", .gpio = 6, .active_low = 1, },
|
||||
{ .name = "soc:yellow:wps", .gpio = 7, .active_low = 1, },
|
||||
{ .name = "soc:red:wps", .gpio = 9, .active_low = 1, },
|
||||
{ .name = "soc:blue:voip", .gpio = 100, .active_low = 1, },
|
||||
{ .name = "soc:blue:fxs1", .gpio = 101, .active_low = 1, },
|
||||
{ .name = "soc:blue:fxs2", .gpio = 102, .active_low = 1, },
|
||||
{ .name = "soc:blue:fxo", .gpio = 103, .active_low = 1, },
|
||||
{ .name = "soc:blue:voice", .gpio = 104, .active_low = 1, },
|
||||
{ .name = "soc:blue:usb", .gpio = 105, .active_low = 1, },
|
||||
{ .name = "soc:blue:wifi", .gpio = 106, .active_low = 1, },
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv452cpw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:blue:power", .gpio = 3, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:adsl", .gpio = 4, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:isdn", .gpio = 5, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:power", .gpio = 6, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:yellow:wps", .gpio = 7, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:wps", .gpio = 9, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:fxs1", .gpio = 100, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:fxs2", .gpio = 101, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:wps", .gpio = 102, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:fxo", .gpio = 103, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:voice", .gpio = 104, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:usb", .gpio = 105, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:wifi", .gpio = 106, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:internet", .gpio = 108, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:internet", .gpio = 109, .active_low = 1, .default_trigger = "default-on" },
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv4525pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:dsl", .gpio = 6, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi", .gpio = 8, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:online", .gpio = 9, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:fxs-internet", .gpio = 5, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:fxs-festnetz", .gpio = 4, .active_low = 1, .default_trigger = "default-on" },
|
||||
};
|
||||
|
||||
#define ARV4525PW_PHYRESET 13
|
||||
#define ARV4525PW_RELAY 31
|
||||
|
||||
static struct gpio
|
||||
arv4525pw_gpios[] __initdata = {
|
||||
{ ARV4525PW_PHYRESET, GPIOF_OUT_INIT_HIGH, "phyreset" },
|
||||
{ ARV4525PW_RELAY, GPIOF_OUT_INIT_HIGH, "relay" },
|
||||
};
|
||||
|
||||
|
||||
static struct gpio_led
|
||||
arv752dpw22_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:blue:power", .gpio = 3, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:internet", .gpio = 5, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:power", .gpio = 6, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:wps", .gpio = 8, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:fxo", .gpio = 103, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:voice", .gpio = 104, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:usb", .gpio = 105, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi", .gpio = 106, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi1", .gpio = 107, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:wifi", .gpio = 108, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:blue:wifi1", .gpio = 109, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:eth1", .gpio = 111, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:eth2", .gpio = 112, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:eth3", .gpio = 113, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:eth4", .gpio = 114, .active_low = 1, .default_trigger = "default-on", },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
arv752dpw22_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "btn0",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 12,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "btn1",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 13,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "btn2",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_2,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 28,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
arv7518pw_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:red:power", .gpio = 7, .active_low = 1, },
|
||||
{ .name = "soc:green:power", .gpio = 2, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wifi", .gpio = 6, .active_low = 1, },
|
||||
{ .name = "soc:green:adsl", .gpio = 4, .active_low = 1, },
|
||||
{ .name = "soc:green:internet", .gpio = 5, .active_low = 1, },
|
||||
{ .name = "soc:red:internet", .gpio = 8, .active_low = 1, },
|
||||
{ .name = "soc:green:voip", .gpio = 100, .active_low = 1, },
|
||||
{ .name = "soc:green:phone1", .gpio = 101, .active_low = 1, },
|
||||
{ .name = "soc:green:phone2", .gpio = 102, .active_low = 1, },
|
||||
{ .name = "soc:orange:fail", .gpio = 103, .active_low = 1, },
|
||||
{ .name = "soc:green:usb", .gpio = 19, .active_low = 1, },
|
||||
{ .name = "soc:orange:wps", .gpio = 104, .active_low = 1, },
|
||||
{ .name = "soc:green:wps", .gpio = 105, .active_low = 1, },
|
||||
{ .name = "soc:red:wps", .gpio = 106, .active_low = 1, },
|
||||
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
arv7518pw_gpio_keys[] __initdata = {
|
||||
/*{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 23,
|
||||
.active_low = 1,
|
||||
},*/
|
||||
{
|
||||
.desc = "wifi",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_2,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 25,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
arv7525pw_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "restart",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 29,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static void __init
|
||||
arv_load_nor(unsigned int max)
|
||||
{
|
||||
#define UBOOT_MAGIC 0x27051956
|
||||
|
||||
int i;
|
||||
int sector = -1;
|
||||
|
||||
if (ltq_brn_boot) {
|
||||
if (max == 0x800000)
|
||||
ltq_register_nor(&arv75xx_brnboot_flash_data);
|
||||
else
|
||||
ltq_register_nor(&arv45xx_brnboot_flash_data);
|
||||
return;
|
||||
}
|
||||
|
||||
for (i = 1; i < 4 && sector < 0; i++) {
|
||||
unsigned int uboot_magic;
|
||||
memcpy_fromio(&uboot_magic, (void *)KSEG1ADDR(LTQ_FLASH_START) + (i * 0x10000), 4);
|
||||
if (uboot_magic == UBOOT_MAGIC)
|
||||
sector = i;
|
||||
}
|
||||
|
||||
if (sector < 0)
|
||||
return;
|
||||
|
||||
arv_partitions[0].size = arv_partitions[1].offset = (sector - 1) * 0x10000;
|
||||
arv_partitions[2].offset = arv_partitions[0].size + 0x10000;
|
||||
arv_partitions[2].size = max - arv_partitions[2].offset - 0x10000;
|
||||
arv_partitions[3].offset = max - 0x10000;
|
||||
ltq_register_nor(&arv_flash_data);
|
||||
}
|
||||
|
||||
static void __init
|
||||
arv_register_ethernet(unsigned int mac_addr)
|
||||
{
|
||||
memcpy_fromio(<q_eth_data.mac.sa_data,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + mac_addr), 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
}
|
||||
|
||||
static u16 arv_ath5k_eeprom_data[ATH5K_PLAT_EEP_MAX_WORDS];
|
||||
static u16 arv_ath9k_eeprom_data[ATH9K_PLAT_EEP_MAX_WORDS];
|
||||
static u8 arv_athxk_eeprom_mac[6];
|
||||
|
||||
static void __init
|
||||
arv_register_ath5k(unsigned int ath_addr, unsigned int mac_addr)
|
||||
{
|
||||
int i;
|
||||
|
||||
memcpy_fromio(arv_athxk_eeprom_mac,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + mac_addr), 6);
|
||||
arv_athxk_eeprom_mac[5]++;
|
||||
memcpy_fromio(arv_ath5k_eeprom_data,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + ath_addr), ATH5K_PLAT_EEP_MAX_WORDS);
|
||||
// swap eeprom bytes
|
||||
for (i = 0; i < ATH5K_PLAT_EEP_MAX_WORDS>>1; i++) {
|
||||
arv_ath5k_eeprom_data[i] = swab16(arv_ath5k_eeprom_data[i]);
|
||||
if (i == 0x17e>>1) {
|
||||
/*
|
||||
* regdomain is invalid. it's unknown how did original
|
||||
* fw convered value to 0x82d4 so for now force to 0x67
|
||||
*/
|
||||
arv_ath5k_eeprom_data[i] &= 0x0000;
|
||||
arv_ath5k_eeprom_data[i] |= 0x67;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void __init
|
||||
arv_register_ath9k(unsigned int ath_addr, unsigned int mac_addr)
|
||||
{
|
||||
int i;
|
||||
u16 *eepdata, sum, el;
|
||||
|
||||
memcpy_fromio(arv_athxk_eeprom_mac,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + mac_addr), 6);
|
||||
arv_athxk_eeprom_mac[5]++;
|
||||
memcpy_fromio(arv_ath9k_eeprom_data,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + ath_addr), ATH9K_PLAT_EEP_MAX_WORDS);
|
||||
|
||||
// force regdomain to 0x67
|
||||
arv_ath9k_eeprom_data[0x208>>1] = 0x67;
|
||||
|
||||
// calculate new checksum
|
||||
sum = arv_ath9k_eeprom_data[0x200>>1];
|
||||
el = sum / sizeof(u16) - 2; /* skip length and (old) checksum */
|
||||
eepdata = (u16 *) (&arv_ath9k_eeprom_data[0x204>>1]); /* after checksum */
|
||||
for (i = 0; i < el; i++)
|
||||
sum ^= *eepdata++;
|
||||
sum ^= 0xffff;
|
||||
arv_ath9k_eeprom_data[0x202>>1] = sum;
|
||||
}
|
||||
|
||||
static void __init
|
||||
arv3527p_init(void)
|
||||
{
|
||||
#define ARV3527P_MAC_ADDR 0x3f0016
|
||||
|
||||
ltq_register_gpio_stp();
|
||||
// ltq_add_device_gpio_leds(arv3527p_gpio_leds, ARRAY_SIZE(arv3527p_gpio_leds));
|
||||
arv_load_nor(0x400000);
|
||||
arv_register_ethernet(ARV3527P_MAC_ADDR);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV3527P,
|
||||
"ARV3527P",
|
||||
"ARV3527P - Arcor Easybox 401",
|
||||
arv3527p_init);
|
||||
|
||||
static void __init
|
||||
arv4510pw_init(void)
|
||||
{
|
||||
#define ARV4510PW_MAC_ADDR 0x3f0014
|
||||
|
||||
ltq_register_gpio_stp();
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4510pw_gpio_leds), arv4510pw_gpio_leds);
|
||||
arv_load_nor(0x400000);
|
||||
ltq_pci_data.irq[12] = (INT_NUM_IM2_IRL0 + 31);
|
||||
ltq_pci_data.irq[15] = (INT_NUM_IM0_IRL0 + 26);
|
||||
ltq_pci_data.gpio |= PCI_EXIN2 | PCI_REQ2;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
arv_register_ethernet(ARV4510PW_MAC_ADDR);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV4510PW,
|
||||
"ARV4510PW",
|
||||
"ARV4510PW - Wippies Homebox",
|
||||
arv4510pw_init);
|
||||
|
||||
static void __init
|
||||
arv4518pw_init(void)
|
||||
{
|
||||
#define ARV4518PW_EBU 0
|
||||
#define ARV4518PW_USB 14
|
||||
#define ARV4518PW_SWITCH_RESET 13
|
||||
#define ARV4518PW_ATH_ADDR 0x3f0400
|
||||
#define ARV4518PW_MAC_ADDR 0x3f0016
|
||||
|
||||
ltq_register_gpio_ebu(ARV4518PW_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4518pw_gpio_leds), arv4518pw_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(arv4518pw_gpio_keys), arv4518pw_gpio_keys);
|
||||
arv_load_nor(0x400000);
|
||||
ltq_pci_data.gpio = PCI_GNT2 | PCI_REQ2;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
xway_register_dwc(ARV4518PW_USB);
|
||||
arv_register_ethernet(ARV4518PW_MAC_ADDR);
|
||||
arv_register_ath5k(ARV4518PW_ATH_ADDR, ARV4518PW_MAC_ADDR);
|
||||
ltq_register_ath5k(arv_ath5k_eeprom_data, arv_athxk_eeprom_mac);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV4518PW_SWITCH_RESET, "switch");
|
||||
gpio_direction_output(ARV4518PW_SWITCH_RESET, 1);
|
||||
gpio_export(ARV4518PW_SWITCH_RESET, 0);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV4518PW,
|
||||
"ARV4518PW",
|
||||
"ARV4518PW - SMC7908A-ISP, Airties WAV-221",
|
||||
arv4518pw_init);
|
||||
|
||||
static void __init
|
||||
arv4519pw_init(void)
|
||||
{
|
||||
#define ARV4519PW_EBU 0
|
||||
#define ARV4519PW_USB 14
|
||||
#define ARV4519PW_RELAY 31
|
||||
#define ARV4519PW_SWITCH_RESET 13
|
||||
#define ARV4519PW_ATH_ADDR 0x3f0400
|
||||
#define ARV4519PW_MAC_ADDR 0x3f0016
|
||||
|
||||
arv_load_nor(0x400000);
|
||||
ltq_register_gpio_ebu(ARV4519PW_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4519pw_gpio_leds), arv4519pw_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(arv4519pw_gpio_keys), arv4519pw_gpio_keys);
|
||||
ltq_pci_data.gpio = PCI_GNT2 | PCI_REQ1;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
xway_register_dwc(ARV4519PW_USB);
|
||||
arv_register_ethernet(ARV4519PW_MAC_ADDR);
|
||||
arv_register_ath5k(ARV4519PW_ATH_ADDR, ARV4519PW_MAC_ADDR);
|
||||
ltq_register_ath5k(arv_ath5k_eeprom_data, arv_athxk_eeprom_mac);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV4519PW_RELAY, "relay");
|
||||
gpio_direction_output(ARV4519PW_RELAY, 1);
|
||||
gpio_export(ARV4519PW_RELAY, 0);
|
||||
|
||||
gpio_request(ARV4519PW_SWITCH_RESET, "switch");
|
||||
gpio_set_value(ARV4519PW_SWITCH_RESET, 1);
|
||||
gpio_export(ARV4519PW_SWITCH_RESET, 0);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV4519PW,
|
||||
"ARV4519PW",
|
||||
"ARV4519PW - Vodafone, Pirelli",
|
||||
arv4519pw_init);
|
||||
|
||||
static void __init
|
||||
arv4520pw_init(void)
|
||||
{
|
||||
#define ARV4520PW_EBU 0x400
|
||||
#define ARV4520PW_USB 28
|
||||
#define ARV4520PW_SWITCH_RESET 110
|
||||
#define ARV4520PW_MAC_ADDR 0x3f0016
|
||||
|
||||
ltq_register_gpio_ebu(ARV4520PW_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4520pw_gpio_leds), arv4520pw_gpio_leds);
|
||||
arv_load_nor(0x400000);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_tapi();
|
||||
arv_register_ethernet(ARV4520PW_MAC_ADDR);
|
||||
ltq_register_rt2x00(NULL, (const u8 *) ltq_eth_data.mac.sa_data);
|
||||
xway_register_dwc(ARV4520PW_USB);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV4520PW_SWITCH_RESET, "switch");
|
||||
gpio_set_value(ARV4520PW_SWITCH_RESET, 1);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV4520PW,
|
||||
"ARV4520PW",
|
||||
"ARV4520PW - Airties WAV-281, Arcor A800",
|
||||
arv4520pw_init);
|
||||
|
||||
static void __init
|
||||
arv452Cpw_init(void)
|
||||
{
|
||||
#define ARV452CPW_EBU 0x77f
|
||||
#define ARV452CPW_USB 28
|
||||
#define ARV452CPW_RELAY1 31
|
||||
#define ARV452CPW_RELAY2 107
|
||||
#define ARV452CPW_SWITCH_RESET 110
|
||||
#define ARV452CPW_ATH_ADDR 0x3f0400
|
||||
#define ARV452CPW_MAC_ADDR 0x3f0016
|
||||
|
||||
ltq_register_gpio_ebu(ARV452CPW_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv452cpw_gpio_leds), arv452cpw_gpio_leds);
|
||||
arv_load_nor(0x400000);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
xway_register_dwc(ARV452CPW_USB);
|
||||
arv_register_ethernet(ARV452CPW_MAC_ADDR);
|
||||
arv_register_ath5k(ARV452CPW_ATH_ADDR, ARV452CPW_MAC_ADDR);
|
||||
ltq_register_ath5k(arv_ath5k_eeprom_data, arv_athxk_eeprom_mac);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV452CPW_SWITCH_RESET, "switch");
|
||||
gpio_set_value(ARV452CPW_SWITCH_RESET, 1);
|
||||
gpio_export(ARV452CPW_SWITCH_RESET, 0);
|
||||
|
||||
gpio_request(ARV452CPW_RELAY1, "relay1");
|
||||
gpio_direction_output(ARV452CPW_RELAY1, 1);
|
||||
gpio_export(ARV452CPW_RELAY1, 0);
|
||||
|
||||
gpio_request(ARV452CPW_RELAY2, "relay2");
|
||||
gpio_set_value(ARV452CPW_RELAY2, 1);
|
||||
gpio_export(ARV452CPW_RELAY2, 0);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV452CPW,
|
||||
"ARV452CPW",
|
||||
"ARV452CPW - Arcor A801",
|
||||
arv452Cpw_init);
|
||||
|
||||
static void __init
|
||||
arv4525pw_init(void)
|
||||
{
|
||||
#define ARV4525PW_ATH_ADDR 0x3f0400
|
||||
#define ARV4525PW_MAC_ADDR 0x3f0016
|
||||
|
||||
arv_load_nor(0x400000);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4525pw_gpio_leds), arv4525pw_gpio_leds);
|
||||
gpio_request_array(arv4525pw_gpios, ARRAY_SIZE(arv4525pw_gpios));
|
||||
gpio_export(ARV4525PW_RELAY, false);
|
||||
gpio_export(ARV4525PW_PHYRESET, false);
|
||||
ltq_pci_data.clock = PCI_CLOCK_INT;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
arv_register_ath5k(ARV4525PW_ATH_ADDR, ARV4525PW_MAC_ADDR);
|
||||
ltq_register_ath5k(arv_ath5k_eeprom_data, arv_athxk_eeprom_mac);
|
||||
ltq_eth_data.mii_mode = PHY_INTERFACE_MODE_MII;
|
||||
arv_register_ethernet(ARV4525PW_MAC_ADDR);
|
||||
ltq_register_tapi();
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV4525PW,
|
||||
"ARV4525PW",
|
||||
"ARV4525PW - Speedport W502V",
|
||||
arv4525pw_init);
|
||||
|
||||
static void __init
|
||||
arv7525pw_init(void)
|
||||
{
|
||||
#define ARV7525P_MAC_ADDR 0x3f0016
|
||||
|
||||
arv_load_nor(0x400000);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv4525pw_gpio_leds), arv4525pw_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(arv7525pw_gpio_keys), arv7525pw_gpio_keys);
|
||||
ltq_pci_data.clock = PCI_CLOCK_INT;
|
||||
ltq_pci_data.gpio = PCI_GNT1 | PCI_EXIN1;
|
||||
ltq_pci_data.irq[14] = (INT_NUM_IM3_IRL0 + 31);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_eth_data.mii_mode = PHY_INTERFACE_MODE_MII;
|
||||
ltq_register_rt2x00("RT2860.eeprom", NULL);
|
||||
ltq_register_tapi();
|
||||
arv_register_ethernet(ARV7525P_MAC_ADDR);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV7525PW,
|
||||
"ARV7525PW",
|
||||
"ARV7525PW - Speedport W303V",
|
||||
arv7525pw_init);
|
||||
|
||||
static void __init
|
||||
arv7518pw_init(void)
|
||||
{
|
||||
#define ARV7518PW_EBU 0x2
|
||||
#define ARV7518PW_USB 14
|
||||
#define ARV7518PW_SWITCH_RESET 13
|
||||
#define ARV7518PW_ATH_ADDR 0x7f0400
|
||||
#define ARV7518PW_MAC_ADDR 0x7f0016
|
||||
|
||||
arv_load_nor(0x800000);
|
||||
ltq_register_gpio_ebu(ARV7518PW_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv7518pw_gpio_leds), arv7518pw_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(arv7518pw_gpio_keys), arv7518pw_gpio_keys);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_tapi();
|
||||
xway_register_dwc(ARV7518PW_USB);
|
||||
arv_register_ethernet(ARV7518PW_MAC_ADDR);
|
||||
arv_register_ath9k(ARV7518PW_ATH_ADDR, ARV7518PW_MAC_ADDR);
|
||||
ltq_register_ath9k(arv_ath9k_eeprom_data, arv_athxk_eeprom_mac);
|
||||
ltq_pci_ath_fixup(14, arv_ath9k_eeprom_data);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV7518PW_SWITCH_RESET, "switch");
|
||||
gpio_direction_output(ARV7518PW_SWITCH_RESET, 1);
|
||||
gpio_export(ARV7518PW_SWITCH_RESET, 0);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV7518PW,
|
||||
"ARV7518PW",
|
||||
"ARV7518PW - ASTORIA",
|
||||
arv7518pw_init);
|
||||
|
||||
static void __init
|
||||
arv752dpw22_init(void)
|
||||
{
|
||||
#define ARV752DPW22_EBU 0x2
|
||||
#define ARV752DPW22_USB 100
|
||||
#define ARV752DPW22_RELAY 101
|
||||
#define ARV752DPW22_MAC_ADDR 0x7f0016
|
||||
|
||||
arv_load_nor(0x800000);
|
||||
ltq_register_gpio_ebu(ARV752DPW22_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv752dpw22_gpio_leds), arv752dpw22_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(arv752dpw22_gpio_keys), arv752dpw22_gpio_keys);
|
||||
ltq_pci_data.irq[15] = (INT_NUM_IM3_IRL0 + 31);
|
||||
ltq_pci_data.gpio |= PCI_EXIN1 | PCI_REQ2;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
xway_register_dwc(ARV752DPW22_USB);
|
||||
arv_register_ethernet(ARV752DPW22_MAC_ADDR);
|
||||
ltq_register_tapi();
|
||||
|
||||
gpio_request(ARV752DPW22_RELAY, "relay");
|
||||
gpio_set_value(ARV752DPW22_RELAY, 1);
|
||||
gpio_export(ARV752DPW22_RELAY, 0);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV752DPW22,
|
||||
"ARV752DPW22",
|
||||
"ARV752DPW22 - Arcor A803",
|
||||
arv752dpw22_init);
|
||||
|
||||
static void __init
|
||||
arv752dpw_init(void)
|
||||
{
|
||||
#define ARV752DPW22_EBU 0x2
|
||||
#define ARV752DPW22_USB 100
|
||||
#define ARV752DPW22_RELAY 101
|
||||
#define ARV752DPW22_MAC_ADDR 0x7f0016
|
||||
|
||||
arv_load_nor(0x800000);
|
||||
ltq_register_gpio_ebu(ARV752DPW22_EBU);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(arv752dpw22_gpio_leds), arv752dpw22_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(arv752dpw22_gpio_keys), arv752dpw22_gpio_keys);
|
||||
ltq_pci_data.irq[14] = (INT_NUM_IM3_IRL0 + 31);
|
||||
ltq_pci_data.gpio |= PCI_EXIN1 | PCI_REQ2;
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_tapi();
|
||||
xway_register_dwc(ARV752DPW22_USB);
|
||||
ltq_register_rt2x00("RT2860.eeprom", NULL);
|
||||
arv_register_ethernet(ARV752DPW22_MAC_ADDR);
|
||||
gpio_request(ARV752DPW22_RELAY, "relay");
|
||||
gpio_set_value(ARV752DPW22_RELAY, 1);
|
||||
gpio_export(ARV752DPW22_RELAY, 0);
|
||||
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_ARV752DPW,
|
||||
"ARV752DPW",
|
||||
"ARV752DPW - Arcor A802",
|
||||
arv752dpw_init);
|
|
@ -1,542 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Andrej Vlašić
|
||||
* Copyright (C) 2011 Luka Perkov
|
||||
*
|
||||
*/
|
||||
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/ath5k_platform.h>
|
||||
#include <linux/ath9k_platform.h>
|
||||
#include <linux/pci.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/string.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/module.h>
|
||||
|
||||
#include <irq.h>
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_platform.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
//#include "dev-wifi-ath9k.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
|
||||
#undef USE_BTHH_GPIO_INIT
|
||||
|
||||
// this reads certain data from u-boot if it's there
|
||||
#define USE_UBOOT_ENV_DATA
|
||||
|
||||
#define UBOOT_ENV_OFFSET 0x040000
|
||||
#define UBOOT_ENV_SIZE 0x010000
|
||||
|
||||
#ifdef NAND_ORGLAYOUT
|
||||
// this is only here for reference
|
||||
// definition of NAND flash area
|
||||
static struct mtd_partition bthomehubv2b_nand_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "ART",
|
||||
.offset = 0x0000000,
|
||||
.size = 0x0004000,
|
||||
},
|
||||
{
|
||||
.name = "image1",
|
||||
.offset = 0x0004000,
|
||||
.size = 0x0E00000,
|
||||
},
|
||||
{
|
||||
.name = "unknown1",
|
||||
.offset = 0x0E04000,
|
||||
.size = 0x00FC000,
|
||||
},
|
||||
{
|
||||
.name = "image2",
|
||||
.offset = 0x0F00000,
|
||||
.size = 0x0E00000,
|
||||
},
|
||||
{
|
||||
.name = "unknown2",
|
||||
.offset = 0x1D00000,
|
||||
.size = 0x0300000,
|
||||
},
|
||||
|
||||
};
|
||||
#endif
|
||||
|
||||
#ifdef NAND_KEEPOPENRG
|
||||
// this allows both firmwares to co-exist
|
||||
|
||||
static struct mtd_partition bthomehubv2b_nand_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "art",
|
||||
.offset = 0x0000000,
|
||||
.size = 0x0004000,
|
||||
},
|
||||
{
|
||||
.name = "Image1",
|
||||
.offset = 0x0004000,
|
||||
.size = 0x0E00000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x0E04000,
|
||||
.size = 0x11fC000,
|
||||
},
|
||||
{
|
||||
.name = "wholeflash",
|
||||
.offset = 0x0000000,
|
||||
.size = 0x2000000,
|
||||
},
|
||||
|
||||
};
|
||||
#endif
|
||||
|
||||
// this gives more jffs2 by overwriting openrg
|
||||
|
||||
static struct mtd_partition bthomehubv2b_nand_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "art",
|
||||
.offset = 0x0000000,
|
||||
.size = 0x0004000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x0004000,
|
||||
.size = 0x1ffC000,
|
||||
},
|
||||
{
|
||||
.name = "wholeflash",
|
||||
.offset = 0x0000000,
|
||||
.size = 0x2000000,
|
||||
},
|
||||
|
||||
};
|
||||
|
||||
extern void __init xway_register_nand(struct mtd_partition *parts, int count);
|
||||
|
||||
// end BTHH_USE_NAND
|
||||
|
||||
static struct gpio_led
|
||||
bthomehubv2b_gpio_leds[] __initdata = {
|
||||
|
||||
{ .name = "soc:orange:upgrading", .gpio = 213, },
|
||||
{ .name = "soc:orange:phone", .gpio = 214, },
|
||||
{ .name = "soc:blue:phone", .gpio = 215, },
|
||||
{ .name = "soc:orange:wireless", .gpio = 216, },
|
||||
{ .name = "soc:blue:wireless", .gpio = 217, },
|
||||
{ .name = "soc:red:broadband", .gpio = 218, },
|
||||
{ .name = "soc:orange:broadband", .gpio = 219, },
|
||||
{ .name = "soc:blue:broadband", .gpio = 220, },
|
||||
{ .name = "soc:red:power", .gpio = 221, },
|
||||
{ .name = "soc:orange:power", .gpio = 222, },
|
||||
{ .name = "soc:blue:power", .gpio = 223, },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
bthomehubv2b_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "restart",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 2,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "findhandset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 15,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "wps",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_2,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 22,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
// definition of NOR flash area - as per original.
|
||||
static struct mtd_partition bthomehubv2b_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x000000,
|
||||
.size = 0x040000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = UBOOT_ENV_OFFSET,
|
||||
.size = UBOOT_ENV_SIZE,
|
||||
},
|
||||
{
|
||||
.name = "rg_conf_1",
|
||||
.offset = 0x050000,
|
||||
.size = 0x010000,
|
||||
},
|
||||
{
|
||||
.name = "rg_conf_2",
|
||||
.offset = 0x060000,
|
||||
.size = 0x010000,
|
||||
},
|
||||
{
|
||||
.name = "rg_conf_factory",
|
||||
.offset = 0x070000,
|
||||
.size = 0x010000,
|
||||
},
|
||||
};
|
||||
|
||||
|
||||
/* nor flash */
|
||||
/* bt homehubv2b has a very small nor flash */
|
||||
/* so make it look for a small one, else we get a lot of alias chips identified - */
|
||||
/* not a bug problem, but fills the logs. */
|
||||
static struct resource bthhv2b_nor_resource =
|
||||
MEM_RES("nor", LTQ_FLASH_START, 0x80000);
|
||||
|
||||
static struct platform_device ltq_nor = {
|
||||
.name = "ltq_nor",
|
||||
.resource = &bthhv2b_nor_resource,
|
||||
.num_resources = 1,
|
||||
};
|
||||
|
||||
static void __init bthhv2b_register_nor(struct physmap_flash_data *data)
|
||||
{
|
||||
ltq_nor.dev.platform_data = data;
|
||||
platform_device_register(<q_nor);
|
||||
}
|
||||
|
||||
static struct physmap_flash_data bthomehubv2b_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(bthomehubv2b_partitions),
|
||||
.parts = bthomehubv2b_partitions,
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_INT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = { [14] = INT_NUM_IM0_IRL0 + 22, },
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_MII,
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
static char __init *get_uboot_env_var(char *haystack, int haystack_len, char *needle, int needle_len) {
|
||||
int i;
|
||||
for (i = 0; i <= haystack_len - needle_len; i++) {
|
||||
if (memcmp(haystack + i, needle, needle_len) == 0) {
|
||||
return haystack + i + needle_len;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
* bthomehubv2b_parse_hex_* are not uniq. in arm/orion there are also duplicates:
|
||||
* dns323_parse_hex_*
|
||||
* TODO: one day write a patch for this :)
|
||||
*/
|
||||
static int __init bthomehubv2b_parse_hex_nibble(char n) {
|
||||
if (n >= '0' && n <= '9')
|
||||
return n - '0';
|
||||
|
||||
if (n >= 'A' && n <= 'F')
|
||||
return n - 'A' + 10;
|
||||
|
||||
if (n >= 'a' && n <= 'f')
|
||||
return n - 'a' + 10;
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int __init bthomehubv2b_parse_hex_byte(const char *b) {
|
||||
int hi;
|
||||
int lo;
|
||||
|
||||
hi = bthomehubv2b_parse_hex_nibble(b[0]);
|
||||
lo = bthomehubv2b_parse_hex_nibble(b[1]);
|
||||
|
||||
if (hi < 0 || lo < 0)
|
||||
return -1;
|
||||
|
||||
return (hi << 4) | lo;
|
||||
}
|
||||
|
||||
static int __init bthomehubv2b_register_ethernet(void) {
|
||||
u_int8_t addr[6];
|
||||
int i;
|
||||
char *mac = "01:02:03:04:05:06";
|
||||
int gotmac = 0;
|
||||
char *boardid = "BTHHV2B";
|
||||
int gotboardid = 0;
|
||||
|
||||
char *uboot_env_page;
|
||||
uboot_env_page = ioremap(LTQ_FLASH_START + UBOOT_ENV_OFFSET, UBOOT_ENV_SIZE);
|
||||
if (uboot_env_page)
|
||||
{
|
||||
char *Data = NULL;
|
||||
Data = get_uboot_env_var(uboot_env_page, UBOOT_ENV_SIZE, "\0ethaddr=", 9);
|
||||
if (Data)
|
||||
{
|
||||
mac = Data;
|
||||
}
|
||||
|
||||
Data = get_uboot_env_var(uboot_env_page, UBOOT_ENV_SIZE, "\0boardid=", 9);
|
||||
|
||||
if (Data)
|
||||
boardid = Data;
|
||||
}
|
||||
else
|
||||
{
|
||||
printk("bthomehubv2b: Failed to get uboot_env_page");
|
||||
}
|
||||
|
||||
if (!mac) {
|
||||
goto error_fail;
|
||||
}
|
||||
|
||||
if (!boardid) {
|
||||
goto error_fail;
|
||||
}
|
||||
|
||||
/* Sanity check the string we're looking at */
|
||||
for (i = 0; i < 5; i++) {
|
||||
if (*(mac + (i * 3) + 2) != ':') {
|
||||
goto error_fail;
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 0; i < 6; i++) {
|
||||
int byte;
|
||||
byte = bthomehubv2b_parse_hex_byte(mac + (i * 3));
|
||||
if (byte < 0) {
|
||||
goto error_fail;
|
||||
}
|
||||
addr[i] = byte;
|
||||
}
|
||||
|
||||
if (gotmac)
|
||||
printk("bthomehubv2b: Found ethernet MAC address: ");
|
||||
else
|
||||
printk("bthomehubv2b: using default MAC (pls set ethaddr in u-boot): ");
|
||||
|
||||
for (i = 0; i < 6; i++)
|
||||
printk("%.2x%s", addr[i], (i < 5) ? ":" : ".\n");
|
||||
|
||||
memcpy(<q_eth_data.mac.sa_data, addr, 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
|
||||
//memcpy(&bthomehubv2b_ath5k_eeprom_mac, addr, 6);
|
||||
//bthomehubv2b_ath5k_eeprom_mac[5]++;
|
||||
|
||||
if (gotboardid)
|
||||
printk("bthomehubv2b: Board id is %s.", boardid);
|
||||
else
|
||||
printk("bthomehubv2b: Default Board id is %s.", boardid);
|
||||
|
||||
if (strncmp(boardid, "BTHHV2B", 7) == 0) {
|
||||
// read in dev-wifi-ath9k
|
||||
//memcpy(&bthomehubv2b_ath5k_eeprom_data, sx763_eeprom_data, ATH5K_PLAT_EEP_MAX_WORDS);
|
||||
}
|
||||
else {
|
||||
printk("bthomehubv2b: Board id is unknown, fix uboot_env data.");
|
||||
}
|
||||
|
||||
|
||||
// should not unmap while we are using the ram?
|
||||
if (uboot_env_page)
|
||||
iounmap(uboot_env_page);
|
||||
|
||||
return 0;
|
||||
|
||||
error_fail:
|
||||
if (uboot_env_page)
|
||||
iounmap(uboot_env_page);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
||||
#define PORTA2_HW_PASS1 0
|
||||
#define PORTA2_HW_PASS1_SC14480 1
|
||||
#define PORTA2_HW_PASS2 2
|
||||
|
||||
int porta2_hw_revision = -1;
|
||||
EXPORT_SYMBOL(porta2_hw_revision);
|
||||
|
||||
#define LTQ_GPIO_OUT 0x00
|
||||
#define LTQ_GPIO_IN 0x04
|
||||
#define LTQ_GPIO_DIR 0x08
|
||||
#define LTQ_GPIO_ALTSEL0 0x0C
|
||||
#define LTQ_GPIO_ALTSEL1 0x10
|
||||
#define LTQ_GPIO_OD 0x14
|
||||
#define LTQ_GPIO_PUDSEL 0x1C
|
||||
#define LTQ_GPIO_PUDEN 0x20
|
||||
|
||||
#ifdef USE_BTHH_GPIO_INIT
|
||||
static void bthomehubv2b_board_prom_init(void)
|
||||
{
|
||||
int revision = 0;
|
||||
unsigned int gpio = 0;
|
||||
void __iomem *mem = ioremap(LTQ_GPIO0_BASE_ADDR, LTQ_GPIO_SIZE*2);
|
||||
|
||||
#define DANUBE_GPIO_P0_OUT (unsigned short *)(mem + LTQ_GPIO_OUT)
|
||||
#define DANUBE_GPIO_P0_IN (unsigned short *)(mem + LTQ_GPIO_IN)
|
||||
#define DANUBE_GPIO_P0_DIR (unsigned short *)(mem + LTQ_GPIO_DIR)
|
||||
#define DANUBE_GPIO_P0_ALTSEL0 (unsigned short *)(mem + LTQ_GPIO_ALTSEL0)
|
||||
#define DANUBE_GPIO_P0_ALTSEL1 (unsigned short *)(mem + LTQ_GPIO_ALTSEL1)
|
||||
|
||||
#define DANUBE_GPIO_P1_OUT (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_OUT)
|
||||
#define DANUBE_GPIO_P1_IN (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_IN)
|
||||
#define DANUBE_GPIO_P1_DIR (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_DIR)
|
||||
#define DANUBE_GPIO_P1_ALTSEL0 (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_ALTSEL0)
|
||||
#define DANUBE_GPIO_P1_ALTSEL1 (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_ALTSEL1)
|
||||
#define DANUBE_GPIO_P1_OD (unsigned short *)(mem + LTQ_GPIO_SIZE + LTQ_GPIO_OD)
|
||||
|
||||
printk("About to sense board using GPIOs at %8.8X\n", (unsigned int)mem);
|
||||
|
||||
|
||||
/* First detect HW revision of the board. For that we need to set the GPIO
|
||||
* lines according to table 7.2.1/7.2.2 in HSI */
|
||||
*DANUBE_GPIO_P0_OUT = 0x0200;
|
||||
*DANUBE_GPIO_P0_DIR = 0x2610;
|
||||
*DANUBE_GPIO_P0_ALTSEL0 = 0x7812;
|
||||
*DANUBE_GPIO_P0_ALTSEL1 = 0x0000;
|
||||
|
||||
*DANUBE_GPIO_P1_OUT = 0x7008;
|
||||
*DANUBE_GPIO_P1_DIR = 0xF3AE;
|
||||
*DANUBE_GPIO_P1_ALTSEL0 = 0x83A7;
|
||||
*DANUBE_GPIO_P1_ALTSEL1 = 0x0400;
|
||||
|
||||
gpio = (*DANUBE_GPIO_P0_IN & 0xFFFF) |
|
||||
((*DANUBE_GPIO_P1_IN & 0xFFFF) << 16);
|
||||
|
||||
revision |= (gpio & (1 << 27)) ? (1 << 0) : 0;
|
||||
revision |= (gpio & (1 << 20)) ? (1 << 1) : 0;
|
||||
revision |= (gpio & (1 << 8)) ? (1 << 2) : 0;
|
||||
revision |= (gpio & (1 << 6)) ? (1 << 3) : 0;
|
||||
revision |= (gpio & (1 << 5)) ? (1 << 4) : 0;
|
||||
revision |= (gpio & (1 << 0)) ? (1 << 5) : 0;
|
||||
|
||||
porta2_hw_revision = revision;
|
||||
printk("PORTA2: detected HW revision %d\n", revision);
|
||||
|
||||
/* Set GPIO lines according to HW revision. */
|
||||
/* !!! Note that we are setting SPI_CS5 (GPIO 9) to be GPIO out with value
|
||||
* of HIGH since the FXO does not use the SPI CS mechanism, it does it
|
||||
* manually by controlling the GPIO line. We need the CS line to be disabled
|
||||
* (HIGH) until needed since it will intefere with other devices on the SPI
|
||||
* bus. */
|
||||
*DANUBE_GPIO_P0_OUT = 0x0200;
|
||||
/*
|
||||
* During the manufacturing process a different machine takes over uart0
|
||||
* so set it as input (so it wouldn't drive the line)
|
||||
*/
|
||||
#define cCONFIG_SHC_BT_MFG_TEST 0
|
||||
*DANUBE_GPIO_P0_DIR = 0x2671 | (cCONFIG_SHC_BT_MFG_TEST ? 0 : (1 << 12));
|
||||
|
||||
if (revision == PORTA2_HW_PASS1_SC14480 || revision == PORTA2_HW_PASS2)
|
||||
*DANUBE_GPIO_P0_ALTSEL0 = 0x7873;
|
||||
else
|
||||
*DANUBE_GPIO_P0_ALTSEL0 = 0x3873;
|
||||
|
||||
*DANUBE_GPIO_P0_ALTSEL1 = 0x0001;
|
||||
|
||||
|
||||
//###################################################################################
|
||||
// Register values before patch
|
||||
// P1_ALTSEL0 = 0x83A7
|
||||
// P1_ALTSEL1 = 0x0400
|
||||
// P1_OU T = 0x7008
|
||||
// P1_DIR = 0xF3AE
|
||||
// P1_OD = 0xE3Fc
|
||||
printk("\nApplying Patch for CPU1 IRQ Issue\n");
|
||||
*DANUBE_GPIO_P1_ALTSEL0 &= ~(1<<12); // switch P1.12 (GPIO28) to GPIO functionality
|
||||
*DANUBE_GPIO_P1_ALTSEL1 &= ~(1<<12); // switch P1.12 (GPIO28) to GPIO functionality
|
||||
*DANUBE_GPIO_P1_OUT &= ~(1<<12); // set P1.12 (GPIO28) to 0
|
||||
*DANUBE_GPIO_P1_DIR |= (1<<12); // configure P1.12 (GPIO28) as output
|
||||
*DANUBE_GPIO_P1_OD |= (1<<12); // activate Push/Pull mode
|
||||
udelay(100); // wait a little bit (100us)
|
||||
*DANUBE_GPIO_P1_OD &= ~(1<<12); // switch back from Push/Pull to Open Drain
|
||||
// important: before! setting output to 1 (3,3V) the mode must be switched
|
||||
// back to Open Drain because the reset pin of the SC14488 is internally
|
||||
// pulled to 1,8V
|
||||
*DANUBE_GPIO_P1_OUT |= (1<<12); // set output P1.12 (GPIO28) to 1
|
||||
// Register values after patch, should be the same as before
|
||||
// P1_ALTSEL0 = 0x83A7
|
||||
// P1_ALTSEL1 = 0x0400
|
||||
// P1_OUT = 0x7008
|
||||
// P1_DIR = 0xF3AE
|
||||
// P1_OD = 0xE3Fc
|
||||
//###################################################################################
|
||||
|
||||
|
||||
*DANUBE_GPIO_P1_OUT = 0x7008;
|
||||
*DANUBE_GPIO_P1_DIR = 0xEBAE | (revision == PORTA2_HW_PASS2 ? 0x1000 : 0);
|
||||
*DANUBE_GPIO_P1_ALTSEL0 = 0x8BA7;
|
||||
*DANUBE_GPIO_P1_ALTSEL1 = 0x0400;
|
||||
|
||||
iounmap(mem);
|
||||
}
|
||||
#endif
|
||||
static void __init bthomehubv2b_init(void) {
|
||||
#define bthomehubv2b_USB 13
|
||||
|
||||
// read the board version
|
||||
#ifdef USE_BTHH_GPIO_INIT
|
||||
bthomehubv2b_board_prom_init();
|
||||
#endif
|
||||
|
||||
// register extra GPPOs used by LEDs as GPO 0x200+
|
||||
ltq_register_gpio_stp();
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(bthomehubv2b_gpio_leds), bthomehubv2b_gpio_leds);
|
||||
bthhv2b_register_nor(&bthomehubv2b_flash_data);
|
||||
xway_register_nand(bthomehubv2b_nand_partitions, ARRAY_SIZE(bthomehubv2b_nand_partitions));
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_tapi();
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(bthomehubv2b_gpio_keys), bthomehubv2b_gpio_keys);
|
||||
// ltq_register_ath9k();
|
||||
xway_register_dwc(bthomehubv2b_USB);
|
||||
bthomehubv2b_register_ethernet();
|
||||
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_BTHOMEHUBV2BOPENRG,
|
||||
"BTHOMEHUBV2BOPENRG",
|
||||
"BTHOMEHUBV2B - BT Homehub V2.0 Type B with OpenRG image retained",
|
||||
bthomehubv2b_init);
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_BTHOMEHUBV2B,
|
||||
"BTHOMEHUBV2B",
|
||||
"BTHOMEHUBV2B - BT Homehub V2.0 Type B",
|
||||
bthomehubv2b_init);
|
|
@ -1,115 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/spi/spi_gpio.h>
|
||||
#include <linux/spi/flash.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <irq.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-ifxhcd.h"
|
||||
#include "dev-gpio-leds.h"
|
||||
#include "dev-gpio-buttons.h"
|
||||
|
||||
static struct mtd_partition fritz7320_partitions[] = {
|
||||
{
|
||||
.name = "urlader",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x20000,
|
||||
.size = 0xf60000,
|
||||
},
|
||||
{
|
||||
.name = "tffs (1)",
|
||||
.offset = 0xf80000,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "tffs (2)",
|
||||
.offset = 0xfc0000,
|
||||
.size = 0x40000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data fritz7320_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(fritz7320_partitions),
|
||||
.parts = fritz7320_partitions,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
fritz7320_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:power", .gpio = 44, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:internet", .gpio = 47, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:dect", .gpio = 38, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:wlan", .gpio = 37, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:dual1", .gpio = 35, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:dual2", .gpio = 45, .active_low = 1, .default_trigger = "default-on" },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
fritz7320_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "wifi",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 1,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "dect",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 2,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_INT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = {
|
||||
[14] = INT_NUM_IM0_IRL0 + 22,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RMII,
|
||||
};
|
||||
|
||||
static int usb_pins[2] = { 50, 51 };
|
||||
|
||||
static void __init
|
||||
fritz7320_init(void)
|
||||
{
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(fritz7320_gpio_keys), fritz7320_gpio_keys);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(fritz7320_gpio_leds), fritz7320_gpio_leds);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
ltq_register_nor(&fritz7320_flash_data);
|
||||
xway_register_hcd(usb_pins);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_FRITZ7320,
|
||||
"FRITZ7320",
|
||||
"FRITZ!BOX 7320",
|
||||
fritz7320_init);
|
|
@ -1,164 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/spi/spi_gpio.h>
|
||||
#include <linux/spi/flash.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <irq.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-ifxhcd.h"
|
||||
#include "dev-gpio-leds.h"
|
||||
#include "dev-gpio-buttons.h"
|
||||
|
||||
static struct mtd_partition fritz3370_partitions[] = {
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x0,
|
||||
.size = 0x400000,
|
||||
},
|
||||
{
|
||||
.name = "filesystem",
|
||||
.offset = 0x400000,
|
||||
.size = 0x3000000,
|
||||
},
|
||||
{
|
||||
.name = "reserved-kernel",
|
||||
.offset = 0x3400000,
|
||||
.size = 0x400000,
|
||||
},
|
||||
{
|
||||
.name = "reserved",
|
||||
.offset = 0x3800000,
|
||||
.size = 0x3000000,
|
||||
},
|
||||
{
|
||||
.name = "config",
|
||||
.offset = 0x6800000,
|
||||
.size = 0x200000,
|
||||
},
|
||||
{
|
||||
.name = "nand-filesystem",
|
||||
.offset = 0x6a00000,
|
||||
.size = 0x1600000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct mtd_partition spi_flash_partitions[] = {
|
||||
{
|
||||
.name = "urlader",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "tffs",
|
||||
.offset = 0x20000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
{
|
||||
.name = "tffs",
|
||||
.offset = 0x30000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
fritz3370_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:1", .gpio = 32, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:2", .gpio = 33, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:red:3", .gpio = 34, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:4", .gpio = 35, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:5", .gpio = 36, .active_low = 1, .default_trigger = "default-on" },
|
||||
{ .name = "soc:green:6", .gpio = 47, .active_low = 1, .default_trigger = "default-on" },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
fritz3370_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "wifi",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 29,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RMII,
|
||||
};
|
||||
|
||||
static int usb_pins[2] = { 5, 14 };
|
||||
|
||||
#define SPI_GPIO_MRST 16
|
||||
#define SPI_GPIO_MTSR 17
|
||||
#define SPI_GPIO_CLK 18
|
||||
#define SPI_GPIO_CS0 10
|
||||
|
||||
static struct spi_gpio_platform_data spi_gpio_data = {
|
||||
.sck = SPI_GPIO_CLK,
|
||||
.mosi = SPI_GPIO_MTSR,
|
||||
.miso = SPI_GPIO_MRST,
|
||||
.num_chipselect = 2,
|
||||
};
|
||||
|
||||
static struct platform_device spi_gpio_device = {
|
||||
.name = "spi_gpio",
|
||||
.dev.platform_data = &spi_gpio_data,
|
||||
};
|
||||
|
||||
static struct flash_platform_data spi_flash_data = {
|
||||
.name = "SPL",
|
||||
.parts = spi_flash_partitions,
|
||||
.nr_parts = ARRAY_SIZE(spi_flash_partitions),
|
||||
};
|
||||
|
||||
static struct spi_board_info spi_flash __initdata = {
|
||||
.modalias = "m25p80",
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
.max_speed_hz = 10 * 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.chip_select = 0,
|
||||
.controller_data = (void *) SPI_GPIO_CS0,
|
||||
.platform_data = &spi_flash_data
|
||||
};
|
||||
|
||||
static void __init
|
||||
spi_gpio_init(void)
|
||||
{
|
||||
spi_register_board_info(&spi_flash, 1);
|
||||
platform_device_register(&spi_gpio_device);
|
||||
}
|
||||
|
||||
static void __init
|
||||
fritz3370_init(void)
|
||||
{
|
||||
spi_gpio_init();
|
||||
platform_device_register_simple("pcie-xway", 0, NULL, 0);
|
||||
xway_register_nand(fritz3370_partitions, ARRAY_SIZE(fritz3370_partitions));
|
||||
xway_register_hcd(usb_pins);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(fritz3370_gpio_leds), fritz3370_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(fritz3370_gpio_keys), fritz3370_gpio_keys);
|
||||
ltq_register_vrx200(<q_eth_data);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_FRITZ3370,
|
||||
"FRITZ3370",
|
||||
"FRITZ!BOX 3370",
|
||||
fritz3370_init);
|
|
@ -1,168 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Andrej Vlašić
|
||||
* Copyright (C) 2011 Luka Perkov
|
||||
*
|
||||
*/
|
||||
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/pci.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/if_ether.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/string.h>
|
||||
|
||||
#include <irq.h>
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_platform.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "dev-wifi-athxk.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
|
||||
#include "mach-gigasx76x.h"
|
||||
|
||||
static u8 ltq_ethaddr[6] = { 0 };
|
||||
|
||||
static int __init
|
||||
setup_ethaddr(char *str)
|
||||
{
|
||||
if (!mac_pton(str, ltq_ethaddr))
|
||||
memset(ltq_ethaddr, 0, 6);
|
||||
return 0;
|
||||
}
|
||||
__setup("ethaddr=", setup_ethaddr);
|
||||
|
||||
|
||||
enum {
|
||||
UNKNOWN = 0,
|
||||
SX761,
|
||||
SX762,
|
||||
SX763,
|
||||
};
|
||||
static u8 board __initdata = SX763;
|
||||
|
||||
static int __init
|
||||
setup_board(char *str)
|
||||
{
|
||||
if (!strcmp(str, "sx761"))
|
||||
board = SX761;
|
||||
else if (!strcmp(str, "sx762"))
|
||||
board = SX762;
|
||||
else if (!strcmp(str, "sx763"))
|
||||
board = SX763;
|
||||
else
|
||||
board = UNKNOWN;
|
||||
return 0;
|
||||
}
|
||||
__setup("board=", setup_board);
|
||||
|
||||
static struct mtd_partition gigasx76x_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x10000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x10000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x20000,
|
||||
.size = 0x7e0000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
gigasx76x_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:voip", .gpio = 216, },
|
||||
{ .name = "soc:green:adsl", .gpio = 217, },
|
||||
{ .name = "soc:green:usb", .gpio = 218, },
|
||||
{ .name = "soc:green:wifi", .gpio = 219, },
|
||||
{ .name = "soc:green:phone2", .gpio = 220, },
|
||||
{ .name = "soc:green:phone1", .gpio = 221, },
|
||||
{ .name = "soc:green:line", .gpio = 222, },
|
||||
{ .name = "soc:green:online", .gpio = 223, },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
gigasx76x_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "wps",
|
||||
.type = EV_KEY,
|
||||
.code = KEY_WPS_BUTTON,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 22,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 14,
|
||||
.active_low = 0,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data gigasx76x_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(gigasx76x_partitions),
|
||||
.parts = gigasx76x_partitions,
|
||||
};
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_INT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = { [14] = INT_NUM_IM0_IRL0 + 22, },
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_MII,
|
||||
};
|
||||
|
||||
static void __init
|
||||
gigasx76x_init(void)
|
||||
{
|
||||
#define GIGASX76X_USB 29
|
||||
|
||||
ltq_register_gpio_stp();
|
||||
ltq_register_nor(&gigasx76x_flash_data);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
ltq_register_tapi();
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(gigasx76x_gpio_leds), gigasx76x_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(gigasx76x_gpio_keys), gigasx76x_gpio_keys);
|
||||
xway_register_dwc(GIGASX76X_USB);
|
||||
|
||||
if (!is_valid_ether_addr(ltq_ethaddr))
|
||||
random_ether_addr(ltq_ethaddr);
|
||||
|
||||
memcpy(<q_eth_data.mac.sa_data, ltq_ethaddr, 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
if (board == SX762)
|
||||
ltq_register_ath5k(sx762_eeprom_data, ltq_ethaddr);
|
||||
else
|
||||
ltq_register_ath5k(sx763_eeprom_data, ltq_ethaddr);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_GIGASX76X,
|
||||
"GIGASX76X",
|
||||
"GIGASX76X - Gigaset SX761,SX762,SX763",
|
||||
gigasx76x_init);
|
|
@ -1,210 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2011 Andrej Vlašić
|
||||
* Copyright (C) 2011 Luka Perkov
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef _MACH_GIGASX76X_H__
|
||||
#define _MACH_GIGASX76X_H__
|
||||
|
||||
#include <linux/ath5k_platform.h>
|
||||
|
||||
static u16 sx763_eeprom_data[ATH5K_PLAT_EEP_MAX_WORDS] =
|
||||
{
|
||||
0x0013,0x168c,0x0200,0x0001,0x0000,0x5001,0x0000,0x2051,0x2051,0x1c0a,0x0100,
|
||||
0x0000,0x01c2,0x0002,0xc606,0x0001,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0xf165,0x7fbe,0x0003,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x5aa5,0x0000,0x0000,0x0313,0x4943,
|
||||
0x2053,0x7104,0x1202,0x0400,0x0306,0x0001,0x0000,0x0500,0x410e,0x39b1,0x1eb5,
|
||||
0x4e2d,0x3056,0xffff,0xe902,0x0700,0x0106,0x0000,0x0100,0x1500,0x0752,0x4101,
|
||||
0x6874,0x7265,0x736f,0x4320,0x6d6f,0x756d,0x696e,0x6163,0x6974,0x6e6f,0x2c73,
|
||||
0x4920,0x636e,0x002e,0x5241,0x3035,0x3130,0x302d,0x3030,0x2d30,0x3030,0x3030,
|
||||
0x5700,0x7269,0x6c65,0x7365,0x2073,0x414c,0x204e,0x6552,0x6566,0x6572,0x636e,
|
||||
0x2065,0x6143,0x6472,0x3000,0x0030,0x00ff,0x2100,0x0602,0x2201,0x0205,0x8d80,
|
||||
0x005b,0x0522,0x4002,0x8954,0x2200,0x0205,0x1b00,0x00b7,0x0522,0x8002,0x12a8,
|
||||
0x2201,0x0205,0x3600,0x016e,0x0522,0x0002,0x2551,0x2202,0x0205,0x6c00,0x02dc,
|
||||
0x0522,0x8002,0x37f9,0x2203,0x0205,0xa200,0x044a,0x0222,0x0803,0x0822,0x0604,
|
||||
0x0300,0xbe7f,0x65f1,0x0222,0x0105,0x00ff,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0x0037,0x971f,0x5003,0x9a66,0x0001,0x81c4,0x016a,
|
||||
0x02ff,0x84ff,0x15a3,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x2d2c,0x0000,0x0000,0x0000,0x0000,0xe028,0xa492,0x1c00,
|
||||
0x000e,0xb8ca,0x0013,0x0000,0x0000,0x6b4b,0xc059,0x1571,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x2370,0x00a5,0x9618,0x419a,0x68a2,0xda35,0x001c,0x0007,0xb0ff,0x01b5,0x0000,
|
||||
0x0000,0xff70,0x19ff,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x3170,0x00a5,0x9618,0x419a,0x68a2,0xda35,
|
||||
0x001c,0x000e,0xb0ff,0x21b5,0x0000,0x2fd8,0xff70,0x1226,0x19ff,0x07be,0x6201,
|
||||
0x032e,0x0587,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1112,
|
||||
0x1441,0x4231,0x3234,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x8000,0x0000,0x0000,0x0000,0x0000,0x8000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x4d31,0x7f54,0x3c93,0x1205,0x1931,
|
||||
0x492d,0x7f50,0x3c93,0x0e01,0x192d,0x0070,0x0000,0x8140,0x724b,0x2ba9,0x3a09,
|
||||
0x99d9,0x1949,0x0070,0x0000,0x80e0,0x624a,0x2af8,0x35c7,0x9d47,0x1938,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x7082,0x0820,0xb882,0x0820,0x7092,0x28a0,0x8992,
|
||||
0x28a0,0xa292,0x28a0,0x70a2,0xa7ac,0x0000,0x0000,0x2464,0x6424,0x0000,0x0000,
|
||||
0x70a2,0xa7ac,0x0000,0x0000,0x2464,0x6424,0x0000,0x0000,0x8989,0x0000,0x0000,
|
||||
0x0000,0x2424,0x0000,0x0000,0x0000,0x7075,0xa2ac,0xb800,0x0000,0x2464,0x2424,
|
||||
0x2400,0x0000,0x7075,0xa2ac,0x0000,0x0000,0x2464,0x2424,0x0000,0x0000,0x7075,
|
||||
0xa7ac,0x0000,0x0000,0x2464,0x6424,0x0000,0x0000,0x7075,0xa7ac,0x0000,0x0000,
|
||||
0x2464,0x6424,0x0000,0x0000,0x8989,0x0000,0x0000,0x0000,0x2424,0x0000,0x0000,
|
||||
0x0000,0x0000,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff};
|
||||
|
||||
static u16 sx762_eeprom_data[ATH5K_PLAT_EEP_MAX_WORDS] =
|
||||
{
|
||||
0x001a,0x168c,0x0200,0x0001,0x0000,0x5001,0x0000,0x2051,0x2051,0x1c0a,0x0100,
|
||||
0x0000,0x01c2,0x0002,0xc606,0x0001,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0xf165,0x7fbe,0x0003,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x5aa5,0x0000,0x0000,0x0313,0x4943,
|
||||
0x2053,0x7104,0x1202,0x0400,0x0306,0x0001,0x0000,0x0500,0x410e,0x39b1,0x1eb5,
|
||||
0x4e2d,0x3056,0xffff,0xe902,0x0700,0x0106,0x0000,0x0100,0x1500,0x0752,0x4101,
|
||||
0x6874,0x7265,0x736f,0x4320,0x6d6f,0x756d,0x696e,0x6163,0x6974,0x6e6f,0x2c73,
|
||||
0x4920,0x636e,0x002e,0x5241,0x3035,0x3130,0x302d,0x3030,0x2d30,0x3030,0x3030,
|
||||
0x5700,0x7269,0x6c65,0x7365,0x2073,0x414c,0x204e,0x6552,0x6566,0x6572,0x636e,
|
||||
0x2065,0x6143,0x6472,0x3000,0x0030,0x00ff,0x2100,0x0602,0x2201,0x0205,0x8d80,
|
||||
0x005b,0x0522,0x4002,0x8954,0x2200,0x0205,0x1b00,0x00b7,0x0522,0x8002,0x12a8,
|
||||
0x2201,0x0205,0x3600,0x016e,0x0522,0x0002,0x2551,0x2202,0x0205,0x6c00,0x02dc,
|
||||
0x0522,0x8002,0x37f9,0x2203,0x0205,0xa200,0x044a,0x0222,0x0803,0x0822,0x0604,
|
||||
0x0300,0xbe7f,0x65f1,0x0222,0x0105,0x00ff,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0x0037,0x6aaa,0x5003,0x9a66,0x0001,0x81c4,0x016a,
|
||||
0x02ff,0x84ff,0x15a3,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x2d2c,0x0000,0x0000,0x0000,0x0000,0xe028,0xa492,0x1c00,
|
||||
0x000e,0xb8ca,0x0013,0x0000,0x0000,0x6b4b,0xc059,0x1571,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x2370,0x00a5,0x9618,0x419a,0x68a2,0xda35,0x001c,0x0007,0xb0ff,0x01b5,0x0000,
|
||||
0x0000,0xff70,0x19ff,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x3170,0x00a5,0x9618,0x419a,0x68a2,0xda35,
|
||||
0x001c,0x000e,0xb0ff,0x21b5,0x0000,0x2fd8,0xff70,0x1226,0x19ff,0x07fa,0x6201,
|
||||
0x032e,0x0587,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1112,
|
||||
0x1441,0x4231,0x3234,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x8000,0x0000,0x0000,0x0000,0x0000,0x8000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x4d31,0x7f54,0x3c93,0x1205,0x1931,
|
||||
0x492d,0x7f50,0x3c93,0x0e01,0x192d,0x0070,0x0000,0x8180,0x724d,0xab59,0x3a08,
|
||||
0xdd79,0x2559,0x0070,0x0000,0x81a0,0x6e4d,0x2b99,0x3a09,0x9989,0x2157,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
|
||||
0x0000,0x0000,0x0000,0x0000,0x7092,0x4924,0xb892,0x4924,0x7092,0x289e,0x8992,
|
||||
0x289e,0xa292,0x289e,0x70a2,0xa7ac,0x0000,0x0000,0x2462,0x5e13,0x0000,0x0000,
|
||||
0x70a2,0xa7ac,0x0000,0x0000,0x1e5c,0x5713,0x0000,0x0000,0x8989,0x0000,0x0000,
|
||||
0x0000,0x2424,0x0000,0x0000,0x0000,0x7075,0xa2ac,0xb800,0x0000,0x2868,0x2828,
|
||||
0x2800,0x0000,0x7075,0xa2ac,0x0000,0x0000,0x2868,0x2828,0x0000,0x0000,0x7075,
|
||||
0xac00,0x0000,0x0000,0x2161,0x2100,0x0000,0x0000,0x7075,0xac00,0x0000,0x0000,
|
||||
0x1b5b,0x1b00,0x0000,0x0000,0x8989,0x0000,0x0000,0x0000,0x2121,0x0000,0x0000,
|
||||
0x0000,0x0000,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,0xffff,
|
||||
0xffff,0xffff};
|
||||
|
||||
#endif
|
|
@ -1,100 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2012 Luka Perkov <openwrt@lukaperkov.net>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/if_ether.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/string.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_platform.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
|
||||
static u8 ltq_ethaddr[6] = { 0 };
|
||||
|
||||
static int __init
|
||||
setup_ethaddr(char *str)
|
||||
{
|
||||
if (!mac_pton(str, ltq_ethaddr))
|
||||
memset(ltq_ethaddr, 0, 6);
|
||||
return 0;
|
||||
}
|
||||
__setup("ethaddr=", setup_ethaddr);
|
||||
|
||||
static struct mtd_partition h201l_partitions[] __initdata =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x20000,
|
||||
.size = 0x10000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x30000,
|
||||
.size = 0x7d0000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data h201l_flash_data __initdata = {
|
||||
.nr_parts = ARRAY_SIZE(h201l_partitions),
|
||||
.parts = h201l_partitions,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
h201l_leds_gpio[] __initdata = {
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
h201l_gpio_keys[] __initdata = {
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RMII,
|
||||
};
|
||||
|
||||
static void __init
|
||||
h201l_init(void)
|
||||
{
|
||||
ltq_register_gpio_stp();
|
||||
ltq_register_nor(&h201l_flash_data);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(h201l_leds_gpio), h201l_leds_gpio);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(h201l_gpio_keys), h201l_gpio_keys);
|
||||
|
||||
if (!is_valid_ether_addr(ltq_ethaddr))
|
||||
random_ether_addr(ltq_ethaddr);
|
||||
|
||||
memcpy(<q_eth_data.mac.sa_data, ltq_ethaddr, 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
|
||||
xway_register_dwc(-1);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_H201L,
|
||||
"H201L",
|
||||
"ZTE ZXV10 H201L",
|
||||
h201l_init);
|
|
@ -1,257 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
* Copyright (C) 2012 Pieter Voorthuijsen <p.voorthuijsen@gmail.com>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/spi/flash.h>
|
||||
#include <linux/spi/spi_gpio.h>
|
||||
#include <linux/ath9k_platform.h>
|
||||
#include <linux/if_ether.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/kobject.h>
|
||||
#include <linux/sysfs.h>
|
||||
#include <linux/rtl8366.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <irq.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
#include "dev-wifi-athxk.h"
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
#include "pci-ath-fixup.h"
|
||||
#include <mtd/mtd-abi.h>
|
||||
#include <asm-generic/sizes.h>
|
||||
|
||||
static struct mtd_partition dgn3500_partitions[] = {
|
||||
{
|
||||
.name = "u-boot",
|
||||
.offset = 0,
|
||||
.size = 0x10000,
|
||||
.mask_flags = MTD_WRITEABLE,
|
||||
},
|
||||
{
|
||||
.name = "environment",
|
||||
.offset = 0x10000,
|
||||
.size = 0x10000,
|
||||
.mask_flags = MTD_WRITEABLE,
|
||||
},
|
||||
{
|
||||
.name = "calibration",
|
||||
.offset = 0x20000,
|
||||
.size = 0x10000,
|
||||
.mask_flags = MTD_WRITEABLE,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x50000,
|
||||
.size = 0xfa0000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_INT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = {
|
||||
[14] = INT_NUM_IM0_IRL0 + 22,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_MII,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
dgn3500_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:green:power", .gpio = 34, .active_low = 1, },
|
||||
{ .name = "soc:red:power", .gpio = 39, .active_low = 1, },
|
||||
{ .name = "soc:orange:wlan", .gpio = 51, .active_low = 1, },
|
||||
{ .name = "soc:green:wps", .gpio = 52, .active_low = 1, },
|
||||
{ .name = "soc:green:usb", .gpio = 22, .active_low = 1, },
|
||||
{ .name = "soc:green:dsl", .gpio = 4, .active_low = 1, },
|
||||
{ .name = "soc:green:internet", .gpio = 2, .active_low = 1, },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
dgn3500_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "wps",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 54,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 36,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
#define SPI_GPIO_MRST 16
|
||||
#define SPI_GPIO_MTSR 17
|
||||
#define SPI_GPIO_CLK 18
|
||||
#define SPI_GPIO_CS0 10
|
||||
|
||||
static struct spi_gpio_platform_data spi_gpio_data = {
|
||||
.sck = SPI_GPIO_CLK,
|
||||
.mosi = SPI_GPIO_MTSR,
|
||||
.miso = SPI_GPIO_MRST,
|
||||
.num_chipselect = 2,
|
||||
};
|
||||
|
||||
static struct platform_device spi_gpio_device = {
|
||||
.name = "spi_gpio",
|
||||
.dev.platform_data = &spi_gpio_data,
|
||||
};
|
||||
|
||||
static struct flash_platform_data spi_flash_data = {
|
||||
.name = "sflash",
|
||||
.parts = dgn3500_partitions,
|
||||
.nr_parts = ARRAY_SIZE(dgn3500_partitions),
|
||||
};
|
||||
|
||||
static struct spi_board_info spi_flash __initdata = {
|
||||
.modalias = "m25p80",
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
.max_speed_hz = 10 * 1000 * 1000,
|
||||
.mode = SPI_MODE_3,
|
||||
.chip_select = 0,
|
||||
.controller_data = (void *) SPI_GPIO_CS0,
|
||||
.platform_data = &spi_flash_data
|
||||
};
|
||||
|
||||
static u8 ltq_ethaddr[6] = { 0 };
|
||||
|
||||
static int __init setup_ethaddr(char *str)
|
||||
{
|
||||
if (!mac_pton(str, ltq_ethaddr))
|
||||
memset(ltq_ethaddr, 0, 6);
|
||||
return 0;
|
||||
}
|
||||
__setup("ethaddr=", setup_ethaddr);
|
||||
|
||||
#define smi_SCK 37
|
||||
#define smi_SDA 35
|
||||
|
||||
static struct rtl8366_platform_data rtl8366rb_data = {
|
||||
.gpio_sda = smi_SDA,
|
||||
.gpio_sck = smi_SCK,
|
||||
};
|
||||
|
||||
static struct platform_device rtl8366rb_device = {
|
||||
.name = RTL8366RB_DRIVER_NAME,
|
||||
.id = -1,
|
||||
.dev = {
|
||||
.platform_data = &rtl8366rb_data,
|
||||
}
|
||||
};
|
||||
|
||||
static u16 dgn3500_eeprom_data[ATH9K_PLAT_EEP_MAX_WORDS] = {0};
|
||||
|
||||
static ssize_t ath_eeprom_read(struct file *filp, struct kobject *kobj,
|
||||
struct bin_attribute *attr, char *buf,
|
||||
loff_t offset, size_t count)
|
||||
{
|
||||
if (unlikely(offset >= sizeof(dgn3500_eeprom_data)))
|
||||
return 0;
|
||||
if ((offset + count) > sizeof(dgn3500_eeprom_data))
|
||||
count = sizeof(dgn3500_eeprom_data) - offset;
|
||||
if (unlikely(!count))
|
||||
return count;
|
||||
|
||||
memcpy(buf, (char *)(dgn3500_eeprom_data) + offset, count);
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
extern struct ath9k_platform_data ath9k_pdata;
|
||||
|
||||
static ssize_t ath_eeprom_write(struct file *filp, struct kobject *kobj,
|
||||
struct bin_attribute *attr, char *buf,
|
||||
loff_t offset, size_t count)
|
||||
{
|
||||
int i;
|
||||
char *eeprom_bytes = (char *)dgn3500_eeprom_data;
|
||||
|
||||
if (unlikely(offset >= sizeof(dgn3500_eeprom_data)))
|
||||
return -EFBIG;
|
||||
if ((offset + count) > sizeof(dgn3500_eeprom_data))
|
||||
count = sizeof(dgn3500_eeprom_data) - offset;
|
||||
if (unlikely(!count))
|
||||
return count;
|
||||
if (count % 2)
|
||||
return 0;
|
||||
|
||||
/* The PCI fixup routine requires an endian swap of the calibartion data
|
||||
* stored in flash */
|
||||
for (i = 0; i < count; i += 2) {
|
||||
eeprom_bytes[offset + i + 1] = buf[i];
|
||||
eeprom_bytes[offset + i] = buf[i+1];
|
||||
}
|
||||
|
||||
/* The original data does not contain a checksum. Set the country and
|
||||
* calculate new checksum when all data is received */
|
||||
if ((count + offset) == sizeof(dgn3500_eeprom_data))
|
||||
memcpy(ath9k_pdata.eeprom_data, dgn3500_eeprom_data,
|
||||
sizeof(ath9k_pdata.eeprom_data));
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
static struct bin_attribute dev_attr_ath_eeprom = {
|
||||
.attr = {
|
||||
.name = "ath_eeprom",
|
||||
.mode = S_IRUGO|S_IWUSR,
|
||||
},
|
||||
.read = ath_eeprom_read,
|
||||
.write = ath_eeprom_write,
|
||||
};
|
||||
|
||||
static void __init dgn3500_init(void)
|
||||
{
|
||||
if (sysfs_create_bin_file(firmware_kobj, &dev_attr_ath_eeprom))
|
||||
printk(KERN_INFO "Failed to create ath eeprom sysfs entry\n");
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(dgn3500_gpio_leds),
|
||||
dgn3500_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL,
|
||||
ARRAY_SIZE(dgn3500_gpio_keys), dgn3500_gpio_keys);
|
||||
platform_device_register(&spi_gpio_device);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
spi_register_board_info(&spi_flash, 1);
|
||||
if (!is_valid_ether_addr(ltq_ethaddr)) {
|
||||
printk(KERN_INFO "MAC invalid using random\n");
|
||||
random_ether_addr(ltq_ethaddr);
|
||||
}
|
||||
memcpy(<q_eth_data.mac.sa_data, ltq_ethaddr, 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
ltq_register_ath9k(dgn3500_eeprom_data, ltq_ethaddr);
|
||||
ltq_pci_ath_fixup(14, dgn3500_eeprom_data);
|
||||
/* The usb power is always enabled, protected by a fuse */
|
||||
xway_register_dwc(-1);
|
||||
platform_device_register(&rtl8366rb_device);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_DGN3500B,
|
||||
"DGN3500B",
|
||||
"Netgear DGN3500B",
|
||||
dgn3500_init);
|
|
@ -1,113 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/mdio-gpio.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/delay.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_platform.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
|
||||
static struct mtd_partition p2601hnfx_partitions[] __initdata =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "uboot_env",
|
||||
.offset = 0x20000,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x40000,
|
||||
.size = 0xfc0000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data p2601hnfx_flash_data __initdata = {
|
||||
.nr_parts = ARRAY_SIZE(p2601hnfx_partitions),
|
||||
.parts = p2601hnfx_partitions,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
p2601hnfx_leds_gpio[] __initdata = {
|
||||
{ .name = "soc:yellow:phone", .gpio = 216, .active_low = 1 },
|
||||
{ .name = "soc:green:phone", .gpio = 217, .active_low = 1 },
|
||||
{ .name = "soc:yellow:wifi", .gpio = 218, .active_low = 1 },
|
||||
{ .name = "soc:green:power", .gpio = 219, .active_low = 1 },
|
||||
{ .name = "soc:red:internet", .gpio = 220, .active_low = 1 },
|
||||
{ .name = "soc:green:internet", .gpio = 221, .active_low = 1 },
|
||||
{ .name = "soc:green:dsl", .gpio = 222, .active_low = 1 },
|
||||
{ .name = "soc:green:wifi", .gpio = 223, .active_low = 1 },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
p2601hnfx_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 53,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "wifi",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 54,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RMII,
|
||||
};
|
||||
|
||||
static void __init
|
||||
p2601hnfx_init(void)
|
||||
{
|
||||
#define P2601HNFX_USB 9
|
||||
|
||||
ltq_register_gpio_stp();
|
||||
ltq_register_nor(&p2601hnfx_flash_data);
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(p2601hnfx_leds_gpio), p2601hnfx_leds_gpio);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(p2601hnfx_gpio_keys), p2601hnfx_gpio_keys);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
xway_register_dwc(P2601HNFX_USB);
|
||||
|
||||
// enable the ethernet ports on the SoC
|
||||
// ltq_w32((ltq_r32(LTQ_GPORT_P0_CTL) & ~(1 << 17)) | (1 << 18), LTQ_GPORT_P0_CTL);
|
||||
// ltq_w32((ltq_r32(LTQ_GPORT_P1_CTL) & ~(1 << 17)) | (1 << 18), LTQ_GPORT_P1_CTL);
|
||||
// ltq_w32((ltq_r32(LTQ_GPORT_P2_CTL) & ~(1 << 17)) | (1 << 18), LTQ_GPORT_P2_CTL);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_P2601HNFX,
|
||||
"P2601HNFX",
|
||||
"ZyXEL P-2601HN-Fx",
|
||||
p2601hnfx_init);
|
|
@ -1,120 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_buttons.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/input.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <irq.h>
|
||||
#include <dev-gpio-leds.h>
|
||||
#include <dev-gpio-buttons.h>
|
||||
|
||||
#include "../machtypes.h"
|
||||
#include "devices.h"
|
||||
#include "dev-dwc_otg.h"
|
||||
|
||||
static struct mtd_partition wbmr_partitions[] =
|
||||
{
|
||||
{
|
||||
.name = "uboot",
|
||||
.offset = 0x0,
|
||||
.size = 0x40000,
|
||||
},
|
||||
{
|
||||
.name = "uboot-env",
|
||||
.offset = 0x40000,
|
||||
.size = 0x20000,
|
||||
},
|
||||
{
|
||||
.name = "linux",
|
||||
.offset = 0x60000,
|
||||
.size = 0x1f20000,
|
||||
},
|
||||
{
|
||||
.name = "calibration",
|
||||
.offset = 0x1fe0000,
|
||||
.size = 0x20000,
|
||||
},
|
||||
};
|
||||
|
||||
static struct physmap_flash_data wbmr_flash_data = {
|
||||
.nr_parts = ARRAY_SIZE(wbmr_partitions),
|
||||
.parts = wbmr_partitions,
|
||||
};
|
||||
|
||||
static struct gpio_led
|
||||
wbmr_gpio_leds[] __initdata = {
|
||||
{ .name = "soc:blue:movie", .gpio = 20, .active_low = 1, },
|
||||
{ .name = "soc:red:internet", .gpio = 18, .active_low = 1, },
|
||||
{ .name = "soc:green:internet", .gpio = 17, .active_low = 1, },
|
||||
{ .name = "soc:green:adsl", .gpio = 16, .active_low = 1, },
|
||||
{ .name = "soc:green:wlan", .gpio = 15, .active_low = 1, },
|
||||
{ .name = "soc:red:security", .gpio = 14, .active_low = 1, },
|
||||
{ .name = "soc:green:power", .gpio = 1, .active_low = 1, },
|
||||
{ .name = "soc:red:power", .gpio = 5, .active_low = 1, },
|
||||
{ .name = "soc:green:usb", .gpio = 28, .active_low = 1, },
|
||||
};
|
||||
|
||||
static struct gpio_keys_button
|
||||
wbmr_gpio_keys[] __initdata = {
|
||||
{
|
||||
.desc = "aoss",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_0,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 0,
|
||||
.active_low = 1,
|
||||
},
|
||||
{
|
||||
.desc = "reset",
|
||||
.type = EV_KEY,
|
||||
.code = BTN_1,
|
||||
.debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL,
|
||||
.gpio = 37,
|
||||
.active_low = 1,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_pci_data ltq_pci_data = {
|
||||
.clock = PCI_CLOCK_INT,
|
||||
.gpio = PCI_GNT1 | PCI_REQ1,
|
||||
.irq = {
|
||||
[14] = INT_NUM_IM0_IRL0 + 22,
|
||||
},
|
||||
};
|
||||
|
||||
static struct ltq_eth_data ltq_eth_data = {
|
||||
.mii_mode = PHY_INTERFACE_MODE_RGMII,
|
||||
};
|
||||
|
||||
static void __init
|
||||
wbmr_init(void)
|
||||
{
|
||||
#define WMBR_BRN_MAC 0x1fd0024
|
||||
|
||||
ltq_add_device_gpio_leds(-1, ARRAY_SIZE(wbmr_gpio_leds), wbmr_gpio_leds);
|
||||
ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(wbmr_gpio_keys), wbmr_gpio_keys);
|
||||
ltq_register_nor(&wbmr_flash_data);
|
||||
ltq_register_pci(<q_pci_data);
|
||||
memcpy_fromio(<q_eth_data.mac.sa_data,
|
||||
(void *)KSEG1ADDR(LTQ_FLASH_START + WMBR_BRN_MAC), 6);
|
||||
ltq_register_etop(<q_eth_data);
|
||||
xway_register_dwc(36);
|
||||
}
|
||||
|
||||
MIPS_MACHINE(LANTIQ_MACH_WBMR,
|
||||
"WBMR",
|
||||
"WBMR",
|
||||
wbmr_init);
|
|
@ -1,216 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/mtd/nand.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/io.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
#include <lantiq_irq.h>
|
||||
#include <lantiq_platform.h>
|
||||
|
||||
#include "devices.h"
|
||||
|
||||
/* nand registers */
|
||||
#define LTQ_EBU_NAND_WAIT 0xB4
|
||||
#define LTQ_EBU_NAND_ECC0 0xB8
|
||||
#define LTQ_EBU_NAND_ECC_AC 0xBC
|
||||
#define LTQ_EBU_NAND_CON 0xB0
|
||||
#define LTQ_EBU_ADDSEL1 0x24
|
||||
|
||||
/* gpio definitions */
|
||||
#define PIN_ALE 13
|
||||
#define PIN_CLE 24
|
||||
#define PIN_CS1 23
|
||||
#define PIN_RDY 48 /* NFLASH_READY */
|
||||
#define PIN_RD 49 /* NFLASH_READ_N */
|
||||
|
||||
#define NAND_CMD_ALE (1 << 2)
|
||||
#define NAND_CMD_CLE (1 << 3)
|
||||
#define NAND_CMD_CS (1 << 4)
|
||||
#define NAND_WRITE_CMD_RESET 0xff
|
||||
#define NAND_WRITE_CMD (NAND_CMD_CS | NAND_CMD_CLE)
|
||||
#define NAND_WRITE_ADDR (NAND_CMD_CS | NAND_CMD_ALE)
|
||||
#define NAND_WRITE_DATA (NAND_CMD_CS)
|
||||
#define NAND_READ_DATA (NAND_CMD_CS)
|
||||
#define NAND_WAIT_WR_C (1 << 3)
|
||||
#define NAND_WAIT_RD (0x1)
|
||||
|
||||
#define ADDSEL1_MASK(x) (x << 4)
|
||||
#define ADDSEL1_REGEN 1
|
||||
#define BUSCON1_SETUP (1 << 22)
|
||||
#define BUSCON1_BCGEN_RES (0x3 << 12)
|
||||
#define BUSCON1_WAITWRC2 (2 << 8)
|
||||
#define BUSCON1_WAITRDC2 (2 << 6)
|
||||
#define BUSCON1_HOLDC1 (1 << 4)
|
||||
#define BUSCON1_RECOVC1 (1 << 2)
|
||||
#define BUSCON1_CMULT4 1
|
||||
#define NAND_CON_NANDM 1
|
||||
#define NAND_CON_CSMUX (1 << 1)
|
||||
#define NAND_CON_CS_P (1 << 4)
|
||||
#define NAND_CON_SE_P (1 << 5)
|
||||
#define NAND_CON_WP_P (1 << 6)
|
||||
#define NAND_CON_PRE_P (1 << 7)
|
||||
#define NAND_CON_IN_CS0 0
|
||||
#define NAND_CON_OUT_CS0 0
|
||||
#define NAND_CON_IN_CS1 (1 << 8)
|
||||
#define NAND_CON_OUT_CS1 (1 << 10)
|
||||
#define NAND_CON_CE (1 << 20)
|
||||
|
||||
#define NAND_BASE_ADDRESS (KSEG1 | 0x14000000)
|
||||
|
||||
static const char *part_probes[] = { "cmdlinepart", NULL };
|
||||
|
||||
static void xway_select_chip(struct mtd_info *mtd, int chip)
|
||||
{
|
||||
switch (chip) {
|
||||
case -1:
|
||||
ltq_ebu_w32_mask(NAND_CON_CE, 0, LTQ_EBU_NAND_CON);
|
||||
ltq_ebu_w32_mask(NAND_CON_NANDM, 0, LTQ_EBU_NAND_CON);
|
||||
break;
|
||||
case 0:
|
||||
ltq_ebu_w32_mask(0, NAND_CON_NANDM, LTQ_EBU_NAND_CON);
|
||||
ltq_ebu_w32_mask(0, NAND_CON_CE, LTQ_EBU_NAND_CON);
|
||||
/* reset the nand chip */
|
||||
while ((ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_WR_C) == 0)
|
||||
;
|
||||
ltq_w32(NAND_WRITE_CMD_RESET,
|
||||
((u32 *) (NAND_BASE_ADDRESS | NAND_WRITE_CMD)));
|
||||
break;
|
||||
default:
|
||||
BUG();
|
||||
}
|
||||
}
|
||||
|
||||
static void xway_cmd_ctrl(struct mtd_info *mtd, int data, unsigned int ctrl)
|
||||
{
|
||||
struct nand_chip *this = mtd->priv;
|
||||
|
||||
if (ctrl & NAND_CTRL_CHANGE) {
|
||||
if (ctrl & NAND_CLE)
|
||||
this->IO_ADDR_W = (void __iomem *)
|
||||
(NAND_BASE_ADDRESS | NAND_WRITE_CMD);
|
||||
else if (ctrl & NAND_ALE)
|
||||
this->IO_ADDR_W = (void __iomem *)
|
||||
(NAND_BASE_ADDRESS | NAND_WRITE_ADDR);
|
||||
}
|
||||
|
||||
if (data != NAND_CMD_NONE) {
|
||||
*(volatile u8*) ((u32) this->IO_ADDR_W) = data;
|
||||
while ((ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_WR_C) == 0)
|
||||
;
|
||||
}
|
||||
}
|
||||
|
||||
static int xway_dev_ready(struct mtd_info *mtd)
|
||||
{
|
||||
return ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_RD;
|
||||
}
|
||||
|
||||
void nand_write(unsigned int addr, unsigned int val)
|
||||
{
|
||||
ltq_w32(val, ((u32 *) (NAND_BASE_ADDRESS | addr)));
|
||||
while ((ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_WR_C) == 0)
|
||||
;
|
||||
}
|
||||
|
||||
unsigned char xway_read_byte(struct mtd_info *mtd)
|
||||
{
|
||||
return ltq_r8((void __iomem *)(NAND_BASE_ADDRESS | (NAND_READ_DATA)));
|
||||
}
|
||||
|
||||
static void xway_read_buf(struct mtd_info *mtd, uint8_t *buf, int len)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
unsigned char res8 = ltq_r8((void __iomem *)(NAND_BASE_ADDRESS | (NAND_READ_DATA)));
|
||||
buf[i] = res8;
|
||||
}
|
||||
}
|
||||
|
||||
static void xway_write_buf(struct mtd_info *mtd, const uint8_t *buf, int len)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
ltq_w8(buf[i], ((u32*)(NAND_BASE_ADDRESS | (NAND_WRITE_DATA))));
|
||||
while((ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_WR_C) == 0);
|
||||
}
|
||||
}
|
||||
|
||||
int xway_probe(struct platform_device *pdev)
|
||||
{
|
||||
/* might need this later ?
|
||||
ltq_gpio_request(PIN_CS1, 2, 1, "NAND_CS1");
|
||||
*/
|
||||
ltq_gpio_request(&pdev->dev, PIN_CLE, 2, 1, "NAND_CLE");
|
||||
ltq_gpio_request(&pdev->dev, PIN_ALE, 2, 1, "NAND_ALE");
|
||||
if (ltq_is_ar9() || ltq_is_vr9()) {
|
||||
ltq_gpio_request(&pdev->dev, PIN_RDY, 2, 0, "NAND_BSY");
|
||||
ltq_gpio_request(&pdev->dev, PIN_RD, 2, 1, "NAND_RD");
|
||||
}
|
||||
|
||||
ltq_ebu_w32((NAND_BASE_ADDRESS & 0x1fffff00)
|
||||
| ADDSEL1_MASK(3) | ADDSEL1_REGEN, LTQ_EBU_ADDSEL1);
|
||||
|
||||
ltq_ebu_w32(BUSCON1_SETUP | BUSCON1_BCGEN_RES | BUSCON1_WAITWRC2
|
||||
| BUSCON1_WAITRDC2 | BUSCON1_HOLDC1 | BUSCON1_RECOVC1
|
||||
| BUSCON1_CMULT4, LTQ_EBU_BUSCON1);
|
||||
|
||||
ltq_ebu_w32(NAND_CON_NANDM | NAND_CON_CSMUX | NAND_CON_CS_P
|
||||
| NAND_CON_SE_P | NAND_CON_WP_P | NAND_CON_PRE_P
|
||||
| NAND_CON_IN_CS0 | NAND_CON_OUT_CS0, LTQ_EBU_NAND_CON);
|
||||
|
||||
ltq_w32(NAND_WRITE_CMD_RESET,
|
||||
((u32 *) (NAND_BASE_ADDRESS | NAND_WRITE_CMD)));
|
||||
while ((ltq_ebu_r32(LTQ_EBU_NAND_WAIT) & NAND_WAIT_WR_C) == 0)
|
||||
;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_nand_data falcon_flash_nand_data = {
|
||||
.chip = {
|
||||
.nr_chips = 1,
|
||||
.chip_delay = 30,
|
||||
.part_probe_types = part_probes,
|
||||
},
|
||||
.ctrl = {
|
||||
.probe = xway_probe,
|
||||
.cmd_ctrl = xway_cmd_ctrl,
|
||||
.dev_ready = xway_dev_ready,
|
||||
.select_chip = xway_select_chip,
|
||||
.read_byte = xway_read_byte,
|
||||
.read_buf = xway_read_buf,
|
||||
.write_buf = xway_write_buf,
|
||||
}
|
||||
};
|
||||
|
||||
static struct resource ltq_nand_res =
|
||||
MEM_RES("nand", 0x14000000, 0x7ffffff);
|
||||
|
||||
static struct platform_device ltq_flash_nand = {
|
||||
.name = "gen_nand",
|
||||
.id = -1,
|
||||
.num_resources = 1,
|
||||
.resource = <q_nand_res,
|
||||
.dev = {
|
||||
.platform_data = &falcon_flash_nand_data,
|
||||
},
|
||||
};
|
||||
|
||||
void __init xway_register_nand(struct mtd_partition *parts, int count)
|
||||
{
|
||||
falcon_flash_nand_data.chip.partitions = parts;
|
||||
falcon_flash_nand_data.chip.nr_partitions = count;
|
||||
platform_device_register(<q_flash_nand);
|
||||
}
|
|
@ -1,109 +0,0 @@
|
|||
/*
|
||||
* Atheros AP94 reference board PCI initialization
|
||||
*
|
||||
* Copyright (C) 2009-2010 Gabor Juhos <juhosg@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <linux/pci.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/delay.h>
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#define LTQ_PCI_MEM_BASE 0x18000000
|
||||
|
||||
struct ath_fixup {
|
||||
u16 *cal_data;
|
||||
unsigned slot;
|
||||
};
|
||||
|
||||
static int ath_num_fixups;
|
||||
static struct ath_fixup ath_fixups[2];
|
||||
|
||||
static void ath_pci_fixup(struct pci_dev *dev)
|
||||
{
|
||||
void __iomem *mem;
|
||||
u16 *cal_data = NULL;
|
||||
u16 cmd;
|
||||
u32 bar0;
|
||||
u32 val;
|
||||
unsigned i;
|
||||
|
||||
for (i = 0; i < ath_num_fixups; i++) {
|
||||
if (ath_fixups[i].cal_data == NULL)
|
||||
continue;
|
||||
|
||||
if (ath_fixups[i].slot != PCI_SLOT(dev->devfn))
|
||||
continue;
|
||||
|
||||
cal_data = ath_fixups[i].cal_data;
|
||||
break;
|
||||
}
|
||||
|
||||
if (cal_data == NULL)
|
||||
return;
|
||||
|
||||
if (*cal_data != 0xa55a) {
|
||||
pr_err("pci %s: invalid calibration data\n", pci_name(dev));
|
||||
return;
|
||||
}
|
||||
|
||||
pr_info("pci %s: fixup device configuration\n", pci_name(dev));
|
||||
|
||||
mem = ioremap(LTQ_PCI_MEM_BASE, 0x10000);
|
||||
if (!mem) {
|
||||
pr_err("pci %s: ioremap error\n", pci_name(dev));
|
||||
return;
|
||||
}
|
||||
|
||||
pci_read_config_dword(dev, PCI_BASE_ADDRESS_0, &bar0);
|
||||
pci_write_config_dword(dev, PCI_BASE_ADDRESS_0, LTQ_PCI_MEM_BASE);
|
||||
pci_read_config_word(dev, PCI_COMMAND, &cmd);
|
||||
cmd |= PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY;
|
||||
pci_write_config_word(dev, PCI_COMMAND, cmd);
|
||||
|
||||
/* set pointer to first reg address */
|
||||
cal_data += 3;
|
||||
while (*cal_data != 0xffff) {
|
||||
u32 reg;
|
||||
reg = *cal_data++;
|
||||
val = *cal_data++;
|
||||
val |= (*cal_data++) << 16;
|
||||
|
||||
ltq_w32(swab32(val), mem + reg);
|
||||
udelay(100);
|
||||
}
|
||||
|
||||
pci_read_config_dword(dev, PCI_VENDOR_ID, &val);
|
||||
dev->vendor = val & 0xffff;
|
||||
dev->device = (val >> 16) & 0xffff;
|
||||
|
||||
pci_read_config_dword(dev, PCI_CLASS_REVISION, &val);
|
||||
dev->revision = val & 0xff;
|
||||
dev->class = val >> 8; /* upper 3 bytes */
|
||||
|
||||
pr_info("pci %s: fixup info: [%04x:%04x] revision %02x class %#08x\n",
|
||||
pci_name(dev), dev->vendor, dev->device, dev->revision, dev->class);
|
||||
|
||||
pci_read_config_word(dev, PCI_COMMAND, &cmd);
|
||||
cmd &= ~(PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
|
||||
pci_write_config_word(dev, PCI_COMMAND, cmd);
|
||||
|
||||
pci_write_config_dword(dev, PCI_BASE_ADDRESS_0, bar0);
|
||||
|
||||
iounmap(mem);
|
||||
}
|
||||
DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_ATHEROS, PCI_ANY_ID, ath_pci_fixup);
|
||||
|
||||
void __init ltq_pci_ath_fixup(unsigned slot, u16 *cal_data)
|
||||
{
|
||||
if (ath_num_fixups >= ARRAY_SIZE(ath_fixups))
|
||||
return;
|
||||
|
||||
ath_fixups[ath_num_fixups].slot = slot;
|
||||
ath_fixups[ath_num_fixups].cal_data = cal_data;
|
||||
ath_num_fixups++;
|
||||
}
|
|
@ -1,6 +0,0 @@
|
|||
#ifndef _PCI_ATH_FIXUP
|
||||
#define _PCI_ATH_FIXUP
|
||||
|
||||
void ltq_pci_ath_fixup(unsigned slot, u16 *cal_data) __init;
|
||||
|
||||
#endif /* _PCI_ATH_FIXUP */
|
|
@ -1,110 +0,0 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 as published
|
||||
* by the Free Software Foundation.
|
||||
*
|
||||
* Copyright (C) 2010 John Crispin <blogic@openwrt.org>
|
||||
*/
|
||||
|
||||
#include <linux/export.h>
|
||||
#include <linux/clk.h>
|
||||
#include <asm/bootinfo.h>
|
||||
#include <asm/time.h>
|
||||
|
||||
#include <lantiq_soc.h>
|
||||
|
||||
#include "../prom.h"
|
||||
#include "devices.h"
|
||||
|
||||
#define SOC_DANUBE "Danube"
|
||||
#define SOC_TWINPASS "Twinpass"
|
||||
#define SOC_AMAZON_SE "Amazon_SE"
|
||||
#define SOC_AR9 "AR9"
|
||||
#define SOC_GR9 "GR9"
|
||||
#define SOC_VR9 "VR9"
|
||||
|
||||
#define PART_SHIFT 12
|
||||
#define PART_MASK 0x0FFFFFFF
|
||||
#define REV_SHIFT 28
|
||||
#define REV_MASK 0xF0000000
|
||||
|
||||
|
||||
void __init ltq_soc_detect(struct ltq_soc_info *i)
|
||||
{
|
||||
i->partnum = (ltq_r32(LTQ_MPS_CHIPID) & PART_MASK) >> PART_SHIFT;
|
||||
i->rev = (ltq_r32(LTQ_MPS_CHIPID) & REV_MASK) >> REV_SHIFT;
|
||||
sprintf(i->rev_type, "1.%d", i->rev);
|
||||
switch (i->partnum) {
|
||||
case SOC_ID_DANUBE1:
|
||||
case SOC_ID_DANUBE2:
|
||||
i->name = SOC_DANUBE;
|
||||
i->type = SOC_TYPE_DANUBE;
|
||||
break;
|
||||
|
||||
case SOC_ID_TWINPASS:
|
||||
i->name = SOC_TWINPASS;
|
||||
i->type = SOC_TYPE_DANUBE;
|
||||
break;
|
||||
|
||||
case SOC_ID_ARX188:
|
||||
case SOC_ID_ARX168_1:
|
||||
case SOC_ID_ARX168_2:
|
||||
case SOC_ID_ARX182:
|
||||
i->name = SOC_AR9;
|
||||
i->type = SOC_TYPE_AR9;
|
||||
break;
|
||||
|
||||
case SOC_ID_GRX188:
|
||||
case SOC_ID_GRX168:
|
||||
i->name = SOC_GR9;
|
||||
i->type = SOC_TYPE_AR9;
|
||||
break;
|
||||
|
||||
case SOC_ID_AMAZON_SE_1:
|
||||
case SOC_ID_AMAZON_SE_2:
|
||||
i->name = SOC_AMAZON_SE;
|
||||
i->type = SOC_TYPE_AMAZON_SE;
|
||||
#ifdef CONFIG_PCI
|
||||
panic("ase is only supported for non pci kernels");
|
||||
#endif
|
||||
break;
|
||||
|
||||
case SOC_ID_VRX282:
|
||||
case SOC_ID_VRX268:
|
||||
case SOC_ID_VRX288:
|
||||
i->name = SOC_VR9;
|
||||
i->type = SOC_TYPE_VR9_1;
|
||||
break;
|
||||
|
||||
case SOC_ID_GRX268:
|
||||
case SOC_ID_GRX288:
|
||||
i->name = SOC_GR9;
|
||||
i->type = SOC_TYPE_VR9_1;
|
||||
break;
|
||||
|
||||
case SOC_ID_VRX268_2:
|
||||
case SOC_ID_VRX288_2:
|
||||
i->name = SOC_VR9;
|
||||
i->type = SOC_TYPE_VR9_2;
|
||||
break;
|
||||
|
||||
case SOC_ID_GRX282_2:
|
||||
case SOC_ID_GRX288_2:
|
||||
i->name = SOC_GR9;
|
||||
i->type = SOC_TYPE_VR9_2;
|
||||
|
||||
default:
|
||||
unreachable();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void __init ltq_soc_setup(void)
|
||||
{
|
||||
if (ltq_is_ase())
|
||||
ltq_register_ase_asc();
|
||||
else
|
||||
ltq_register_asc(1);
|
||||
ltq_register_gpio();
|
||||
ltq_register_wdt();
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue