sandbox: fix return type of os_filesize()
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Wed, 5 Apr 2023 09:34:15 +0000 (11:34 +0200)
committerSimon Glass <sjg@chromium.org>
Fri, 28 Apr 2023 17:30:17 +0000 (11:30 -0600)
Given a file ../img of size 4294967296 with GPT partition table and
partitions:

=> host bind 0 ../img
=> part list host 0
Disk host-0.blk not ready

The cause is os_filesize() returning int. File sizes must use off_t.

Correct all uses of os_filesize() too.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
arch/sandbox/cpu/os.c
drivers/block/host_dev.c
include/os.h

index 5e66304e2b9dfdd544d99563b0a56b186d83e051..9e93a0fa571fb9d098b820226f21149e1e337b83 100644 (file)
@@ -166,7 +166,7 @@ int os_write_file(const char *fname, const void *buf, int size)
        return 0;
 }
 
-int os_filesize(int fd)
+off_t os_filesize(int fd)
 {
        off_t size;
 
@@ -218,7 +218,7 @@ err:
 int os_map_file(const char *pathname, int os_flags, void **bufp, int *sizep)
 {
        void *ptr;
-       int size;
+       off_t size;
        int ifd;
 
        ifd = os_open(pathname, os_flags);
@@ -231,6 +231,10 @@ int os_map_file(const char *pathname, int os_flags, void **bufp, int *sizep)
                printf("Cannot get file size of '%s'\n", pathname);
                return -EIO;
        }
+       if ((unsigned long long)size > (unsigned long long)SIZE_MAX) {
+               printf("File '%s' too large to map\n", pathname);
+               return -EIO;
+       }
 
        ptr = mmap(0, size, PROT_READ | PROT_WRITE, MAP_SHARED, ifd, 0);
        if (ptr == MAP_FAILED) {
index 5885fc358a54267202bc9252c3f04ae1cb49f86a..64422417b7496a2ba66d4b142fb9b6f19513c21f 100644 (file)
@@ -24,7 +24,8 @@ static int host_sb_attach_file(struct udevice *dev, const char *filename)
        struct host_sb_plat *plat = dev_get_plat(dev);
        struct blk_desc *desc;
        struct udevice *blk;
-       int ret, fd, size;
+       int ret, fd;
+       off_t size;
        char *fname;
 
        if (!filename)
index 0415f0f0e7a16d1981d690d94fdf418b4c443da0..968412b0a822914943751e503aa2e7f502f53ef8 100644 (file)
@@ -64,7 +64,7 @@ off_t os_lseek(int fd, off_t offset, int whence);
  * @fd:                File descriptor as returned by os_open()
  * Return:     file size or negative error code
  */
-int os_filesize(int fd);
+off_t os_filesize(int fd);
 
 /**
  * Access to the OS open() system call