[U-Boot] [PATCH 3/8] x86: ifdtool: Display filename when file errors are reported

Simon Glass sjg at chromium.org
Tue Dec 16 06:03:22 CET 2014


On 15 December 2014 at 02:23, Bin Meng <bmeng.cn at gmail.com> wrote:
> On Mon, Dec 15, 2014 at 8:15 AM, Simon Glass <sjg at chromium.org> wrote:
>> When a file is missing it helps to know which file. Update the error message
>> to print this information.
>>
>> Signed-off-by: Simon Glass <sjg at chromium.org>
>> ---
>>
>>  tools/ifdtool.c | 30 ++++++++++++++++++------------
>>  1 file changed, 18 insertions(+), 12 deletions(-)
>>
>> diff --git a/tools/ifdtool.c b/tools/ifdtool.c
>> index 4cdfdcc..8afb6b5 100644
>> --- a/tools/ifdtool.c
>> +++ b/tools/ifdtool.c
>> @@ -465,6 +465,16 @@ static int write_regions(char *image, int size)
>>         return ret;
>>  }
>>
>> +static int perror_fname(const char *fmt, const char *fname)
>> +{
>> +       char msg[strlen(fmt) + strlen(fname) + 1];
>> +
>> +       sprintf(msg, fmt, fname);
>> +       perror(msg);
>> +
>> +       return -1;
>> +}
>> +
>>  /**
>>   * write_image() - Write the image to a file
>>   *
>> @@ -481,10 +491,10 @@ static int write_image(char *filename, char *image, int size)
>>
>>         new_fd = open(filename, O_WRONLY | O_CREAT | O_TRUNC, S_IRUSR |
>>                       S_IWUSR | S_IRGRP | S_IROTH);
>> -       if (write(new_fd, image, size) != size) {
>> -               perror("Error while writing");
>> -               return -1;
>> -       }
>> +       if (new_fd < 0)
>> +               return perror_fname("Could not open file '%s'", filename);
>> +       if (write(new_fd, image, size) != size)
>> +               return perror_fname("Could not write file '%s'", filename);
>>         close(new_fd);
>>
>>         return 0;
>> @@ -586,14 +596,10 @@ int open_for_read(const char *fname, int *sizep)
>>         int fd = open(fname, O_RDONLY);
>>         struct stat buf;
>>
>> -       if (fd == -1) {
>> -               perror("Could not open file");
>> -               return -1;
>> -       }
>> -       if (fstat(fd, &buf) == -1) {
>> -               perror("Could not stat file");
>> -               return -1;
>> -       }
>> +       if (fd == -1)
>> +               return perror_fname("Could not open file '%s'", fname);
>> +       if (fstat(fd, &buf) == -1)
>> +               return perror_fname("Could not stat file '%s'", fname);
>>         *sizep = buf.st_size;
>>         debug("File %s is %d bytes\n", fname, *sizep);
>>
>> --
>
> Reviewed-by: Bin Meng <bmeng.cn at gmail.com>

Applied to u-boot-x86.


More information about the U-Boot mailing list