|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v1 1/3] tools: allocate bitmaps in units of unsigned long
On Wed, Dec 09, 2020 at 04:54:49PM +0100, Olaf Hering wrote:
> Allocate enough memory so that the returned pointer can be safely
> accessed as an array of unsigned long.
>
> The actual bitmap size in units of bytes, as returned by bitmap_size,
> remains unchanged.
>
> Signed-off-by: Olaf Hering <olaf@xxxxxxxxx>
Acked-by: Wei Liu <wl@xxxxxxx>
I can see where you're coming from. This (internal) API's returned
pointer is being assigned to unsigned long *.
> ---
> tools/libs/ctrl/xc_bitops.h | 5 ++++-
> 1 file changed, 4 insertions(+), 1 deletion(-)
>
> diff --git a/tools/libs/ctrl/xc_bitops.h b/tools/libs/ctrl/xc_bitops.h
> index 3d3a09772a..d6c5ea5138 100644
> --- a/tools/libs/ctrl/xc_bitops.h
> +++ b/tools/libs/ctrl/xc_bitops.h
> @@ -21,7 +21,10 @@ static inline unsigned long bitmap_size(unsigned long
> nr_bits)
>
> static inline void *bitmap_alloc(unsigned long nr_bits)
> {
> - return calloc(1, bitmap_size(nr_bits));
> + unsigned long longs;
> +
> + longs = (nr_bits + BITS_PER_LONG - 1) / BITS_PER_LONG;
> + return calloc(longs, sizeof(unsigned long));
> }
>
> static inline void bitmap_set(void *addr, unsigned long nr_bits)
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |