util: Detect more I/O errors
Many of GRUB's utilities don't check anywhere near all the possible write errors. For example, if grub-install runs out of space when copying a file, it won't notice. There were missing checks for the return values of write, fflush, fsync, and close (or the equivalents on other OSes), all of which must be checked. I tried to be consistent with the existing logging practices of the various hostdisk implementations, but they weren't entirely consistent to start with so I used my judgement. The result at least looks reasonable on GNU/Linux when I provoke a write error: Installing for x86_64-efi platform. grub-install: error: cannot copy `/usr/lib/grub/x86_64-efi-signed/grubx64.efi.signed' to `/boot/efi/EFI/debian/grubx64.efi': No space left on device. There are more missing checks in other utilities, but this should fix the most critical ones. Fixes Debian bug #922741. Signed-off-by: Colin Watson <cjwatson@ubuntu.com> Reviewed-by: Steve McIntyre <93sam@debian.org> Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
This commit is contained in:
parent
222cb8f6df
commit
62daa27056
10 changed files with 90 additions and 45 deletions
|
@ -275,11 +275,18 @@ grub_util_fd_write (grub_util_fd_t fd, const char *buf, size_t len)
|
|||
|
||||
static int allow_fd_syncs = 1;
|
||||
|
||||
void
|
||||
int
|
||||
grub_util_fd_sync (grub_util_fd_t fd)
|
||||
{
|
||||
if (allow_fd_syncs)
|
||||
FlushFileBuffers (fd);
|
||||
{
|
||||
if (!FlushFileBuffers (fd))
|
||||
{
|
||||
grub_util_info ("flush err %x", (int) GetLastError ());
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -288,10 +295,15 @@ grub_util_disable_fd_syncs (void)
|
|||
allow_fd_syncs = 0;
|
||||
}
|
||||
|
||||
void
|
||||
int
|
||||
grub_util_fd_close (grub_util_fd_t fd)
|
||||
{
|
||||
CloseHandle (fd);
|
||||
if (!CloseHandle (fd))
|
||||
{
|
||||
grub_util_info ("close err %x", (int) GetLastError ());
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
const char *
|
||||
|
@ -620,16 +632,25 @@ grub_util_fopen (const char *path, const char *mode)
|
|||
return ret;
|
||||
}
|
||||
|
||||
void
|
||||
int
|
||||
grub_util_file_sync (FILE *f)
|
||||
{
|
||||
HANDLE hnd;
|
||||
|
||||
fflush (f);
|
||||
if (fflush (f) != 0)
|
||||
{
|
||||
grub_util_info ("fflush err %x", (int) GetLastError ());
|
||||
return -1;
|
||||
}
|
||||
if (!allow_fd_syncs)
|
||||
return;
|
||||
return 0;
|
||||
hnd = (HANDLE) _get_osfhandle (fileno (f));
|
||||
FlushFileBuffers (hnd);
|
||||
if (!FlushFileBuffers (hnd))
|
||||
{
|
||||
grub_util_info ("flush err %x", (int) GetLastError ());
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue