[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v6 3/6] xen: Introduce a helper to read a u32 property in device tree.
On Aug 13, 2013, at 6:19 AM, Julien Grall <julien.grall@xxxxxxxxxx> wrote: > On 12 August 2013 16:19, Julien Grall <julien.grall@xxxxxxxxxx> wrote: >> On 08/09/2013 03:20 AM, Chen Baozi wrote: >>> Signed-off-by: Chen Baozi <baozich@xxxxxxxxx> >> Acked-by: Julien Grall <julien.grall@xxxxxxxxxx> >>> --- >>> xen/common/device_tree.c | 15 +++++++++++++++ >>> xen/include/xen/device_tree.h | 11 +++++++++++ >>> 2 files changed, 26 insertions(+) >>> >>> diff --git a/xen/common/device_tree.c b/xen/common/device_tree.c >>> index 84d704d..a4701eb 100644 >>> --- a/xen/common/device_tree.c >>> +++ b/xen/common/device_tree.c >>> @@ -574,6 +574,21 @@ const void *dt_get_property(const struct >>> dt_device_node *np, >>> return pp ? pp->value : NULL; >>> } >>> >>> +bool_t dt_property_read_u32(const struct dt_device_node *np, >>> + const char *name, u32 *out_value) >>> +{ >>> + u32 len; >>> + const __be32 *val; >>> + >>> + val = dt_get_property(np, name, &len); >>> + if ( !val || len > sizeof(*out_value) ) >>> + return 0; > > Hum .. I have just noticed that the check is wrong. > Len must be greater or equal to sizeof (*out_value). Otherwise you can > read random bytes. Oops... I think I mixed up the "len" between linux codes and this. Thanks for catching it out! Baozi > > >>> + >>> + *out_value = be32_to_cpup(val); >>> + >>> + return 1; >>> +} >>> + >>> bool_t dt_device_is_compatible(const struct dt_device_node *device, >>> const char *compat) >>> { >>> diff --git a/xen/include/xen/device_tree.h b/xen/include/xen/device_tree.h >>> index 5a2a5c6..faf727f 100644 >>> --- a/xen/include/xen/device_tree.h >>> +++ b/xen/include/xen/device_tree.h >>> @@ -300,6 +300,17 @@ const void *dt_get_property(const struct >>> dt_device_node *np, >>> const char *name, u32 *lenp); >>> >>> /** >>> + * dt_property_read_u32 - Helper to read a u32 property. >>> + * @np: node to get the value >>> + * @name: name of the property >>> + * @out_value: pointer to return value >>> + * >>> + * Return true if get the desired value. >>> + */ >>> +bool_t dt_property_read_u32(const struct dt_device_node *np, >>> + const char *name, u32 *out_value); >>> + >>> +/** >>> * Checks if the given "compat" string matches one of the strings in >>> * the device's "compatible" property >>> */ >>> >> >> >> -- >> Julien Grall > > > > -- > Julien Grall _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |