Activity log for bug #1779955

Date Who What changed Old value New value Message
2018-07-03 22:32:02 Kan Li bug added bug
2018-07-03 22:32:02 Kan Li attachment added a.cpp https://bugs.launchpad.net/bugs/1779955/+attachment/5159341/+files/a.cpp
2018-07-03 22:35:00 Kan Li description When read() function takes an mmap'ed address as output buffer, it returns EFAULT. The expected behavior is it should just work. The following code works for qemu-system-arm, but not for qemu-arm-static. Steps to reproduce (please substitute /path/to/qemu-arm-static with the path of the binary, and /tmp/a.cpp with the example source code attached): # First register binfmt_misc [hidden]$ docker run --rm --privileged multiarch/qemu-user-static:register --reset # Compile the code and run [hidden]$ docker run --rm -it -v /tmp/a.cpp:/tmp/a.cpp -v /path/to/qemu-arm-static:/usr/bin/qemu-arm-static arm32v7/ubuntu:18.04 bash -c '{ apt update -y && apt install -y g++; } >& /dev/null && g++ -std=c++14 /tmp/a.cpp -o /tmp/a.out && echo hehe > /tmp/haha.txt && /tmp/a.out' ofd=3 ftruncate=0 mmap=0xff3f5000 fd=4 0xff3f5023 -1 14 The expected result in qemu-system-arm as well as natively on x86_64 host: hidden$ ./a.out ofd=3 ftruncate=0 mmap=0xb6fb7000 fd=4 0xb6fb7023 5 0 When read() function takes an mmap'ed address as output buffer, it returns EFAULT. The expected behavior is it should just work. The following code works for qemu-system-arm, but not for qemu-arm-static. QEMU version affected: latest release 2.12.0. Steps to reproduce (please substitute /path/to/qemu-arm-static with the path of the binary, and /tmp/a.cpp with the example source code attached): # First register binfmt_misc [hidden]$ docker run --rm --privileged multiarch/qemu-user-static:register --reset # Compile the code and run [hidden]$ docker run --rm -it -v /tmp/a.cpp:/tmp/a.cpp -v /path/to/qemu-arm-static:/usr/bin/qemu-arm-static arm32v7/ubuntu:18.04 bash -c '{ apt update -y && apt install -y g++; } >& /dev/null && g++ -std=c++14 /tmp/a.cpp -o /tmp/a.out && echo hehe > /tmp/haha.txt && /tmp/a.out' ofd=3 ftruncate=0 mmap=0xff3f5000 fd=4 0xff3f5023 -1 14 The expected result in qemu-system-arm as well as natively on x86_64 host: hidden$ ./a.out ofd=3 ftruncate=0 mmap=0xb6fb7000 fd=4 0xb6fb7023 5 0
2018-07-04 00:10:32 Kan Li tags arm
2018-07-04 00:12:43 Kan Li tags arm arm linux-user
2018-07-04 00:12:50 Kan Li tags arm linux-user arm linux-user qemu
2018-07-06 12:24:53 Peter Maydell summary qemu-arm-static read() doesn't accept mmap address as destination qemu linux-user requires read permissions on memory passed to syscalls that should only need write access
2018-07-06 12:25:02 Peter Maydell qemu: status New Confirmed
2021-04-29 09:53:25 Thomas Huth tags arm linux-user qemu arm linux-user
2021-05-11 05:14:43 Thomas Huth qemu: status Confirmed Incomplete
2021-07-11 04:17:18 Launchpad Janitor qemu: status Incomplete Expired
2021-07-11 09:07:20 Peter Maydell qemu: status Expired Confirmed
2021-07-11 10:01:45 Thomas Huth qemu: status Confirmed Expired
2021-07-11 10:01:46 Thomas Huth bug watch added https://gitlab.com/qemu-project/qemu/-/issues/470