summaryrefslogtreecommitdiff
path: root/mail
diff options
context:
space:
mode:
authortoshii <toshii@pkgsrc.org>2004-02-29 03:45:37 +0000
committertoshii <toshii@pkgsrc.org>2004-02-29 03:45:37 +0000
commit99c404f7c3b268a7b4f0ac7abce9f7a914faee06 (patch)
tree4bb45e22561c80ee0d14d87d790c9e87673effcb /mail
parentd6f353e14ecd49b42a41aa6b0f50d4c185664674 (diff)
downloadpkgsrc-99c404f7c3b268a7b4f0ac7abce9f7a914faee06.tar.gz
Fread(2)ing /dev/urandom is bad due to libc buffering.
Use read(2) instead.
Diffstat (limited to 'mail')
-rw-r--r--mail/clamav/distinfo3
-rw-r--r--mail/clamav/patches/patch-ac35
2 files changed, 37 insertions, 1 deletions
diff --git a/mail/clamav/distinfo b/mail/clamav/distinfo
index 738f34a6685..76b259ab664 100644
--- a/mail/clamav/distinfo
+++ b/mail/clamav/distinfo
@@ -1,7 +1,8 @@
-$NetBSD: distinfo,v 1.7 2004/02/11 10:55:49 recht Exp $
+$NetBSD: distinfo,v 1.8 2004/02/29 03:46:22 toshii Exp $
SHA1 (clamav-0.66.tar.gz) = 1a008d33f8e2caf54708b952747e5a5266610cfc
Size (clamav-0.66.tar.gz) = 2275692 bytes
SHA1 (patch-aa) = 779aef1a73f78749e1e6b9ed5e5fd6eb0d537a41
SHA1 (patch-ab) = 49f80b512704fec57c6b920d2625c083c756f957
+SHA1 (patch-ac) = cab02632217fe4d75c0b48d0fd962d7822c3617d
SHA1 (patch-ad) = 6f2bfa05bb3421280272719c03260784a7826e91
diff --git a/mail/clamav/patches/patch-ac b/mail/clamav/patches/patch-ac
new file mode 100644
index 00000000000..810ab8a6dfb
--- /dev/null
+++ b/mail/clamav/patches/patch-ac
@@ -0,0 +1,35 @@
+$NetBSD: patch-ac,v 1.3 2004/02/29 03:45:37 toshii Exp $
+
+--- libclamav/others.c.orig Wed Feb 11 08:03:01 2004
++++ libclamav/others.c
+@@ -261,13 +261,13 @@
+
+ unsigned int cl_rndnum(unsigned int max)
+ {
+- FILE *fd;
++ int fd;
+ unsigned int generated;
+ char *byte;
+ int size;
+
+
+- if((fd = fopen("/dev/urandom", "rb")) == NULL) {
++ if((fd = open("/dev/urandom", O_RDONLY)) < 0) {
+ cli_errmsg("!Can't open /dev/urandom.\n");
+ return -1;
+ }
+@@ -276,12 +276,12 @@
+ size = sizeof(generated);
+ do {
+ int bread;
+- bread = fread(byte, 1, size, fd);
++ bread = read(fd, byte, size);
+ size -= bread;
+ byte += bread;
+ } while(size > 0);
+
+- fclose(fd);
++ close(fd);
+ return generated % max;
+ }
+ #endif