aboutsummaryrefslogtreecommitdiff
path: root/fsdev/9p-marshal.c
diff options
context:
space:
mode:
authorDavid Hildenbrand <david@redhat.com>2023-09-06 14:04:59 +0200
committerDavid Hildenbrand <david@redhat.com>2023-09-19 10:23:21 +0200
commitca01f1b89b0884e39a58d8bc1d3fbd7ca91272a1 (patch)
tree86011512424971af15b75548a8229f95be1a7093 /fsdev/9p-marshal.c
parent4d6b23f7e2b7a34a6ab3b7c40693d8b1a0dee0b5 (diff)
downloadqemu-ca01f1b89b0884e39a58d8bc1d3fbd7ca91272a1.zip
qemu-ca01f1b89b0884e39a58d8bc1d3fbd7ca91272a1.tar.gz
qemu-ca01f1b89b0884e39a58d8bc1d3fbd7ca91272a1.tar.bz2
softmmu/physmem: Never return directories from file_ram_open()
open() does not fail on directories when opening them readonly (O_RDONLY). Currently, we succeed opening such directories and fail later during mmap(), resulting in a misleading error message. $ ./qemu-system-x86_64 \ -object memory-backend-file,id=ram0,mem-path=tmp,readonly=true,size=1g qemu-system-x86_64: unable to map backing store for guest RAM: No such device To identify directories and handle them accordingly in file_ram_open() also when readonly=true was specified, detect if we just opened a directory using fstat() instead. Then, fail file_ram_open() right away, similarly to how we now fail if the file does not exist and we want to open the file readonly. With this change, we get a nicer error message: qemu-system-x86_64: can't open backing store tmp for guest RAM: Is a directory Note that the only memory-backend-file will end up calling memory_region_init_ram_from_file() -> qemu_ram_alloc_from_file() -> file_ram_open(). Message-ID: <20230906120503.359863-8-david@redhat.com> Reported-by: Thiner Logoer <logoerthiner1@163.com> Reviewed-by: Peter Xu <peterx@redhat.com> Tested-by: Mario Casquero <mcasquer@redhat.com> Signed-off-by: David Hildenbrand <david@redhat.com>
Diffstat (limited to 'fsdev/9p-marshal.c')
0 files changed, 0 insertions, 0 deletions