mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 16:23:55 -06:00
cutils: Adjust signature of parse_uint[_full]
It's already confusing that we have two very similar functions for wrapping the parse of a 64-bit unsigned value, differing mainly on whether they permit leading '-'. Adjust the signature of parse_uint() and parse_uint_full() to be like all of qemu_strto*(): put the result parameter last, use the same types (uint64_t and unsigned long long have the same width, but are not always the same type), and mark endptr const (this latter change only affects the rare caller of parse_uint). Adjust all callers in the tree. While at it, note that since cutils.c already includes: QEMU_BUILD_BUG_ON(sizeof(int64_t) != sizeof(long long)); we are guaranteed that the result of parse_uint* cannot exceed UINT64_MAX (or the build would have failed), so we can drop pre-existing dead comparisons in opts-visitor.c that were never false. Reviewed-by: Hanna Czenczek <hreitz@redhat.com> Message-Id: <20230522190441.64278-8-eblake@redhat.com> [eblake: Drop dead code spotted by Markus] Signed-off-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
84760bbca9
commit
bd1386cce1
12 changed files with 86 additions and 101 deletions
|
@ -454,8 +454,8 @@ opts_type_uint64(Visitor *v, const char *name, uint64_t *obj, Error **errp)
|
|||
OptsVisitor *ov = to_ov(v);
|
||||
const QemuOpt *opt;
|
||||
const char *str;
|
||||
unsigned long long val;
|
||||
char *endptr;
|
||||
uint64_t val;
|
||||
const char *endptr;
|
||||
|
||||
if (ov->list_mode == LM_UNSIGNED_INTERVAL) {
|
||||
*obj = ov->range_next.u;
|
||||
|
@ -471,18 +471,18 @@ opts_type_uint64(Visitor *v, const char *name, uint64_t *obj, Error **errp)
|
|||
/* we've gotten past lookup_scalar() */
|
||||
assert(ov->list_mode == LM_NONE || ov->list_mode == LM_IN_PROGRESS);
|
||||
|
||||
if (parse_uint(str, &val, &endptr, 0) == 0 && val <= UINT64_MAX) {
|
||||
if (parse_uint(str, &endptr, 0, &val) == 0) {
|
||||
if (*endptr == '\0') {
|
||||
*obj = val;
|
||||
processed(ov, name);
|
||||
return true;
|
||||
}
|
||||
if (*endptr == '-' && ov->list_mode == LM_IN_PROGRESS) {
|
||||
unsigned long long val2;
|
||||
uint64_t val2;
|
||||
|
||||
str = endptr + 1;
|
||||
if (parse_uint_full(str, &val2, 0) == 0 &&
|
||||
val2 <= UINT64_MAX && val <= val2 &&
|
||||
if (parse_uint_full(str, 0, &val2) == 0 &&
|
||||
val <= val2 &&
|
||||
val2 - val < OPTS_VISITOR_RANGE_MAX) {
|
||||
ov->range_next.u = val;
|
||||
ov->range_limit.u = val2;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue