diff options
author | 2008-10-15 03:30:57 +0000 | |
---|---|---|
committer | 2008-10-15 03:30:57 +0000 | |
commit | e05b37f5025e432d317e7022be2804b3e047a2df (patch) | |
tree | cf386fb3bf43de8c5b532cbc55733d2a3669f03c | |
parent | Sh capitalization (diff) | |
download | wireguard-openbsd-e05b37f5025e432d317e7022be2804b3e047a2df.tar.xz wireguard-openbsd-e05b37f5025e432d317e7022be2804b3e047a2df.zip |
kernel/5592: yield() between copying out large chunks of random data to
userspace - mitigates an effective DoS since generating these can hog
the CPU at splhigh()
feedback & ok tedu@ deraadt@
-rw-r--r-- | sys/dev/rnd.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/sys/dev/rnd.c b/sys/dev/rnd.c index d8d62fa92b7..9bb08acc845 100644 --- a/sys/dev/rnd.c +++ b/sys/dev/rnd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rnd.c,v 1.94 2008/10/10 20:13:11 deraadt Exp $ */ +/* $OpenBSD: rnd.c,v 1.95 2008/10/15 03:30:57 djm Exp $ */ /* * rnd.c -- A strong random number generator @@ -1057,8 +1057,11 @@ randomread(dev_t dev, struct uio *uio, int ioflag) default: ret = ENXIO; } - if (n != 0 && ret == 0) + if (n != 0 && ret == 0) { ret = uiomove((caddr_t)buf, n, uio); + if (!ret && uio->uio_resid > 0) + yield(); + } } free(buf, M_TEMP); |