Searched hist:"7 bf36a5c5276c4dc7926a0bc2e5ebbd93eedac41" (Results 1 – 1 of 1) sorted by relevance
/openbmc/qemu/linux-user/ |
H A D | syscall_defs.h | diff 7bf36a5c5276c4dc7926a0bc2e5ebbd93eedac41 Thu Oct 06 05:07:10 CDT 2022 WANG Xuerui <xen0n@gentoo.org> linux-user: Fix struct statfs ABI on loongarch64
Previously the 32-bit version was incorrectly chosen, leading to funny but incorrect output from e.g. df(1). Simply select the version corresponding to the 64-bit asm-generic definition.
For reference, this program should produce the same output no matter natively compiled or not, for loongarch64 or not:
```c #include <stdio.h> #include <sys/statfs.h>
int main(int argc, const char *argv[]) { struct statfs b; if (statfs(argv[0], &b)) return 1;
printf("f_type = 0x%lx\n", b.f_type); printf("f_bsize = %ld\n", b.f_bsize); printf("f_blocks = %ld\n", b.f_blocks); printf("f_bfree = %ld\n", b.f_bfree); printf("f_bavail = %ld\n", b.f_bavail);
return 0; }
// Example output on my amd64 box, with the test binary residing on a // btrfs partition.
// Native and emulated output after the fix: // // f_type = 0x9123683e // f_bsize = 4096 // f_blocks = 268435456 // f_bfree = 168406890 // f_bavail = 168355058
// Output before the fix, note the messed layout: // // f_type = 0x10009123683e // f_bsize = 723302085239504896 // f_blocks = 168355058 // f_bfree = 2250817541779750912 // f_bavail = 1099229433104 ```
Fixes: 1f63019632 ("linux-user: Add LoongArch syscall support") Signed-off-by: WANG Xuerui <xen0n@gentoo.org> Cc: Song Gao <gaosong@loongson.cn> Cc: Xiaojuan Yang <yangxiaojuan@loongson.cn> Cc: Andreas K. Hüttel <dilfridge@gentoo.org> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Tested-by: Andreas K. Huettel <dilfridge@gentoo.org> Message-Id: <20221006100710.427252-1-xen0n@gentoo.org> Signed-off-by: Song Gao <gaosong@loongson.cn>
|