From: Peter Maydell Date: Thu, 27 Jun 2013 14:03:51 +0000 (+0100) Subject: sd/pl181.c: Avoid undefined shift behaviour in RWORD macro X-Git-Tag: v1.6.0-rc0~132^2~4 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8827b0fb66cab9f7978c4e66dad4cf3c0989a72e;p=thirdparty%2Fqemu.git sd/pl181.c: Avoid undefined shift behaviour in RWORD macro Add a cast to avoid potentially shifting into the sign bit of a signed value, which is undefined behaviour in C. (Detected with clang's -fsanitize=undefined.) Signed-off-by: Peter Maydell Message-id: 1372341831-4264-1-git-send-email-peter.maydell@linaro.org --- diff --git a/hw/sd/pl181.c b/hw/sd/pl181.c index 4b1723418d3..f5eb1e40120 100644 --- a/hw/sd/pl181.c +++ b/hw/sd/pl181.c @@ -175,7 +175,7 @@ static void pl181_send_command(pl181_state *s) if (rlen < 0) goto error; if (s->cmd & PL181_CMD_RESPONSE) { -#define RWORD(n) ((response[n] << 24) | (response[n + 1] << 16) \ +#define RWORD(n) (((uint32_t)response[n] << 24) | (response[n + 1] << 16) \ | (response[n + 2] << 8) | response[n + 3]) if (rlen == 0 || (rlen == 4 && (s->cmd & PL181_CMD_LONGRESP))) goto error;