mirror of https://gitee.com/openkylin/linux.git
70 lines
2.6 KiB
Plaintext
70 lines
2.6 KiB
Plaintext
|
Hardware driver for Intel/AMD/VIA Random Number Generators (RNG)
|
||
|
Copyright 2000,2001 Jeff Garzik <jgarzik@pobox.com>
|
||
|
Copyright 2000,2001 Philipp Rumpf <prumpf@mandrakesoft.com>
|
||
|
|
||
|
Introduction:
|
||
|
|
||
|
The hw_random device driver is software that makes use of a
|
||
|
special hardware feature on your CPU or motherboard,
|
||
|
a Random Number Generator (RNG).
|
||
|
|
||
|
In order to make effective use of this device driver, you
|
||
|
should download the support software as well. Download the
|
||
|
latest version of the "rng-tools" package from the
|
||
|
hw_random driver's official Web site:
|
||
|
|
||
|
http://sourceforge.net/projects/gkernel/
|
||
|
|
||
|
About the Intel RNG hardware, from the firmware hub datasheet:
|
||
|
|
||
|
The Firmware Hub integrates a Random Number Generator (RNG)
|
||
|
using thermal noise generated from inherently random quantum
|
||
|
mechanical properties of silicon. When not generating new random
|
||
|
bits the RNG circuitry will enter a low power state. Intel will
|
||
|
provide a binary software driver to give third party software
|
||
|
access to our RNG for use as a security feature. At this time,
|
||
|
the RNG is only to be used with a system in an OS-present state.
|
||
|
|
||
|
Theory of operation:
|
||
|
|
||
|
Character driver. Using the standard open()
|
||
|
and read() system calls, you can read random data from
|
||
|
the hardware RNG device. This data is NOT CHECKED by any
|
||
|
fitness tests, and could potentially be bogus (if the
|
||
|
hardware is faulty or has been tampered with). Data is only
|
||
|
output if the hardware "has-data" flag is set, but nevertheless
|
||
|
a security-conscious person would run fitness tests on the
|
||
|
data before assuming it is truly random.
|
||
|
|
||
|
/dev/hwrandom is char device major 10, minor 183.
|
||
|
|
||
|
Driver notes:
|
||
|
|
||
|
* FIXME: support poll(2)
|
||
|
|
||
|
NOTE: request_mem_region was removed, for two reasons:
|
||
|
1) Only one RNG is supported by this driver, 2) The location
|
||
|
used by the RNG is a fixed location in MMIO-addressable memory,
|
||
|
3) users with properly working BIOS e820 handling will always
|
||
|
have the region in which the RNG is located reserved, so
|
||
|
request_mem_region calls always fail for proper setups.
|
||
|
However, for people who use mem=XX, BIOS e820 information is
|
||
|
-not- in /proc/iomem, and request_mem_region(RNG_ADDR) can
|
||
|
succeed.
|
||
|
|
||
|
Driver details:
|
||
|
|
||
|
Based on:
|
||
|
Intel 82802AB/82802AC Firmware Hub (FWH) Datasheet
|
||
|
May 1999 Order Number: 290658-002 R
|
||
|
|
||
|
Intel 82802 Firmware Hub: Random Number Generator
|
||
|
Programmer's Reference Manual
|
||
|
December 1999 Order Number: 298029-001 R
|
||
|
|
||
|
Intel 82802 Firmware HUB Random Number Generator Driver
|
||
|
Copyright (c) 2000 Matt Sottek <msottek@quiknet.com>
|
||
|
|
||
|
Special thanks to Matt Sottek. I did the "guts", he
|
||
|
did the "brains" and all the testing.
|