From: Werner Fink Date: Fri, 7 Jul 2017 12:09:11 +0000 (+0200) Subject: Increase standard I/O buffer a lot to be able to X-Git-Tag: v4.0.0~706 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8af3db927439a43e428d51dcf71a72e1604b0cf7;p=procps-ng Increase standard I/O buffer a lot to be able to read huge informations at once as otherwise all files below /proc/sys, not using the seq_file API at the kernel side, will return EOF on a second read. Signed-off-by: Werner Fink --- diff --git a/sysctl.c b/sysctl.c index 5353511b..cb45ed81 100644 --- a/sysctl.c +++ b/sysctl.c @@ -156,6 +156,8 @@ static char *StripLeadingAndTrailingSpaces(char *oneline) /* * Read a sysctl setting */ +#define IOBUFSIZ (128<<10) +static char *iobuf; static int ReadSetting(const char *restrict const name) { int rc = 0; @@ -218,6 +220,9 @@ static int ReadSetting(const char *restrict const name) fp = fopen(tmpname, "r"); + if (iobuf) + setvbuf(fp, iobuf, _IOFBF, IOBUFSIZ); + if (!fp) { switch (errno) { case ENOENT: @@ -428,6 +433,9 @@ static int WriteSetting(const char *setting) fp = fopen(tmpname, "w"); + if (iobuf) + setvbuf(fp, iobuf, _IOFBF, IOBUFSIZ); + if (!fp) { switch (errno) { case ENOENT: @@ -791,6 +799,8 @@ int main(int argc, char *argv[]) argc -= optind; argv += optind; + iobuf = (char*)malloc(IOBUFSIZ); /* Allow to fail */ + if (DisplayAllOpt) return DisplayAll(PROC_PATH);