From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:41138) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1QpNXL-0004ow-Bx for qemu-devel@nongnu.org; Fri, 05 Aug 2011 12:46:16 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1QpNXJ-0000Ak-Um for qemu-devel@nongnu.org; Fri, 05 Aug 2011 12:46:15 -0400 Message-ID: <4E3C1E51.3040003@codemonkey.ws> Date: Fri, 05 Aug 2011 11:46:09 -0500 From: Anthony Liguori MIME-Version: 1.0 References: <1312181399-29841-1-git-send-email-david@gibson.dropbear.id.au> In-Reply-To: <1312181399-29841-1-git-send-email-david@gibson.dropbear.id.au> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH] Check fread() results to avoid gcc 4.6 warnings List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: David Gibson Cc: qemu-trivial@nongnu.org, qemu-devel@nongnu.org On 08/01/2011 01:49 AM, David Gibson wrote: > When compiling with gcc 4.6, some code in fw_cfg.c complains that fop_ret > is assigned but not used (which is true). However, it looks like the > meaningless assignments to fop_ret were done to suppress other gcc warnings > due to the fact that fread() is labelled as warn_unused_result in glibc. > > This patch avoids both errors, by actually checking the fread() result code > and dropping out with an error message if it fails. > > Signed-off-by: David Gibson Applied. Thanks. Regards, Anthony Liguori > --- > hw/fw_cfg.c | 13 +++++++++++++ > 1 files changed, 13 insertions(+), 0 deletions(-) > > diff --git a/hw/fw_cfg.c b/hw/fw_cfg.c > index a29db90..e4847b7 100644 > --- a/hw/fw_cfg.c > +++ b/hw/fw_cfg.c > @@ -87,6 +87,13 @@ static FILE *probe_splashfile(char *filename, int *file_sizep, int *file_typep) > /* check magic ID */ > fseek(fp, 0L, SEEK_SET); > fop_ret = fread(buf, 1, 2, fp); > + if (fop_ret != 2) { > + error_report("Could not read header from '%s': %s", > + filename, strerror(errno)); > + fclose(fp); > + fp = NULL; > + return fp; > + } > filehead_value = (buf[0] + (buf[1]<< 8))& 0xffff; > if (filehead_value == 0xd8ff) { > file_type = JPG_FILE; > @@ -181,6 +188,12 @@ static void fw_cfg_bootsplash(FWCfgState *s) > boot_splash_filedata_size = file_size; > fseek(fp, 0L, SEEK_SET); > fop_ret = fread(boot_splash_filedata, 1, file_size, fp); > + if (fop_ret != file_size) { > + error_report("failed to read data from '%s'.", > + boot_splash_filename); > + fclose(fp); > + return; > + } > fclose(fp); > /* insert data */ > if (file_type == JPG_FILE) {