2011-04-03 13:19:58 +00:00
|
|
|
#
|
|
|
|
# AR91XX -- Kernel configuration base file for the Atheros AR913x SoC.
|
|
|
|
#
|
|
|
|
# This file (and the hints file accompanying it) are not designed to be
|
|
|
|
# used by themselves. Instead, users of this file should create a kernel
|
|
|
|
# config file which includes this file (which gets the basic hints), then
|
|
|
|
# override the default options (adding devices as needed) and adding
|
|
|
|
# hints as needed (for example, the GPIO and LAN PHY.)
|
|
|
|
#
|
|
|
|
# $FreeBSD$
|
|
|
|
#
|
|
|
|
|
2012-03-29 02:54:35 +00:00
|
|
|
machine mips mips
|
2011-04-03 13:19:58 +00:00
|
|
|
ident AR91XX_BASE
|
2016-02-11 06:23:02 +00:00
|
|
|
cpu CPU_MIPS24K
|
2011-04-03 13:19:58 +00:00
|
|
|
makeoptions KERNLOADADDR=0x80050000
|
2014-03-18 14:41:18 +00:00
|
|
|
options HZ=1000
|
2011-04-03 13:19:58 +00:00
|
|
|
|
|
|
|
files "../atheros/files.ar71xx"
|
|
|
|
hints "AR91XX_BASE.hints"
|
|
|
|
|
|
|
|
makeoptions DEBUG=-g #Build kernel with gdb(1) debug symbols
|
Huge cleanup of random(4) code.
* GENERAL
- Update copyright.
- Make kernel options for RANDOM_YARROW and RANDOM_DUMMY. Set
neither to ON, which means we want Fortuna
- If there is no 'device random' in the kernel, there will be NO
random(4) device in the kernel, and the KERN_ARND sysctl will
return nothing. With RANDOM_DUMMY there will be a random(4) that
always blocks.
- Repair kern.arandom (KERN_ARND sysctl). The old version went
through arc4random(9) and was a bit weird.
- Adjust arc4random stirring a bit - the existing code looks a little
suspect.
- Fix the nasty pre- and post-read overloading by providing explictit
functions to do these tasks.
- Redo read_random(9) so as to duplicate random(4)'s read internals.
This makes it a first-class citizen rather than a hack.
- Move stuff out of locked regions when it does not need to be
there.
- Trim RANDOM_DEBUG printfs. Some are excess to requirement, some
behind boot verbose.
- Use SYSINIT to sequence the startup.
- Fix init/deinit sysctl stuff.
- Make relevant sysctls also tunables.
- Add different harvesting "styles" to allow for different requirements
(direct, queue, fast).
- Add harvesting of FFS atime events. This needs to be checked for
weighing down the FS code.
- Add harvesting of slab allocator events. This needs to be checked for
weighing down the allocator code.
- Fix the random(9) manpage.
- Loadable modules are not present for now. These will be re-engineered
when the dust settles.
- Use macros for locks.
- Fix comments.
* src/share/man/...
- Update the man pages.
* src/etc/...
- The startup/shutdown work is done in D2924.
* src/UPDATING
- Add UPDATING announcement.
* src/sys/dev/random/build.sh
- Add copyright.
- Add libz for unit tests.
* src/sys/dev/random/dummy.c
- Remove; no longer needed. Functionality incorporated into randomdev.*.
* live_entropy_sources.c live_entropy_sources.h
- Remove; content moved.
- move content to randomdev.[ch] and optimise.
* src/sys/dev/random/random_adaptors.c src/sys/dev/random/random_adaptors.h
- Remove; plugability is no longer used. Compile-time algorithm
selection is the way to go.
* src/sys/dev/random/random_harvestq.c src/sys/dev/random/random_harvestq.h
- Add early (re)boot-time randomness caching.
* src/sys/dev/random/randomdev_soft.c src/sys/dev/random/randomdev_soft.h
- Remove; no longer needed.
* src/sys/dev/random/uint128.h
- Provide a fake uint128_t; if a real one ever arrived, we can use
that instead. All that is needed here is N=0, N++, N==0, and some
localised trickery is used to manufacture a 128-bit 0ULLL.
* src/sys/dev/random/unit_test.c src/sys/dev/random/unit_test.h
- Improve unit tests; previously the testing human needed clairvoyance;
now the test will do a basic check of compressibility. Clairvoyant
talent is still a good idea.
- This is still a long way off a proper unit test.
* src/sys/dev/random/fortuna.c src/sys/dev/random/fortuna.h
- Improve messy union to just uint128_t.
- Remove unneeded 'static struct fortuna_start_cache'.
- Tighten up up arithmetic.
- Provide a method to allow eternal junk to be introduced; harden
it against blatant by compress/hashing.
- Assert that locks are held correctly.
- Fix the nasty pre- and post-read overloading by providing explictit
functions to do these tasks.
- Turn into self-sufficient module (no longer requires randomdev_soft.[ch])
* src/sys/dev/random/yarrow.c src/sys/dev/random/yarrow.h
- Improve messy union to just uint128_t.
- Remove unneeded 'staic struct start_cache'.
- Tighten up up arithmetic.
- Provide a method to allow eternal junk to be introduced; harden
it against blatant by compress/hashing.
- Assert that locks are held correctly.
- Fix the nasty pre- and post-read overloading by providing explictit
functions to do these tasks.
- Turn into self-sufficient module (no longer requires randomdev_soft.[ch])
- Fix some magic numbers elsewhere used as FAST and SLOW.
Differential Revision: https://reviews.freebsd.org/D2025
Reviewed by: vsevolod,delphij,rwatson,trasz,jmg
Approved by: so (delphij)
2015-06-30 17:00:45 +00:00
|
|
|
makeoptions MODULES_OVERRIDE="gpio ar71xx if_gif if_gre if_bridge bridgestp usb wlan wlan_xauth wlan_acl wlan_wep wlan_tkip wlan_ccmp wlan_rssadapt wlan_amrr ath ath_ahb hwpmc"
|
2011-04-03 13:19:58 +00:00
|
|
|
|
2014-03-18 14:41:18 +00:00
|
|
|
options DDB
|
|
|
|
options KDB
|
2012-03-12 20:32:23 +00:00
|
|
|
options ALQ
|
2011-04-03 13:19:58 +00:00
|
|
|
|
2015-03-28 06:54:18 +00:00
|
|
|
# For small memory footprints
|
|
|
|
options VM_KMEM_SIZE_SCALE=1
|
|
|
|
|
2014-03-18 14:41:18 +00:00
|
|
|
options SCHED_4BSD #4BSD scheduler
|
|
|
|
options INET #InterNETworking
|
|
|
|
options INET6 #InterNETworking
|
|
|
|
#options NFSCL #Network Filesystem Client
|
|
|
|
options PSEUDOFS #Pseudo-filesystem framework
|
|
|
|
options _KPOSIX_PRIORITY_SCHEDULING #Posix P1003_1B real-time extensions
|
2011-04-03 13:19:58 +00:00
|
|
|
|
2012-03-12 20:32:23 +00:00
|
|
|
# PMC
|
2014-03-18 14:41:18 +00:00
|
|
|
options HWPMC_HOOKS
|
2012-05-12 17:42:22 +00:00
|
|
|
device hwpmc
|
2012-11-17 04:11:57 +00:00
|
|
|
device hwpmc_mips24k
|
2012-03-12 20:32:23 +00:00
|
|
|
|
2014-03-18 14:41:18 +00:00
|
|
|
# options NFS_LEGACYRPC
|
2011-04-03 13:19:58 +00:00
|
|
|
# Debugging for use in -current
|
2014-03-18 14:41:18 +00:00
|
|
|
options INVARIANTS
|
|
|
|
options INVARIANT_SUPPORT
|
|
|
|
options WITNESS
|
|
|
|
options WITNESS_SKIPSPIN
|
|
|
|
options FFS #Berkeley Fast Filesystem
|
|
|
|
#options SOFTUPDATES #Enable FFS soft updates support
|
|
|
|
#options UFS_ACL #Support for access control lists
|
|
|
|
#options UFS_DIRHASH #Improve performance on big directories
|
|
|
|
options NO_FFS_SNAPSHOT # We don't require snapshot support
|
2011-04-03 13:19:58 +00:00
|
|
|
|
|
|
|
# Wireless NIC cards
|
2014-03-18 14:41:18 +00:00
|
|
|
options IEEE80211_DEBUG
|
|
|
|
options IEEE80211_SUPPORT_MESH
|
|
|
|
options IEEE80211_SUPPORT_TDMA
|
2012-03-12 20:32:23 +00:00
|
|
|
options IEEE80211_ALQ # 802.11 ALQ logging support
|
2011-04-28 12:52:01 +00:00
|
|
|
device wlan # 802.11 support
|
|
|
|
device wlan_wep # 802.11 WEP support
|
|
|
|
device wlan_ccmp # 802.11 CCMP support
|
|
|
|
device wlan_tkip # 802.11 TKIP support
|
|
|
|
device wlan_xauth # 802.11 hostap support
|
2011-04-03 13:19:58 +00:00
|
|
|
|
2012-03-12 20:32:23 +00:00
|
|
|
# ath(4)
|
|
|
|
device ath # Atheros network device
|
2011-04-28 12:52:01 +00:00
|
|
|
device ath_rate_sample
|
2012-03-12 20:32:23 +00:00
|
|
|
device ath_ahb # Atheros host bus glue
|
2011-04-03 13:19:58 +00:00
|
|
|
options ATH_DEBUG
|
2014-03-18 14:41:18 +00:00
|
|
|
options ATH_DIAGAPI
|
2011-04-28 12:52:01 +00:00
|
|
|
option ATH_ENABLE_11N
|
|
|
|
|
2011-11-24 04:34:04 +00:00
|
|
|
# Don't bother compiling the whole HAL - AH_SUPPORT_AR9130 breaks the
|
|
|
|
# rest of the 11n chipset support at the moment and the pre-AR5212
|
|
|
|
# HALs aren't required.
|
|
|
|
# device ath_hal
|
|
|
|
|
|
|
|
# The AR9130 code requires AR5416; and AR5416 requires the AR5212 code.
|
|
|
|
device ath_ar5212
|
|
|
|
device ath_ar5416
|
|
|
|
device ath_ar9130
|
2011-04-28 12:52:01 +00:00
|
|
|
|
2014-03-18 14:41:18 +00:00
|
|
|
options AH_DEBUG
|
2011-04-03 13:19:58 +00:00
|
|
|
option AH_SUPPORT_AR5416
|
2011-04-28 12:52:01 +00:00
|
|
|
option AH_SUPPORT_AR9130 # Makes other chipsets not function!
|
2012-03-12 20:32:23 +00:00
|
|
|
option AH_DEBUG_ALQ
|
2011-04-28 12:52:01 +00:00
|
|
|
# interrupt mitigation not possible on AR9130
|
|
|
|
# option AH_AR5416_INTERRUPT_MITIGATION
|
2011-04-03 13:19:58 +00:00
|
|
|
|
|
|
|
device mii
|
|
|
|
device arge
|
|
|
|
|
|
|
|
device usb
|
2014-03-18 14:41:18 +00:00
|
|
|
options USB_EHCI_BIG_ENDIAN_DESC # handle big-endian byte order
|
|
|
|
options USB_DEBUG
|
|
|
|
options USB_HOST_ALIGN=32 # AR71XX (MIPS in general?) requires this
|
2011-04-03 13:19:58 +00:00
|
|
|
device ehci
|
|
|
|
|
|
|
|
device scbus
|
|
|
|
device umass
|
|
|
|
device da
|
|
|
|
|
|
|
|
device spibus
|
|
|
|
device ar71xx_spi
|
|
|
|
device mx25l
|
|
|
|
device ar71xx_wdog
|
|
|
|
|
|
|
|
device uart
|
2012-11-17 04:05:46 +00:00
|
|
|
device uart_ar71xx
|
2011-04-03 13:19:58 +00:00
|
|
|
|
2015-01-06 07:43:07 +00:00
|
|
|
device ar71xx_apb
|
|
|
|
|
2011-04-03 13:19:58 +00:00
|
|
|
device loop
|
|
|
|
device ether
|
|
|
|
device md
|
|
|
|
device bpf
|
|
|
|
device random
|
|
|
|
device if_bridge
|
2011-12-15 01:05:38 +00:00
|
|
|
device gpio
|
|
|
|
device gpioled
|