aboutsummaryrefslogtreecommitdiffstats
path: root/src/zrand.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2016-04-27 17:19:53 +0200
committerMattias Andrée <maandree@kth.se>2016-04-27 17:19:53 +0200
commite746f06265981fd17bc656ca59e0ed82f6cea84d (patch)
tree9161d4428b889f7aa4375988c4fdc29e1ab02ee2 /src/zrand.c
parentMinor word fix in STATUS (diff)
downloadlibzahl-e746f06265981fd17bc656ca59e0ed82f6cea84d.tar.gz
libzahl-e746f06265981fd17bc656ca59e0ed82f6cea84d.tar.bz2
libzahl-e746f06265981fd17bc656ca59e0ed82f6cea84d.tar.xz
Add option UNSAFE which disables all internal error checks
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'src/zrand.c')
-rw-r--r--src/zrand.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/zrand.c b/src/zrand.c
index f1913e1..079520e 100644
--- a/src/zrand.c
+++ b/src/zrand.c
@@ -104,7 +104,7 @@ zrand_fd(void *out, size_t n, void *statep)
while (n) {
read_just = read(fd, buf + read_total, n);
- if (unlikely(read_just < 0))
+ if (check(unlikely(read_just < 0)))
libzahl_failure(errno);
read_total += (size_t)read_just;
n -= (size_t)read_just;
@@ -141,7 +141,7 @@ zrand(z_t r, enum zranddev dev, enum zranddist dist, z_t n)
{
#define RANDOM_UNIFORM(RETRY)\
do {\
- if (unlikely(znegative(n)))\
+ if (check(unlikely(znegative(n))))\
libzahl_failure(-ZERROR_NEGATIVE);\
bits = zbits(n);\
do\
@@ -185,7 +185,7 @@ zrand(z_t r, enum zranddev dev, enum zranddist dist, z_t n)
if (pathname) {
fd = open(pathname, O_RDONLY);
- if (unlikely(fd < 0))
+ if (check(unlikely(fd < 0)))
libzahl_failure(errno);
statep = &fd;
}
@@ -209,7 +209,10 @@ zrand(z_t r, enum zranddev dev, enum zranddist dist, z_t n)
break;
default:
+#if !defined(UNSAFE)
libzahl_failure(EINVAL);
+#endif
+ break;
}
if (fd >= 0)