[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v2 1/7] Mini-OS: xenbus: add support for reading node from directory
Juergen Gross, le ven. 10 févr. 2023 11:46:22 +0100, a ecrit: > Especially PV device drivers often need to read multiple Xenstore > nodes from a common directory. Add support for reading a string or an > unsigned value by specifying the directory and the node. > > Signed-off-by: Juergen Gross <jgross@xxxxxxxx> Reviewed-by: Samuel Thibault <samuel.thibault@xxxxxxxxxxxx> > --- > V2: > - check sscanf() return value (Samuel Thibault) > --- > include/xenbus.h | 6 ++++++ > xenbus.c | 40 +++++++++++++++++++++++++++++++++++++--- > 2 files changed, 43 insertions(+), 3 deletions(-) > > diff --git a/include/xenbus.h b/include/xenbus.h > index 3871f358..c0fc0ac5 100644 > --- a/include/xenbus.h > +++ b/include/xenbus.h > @@ -108,6 +108,12 @@ int xenbus_read_integer(const char *path); > * read and parsing were successful, 0 if not */ > int xenbus_read_uuid(const char* path, unsigned char uuid[16]); > > +/* Support functions for reading values from directory/node tuple. */ > +char *xenbus_read_string(xenbus_transaction_t xbt, const char *dir, > + const char *node, char **value); > +char *xenbus_read_unsigned(xenbus_transaction_t xbt, const char *dir, > + const char *node, unsigned int *value); > + > /* Contraction of snprintf and xenbus_write(path/node). */ > char* xenbus_printf(xenbus_transaction_t xbt, > const char* node, const char* path, > diff --git a/xenbus.c b/xenbus.c > index 81e9b65d..923e8181 100644 > --- a/xenbus.c > +++ b/xenbus.c > @@ -936,16 +936,21 @@ int xenbus_read_uuid(const char *path, unsigned char > uuid[16]) > return 1; > } > > +#define BUFFER_SIZE 256 > +static void xenbus_build_path(const char *dir, const char *node, char *res) > +{ > + BUG_ON(strlen(dir) + strlen(node) + 1 >= BUFFER_SIZE); > + sprintf(res,"%s/%s", dir, node); > +} > + > char *xenbus_printf(xenbus_transaction_t xbt, const char* node, > const char* path, const char* fmt, ...) > { > -#define BUFFER_SIZE 256 > char fullpath[BUFFER_SIZE]; > char val[BUFFER_SIZE]; > va_list args; > > - BUG_ON(strlen(node) + strlen(path) + 1 >= BUFFER_SIZE); > - sprintf(fullpath,"%s/%s", node, path); > + xenbus_build_path(node, path, fullpath); > va_start(args, fmt); > vsprintf(val, fmt, args); > va_end(args); > @@ -964,6 +969,35 @@ domid_t xenbus_get_self_id(void) > return ret; > } > > +char *xenbus_read_string(xenbus_transaction_t xbt, const char *dir, > + const char *node, char **value) > +{ > + char path[BUFFER_SIZE]; > + > + xenbus_build_path(dir, node, path); > + > + return xenbus_read(xbt, path, value); > +} > + > +char *xenbus_read_unsigned(xenbus_transaction_t xbt, const char *dir, > + const char *node, unsigned int *value) > +{ > + char path[BUFFER_SIZE]; > + char *msg; > + char *str; > + > + xenbus_build_path(dir, node, path); > + msg = xenbus_read(xbt, path, &str); > + if ( msg ) > + return msg; > + > + if ( sscanf(str, "%u", value) != 1 ) > + msg = strdup("EINVAL"); > + free(str); > + > + return msg; > +} > + > /* > * Local variables: > * mode: C > -- > 2.35.3 > -- Samuel --- Pour une évaluation indépendante, transparente et rigoureuse ! Je soutiens la Commission d'Évaluation de l'Inria.
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |