From: Rich Felker Date: Fri, 17 Apr 2020 20:10:28 +0000 (-0400) Subject: combine two calls to memset in fmemopen X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=74fa4aac12d0d5a04ed411f2b3240f235a4475a1;p=oweals%2Fmusl.git combine two calls to memset in fmemopen this idea came up when I thought we might need to zero the UNGET portion of buf as well, but it seems like a useful improvement even when that turned out not to be necessary. --- diff --git a/src/stdio/fmemopen.c b/src/stdio/fmemopen.c index 5685092e..5afd85cf 100644 --- a/src/stdio/fmemopen.c +++ b/src/stdio/fmemopen.c @@ -2,6 +2,7 @@ #include #include #include +#include #include #include "libc.h" @@ -95,7 +96,7 @@ FILE *fmemopen(void *restrict buf, size_t size, const char *restrict mode) f = malloc(sizeof *f + (buf?0:size)); if (!f) return 0; - memset(&f->f, 0, sizeof f->f); + memset(f, 0, offsetof(struct mem_FILE, buf)); f->f.cookie = &f->c; f->f.fd = -1; f->f.lbf = EOF; @@ -106,7 +107,6 @@ FILE *fmemopen(void *restrict buf, size_t size, const char *restrict mode) memset(buf, 0, size); } - memset(&f->c, 0, sizeof f->c); f->c.buf = buf; f->c.size = size; f->c.mode = *mode;