freebsd-dev/sys/mips/cavium
Mark Murray d1b06863fb 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
..
cryptocteon
octe CALLOUT_MPSAFE has lost its meaning since r141428, i.e., for more than ten 2015-05-22 17:05:21 +00:00
usb Add 64-bit DMA support in the XHCI controller driver. 2015-01-05 20:22:18 +00:00
asm_octeon.S
ciu.c Migrate ie->ie_assign_cpu and associated code to use an int for CPU rather 2014-09-17 17:33:22 +00:00
cvmx_config.h Turn on messages from the Simple Executive codebase, what few there are. 2012-03-29 02:05:11 +00:00
files.octeon1 Add preliminary Octeon PCI console support. Radisys-specific PCI console 2012-11-13 07:39:49 +00:00
if_octm.c Mechanically convert to if_inc_counter(). 2014-09-19 09:19:49 +00:00
obio.c
obiovar.h
octeon_cop2.h
octeon_cop2.S
octeon_ds1337.c Fix RTC clock writes on many Octeon boards. 2014-09-14 00:02:40 +00:00
octeon_ebt3000_cf.c Devices that rely on hints or identify routines for discovery need to 2013-10-29 14:07:31 +00:00
octeon_gpio.c Implement GPIO_GET_BUS() method for all GPIO drivers. 2015-01-31 19:32:14 +00:00
octeon_gpiovar.h Implement GPIO_GET_BUS() method for all GPIO drivers. 2015-01-31 19:32:14 +00:00
octeon_irq.h Remap PMC interrupt for all cores 2012-03-24 06:28:15 +00:00
octeon_machdep.c Merge from vmobj-rwlock branch: 2013-02-26 01:00:11 +00:00
octeon_mp.c
octeon_nmi.S
octeon_pci_console.c Add basic support for the Radisys-specific PCI console mechanism found on the 2012-11-19 01:58:20 +00:00
octeon_pcmap_regs.h Actually check board type rather than using a specialized octeon_is_simulation 2012-10-30 06:36:14 +00:00
octeon_pmc.c Devices that rely on hints or identify routines for discovery need to 2013-10-29 14:07:31 +00:00
octeon_rnd.c Huge cleanup of random(4) code. 2015-06-30 17:00:45 +00:00
octeon_rtc.c Devices that rely on hints or identify routines for discovery need to 2013-10-29 14:07:31 +00:00
octeon_wdog.c
octopci_bus_space.c Update NetBSD Foundation copyrights to 2-clause BSD 2014-03-18 01:40:25 +00:00
octopci.c Don't disable PCIe just because the host is not a PCI host; the latter flag 2012-11-01 20:39:39 +00:00
octopcireg.h
octopcivar.h
std.octeon1 Remove the gross hack for the Octeon Simple Executive to the least 2013-11-06 05:26:15 +00:00
uart_bus_octeonusart.c octeon_uart_class was removed some time ago everywhere but here. 2012-06-28 06:49:04 +00:00
uart_cpu_octeonusart.c Remove oct_read64 and oct_write64 and use their equivalents from the Simple 2012-10-30 06:29:17 +00:00
uart_dev_oct16550.c Add support for the uart classes to set their default register shift value. 2015-04-11 17:16:23 +00:00