Remove armv5 marvell support.
Per plans to remove armv5 support, remove the armv5 marvell discovery, kirkwood and orion families.
This commit is contained in:
parent
29e563a654
commit
de83b0d12c
@ -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
|
@ -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
|
@ -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
|
@ -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
|
@ -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
|
@ -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
|
@ -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
|
||||
|
@ -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
|
||||
|
||||
|
||||
|
@ -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 <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#define _ARM32_BUS_DMA_PRIVATE
|
||||
#include <sys/param.h>
|
||||
#include <sys/systm.h>
|
||||
#include <sys/bus.h>
|
||||
#include <sys/devmap.h>
|
||||
#include <sys/kernel.h>
|
||||
|
||||
#include <vm/vm.h>
|
||||
#include <vm/pmap.h>
|
||||
|
||||
#include <arm/arm/mpcore_timervar.h>
|
||||
#include <arm/arm/nexusvar.h>
|
||||
|
||||
#include <machine/bus.h>
|
||||
#include <machine/fdt.h>
|
||||
#include <machine/machdep.h>
|
||||
#include <machine/platform.h>
|
||||
|
||||
#include <machine/cpu-v4.h>
|
||||
|
||||
#include <arm/mv/mvreg.h> /* XXX */
|
||||
#include <arm/mv/mvvar.h> /* XXX eventually this should be eliminated */
|
||||
#include <arm/mv/mvwin.h>
|
||||
|
||||
#include <dev/fdt/fdt_common.h>
|
||||
#include <dev/ofw/ofw_bus_subr.h>
|
||||
|
||||
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 <ddb/ddb.h>
|
||||
|
||||
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 <virt_addr>\n");
|
||||
}
|
||||
#endif /* DDB */
|
@ -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 <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/systm.h>
|
||||
#include <sys/bus.h>
|
||||
|
||||
#include <machine/bus.h>
|
||||
#include <machine/fdt.h>
|
||||
|
||||
#include <arm/mv/mvreg.h>
|
||||
#include <arm/mv/mvvar.h>
|
||||
#include <arm/mv/mvwin.h>
|
||||
|
||||
/*
|
||||
* 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);
|
||||
}
|
@ -1,5 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
arm/mv/discovery/discovery.c standard
|
||||
arm/mv/ic.c standard
|
||||
|
@ -1,7 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
include "../mv/std.mv"
|
||||
files "../mv/discovery/files.db78xxx"
|
||||
|
||||
makeoptions KERNVIRTADDR=0xc0900000
|
||||
options KERNVIRTADDR=0xc0900000
|
@ -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
|
@ -1,5 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
arm/mv/ic.c standard
|
||||
arm/mv/rtc.c standard
|
||||
arm/mv/kirkwood/kirkwood.c standard
|
@ -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 <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/systm.h>
|
||||
#include <sys/bus.h>
|
||||
|
||||
#include <machine/bus.h>
|
||||
|
||||
#include <arm/mv/mvreg.h>
|
||||
#include <arm/mv/mvvar.h>
|
||||
#include <arm/mv/mvwin.h>
|
||||
|
||||
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);
|
||||
}
|
@ -1,5 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
include "../mv/std.mv"
|
||||
include "../mv/kirkwood/std.kirkwood"
|
||||
files "../mv/kirkwood/files.kirkwood"
|
@ -1,4 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
makeoptions KERNVIRTADDR=0xc0000000
|
||||
options KERNVIRTADDR=0xc0000000
|
@ -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 <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/systm.h>
|
||||
#include <sys/bus.h>
|
||||
#include <sys/kernel.h>
|
||||
|
||||
#include <vm/vm.h>
|
||||
#include <vm/pmap.h>
|
||||
|
||||
#include <machine/bus.h>
|
||||
#include <machine/intr.h>
|
||||
#include <machine/vmparam.h>
|
||||
|
||||
#include <arm/mv/mvreg.h>
|
||||
#include <arm/mv/mvvar.h>
|
||||
#include <arm/mv/mvwin.h>
|
||||
|
||||
/*
|
||||
* 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 number>, <GPIO flags>, <GPIO mode>
|
||||
*
|
||||
* - 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
|
@ -1,5 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
arm/mv/ic.c standard
|
||||
arm/mv/orion/orion.c standard
|
||||
arm/mv/orion/db88f5xxx.c standard
|
@ -1,5 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
arm/mv/ic.c standard
|
||||
arm/mv/orion/orion.c standard
|
||||
|
@ -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 <sys/cdefs.h>
|
||||
__FBSDID("$FreeBSD$");
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/systm.h>
|
||||
#include <sys/bus.h>
|
||||
|
||||
#include <machine/bus.h>
|
||||
#include <machine/fdt.h>
|
||||
|
||||
#include <arm/mv/mvreg.h>
|
||||
#include <arm/mv/mvvar.h>
|
||||
#include <arm/mv/mvwin.h>
|
||||
|
||||
#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);
|
||||
}
|
@ -1,7 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
include "../mv/std.mv"
|
||||
files "../mv/orion/files.db88f5xxx"
|
||||
|
||||
makeoptions KERNVIRTADDR=0xc0900000
|
||||
options KERNVIRTADDR=0xc0900000
|
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user