diff options
author | David Hildenbrand <david@redhat.com> | 2018-11-21 17:44:14 +0100 |
---|---|---|
committer | Markus Armbruster <armbru@redhat.com> | 2018-12-13 19:10:06 +0100 |
commit | af02f4c5179675ad4e26b17ba26694a8fcde17fa (patch) | |
tree | 7b316a4e89c962284f479f604f4b2515b4cc4f97 /include | |
parent | ca28f5481607e5c59481e70e429f5dd23662cb69 (diff) | |
download | qemu-af02f4c5179675ad4e26b17ba26694a8fcde17fa.zip qemu-af02f4c5179675ad4e26b17ba26694a8fcde17fa.tar.gz qemu-af02f4c5179675ad4e26b17ba26694a8fcde17fa.tar.bz2 |
cutils: Fix qemu_strtosz() & friends to reject non-finite sizes
qemu_strtosz() & friends reject NaNs, but happily accept infinities.
They shouldn't. Fix that.
The fix makes use of qemu_strtod_finite(). To avoid ugly casts,
change the @end parameter of qemu_strtosz() & friends from char **
to const char **.
Also, add two test cases, testing that "inf" and "NaN" are properly
rejected. While at it, also fixup the function documentation.
Reviewed-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
Signed-off-by: David Hildenbrand <david@redhat.com>
Message-Id: <20181121164421.20780-3-david@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Diffstat (limited to 'include')
-rw-r--r-- | include/qemu/cutils.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/include/qemu/cutils.h b/include/qemu/cutils.h index 756b41c..d2dad30 100644 --- a/include/qemu/cutils.h +++ b/include/qemu/cutils.h @@ -153,9 +153,9 @@ int parse_uint(const char *s, unsigned long long *value, char **endptr, int base); int parse_uint_full(const char *s, unsigned long long *value, int base); -int qemu_strtosz(const char *nptr, char **end, uint64_t *result); -int qemu_strtosz_MiB(const char *nptr, char **end, uint64_t *result); -int qemu_strtosz_metric(const char *nptr, char **end, uint64_t *result); +int qemu_strtosz(const char *nptr, const char **end, uint64_t *result); +int qemu_strtosz_MiB(const char *nptr, const char **end, uint64_t *result); +int qemu_strtosz_metric(const char *nptr, const char **end, uint64_t *result); /* used to print char* safely */ #define STR_OR_NULL(str) ((str) ? (str) : "null") |