linux/include/asm-um
Jeff Dike 5d33e4d7fd uml: random driver fixes
The random driver would essentially hang if the host's /dev/random returned
-EAGAIN.  There was a test of need_resched followed by a schedule inside the
loop, but that didn't help and it's the wrong way to work anyway.

The right way is to ask for an interrupt when there is input available from
the host and handle it then rather than polling.

Now, when the host's /dev/random returns -EAGAIN, the driver asks for a wakeup
when there's randomness available again and sleeps.  The interrupt routine
just wakes up whatever processes are sleeping on host_read_wait.

There is an atomic_t, host_sleep_count, which counts the number of processes
waiting for randomness.  When this reaches zero, the interrupt is disabled.

An added complication is that async I/O notification was only recently added
to /dev/random (by me), so essentially all hosts will lack it.  So, we use the
sigio workaround here, which is to have a separate thread poll on the
descriptor and send an interrupt when there is input on it.  This mechanism is
activated when a process gets -EAGAIN (activating this multiple times is
harmless, if a bit wasteful) and deactivated by the last process still
waiting.

The module name was changed from "random" to "hw_random" in order for udev to
recognize it.

The sigio workaround needed some changes.  sigio_broken was added for cases
when we know that async notification doesn't work.  This is now called from
maybe_sigio_broken, which deals with pts devices.

Signed-off-by: Jeff Dike <jdike@linux.intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-05-13 08:02:22 -07:00
..
a.out-core.h aout: suppress A.OUT library support if !CONFIG_ARCH_SUPPORTS_AOUT 2008-02-08 09:22:30 -08:00
a.out.h aout: move STACK_TOP[_MAX] to asm/processor.h 2008-02-08 09:22:29 -08:00
alternative-asm.h x86: rename .i assembler includes to .h 2007-10-17 20:16:29 +02:00
alternative.h
apic.h
archparam-i386.h
archparam-ppc.h
archparam-x86_64.h
asm.h uml: add asm-um/asm.h 2008-01-30 13:31:17 +01:00
atomic.h
auxvec.h
bitops.h forbid asm/bitops.h direct inclusion 2007-10-19 11:53:41 -07:00
boot.h
bug.h
bugs.h
byteorder.h
cache.h
cacheflush.h
calling.h
checksum.h
cmpxchg.h
cobalt.h
common.lds.S
cpufeature.h
cputime.h
current.h uml: current.h cleanup 2008-02-05 09:44:28 -08:00
delay.h
desc.h
device.h
div64.h rename div64_64 to div64_u64 2008-05-01 08:03:58 -07:00
dma-mapping.h
dma.h
dwarf2.h
elf-i386.h uml: style cleanup 2008-02-05 09:44:28 -08:00
elf-ppc.h
elf-x86_64.h uml: header untangling 2008-02-05 09:44:28 -08:00
emergency-restart.h
errno.h
fcntl.h
fixmap.h uml: runtime host VMSPLIT detection 2008-02-08 09:22:42 -08:00
floppy.h
frame.h x86: rename .i assembler includes to .h 2007-10-17 20:16:29 +02:00
futex.h
hardirq.h
highmem.h
host_ldt-i386.h
host_ldt-x86_64.h
hw_irq.h
ide.h
io.h
ioctl.h
ioctls.h
ipcbuf.h
irq_regs.h
irq_vectors.h
irq.h uml: random driver fixes 2008-05-13 08:02:22 -07:00
irqflags.h
kdebug.h
kmap_types.h
kvm.h kvm: provide kvm.h for all architecture: fixes headers_install 2008-04-02 15:28:18 -07:00
ldt.h uml: LDT mutex conversion 2008-02-05 09:44:31 -08:00
linkage.h uml: get rid of asmlinkage 2008-02-05 09:44:25 -08:00
local.h
locks.h
mca_dma.h
mman.h
mmu_context.h uml: cover stubs with a VMA 2008-02-05 09:44:29 -08:00
mmu.h
module-generic.h
module-i386.h
module-x86_64.h
msgbuf.h
mtrr.h
mutex.h
namei.h
nops.h git-x86: unbreak UML 2008-01-30 13:32:38 +01:00
page_offset.h
page.h uml: use PAGE_SIZE in linker scripts 2008-05-13 08:02:22 -07:00
param.h uml: add back CONFIG_HZ 2008-02-05 09:44:31 -08:00
paravirt.h
pci.h
pda.h
percpu.h
pgalloc.h CONFIG_HIGHPTE vs. sub-page page tables. 2008-02-08 09:22:42 -08:00
pgtable-2level.h uml: 64-bit tlb fixes 2008-02-05 09:44:29 -08:00
pgtable-3level.h uml: 64-bit tlb fixes 2008-02-05 09:44:29 -08:00
pgtable.h mm: introduce pte_special pte bit 2008-04-28 08:58:23 -07:00
poll.h
posix_types.h
prctl.h
processor-generic.h uml: runtime host VMSPLIT detection 2008-02-08 09:22:42 -08:00
processor-i386.h uml: remove xmm checking on x86 2008-02-05 09:44:24 -08:00
processor-ppc.h
processor-x86_64.h uml: x86_64 should copy %fs during fork 2008-02-08 09:22:43 -08:00
ptrace-generic.h uml: ptrace floating point fixes 2007-10-16 09:43:07 -07:00
ptrace-i386.h uml: ptrace floating point fixes 2007-10-16 09:43:07 -07:00
ptrace-x86_64.h uml: remove code made redundant by CHOOSE_MODE removal 2007-10-16 09:43:05 -07:00
required-features.h
resource.h
rwlock.h
rwsem.h
scatterlist.h
sections.h
segment.h
semaphore.h Generic semaphore implementation 2008-04-17 10:42:34 -04:00
sembuf.h
serial.h
setup.h
shmbuf.h
shmparam.h
sigcontext-generic.h
sigcontext-i386.h
sigcontext-ppc.h
sigcontext-x86_64.h
siginfo.h
signal.h
smp.h uml: fix inlines 2007-10-16 09:43:06 -07:00
socket.h
sockios.h
spinlock_types.h
spinlock.h
stat.h
statfs.h
string.h
suspend.h
system-generic.h
system-i386.h
system-ppc.h
system-x86_64.h
termbits.h
termios.h
thread_info.h uml: current.h cleanup 2008-02-05 09:44:28 -08:00
timex.h
tlb.h uml: compile error fix 2008-04-15 19:35:40 -07:00
tlbflush.h remove unused flush_tlb_pgtables 2007-10-19 11:53:34 -07:00
topology.h
types.h
uaccess.h uml: header untangling 2008-02-05 09:44:28 -08:00
ucontext.h
unaligned.h kernel: Move arches to use common unaligned access 2008-04-29 08:06:27 -07:00
unistd.h x86 merge fallout: uml 2007-10-29 07:41:32 -07:00
user.h
vga.h
vm86.h
vm-flags-i386.h
vm-flags-x86_64.h
xor.h