block/vpc: give option to force the current_size field in .bdrv_create
[qemu.git] / util / id.c
blobbbbadcc7841cac091c59d39f1e5c69fdba1dec9b
1 /*
2 * Dealing with identifiers
4 * Copyright (C) 2014 Red Hat, Inc.
6 * Authors:
7 * Markus Armbruster <armbru@redhat.com>,
9 * This work is licensed under the terms of the GNU LGPL, version 2.1
10 * or later. See the COPYING.LIB file in the top-level directory.
13 #include "qemu/osdep.h"
14 #include "qemu-common.h"
16 bool id_wellformed(const char *id)
18 int i;
20 if (!qemu_isalpha(id[0])) {
21 return false;
23 for (i = 1; id[i]; i++) {
24 if (!qemu_isalnum(id[i]) && !strchr("-._", id[i])) {
25 return false;
28 return true;
31 #define ID_SPECIAL_CHAR '#'
33 static const char *const id_subsys_str[ID_MAX] = {
34 [ID_QDEV] = "qdev",
35 [ID_BLOCK] = "block",
39 * Generates an ID of the form PREFIX SUBSYSTEM NUMBER
40 * where:
42 * - PREFIX is the reserved character '#'
43 * - SUBSYSTEM identifies the subsystem creating the ID
44 * - NUMBER is a decimal number unique within SUBSYSTEM.
46 * Example: "#block146"
48 * Note that these IDs do not satisfy id_wellformed().
50 * The caller is responsible for freeing the returned string with g_free()
52 char *id_generate(IdSubSystems id)
54 static uint64_t id_counters[ID_MAX];
55 uint32_t rnd;
57 assert(id < ARRAY_SIZE(id_subsys_str));
58 assert(id_subsys_str[id]);
60 rnd = g_random_int_range(0, 100);
62 return g_strdup_printf("%c%s%" PRIu64 "%02" PRId32, ID_SPECIAL_CHAR,
63 id_subsys_str[id],
64 id_counters[id]++,
65 rnd);