From: Harald Welte Date: Fri, 22 Oct 2004 08:14:07 +0000 (+0000) Subject: Fix module-autoloading in certain cases (Fixse Debian Bug 219686) X-Git-Tag: v1.3.0-rc1~38 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=10f7f1448314e59d7b536df7e097c5b48f2efd96;p=thirdparty%2Fiptables.git Fix module-autoloading in certain cases (Fixse Debian Bug 219686) --- diff --git a/ip6tables.c b/ip6tables.c index 4b81e782..7cdf4572 100644 --- a/ip6tables.c +++ b/ip6tables.c @@ -1595,15 +1595,17 @@ static char *get_modprobe(void) int procfile; char *ret; +#define PROCFILE_BUFSIZ 1024 procfile = open(PROC_SYS_MODPROBE, O_RDONLY); if (procfile < 0) return NULL; - ret = malloc(1024); + ret = malloc(PROCFILE_BUFSIZ); if (ret) { - switch (read(procfile, ret, 1024)) { + memset(ret, 0, PROCFILE_BUFSIZ); + switch (read(procfile, ret, PROCFILE_BUFSIZ)) { case -1: goto fail; - case 1024: goto fail; /* Partial read. Wierd */ + case PROCFILE_BUFSIZ: goto fail; /* Partial read. Wierd */ } if (ret[strlen(ret)-1]=='\n') ret[strlen(ret)-1]=0; diff --git a/iptables.c b/iptables.c index 91e6a9e6..12fe316d 100644 --- a/iptables.c +++ b/iptables.c @@ -1593,15 +1593,17 @@ static char *get_modprobe(void) int procfile; char *ret; +#define PROCFILE_BUFSIZ 1024 procfile = open(PROC_SYS_MODPROBE, O_RDONLY); if (procfile < 0) return NULL; - ret = malloc(1024); + ret = (char *) malloc(PROCFILE_BUFSIZ); if (ret) { - switch (read(procfile, ret, 1024)) { + memset(ret, 0, PROCFILE_BUFSIZ); + switch (read(procfile, ret, PROCFILE_BUFSIZ)) { case -1: goto fail; - case 1024: goto fail; /* Partial read. Wierd */ + case PROCFILE_BUFSIZ: goto fail; /* Partial read. Wierd */ } if (ret[strlen(ret)-1]=='\n') ret[strlen(ret)-1]=0;