Assuming this program:
#include <stdio.h>
#include <string.h>
static void ring_pool_alloc(void **p, size_t n) {
static unsigned char pool[256], i = 0;
*p = &pool[i];
i += n;
}
int main(void) {
char *str;
ring_pool_alloc(&str, 7);
strcpy(str, "foobar");
printf("%s\n", str);
return 0;
}
... is it possible to somehow avoid the GCC warning
test.c:12: warning: passing argument 1 of ‘ring_pool_alloc’ from incompatible pointer type
test.c:4: note: expected ‘void **’ but argument is of type ‘char **’
... without casting to (void**) (or simply disabling the compatibility checks)? Because I would very much like to keep compatibility warnings regarding indirection-level...
Why don’t you change the method signature such that it returns the new pointer instead of passing it by pointer? In fact, just like regular
malloc
does:Simply change:
to:
Change
ring_pool_alloc
to receive avoid *
. You can then recast tovoid **
in the function, if you wish.Or in your specific case:
Note that
void **
cannot act as a generic pointer-to-pointer type. On the other hand, convertions from and tovoid *
with other pointer types are applied automatically.