summary refs log tree commit diff stats
path: root/results/classifier/gemma3:27b/syscall/602
blob: 05132daf5bdce25b945e24b2b7874e24511a52f0 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Failure to translate host to target errno in IP_RECVERR, IPV6_RECVERR emulation
Description of problem:
In translated IP_RECVERR (and IPV6_RECVERR) control messages, the `ee_errno` is not translated, so host errnos are observed on guests.  E.g., `ECONNREFUSED` is 111 on x86_64 host, but expected to be 146 in MIPS ABI.
Steps to reproduce:
1. https://cirrus-ci.com/task/5914289870471168
Additional information:
The bugs are on [lines 1970 and 2014 here](https://github.com/qemu/qemu/blob/211364c21e7f757ae1acf4e72b5df39c498fb88b/linux-user/syscall.c#L1970-L2014).

The fix is something like:

```
__put_user(host_to_target_errno(errh->ee.ee_errno), &target_errh->ee.ee_errno);
```