aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Maydell <peter.maydell@linaro.org>2018-05-14 18:46:16 +0100
committerLaurent Vivier <laurent@vivier.eu>2018-05-24 20:46:54 +0200
commit75578d6fcedc55b85b44dfc83f506b74c32b7395 (patch)
tree25734ae87abd2de29adf898baead6da15ac56ca2
parent62b9b076d9d37117696ec64f0b3544c1205ff7f9 (diff)
downloadqemu-75578d6fcedc55b85b44dfc83f506b74c32b7395.zip
qemu-75578d6fcedc55b85b44dfc83f506b74c32b7395.tar.gz
qemu-75578d6fcedc55b85b44dfc83f506b74c32b7395.tar.bz2
linux-user: Assert on bad type in thunk_type_align() and thunk_type_size()
In thunk_type_align() and thunk_type_size() we currently return -1 if the value at the type_ptr isn't one of the TYPE_* values we understand. However, this should never happen, and if it does then the calling code will go confusingly wrong because none of the callsites try to handle an error return. Switch to an assertion instead, so that if this does somehow happen we'll have a nice clear backtrace of what happened rather than a weird crash or misbehaviour. This also silences various Coverity complaints about not handling the negative return value (CID 1005735, 1005736, 1005738, 1390582). Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Message-Id: <20180514174616.19601-1-peter.maydell@linaro.org> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
-rw-r--r--include/exec/user/thunk.h4
1 files changed, 2 insertions, 2 deletions
diff --git a/include/exec/user/thunk.h b/include/exec/user/thunk.h
index 8f55b23..8d3af5a 100644
--- a/include/exec/user/thunk.h
+++ b/include/exec/user/thunk.h
@@ -135,7 +135,7 @@ static inline int thunk_type_size(const argtype *type_ptr, int is_host)
se = struct_entries + type_ptr[1];
return se->size[is_host];
default:
- return -1;
+ g_assert_not_reached();
}
}
@@ -185,7 +185,7 @@ static inline int thunk_type_align(const argtype *type_ptr, int is_host)
se = struct_entries + type_ptr[1];
return se->align[is_host];
default:
- return -1;
+ g_assert_not_reached();
}
}