hw/char/sh_serial: Do not abort on invalid access

Replace fprintf with qemu_log_mask LOG_GUEST_ERROR as the intention is
to handle valid accesses in these functions so if we get to these
errors then it's an invalid access. Do not abort as that would allow
the guest to crash QEMU and the practice in other devices is to not do
that just log and ignore the invalid access. While at it also simplify
the complex bit ops to check if a return value was set which can be
done much simpler and clearer.

Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <6b46045141d6d9cc32e17c223896fa1116384796.1635541329.git.balaton@eik.bme.hu>
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
This commit is contained in:
BALATON Zoltan 2021-10-29 23:02:09 +02:00 committed by Philippe Mathieu-Daudé
parent 6e5dd76f21
commit 3cf7ce4337

View File

@ -31,6 +31,7 @@
#include "chardev/char-fe.h" #include "chardev/char-fe.h"
#include "qapi/error.h" #include "qapi/error.h"
#include "qemu/timer.h" #include "qemu/timer.h"
#include "qemu/log.h"
#include "trace.h" #include "trace.h"
#define SH_SERIAL_FLAG_TEND (1 << 0) #define SH_SERIAL_FLAG_TEND (1 << 0)
@ -195,17 +196,16 @@ static void sh_serial_write(void *opaque, hwaddr offs,
return; return;
} }
} }
qemu_log_mask(LOG_GUEST_ERROR,
fprintf(stderr, "sh_serial: unsupported write to 0x%02" "%s: unsupported write to 0x%02" HWADDR_PRIx "\n",
HWADDR_PRIx "\n", offs); __func__, offs);
abort();
} }
static uint64_t sh_serial_read(void *opaque, hwaddr offs, static uint64_t sh_serial_read(void *opaque, hwaddr offs,
unsigned size) unsigned size)
{ {
sh_serial_state *s = opaque; sh_serial_state *s = opaque;
uint32_t ret = ~0; uint32_t ret = UINT32_MAX;
#if 0 #if 0
switch (offs) { switch (offs) {
@ -299,10 +299,11 @@ static uint64_t sh_serial_read(void *opaque, hwaddr offs,
} }
trace_sh_serial_read(size, offs, ret); trace_sh_serial_read(size, offs, ret);
if (ret & ~((1 << 16) - 1)) { if (ret > UINT16_MAX) {
fprintf(stderr, "sh_serial: unsupported read from 0x%02" qemu_log_mask(LOG_GUEST_ERROR,
HWADDR_PRIx "\n", offs); "%s: unsupported read from 0x%02" HWADDR_PRIx "\n",
abort(); __func__, offs);
ret = 0;
} }
return ret; return ret;