diff --git a/sys/arm/conf/DB-78XXX b/sys/arm/conf/DB-78XXX deleted file mode 100644 index 517e19454645..000000000000 --- a/sys/arm/conf/DB-78XXX +++ /dev/null @@ -1,81 +0,0 @@ -# -# Custom kernel for Marvell DB-78xx boards. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident DB-88F78XX -include "std.arm" -include "../mv/discovery/std.db78xxx" - -options SOC_MV_DISCOVERY - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options TMPFS # Efficient memory filesystem -options FFS # Berkeley Fast Filesystem -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -options NFS_ROOT # NFS usable as /, requires NFSCL -options BOOTP -options BOOTP_NFSROOT -options BOOTP_NFSV3 -options BOOTP_WIRED_TO=mge0 - -#options ROOTDEVNAME=\"ufs:/dev/da0a\" - -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # Posix P1003_1B real-time extensions -options MUTEX_NOINLINE -options RWLOCK_NOINLINE -options NO_FFS_SNAPSHOT -options NO_SWAPPING - -device pci - -# Pseudo devices -device loop -device md - -# Serial ports -device uart - -# Networking -device ether -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy -device bpf - -# USB -device usb -device ehci -device umass -device scbus -device pass -device da - -# I2C (TWSI) -device iic -device iicbus -device twsi -device ds133x - -# SATA -device mvs - -# GPIO -device gpio - -# Flattened Device Tree -options FDT -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=db78100.dts diff --git a/sys/arm/conf/DB-88F5XXX b/sys/arm/conf/DB-88F5XXX deleted file mode 100644 index d9fe43f9dfeb..000000000000 --- a/sys/arm/conf/DB-88F5XXX +++ /dev/null @@ -1,82 +0,0 @@ -# -# Custom kernel for Marvell DB-88F5xxx boards. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident DB-88F5XXX -include "std.arm" -include "../mv/orion/std.db88f5xxx" - -options SOC_MV_ORION - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options TMPFS # Efficient memory filesystem -options FFS # Berkeley Fast Filesystem -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -options NFS_ROOT # NFS usable as /, requires NFSCL -options BOOTP -options BOOTP_NFSROOT -options BOOTP_NFSV3 -options BOOTP_WIRED_TO=mge0 - -#options ROOTDEVNAME=\"ufs:/dev/da0a\" - -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # Posix P1003_1B real-time extensions -options MUTEX_NOINLINE -options RWLOCK_NOINLINE -options NO_FFS_SNAPSHOT -options NO_SWAPPING - -device pci - -# Pseudo devices -device md -device loop - -# Serial ports -device uart - -# Networking -device ether -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy -device bpf -options DEVICE_POLLING -options HZ=1000 - -# I2C (TWSI) -device iic -device iicbus -device twsi -device ds133x - -# USB -device usb -device ehci -device umass -device scbus -device pass -device da - -# SATA -device mvs - -# GPIO -device gpio - -# Flattened Device Tree -options FDT -makeoptions FDT_DTS_FILE=db88f5281.dts diff --git a/sys/arm/conf/DB-88F6XXX b/sys/arm/conf/DB-88F6XXX deleted file mode 100644 index 7ff1f727e2ac..000000000000 --- a/sys/arm/conf/DB-88F6XXX +++ /dev/null @@ -1,85 +0,0 @@ -# -# Custom kernel for Marvell DB-88F6xxx boards. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident DB-88F6XXX -include "std.arm" -include "../mv/kirkwood/std.db88f6xxx" - -options SOC_MV_KIRKWOOD - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options FFS # Berkeley Fast Filesystem -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -options NFS_ROOT # NFS usable as /, requires NFSCL -options TMPFS # Efficient memory filesystem -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions -options MUTEX_NOINLINE -options RWLOCK_NOINLINE -options NO_FFS_SNAPSHOT -options NO_SWAPPING - -# NFS root from boopt/dhcp -options BOOTP -options BOOTP_NFSROOT -options BOOTP_NFSV3 -options BOOTP_WIRED_TO=mge0 - -#options ROOTDEVNAME=\"ufs:/dev/da0a\" - -device pci - -# Pseudo devices -device loop -device md - -# Serial ports -device uart - -# Networking -device ether -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy -device bpf - -device cesa # Marvell security engine -device crypto -device cryptodev - -# USB -device usb -device ehci -device umass -device scbus -device pass -device da - -# I2C (TWSI) -device iic -device iicbus -device twsi - -# SATA -device mvs - -# GPIO -device gpio - -# Flattened Device Tree -options FDT # Configure using FDT/DTB data -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=db88f6281.dts diff --git a/sys/arm/conf/DOCKSTAR b/sys/arm/conf/DOCKSTAR deleted file mode 100644 index 6f26d4290801..000000000000 --- a/sys/arm/conf/DOCKSTAR +++ /dev/null @@ -1,155 +0,0 @@ -# -# Custom kernel for Seagate DockStar (Marvell SheevaPlug based) devices. -# -# $FreeBSD$ -# -# https://www.FreeBSD.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig-config.html -# -# The handbook is also available locally in /usr/share/doc/handbook -# if you've installed the doc distribution, otherwise always see the -# FreeBSD World Wide Web server (https://www.FreeBSD.org/) for the -# latest information. -# -# An exhaustive list of options and more detailed explanations of the -# device lines is also present in the ../../conf/NOTES and NOTES files. -# If you are in doubt as to the purpose or necessity of a line, check first -# in NOTES. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident DOCKSTAR - -include "std.arm" -include "../mv/kirkwood/std.db88f6xxx" - -options SOC_MV_KIRKWOOD - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options FFS # Berkeley Fast Filesystem -options SOFTUPDATES # Enable FFS soft updates support -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -#options NFS_ROOT # NFS usable as /, requires NFSCL -options MSDOSFS # MSDOS Filesystem -options CD9660 # ISO 9660 filesystem -options NULLFS # NULL filesystem -options TMPFS # Efficient memory filesystem -options GEOM_PART_GPT # GUID Partition Tables -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options GEOM_LABEL # Provides labelization -options GEOM_ELI # Disk encryption -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions - -# Enable these options for nfs root configured via BOOTP. -#options BOOTP -#options BOOTP_NFSROOT -#options BOOTP_NFSV3 -#options BOOTP_WIRED_TO=mge0 - -# If not using BOOTP, use something like one of these... -#options ROOTDEVNAME=\"ufs:/dev/da0a\" -options ROOTDEVNAME=\"ufs:/dev/da0s1a\" -#options ROOTDEVNAME=\"ufs:/dev/da0p10\" -#options ROOTDEVNAME=\"nfs:192.168.0.254/dreamplug\" - -# Misc pseudo devices -device bpf # Required for DHCP -device firmware # firmware(9) required for USB wlan -device gif # IPv6 and IPv4 tunneling -device loop # Network loopback -device md # Memory/malloc disk -device pty # BSD-style compatibility pseudo ttys -device tuntap # Packet tunnel. -device ether # Required for all ethernet devices -device vlan # 802.1Q VLAN support -device wlan # 802.11 WLAN support - -# cam support for umass and ahci -device scbus -device pass -device da - -# Serial ports -device uart - -# Networking -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy - -# USB -options USB_HOST_ALIGN=32 # Align DMA to cacheline -device usb # Basic usb support -device ehci # USB host controller -device umass # Mass storage -device uhid # Human-interface devices -device rum # Ralink Technology RT2501USB wireless NICs -device uath # Atheros AR5523 wireless NICs -device ural # Ralink Technology RT2500USB wireless NICs -device zyd # ZyDAS zb1211/zb1211b wireless NICs -device urtw # Realtek RTL8187B/L USB -device upgt # Conexant/Intersil PrismGT SoftMAC USB -device u3g # USB-based 3G modems (Option, Huawei, Sierra) - -# I2C (TWSI) -device iic -device iicbus -device twsi - -# Sound -device sound -device snd_uaudio - -#crypto -device cesa # Marvell security engine -device crypto -device cryptodev - -# IPSec -device enc -options IPSEC -options TCP_SIGNATURE # include support for RFC 2385 - -# IPFW -options IPFIREWALL -options IPFIREWALL_DEFAULT_TO_ACCEPT -options IPFIREWALL_VERBOSE -options IPFIREWALL_VERBOSE_LIMIT=100 -options IPFIREWALL_NAT -options LIBALIAS -options DUMMYNET -options IPDIVERT - -#PF -device pf -device pflog -device pfsync - -# GPIO -device gpio - -# ALTQ, required for PF -options ALTQ # Basic ALTQ support -options ALTQ_CBQ # Class Based Queueing -options ALTQ_RED # Random Early Detection -options ALTQ_RIO # RED In/Out -options ALTQ_HFSC # Hierarchical Packet Scheduler -options ALTQ_CDNR # Traffic conditioner -options ALTQ_PRIQ # Priority Queueing -options ALTQ_NOPCC # Required if the TSC is unusable -#options ALTQ_DEBUG - -# Flattened Device Tree -options FDT # Configure using FDT/DTB data -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=dockstar.dts diff --git a/sys/arm/conf/DREAMPLUG-1001 b/sys/arm/conf/DREAMPLUG-1001 deleted file mode 100644 index 18b2dee86fac..000000000000 --- a/sys/arm/conf/DREAMPLUG-1001 +++ /dev/null @@ -1,163 +0,0 @@ -# Kernel config for GlobalScale Technologies DreamPlug version 1001. -# -# This is for units that are version 10, revision 01, with NOR SPI flash. -# These units are identified with the number "1001" on the S/N label. -# -# For more information on this file, please read the handbook section on -# Kernel Configuration Files: -# -# https://www.FreeBSD.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig-config.html -# -# The handbook is also available locally in /usr/share/doc/handbook -# if you've installed the doc distribution, otherwise always see the -# FreeBSD World Wide Web server (https://www.FreeBSD.org/) for the -# latest information. -# -# An exhaustive list of options and more detailed explanations of the -# device lines is also present in the ../../conf/NOTES and NOTES files. -# If you are in doubt as to the purpose or necessity of a line, check first -# in NOTES. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident DREAMPLUG-1001 - -include "std.arm" -include "../mv/kirkwood/std.db88f6xxx" - -options SOC_MV_KIRKWOOD - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options FFS # Berkeley Fast Filesystem -options SOFTUPDATES # Enable FFS soft updates support -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -#options NFS_ROOT # NFS usable as /, requires NFSCL -options MSDOSFS # MSDOS Filesystem -options CD9660 # ISO 9660 filesystem -options NULLFS # NULL filesystem -options TMPFS # Efficient memory filesystem -options GEOM_PART_GPT # GUID Partition Tables -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options GEOM_LABEL # Provides labelization -options GEOM_ELI # Disk encryption -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions - -# Enable these options for nfs root configured via BOOTP. -#options BOOTP -#options BOOTP_NFSROOT -#options BOOTP_NFSV3 -#options BOOTP_WIRED_TO=mge0 - -# If not using BOOTP, use something like one of these... -#options ROOTDEVNAME=\"ufs:/dev/da1a\" -options ROOTDEVNAME=\"ufs:/dev/da1s1a\" -#options ROOTDEVNAME=\"ufs:/dev/da1p10\" -#options ROOTDEVNAME=\"nfs:192.168.0.254/dreamplug\" - -# Misc pseudo devices -device bpf # Required for DHCP -device firmware # firmware(9) required for USB wlan -device gif # IPv6 and IPv4 tunneling -device loop # Network loopback -device md # Memory/malloc disk -device pty # BSD-style compatibility pseudo ttys -device tuntap # Packet tunnel. -device ether # Required for all ethernet devices -device vlan # 802.1Q VLAN support -device wlan # 802.11 WLAN support - -# cam support for umass and ahci -device scbus -device pass -device da -device cd - -# Serial ports -device uart - -# Networking -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy - -# USB -options USB_HOST_ALIGN=32 # Align DMA to cacheline -device usb # Basic usb support -device ehci # USB host controller -device umass # Mass storage -device uhid # Human-interface devices -device rum # Ralink Technology RT2501USB wireless NICs -device uath # Atheros AR5523 wireless NICs -device ural # Ralink Technology RT2500USB wireless NICs -device zyd # ZyDAS zb1211/zb1211b wireless NICs -device urtw # Realtek RTL8187B/L USB -device upgt # Conexant/Intersil PrismGT SoftMAC USB -device u3g # USB-based 3G modems (Option, Huawei, Sierra) - -# I2C (TWSI) -device iic -device iicbus -device twsi - -# GPIO -device gpio - -# SATA -device mvs -device ahci - -# Sound -device sound -device snd_uaudio - -#crypto -device cesa # Marvell security engine -device crypto -device cryptodev - -# IPSec -device enc -options IPSEC -options TCP_SIGNATURE # include support for RFC 2385 - -# IPFW -options IPFIREWALL -options IPFIREWALL_DEFAULT_TO_ACCEPT -options IPFIREWALL_VERBOSE -options IPFIREWALL_VERBOSE_LIMIT=100 -options IPFIREWALL_NAT -options LIBALIAS -options DUMMYNET -options IPDIVERT - -#PF -device pf -device pflog -device pfsync - -# ALTQ, required for PF -options ALTQ # Basic ALTQ support -options ALTQ_CBQ # Class Based Queueing -options ALTQ_RED # Random Early Detection -options ALTQ_RIO # RED In/Out -options ALTQ_HFSC # Hierarchical Packet Scheduler -options ALTQ_CDNR # Traffic conditioner -options ALTQ_PRIQ # Priority Queueing -options ALTQ_NOPCC # Required if the TSC is unusable -#options ALTQ_DEBUG - -# Flattened Device Tree -options FDT # Configure using FDT/DTB data -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=dreamplug-1001.dts diff --git a/sys/arm/conf/SHEEVAPLUG b/sys/arm/conf/SHEEVAPLUG deleted file mode 100644 index d47d2ba08700..000000000000 --- a/sys/arm/conf/SHEEVAPLUG +++ /dev/null @@ -1,78 +0,0 @@ -# -# Custom kernel for Marvell SheevaPlug devices. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident SHEEVAPLUG -include "std.arm" -include "../mv/kirkwood/std.db88f6xxx" - -options SOC_MV_KIRKWOOD - -options HZ=1000 -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options FFS # Berkeley Fast Filesystem -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -options NFS_ROOT # NFS usable as /, requires NFSCL -options TMPFS # Efficient memory filesystem -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions -options MUTEX_NOINLINE -options RWLOCK_NOINLINE -options NO_FFS_SNAPSHOT -options NO_SWAPPING - -# NFS root from boopt/dhcp -options BOOTP -options BOOTP_NFSROOT -options BOOTP_NFSV3 -options BOOTP_WIRED_TO=mge0 - -# Root fs on USB device -#options ROOTDEVNAME=\"ufs:/dev/da0a\" - -# Pseudo devices -device loop - -# Serial ports -device uart - -# Networking -device ether -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy -device bpf -options DEVICE_POLLING -device vlan - -device cesa # Marvell security engine -device crypto -device cryptodev - -# USB -device usb -device ehci -device umass -device scbus -device pass -device da - -# GPIO -device gpio - -# Flattened Device Tree -options FDT # Configure using FDT/DTB data -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=sheevaplug.dts diff --git a/sys/arm/conf/TS7800 b/sys/arm/conf/TS7800 deleted file mode 100644 index 7fb1e1741cb4..000000000000 --- a/sys/arm/conf/TS7800 +++ /dev/null @@ -1,78 +0,0 @@ -# -# Custom kernel for the TS-7800 board. -# -# $FreeBSD$ -# -#NO_UNIVERSE - -ident TS7800 -include "std.arm" -include "../mv/orion/std.ts7800" - -options SOC_MV_ORION - -options SCHED_4BSD # 4BSD scheduler -options INET # InterNETworking -options INET6 # IPv6 communications protocols -options TCP_HHOOK # hhook(9) framework for TCP -options FFS # Berkeley Fast Filesystem -options SOFTUPDATES # Enable FFS soft updates support -options NFSCL # Network Filesystem Client -options NFSLOCKD # Network Lock Manager -options NFS_ROOT # NFS usable as /, requires NFSCL -options BOOTP -options BOOTP_NFSROOT -options BOOTP_NFSV3 -options BOOTP_WIRED_TO=mge0 - -options GEOM_PART_BSD # BSD partition scheme -options GEOM_PART_MBR # MBR partition scheme -options TMPFS # Efficient memory filesystem - -options SYSVSHM # SYSV-style shared memory -options SYSVMSG # SYSV-style message queues -options SYSVSEM # SYSV-style semaphores -options _KPOSIX_PRIORITY_SCHEDULING # Posix P1003_1B real-time extensions -options MUTEX_NOINLINE -options RWLOCK_NOINLINE -options NO_FFS_SNAPSHOT -options NO_SWAPPING - -device mvs -device pci - -# Pseudo devices -device md -device loop - -# Serial ports -device uart - -# Networking -device ether -device mge # Marvell Gigabit Ethernet controller -device mii -device mdio -device e1000phy -device bpf -options HZ=1000 - -# USB -device usb -device ehci -device umass -device scbus -device pass -device da - -# SATA -device ata - -# GPIO -device gpio - -# Flattened Device Tree -options FDT -options FDT_DTB_STATIC -makeoptions FDT_DTS_FILE=ts7800.dts - diff --git a/sys/arm/conf/std.arm b/sys/arm/conf/std.arm deleted file mode 100644 index f7be61fd4095..000000000000 --- a/sys/arm/conf/std.arm +++ /dev/null @@ -1,38 +0,0 @@ -# Standard kernel config items for all ARMv4/v5 systems. -# -# $FreeBSD$ - -options COMPAT_FREEBSD10 # Compatible with FreeBSD10 -options COMPAT_FREEBSD11 # Compatible with FreeBSD11 -options COMPAT_FREEBSD12 # Compatible with FreeBSD12 - -# Debugging support. Always need this: -makeoptions DEBUG=-g # Build kernel with gdb(1) debug symbols -options KDB # Enable kernel debugger support. -options KDB_TRACE # Print a stack trace for a panic. - -# For full debugger support use (turn off in stable branch): -options DDB # Support DDB -#options DEADLKRES # Enable the deadlock resolver -options INVARIANTS # Enable calls of extra sanity checking -options INVARIANT_SUPPORT # Extra sanity checks of internal structures, required by INVARIANTS -options WITNESS # Enable checks to detect deadlocks and cycles -options WITNESS_SKIPSPIN # Don't run witness on spinlocks for speed -#options MALLOC_DEBUG_MAXZONES=8 # Separate malloc(9) zones -options ALT_BREAK_TO_DEBUGGER # Enter debugger on keyboard escape sequence -options USB_DEBUG # Enable usb debug support code -options VERBOSE_SYSINIT=0 # Support debug.verbose_sysinit, off by default - -# Optional extras, never enabled by default: -#options BOOTVERBOSE -#options DEBUG # May result in extreme spewage -#options KTR -#options KTR_COMPILE=KTR_ALL -#options KTR_ENTRIES=16384 -#options KTR_MASK=(KTR_SPARE2) -#options KTR_VERBOSE=0 -#options USB_REQ_DEBUG -#options USB_VERBOSE - - - diff --git a/sys/arm/mv/armv5_machdep.c b/sys/arm/mv/armv5_machdep.c deleted file mode 100644 index 53cc21c74e3b..000000000000 --- a/sys/arm/mv/armv5_machdep.c +++ /dev/null @@ -1,500 +0,0 @@ -/*- - * SPDX-License-Identifier: BSD-2-Clause-FreeBSD - * - * Copyright (c) 1994-1998 Mark Brinicombe. - * Copyright (c) 1994 Brini. - * All rights reserved. - * - * This code is derived from software written for Brini by Mark Brinicombe - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Brini. - * 4. The name of the company nor the name of the author may be used to - * endorse or promote products derived from this software without specific - * prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY BRINI ``AS IS'' AND ANY EXPRESS OR IMPLIED - * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL BRINI OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, - * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - * from: FreeBSD: //depot/projects/arm/src/sys/arm/at91/kb920x_machdep.c, rev 45 - */ - -#include "opt_ddb.h" -#include "opt_platform.h" - -#include -__FBSDID("$FreeBSD$"); - -#define _ARM32_BUS_DMA_PRIVATE -#include -#include -#include -#include -#include - -#include -#include - -#include -#include - -#include -#include -#include -#include - -#include - -#include /* XXX */ -#include /* XXX eventually this should be eliminated */ -#include - -#include -#include - -static int platform_mpp_init(void); -void cpu_reset(void); - -#define MPP_PIN_MAX 68 -#define MPP_PIN_CELLS 2 -#define MPP_PINS_PER_REG 8 -#define MPP_SEL(pin,func) (((func) & 0xf) << \ - (((pin) % MPP_PINS_PER_REG) * 4)) - -static void -mv_busdma_tag_init(void *arg __unused) -{ - phandle_t node; - bus_dma_tag_t dmat; - - /* - * If this platform has coherent DMA, create the parent DMA tag to pass - * down the coherent flag to all busses and devices on the platform, - * otherwise return without doing anything. By default create tag - * for all A38x-based platforms only. - */ - if ((node = OF_finddevice("/")) == -1) - return; - if (ofw_bus_node_is_compatible(node, "marvell,armada380") == 0) - return; - - bus_dma_tag_create(NULL, /* No parent tag */ - 1, 0, /* alignment, bounds */ - BUS_SPACE_MAXADDR, /* lowaddr */ - BUS_SPACE_MAXADDR, /* highaddr */ - NULL, NULL, /* filter, filterarg */ - BUS_SPACE_MAXSIZE, /* maxsize */ - BUS_SPACE_UNRESTRICTED, /* nsegments */ - BUS_SPACE_MAXSIZE, /* maxsegsize */ - BUS_DMA_COHERENT, /* flags */ - NULL, NULL, /* lockfunc, lockarg */ - &dmat); - - nexus_set_dma_tag(dmat); -} -SYSINIT(mv_busdma_tag, SI_SUB_DRIVERS, SI_ORDER_ANY, mv_busdma_tag_init, NULL); - -static int -platform_mpp_init(void) -{ - pcell_t pinmap[MPP_PIN_MAX * MPP_PIN_CELLS]; - int mpp[MPP_PIN_MAX]; - uint32_t ctrl_val, ctrl_offset; - pcell_t reg[4]; - u_long start, size; - phandle_t node; - pcell_t pin_cells, *pinmap_ptr, pin_count; - ssize_t len; - int par_addr_cells, par_size_cells; - int tuple_size, tuples, rv, pins, i, j; - int mpp_pin, mpp_function; - - /* - * Try to access the MPP node directly i.e. through /aliases/mpp. - */ - if ((node = OF_finddevice("mpp")) != -1) - if (ofw_bus_node_is_compatible(node, "mrvl,mpp")) - goto moveon; - /* - * Find the node the long way. - */ - if ((node = OF_finddevice("/")) == -1) - return (ENXIO); - - if ((node = fdt_find_compatible(node, "simple-bus", 0)) == 0) - return (ENXIO); - - if ((node = fdt_find_compatible(node, "mrvl,mpp", 0)) == 0) - /* - * No MPP node. Fall back to how MPP got set by the - * first-stage loader and try to continue booting. - */ - return (0); -moveon: - /* - * Process 'reg' prop. - */ - if ((rv = fdt_addrsize_cells(OF_parent(node), &par_addr_cells, - &par_size_cells)) != 0) - return(ENXIO); - - tuple_size = sizeof(pcell_t) * (par_addr_cells + par_size_cells); - len = OF_getprop(node, "reg", reg, sizeof(reg)); - tuples = len / tuple_size; - if (tuple_size <= 0) - return (EINVAL); - - /* - * Get address/size. XXX we assume only the first 'reg' tuple is used. - */ - rv = fdt_data_to_res(reg, par_addr_cells, par_size_cells, - &start, &size); - if (rv != 0) - return (rv); - start += fdt_immr_va; - - /* - * Process 'pin-count' and 'pin-map' props. - */ - if (OF_getencprop(node, "pin-count", &pin_count, sizeof(pin_count)) <= 0) - return (ENXIO); - if (pin_count > MPP_PIN_MAX) - return (ERANGE); - - if (OF_getencprop(node, "#pin-cells", &pin_cells, sizeof(pin_cells)) <= 0) - pin_cells = MPP_PIN_CELLS; - if (pin_cells > MPP_PIN_CELLS) - return (ERANGE); - tuple_size = sizeof(pcell_t) * pin_cells; - - bzero(pinmap, sizeof(pinmap)); - len = OF_getencprop(node, "pin-map", pinmap, sizeof(pinmap)); - if (len <= 0) - return (ERANGE); - if (len % tuple_size) - return (ERANGE); - pins = len / tuple_size; - if (pins > pin_count) - return (ERANGE); - /* - * Fill out a "mpp[pin] => function" table. All pins unspecified in - * the 'pin-map' property are defaulted to 0 function i.e. GPIO. - */ - bzero(mpp, sizeof(mpp)); - pinmap_ptr = pinmap; - for (i = 0; i < pins; i++) { - mpp_pin = *pinmap_ptr; - mpp_function = *(pinmap_ptr + 1); - mpp[mpp_pin] = mpp_function; - pinmap_ptr += pin_cells; - } - - /* - * Prepare and program MPP control register values. - */ - ctrl_offset = 0; - for (i = 0; i < pin_count;) { - ctrl_val = 0; - - for (j = 0; j < MPP_PINS_PER_REG; j++) { - if (i + j == pin_count - 1) - break; - ctrl_val |= MPP_SEL(i + j, mpp[i + j]); - } - i += MPP_PINS_PER_REG; - bus_space_write_4(fdtbus_bs_tag, start, ctrl_offset, - ctrl_val); - -#if defined(SOC_MV_ORION) - /* - * Third MPP reg on Orion SoC is placed - * non-linearly (with different offset). - */ - if (i == (2 * MPP_PINS_PER_REG)) - ctrl_offset = 0x50; - else -#endif - ctrl_offset += 4; - } - - return (0); -} - -vm_offset_t -platform_lastaddr(void) -{ - - return (fdt_immr_va); -} - -void -platform_probe_and_attach(void) -{ - - if (fdt_immr_addr(MV_BASE) != 0) - while (1); -} - -void -platform_gpio_init(void) -{ - - /* - * Re-initialise MPP. It is important to call this prior to using - * console as the physical connection can be routed via MPP. - */ - if (platform_mpp_init() != 0) - while (1); -} - -void -platform_late_init(void) -{ - /* - * Re-initialise decode windows - */ - if (mv_check_soc_family() == MV_SOC_UNSUPPORTED) - panic("Unsupported SoC family\n"); - - if (soc_decode_win() != 0) - printf("WARNING: could not re-initialise decode windows! " - "Running with existing settings...\n"); -} -#define FDT_DEVMAP_MAX (MV_WIN_CPU_MAX + 2) -static struct devmap_entry fdt_devmap[FDT_DEVMAP_MAX] = { - { 0, 0, 0, } -}; - -static int -platform_sram_devmap(struct devmap_entry *map) -{ - phandle_t child, root; - u_long base, size; - /* - * SRAM range. - */ - if ((root = OF_finddevice("/")) == 0) - return (ENXIO); - - if ((child = OF_finddevice("/sram")) != 0) - if (ofw_bus_node_is_compatible(child, "mrvl,cesa-sram") || - ofw_bus_node_is_compatible(child, "mrvl,scratchpad")) - goto moveon; - - if ((child = fdt_find_compatible(root, "mrvl,cesa-sram", 0)) == 0 && - (child = fdt_find_compatible(root, "mrvl,scratchpad", 0)) == 0) - goto out; - -moveon: - if (fdt_regsize(child, &base, &size) != 0) - return (EINVAL); - - map->pd_va = MV_CESA_SRAM_BASE; /* XXX */ - map->pd_pa = base; - map->pd_size = size; - - return (0); -out: - return (ENOENT); - -} - -/* - * Supply a default do-nothing implementation of mv_pci_devmap() via a weak - * alias. Many Marvell platforms don't support a PCI interface, but to support - * those that do, we end up with a reference to this function below, in - * platform_devmap_init(). If "device pci" appears in the kernel config, the - * real implementation of this function in arm/mv/mv_pci.c overrides the weak - * alias defined here. - */ -int mv_default_fdt_pci_devmap(phandle_t node, struct devmap_entry *devmap, - vm_offset_t io_va, vm_offset_t mem_va); -int -mv_default_fdt_pci_devmap(phandle_t node, struct devmap_entry *devmap, - vm_offset_t io_va, vm_offset_t mem_va) -{ - - return (0); -} -__weak_reference(mv_default_fdt_pci_devmap, mv_pci_devmap); - -/* - * XXX: When device entry in devmap has pd_size smaller than section size, - * system will freeze during initialization - */ - -/* - * Construct devmap table with DT-derived config data. - */ -int -platform_devmap_init(void) -{ - phandle_t root, child; - pcell_t bank_count; - int i, num_mapped; - - i = 0; - devmap_register_table(&fdt_devmap[0]); - - if ((root = OF_finddevice("/")) == -1) - return (ENXIO); - - /* - * IMMR range. - */ - fdt_devmap[i].pd_va = fdt_immr_va; - fdt_devmap[i].pd_pa = fdt_immr_pa; - fdt_devmap[i].pd_size = fdt_immr_size; - i++; - - /* - * SRAM range. - */ - if (i < FDT_DEVMAP_MAX) - if (platform_sram_devmap(&fdt_devmap[i]) == 0) - i++; - - /* - * PCI range(s). - * PCI range(s) and localbus. - */ - for (child = OF_child(root); child != 0; child = OF_peer(child)) { - if (mv_fdt_is_type(child, "pci") || - mv_fdt_is_type(child, "pciep")) { - /* - * Check space: each PCI node will consume 2 devmap - * entries. - */ - if (i + 1 >= FDT_DEVMAP_MAX) - return (ENOMEM); - - /* - * XXX this should account for PCI and multiple ranges - * of a given kind. - */ - if (mv_pci_devmap(child, &fdt_devmap[i], MV_PCI_VA_IO_BASE, - MV_PCI_VA_MEM_BASE) != 0) - return (ENXIO); - i += 2; - } - - if (ofw_bus_node_is_compatible(child, "mrvl,lbc")) { - /* Check available space */ - if (OF_getencprop(child, "bank-count", &bank_count, - sizeof(bank_count)) <= 0) - /* If no property, use default value */ - bank_count = 1; - - if ((i + bank_count) >= FDT_DEVMAP_MAX) - return (ENOMEM); - - /* Add all localbus ranges to device map */ - num_mapped = 0; - - if (fdt_localbus_devmap(child, &fdt_devmap[i], - (int)bank_count, &num_mapped) != 0) - return (ENXIO); - - i += num_mapped; - } - } - - return (0); -} - -struct arm32_dma_range * -bus_dma_get_range(void) -{ - - return (NULL); -} - -int -bus_dma_get_range_nb(void) -{ - - return (0); -} - -void -cpu_reset(void) -{ - - write_cpu_ctrl(RSTOUTn_MASK, SOFT_RST_OUT_EN); - write_cpu_ctrl(SYSTEM_SOFT_RESET, SYS_SOFT_RST); - while(1); -} - -#ifdef DDB -#include - -DB_SHOW_COMMAND(cp15, db_show_cp15) -{ - u_int reg; - - __asm __volatile("mrc p15, 0, %0, c0, c0, 0" : "=r" (reg)); - db_printf("Cpu ID: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c0, 1" : "=r" (reg)); - db_printf("Current Cache Lvl ID: 0x%08x\n",reg); - - reg = cp15_sctlr_get(); - db_printf("Ctrl: 0x%08x\n",reg); - reg = cp15_actlr_get(); - db_printf("Aux Ctrl: 0x%08x\n",reg); - - __asm __volatile("mrc p15, 0, %0, c0, c1, 0" : "=r" (reg)); - db_printf("Processor Feat 0: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 1" : "=r" (reg)); - db_printf("Processor Feat 1: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 2" : "=r" (reg)); - db_printf("Debug Feat 0: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 3" : "=r" (reg)); - db_printf("Auxiliary Feat 0: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 4" : "=r" (reg)); - db_printf("Memory Model Feat 0: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 5" : "=r" (reg)); - db_printf("Memory Model Feat 1: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 6" : "=r" (reg)); - db_printf("Memory Model Feat 2: 0x%08x\n", reg); - __asm __volatile("mrc p15, 0, %0, c0, c1, 7" : "=r" (reg)); - db_printf("Memory Model Feat 3: 0x%08x\n", reg); - - __asm __volatile("mrc p15, 1, %0, c15, c2, 0" : "=r" (reg)); - db_printf("Aux Func Modes Ctrl 0: 0x%08x\n",reg); - __asm __volatile("mrc p15, 1, %0, c15, c2, 1" : "=r" (reg)); - db_printf("Aux Func Modes Ctrl 1: 0x%08x\n",reg); - - __asm __volatile("mrc p15, 1, %0, c15, c12, 0" : "=r" (reg)); - db_printf("CPU ID code extension: 0x%08x\n",reg); -} - -DB_SHOW_COMMAND(vtop, db_show_vtop) -{ - u_int reg; - - if (have_addr) { - __asm __volatile("mcr p15, 0, %0, c7, c8, 0" : : "r" (addr)); - __asm __volatile("mrc p15, 0, %0, c7, c4, 0" : "=r" (reg)); - db_printf("Physical address reg: 0x%08x\n",reg); - } else - db_printf("show vtop \n"); -} -#endif /* DDB */ diff --git a/sys/arm/mv/discovery/discovery.c b/sys/arm/mv/discovery/discovery.c deleted file mode 100644 index c93179e96bbd..000000000000 --- a/sys/arm/mv/discovery/discovery.c +++ /dev/null @@ -1,120 +0,0 @@ -/*- - * SPDX-License-Identifier: BSD-3-Clause - * - * Copyright (C) 2008 MARVELL INTERNATIONAL LTD. - * All rights reserved. - * - * Developed by Semihalf. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of MARVELL nor the names of contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ - -#include -__FBSDID("$FreeBSD$"); - -#include -#include -#include - -#include -#include - -#include -#include -#include - -/* - * Virtual address space layout: - * ----------------------------- - * 0x0000_0000 - 0xBFFF_FFFF : User Process (3 GB) - * 0xC000_0000 - virtual_avail : Kernel Reserved (text, data, page tables, - * : stack etc.) - * virtual-avail - 0xEFFF_FFFF : KVA (virtual_avail is typically < 0xc0a0_0000) - * 0xF000_0000 - 0xF0FF_FFFF : No-Cache allocation area (16 MB) - * 0xF100_0000 - 0xF10F_FFFF : SoC Integrated devices registers range (1 MB) - * 0xF110_0000 - 0xF11F_FFFF : PCI-Express I/O space (1MB) - * 0xF120_0000 - 0xF12F_FFFF : PCI I/O space (1MB) - * 0xF130_0000 - 0xF52F_FFFF : PCI-Express memory space (64MB) - * 0xF530_0000 - 0xF92F_FFFF : PCI memory space (64MB) - * 0xF930_0000 - 0xF93F_FFFF : Device Bus: BOOT (1 MB) - * 0xF940_0000 - 0xF94F_FFFF : Device Bus: CS0 (1 MB) - * 0xF950_0000 - 0xFB4F_FFFF : Device Bus: CS1 (32 MB) - * 0xFB50_0000 - 0xFB5F_FFFF : Device Bus: CS2 (1 MB) - * 0xFB60_0000 - 0xFFFE_FFFF : Unused (~74MB) - * 0xFFFF_0000 - 0xFFFF_0FFF : 'High' vectors page (4 kB) - * 0xFFFF_1000 - 0xFFFF_1FFF : ARM_TP_ADDRESS/RAS page (4 kB) - * 0xFFFF_2000 - 0xFFFF_FFFF : Unused (56 kB) - */ - - -struct resource_spec mv_gpio_res[] = { - { SYS_RES_MEMORY, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 1, RF_ACTIVE }, - { SYS_RES_IRQ, 2, RF_ACTIVE }, - { SYS_RES_IRQ, 3, RF_ACTIVE }, - { -1, 0 } -}; - -const struct decode_win idma_win_tbl[] = { - { 0 }, -}; -const struct decode_win *idma_wins = idma_win_tbl; -int idma_wins_no = 0; - -const struct decode_win xor_win_tbl[] = { - { 0 }, -}; -const struct decode_win *xor_wins = xor_win_tbl; -int xor_wins_no = 0; - -uint32_t -get_tclk(void) -{ - uint32_t sar; - - /* - * On Discovery TCLK is can be configured to 166 MHz or 200 MHz. - * Current setting is read from Sample At Reset register. - */ - sar = bus_space_read_4(fdtbus_bs_tag, MV_MPP_BASE, SAMPLE_AT_RESET_HI); - sar = (sar & TCLK_MASK) >> TCLK_SHIFT; - - switch (sar) { - case 0: - return (TCLK_166MHZ); - case 1: - return (TCLK_200MHZ); - default: - panic("Unknown TCLK settings!"); - } -} - -uint32_t -get_cpu_freq(void) -{ - - return (0); -} diff --git a/sys/arm/mv/discovery/files.db78xxx b/sys/arm/mv/discovery/files.db78xxx deleted file mode 100644 index 07a4279f0b25..000000000000 --- a/sys/arm/mv/discovery/files.db78xxx +++ /dev/null @@ -1,5 +0,0 @@ -# $FreeBSD$ - -arm/mv/discovery/discovery.c standard -arm/mv/ic.c standard - diff --git a/sys/arm/mv/discovery/std.db78xxx b/sys/arm/mv/discovery/std.db78xxx deleted file mode 100644 index 582f26549964..000000000000 --- a/sys/arm/mv/discovery/std.db78xxx +++ /dev/null @@ -1,7 +0,0 @@ -# $FreeBSD$ - -include "../mv/std.mv" -files "../mv/discovery/files.db78xxx" - -makeoptions KERNVIRTADDR=0xc0900000 -options KERNVIRTADDR=0xc0900000 diff --git a/sys/arm/mv/files.mv b/sys/arm/mv/files.mv deleted file mode 100644 index 1dc45105450c..000000000000 --- a/sys/arm/mv/files.mv +++ /dev/null @@ -1,34 +0,0 @@ -# $FreeBSD$ -# -# The Marvell CPU cores -# - Compliant with V5TE architecture -# - Super scalar dual issue CPU -# - Big/Little Endian -# - MMU/MPU -# - L1 Cache: Supports streaming and write allocate -# - Variable pipeline stages -# - Out-of-order execution -# - Branch Prediction -# - JTAG/ICE -# - Vector Floating Point (VFP) unit -# -arm/mv/gpio.c optional gpio -arm/mv/mv_common.c standard -arm/mv/mv_localbus.c standard -arm/mv/armv5_machdep.c standard -arm/mv/mv_pci_ctrl.c optional pci | fdt -arm/mv/mv_pci.c optional pci -arm/mv/mv_ts.c standard -arm/mv/timer.c optional !soc_mv_armada38x - -dev/cesa/cesa.c optional cesa -dev/iicbus/twsi/mv_twsi.c optional twsi -dev/mge/if_mge.c optional mge -dev/neta/if_mvneta_fdt.c optional neta fdt -dev/neta/if_mvneta.c optional neta mdio mii -dev/mvs/mvs_soc.c optional mvs -dev/uart/uart_dev_ns8250.c optional uart -dev/uart/uart_dev_snps.c optional uart -dev/usb/controller/ehci_mv.c optional ehci -dev/usb/controller/generic_xhci.c optional xhci -dev/ahci/ahci_mv_fdt.c optional ahci diff --git a/sys/arm/mv/kirkwood/files.kirkwood b/sys/arm/mv/kirkwood/files.kirkwood deleted file mode 100644 index 70ba5eedd890..000000000000 --- a/sys/arm/mv/kirkwood/files.kirkwood +++ /dev/null @@ -1,5 +0,0 @@ -# $FreeBSD$ - -arm/mv/ic.c standard -arm/mv/rtc.c standard -arm/mv/kirkwood/kirkwood.c standard diff --git a/sys/arm/mv/kirkwood/kirkwood.c b/sys/arm/mv/kirkwood/kirkwood.c deleted file mode 100644 index c7d30c472212..000000000000 --- a/sys/arm/mv/kirkwood/kirkwood.c +++ /dev/null @@ -1,90 +0,0 @@ -/*- - * SPDX-License-Identifier: BSD-3-Clause - * - * Copyright (C) 2008 MARVELL INTERNATIONAL LTD. - * All rights reserved. - * - * Developed by Semihalf. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of MARVELL nor the names of contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ - -#include -__FBSDID("$FreeBSD$"); - -#include -#include -#include - -#include - -#include -#include -#include - -struct resource_spec mv_gpio_res[] = { - { SYS_RES_MEMORY, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 1, RF_ACTIVE }, - { SYS_RES_IRQ, 2, RF_ACTIVE }, - { SYS_RES_IRQ, 3, RF_ACTIVE }, - { SYS_RES_IRQ, 4, RF_ACTIVE }, - { SYS_RES_IRQ, 5, RF_ACTIVE }, - { SYS_RES_IRQ, 6, RF_ACTIVE }, - { -1, 0 } -}; - -const struct decode_win xor_win_tbl[] = { - { 0 }, -}; -const struct decode_win *xor_wins = xor_win_tbl; -int xor_wins_no = 0; - -uint32_t -get_tclk(void) -{ - uint32_t dev, rev; - - /* - * On Kirkwood TCLK is not configurable and depends on silicon - * revision: - * - A0 and A1 have TCLK hardcoded to 200 MHz. - * - Z0 and others have TCLK hardcoded to 166 MHz. - */ - soc_id(&dev, &rev); - if (dev == MV_DEV_88F6281 && (rev == 2 || rev == 3)) - return (TCLK_200MHZ); - if (dev == MV_DEV_88F6282) - return (TCLK_200MHZ); - - return (TCLK_166MHZ); -} - -uint32_t -get_cpu_freq(void) -{ - - return (0); -} diff --git a/sys/arm/mv/kirkwood/std.db88f6xxx b/sys/arm/mv/kirkwood/std.db88f6xxx deleted file mode 100644 index 012a88290571..000000000000 --- a/sys/arm/mv/kirkwood/std.db88f6xxx +++ /dev/null @@ -1,5 +0,0 @@ -# $FreeBSD$ - -include "../mv/std.mv" -include "../mv/kirkwood/std.kirkwood" -files "../mv/kirkwood/files.kirkwood" diff --git a/sys/arm/mv/kirkwood/std.kirkwood b/sys/arm/mv/kirkwood/std.kirkwood deleted file mode 100644 index 7fa24baa1c24..000000000000 --- a/sys/arm/mv/kirkwood/std.kirkwood +++ /dev/null @@ -1,4 +0,0 @@ -# $FreeBSD$ - -makeoptions KERNVIRTADDR=0xc0000000 -options KERNVIRTADDR=0xc0000000 diff --git a/sys/arm/mv/orion/db88f5xxx.c b/sys/arm/mv/orion/db88f5xxx.c deleted file mode 100644 index 1e5e728d000c..000000000000 --- a/sys/arm/mv/orion/db88f5xxx.c +++ /dev/null @@ -1,175 +0,0 @@ -/*- - * SPDX-License-Identifier: BSD-3-Clause - * - * Copyright (C) 2008 MARVELL INTERNATIONAL LTD. - * All rights reserved. - * - * Developed by Semihalf. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of MARVELL nor the names of contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ - -#include -__FBSDID("$FreeBSD$"); - -#include -#include -#include -#include - -#include -#include - -#include -#include -#include - -#include -#include -#include - -/* - * Virtual address space layout: - * ----------------------------- - * 0x0000_0000 - 0xbfff_ffff : user process - * - * 0xc040_0000 - virtual_avail : kernel reserved (text, data, page tables - * : structures, ARM stacks etc.) - * virtual_avail - 0xefff_ffff : KVA (virtual_avail is typically < 0xc0a0_0000) - * 0xf000_0000 - 0xf0ff_ffff : no-cache allocation area (16MB) - * 0xf100_0000 - 0xf10f_ffff : SoC integrated devices registers range (1MB) - * 0xf110_0000 - 0xf11f_ffff : PCI-Express I/O space (1MB) - * 0xf120_0000 - 0xf12f_ffff : PCI I/O space (1MB) - * 0xf130_0000 - 0xf52f_ffff : PCI-Express memory space (64MB) - * 0xf530_0000 - 0xf92f_ffff : PCI memory space (64MB) - * 0xf930_0000 - 0xfffe_ffff : unused (~108MB) - * 0xffff_0000 - 0xffff_0fff : 'high' vectors page (4KB) - * 0xffff_1000 - 0xffff_1fff : ARM_TP_ADDRESS/RAS page (4KB) - * 0xffff_2000 - 0xffff_ffff : unused (~55KB) - */ - - -#if 0 -int platform_pci_get_irq(u_int bus, u_int slot, u_int func, u_int pin); - -/* Static device mappings. */ -const struct devmap_entry db88f5xxx_devmap[] = { - /* - * Map the on-board devices VA == PA so that we can access them - * with the MMU on or off. - */ - { /* SoC integrated peripherals registers range */ - MV_BASE, - MV_PHYS_BASE, - MV_SIZE, - }, - { /* PCIE I/O */ - MV_PCIE_IO_BASE, - MV_PCIE_IO_PHYS_BASE, - MV_PCIE_IO_SIZE, - }, - { /* PCIE Memory */ - MV_PCIE_MEM_BASE, - MV_PCIE_MEM_PHYS_BASE, - MV_PCIE_MEM_SIZE, - }, - { /* PCI I/O */ - MV_PCI_IO_BASE, - MV_PCI_IO_PHYS_BASE, - MV_PCI_IO_SIZE, - }, - { /* PCI Memory */ - MV_PCI_MEM_BASE, - MV_PCI_MEM_PHYS_BASE, - MV_PCI_MEM_SIZE, - }, - { /* 7-seg LED */ - MV_DEV_CS0_BASE, - MV_DEV_CS0_PHYS_BASE, - MV_DEV_CS0_SIZE, - }, - { 0, 0, 0, } -}; - -/* - * The pci_irq_map table consists of 3 columns: - * - PCI slot number (less than zero means ANY). - * - PCI IRQ pin (less than zero means ANY). - * - PCI IRQ (less than zero marks end of table). - * - * IRQ number from the first matching entry is used to configure PCI device - */ - -/* PCI IRQ Map for DB-88F5281 */ -const struct obio_pci_irq_map pci_irq_map[] = { - { 7, -1, GPIO2IRQ(12) }, - { 8, -1, GPIO2IRQ(13) }, - { 9, -1, GPIO2IRQ(13) }, - { -1, -1, -1 } -}; - -/* PCI IRQ Map for DB-88F5182 */ -const struct obio_pci_irq_map pci_irq_map[] = { - { 7, -1, GPIO2IRQ(0) }, - { 8, -1, GPIO2IRQ(1) }, - { 9, -1, GPIO2IRQ(1) }, - { -1, -1, -1 } -}; -#endif - -#if 0 -/* - * mv_gpio_config row structure: - * , , - * - * - GPIO pin number (less than zero marks end of table) - * - GPIO flags: - * MV_GPIO_BLINK - * MV_GPIO_POLAR_LOW - * MV_GPIO_EDGE - * MV_GPIO_LEVEL - * - GPIO mode: - * 1 - Output, set to HIGH. - * 0 - Output, set to LOW. - * -1 - Input. - */ - -/* GPIO Configuration for DB-88F5281 */ -const struct gpio_config mv_gpio_config[] = { - { 12, MV_GPIO_POLAR_LOW | MV_GPIO_LEVEL, -1 }, - { 13, MV_GPIO_POLAR_LOW | MV_GPIO_LEVEL, -1 }, - { -1, -1, -1 } -}; - -#if 0 -/* GPIO Configuration for DB-88F5182 */ -const struct gpio_config mv_gpio_config[] = { - { 0, MV_GPIO_POLAR_LOW | MV_GPIO_LEVEL, -1 }, - { 1, MV_GPIO_POLAR_LOW | MV_GPIO_LEVEL, -1 }, - { -1, -1, -1 } -}; -#endif - -#endif diff --git a/sys/arm/mv/orion/files.db88f5xxx b/sys/arm/mv/orion/files.db88f5xxx deleted file mode 100644 index 54c453c7b6a3..000000000000 --- a/sys/arm/mv/orion/files.db88f5xxx +++ /dev/null @@ -1,5 +0,0 @@ -# $FreeBSD$ - -arm/mv/ic.c standard -arm/mv/orion/orion.c standard -arm/mv/orion/db88f5xxx.c standard diff --git a/sys/arm/mv/orion/files.ts7800 b/sys/arm/mv/orion/files.ts7800 deleted file mode 100644 index df93815d8153..000000000000 --- a/sys/arm/mv/orion/files.ts7800 +++ /dev/null @@ -1,5 +0,0 @@ -# $FreeBSD$ - -arm/mv/ic.c standard -arm/mv/orion/orion.c standard - diff --git a/sys/arm/mv/orion/orion.c b/sys/arm/mv/orion/orion.c deleted file mode 100644 index a3ed62935365..000000000000 --- a/sys/arm/mv/orion/orion.c +++ /dev/null @@ -1,111 +0,0 @@ -/*- - * SPDX-License-Identifier: BSD-3-Clause - * - * Copyright (C) 2008 MARVELL INTERNATIONAL LTD. - * All rights reserved. - * - * Developed by Semihalf. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of MARVELL nor the names of contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ - -#include -__FBSDID("$FreeBSD$"); - -#include -#include -#include - -#include -#include - -#include -#include -#include - -#if 0 -extern const struct obio_pci_irq_map pci_irq_map[]; -const struct obio_pci mv_pci_info[] = { - { MV_TYPE_PCIE, - MV_PCIE_BASE, MV_PCIE_SIZE, - MV_PCIE_IO_BASE, MV_PCIE_IO_SIZE, 4, 0x51, - MV_PCIE_MEM_BASE, MV_PCIE_MEM_SIZE, 4, 0x59, - NULL, MV_INT_PEX0 - }, - - { MV_TYPE_PCI, - MV_PCI_BASE, MV_PCI_SIZE, - MV_PCI_IO_BASE, MV_PCI_IO_SIZE, 3, 0x51, - MV_PCI_MEM_BASE, MV_PCI_MEM_SIZE, 3, 0x59, - pci_irq_map, -1 - }, - - { 0, 0, 0 } -}; -#endif - -struct resource_spec mv_gpio_res[] = { - { SYS_RES_MEMORY, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 0, RF_ACTIVE }, - { SYS_RES_IRQ, 1, RF_ACTIVE }, - { SYS_RES_IRQ, 2, RF_ACTIVE }, - { SYS_RES_IRQ, 3, RF_ACTIVE }, - { -1, 0 } -}; - -const struct decode_win idma_win_tbl[] = { - { 0 }, -}; -const struct decode_win *idma_wins = idma_win_tbl; -int idma_wins_no = 0; - -uint32_t -get_tclk(void) -{ - uint32_t sar; - - /* - * On Orion TCLK is can be configured to 150 MHz or 166 MHz. - * Current setting is read from Sample At Reset register. - */ - /* XXX MPP addr should be retrieved from the DT */ - sar = bus_space_read_4(fdtbus_bs_tag, MV_MPP_BASE, SAMPLE_AT_RESET); - sar = (sar & TCLK_MASK) >> TCLK_SHIFT; - switch (sar) { - case 1: - return (TCLK_150MHZ); - case 2: - return (TCLK_166MHZ); - default: - panic("Unknown TCLK settings!"); - } -} - -uint32_t -get_cpu_freq(void) -{ - - return (0); -} diff --git a/sys/arm/mv/orion/std.db88f5xxx b/sys/arm/mv/orion/std.db88f5xxx deleted file mode 100644 index e6b09890ad6b..000000000000 --- a/sys/arm/mv/orion/std.db88f5xxx +++ /dev/null @@ -1,7 +0,0 @@ -# $FreeBSD$ - -include "../mv/std.mv" -files "../mv/orion/files.db88f5xxx" - -makeoptions KERNVIRTADDR=0xc0900000 -options KERNVIRTADDR=0xc0900000 diff --git a/sys/arm/mv/orion/std.ts7800 b/sys/arm/mv/orion/std.ts7800 deleted file mode 100644 index 53d6aa809649..000000000000 --- a/sys/arm/mv/orion/std.ts7800 +++ /dev/null @@ -1,11 +0,0 @@ -# $FreeBSD$ - -include "../mv/std.mv" -files "../mv/orion/files.ts7800" - -makeoptions KERNVIRTADDR=0xc0900000 -options KERNVIRTADDR=0xc0900000 -options PHYSADDR=0x00000000 -options LOADERRAMADDR=0x00000000 -options FLASHADDR=0x00008000 -