[getdns-api] Custom memory management functions again
Matt Miller
linuxwolf at outer-planes.net
Wed Nov 20 22:25:44 CET 2013
+1 to that. Makes it even easier to integrate with a VMM.
- m&m
Matthew A. Miller
< http://goo.gl/LK55L >
On Nov 20, 2013, at 2:23 PM, Wiley, Glen <gwiley at verisign.com> wrote:
> Wouter had suggested adding a void* userarg to
> getdns_context_set_memory_functions() which I think may come in handy for
> folks that are taking things far enough to provide their own allocators.
> His suggested function signature would be:
>
> void getdns_context_set_memory_functions(getdns_context_t context,
> void *(*malloc)(void *userarg, size_t sz),
> void *(*realloc)(void *userarg, void *ptr, size_t sz),
> void (*free)(void *userarg, void *ptr),
> void *userarg);
>
>
>
> --
> Glen Wiley
> KK4SFV
>
> Sr. Engineer
> The Hive, Verisign, Inc.
>
>
>
>
> On 11/20/13 10:00 AM, "Willem Toorop" <willem at nlnetlabs.nl> wrote:
>
>> From talking to people involved in the getdns-api design at the IETF-88,
>> we learned that custom memory functions configured per context are an
>> essential part of the design. They really did *not* want custom memory
>> functions to be global. They did agree that setting all memory
>> functions in one go is the better method.
>>
>> We propose to replace getdns_context_set_allocator,
>> getdns_context_set_reallocator and getdns_context_set_deallocator with
>> the following signature for setting them:
>>
>> getdns_return_t
>> getdns_context_set_memory_functions(getdns_context_t context,
>> void *(*malloc) (size_t),
>> void *(*realloc) (void *, size_t),
>> void (*free) (void *)
>> );
>>
>> Now the creation of the context itself should also be possible with
>> those custom memory function. Therefore I propose to have this extra
>> context constructor:
>>
>> getdns_return_t
>> getdns_context_create_with_memory_functions(
>> getdns_context_t * context,
>> int set_from_os,
>> void *(*malloc) (size_t),
>> void *(*realloc) (void *, size_t),
>> void (*free) (void *)
>> );
>>
>> Dicts and lists that were generated as a result of actions done by the
>> library will inherit the custom memory functions from the context.
>>
>> But the user is able to create dicts and lists on its own. We propose to
>> add the following signatures to facilitate creation of dicts and lists
>> by the user with custom memory functions:
>>
>> struct getdns_list *
>> getdns_list_create_with_context(getdns_context_t context);
>>
>> struct getdns_list *
>> getdns_list_create_with_memory_functions(
>> void *(*malloc) (size_t),
>> void *(*realloc) (void *, size_t),
>> void (*free) (void *));
>>
>> struct getdns_dict *
>> getdns_dict_create_with_context(getdns_context_t context);
>>
>> struct getdns_dict *
>> getdns_dict_create_with_memory_functions(
>> void *(*malloc) (size_t),
>> void *(*realloc) (void *, size_t),
>> void (*free) (void *));
>>
>>
>> Now custom memory functions might be even more useful if they have the
>> possibility to have state (i.e. the region with Region-based memory
>> management etc.). This is best accomplished with a "user argument" that
>> will be passed to the custom memory management functions.
>> We propose four more API functions to allow for this:
>>
>> void
>> getdns_context_set_extended_memory_functions(getdns_context_t context,
>> void *userarg,
>> void *(*malloc)(void *userarg, size_t sz),
>> void *(*realloc)(void *userarg, void *ptr, size_t sz),
>> void (*free)(void *userarg, void *ptr));
>>
>> getdns_return_t
>> getdns_context_create_with_extended_memory_functions(
>> getdns_context_t * context,
>> int set_from_os,
>> void *userarg,
>> void *(*malloc) (void *userarg, size_t),
>> void *(*realloc) (void *userarg, void *, size_t),
>> void (*free) (void *userarg, void *)
>> );
>>
>> struct getdns_list *
>> getdns_list_create_with_extended_memory_functions(
>> void *userarg,
>> void *(*malloc) (void *userarg, size_t),
>> void *(*realloc) (void *userarg, void *, size_t),
>> void (*free) (void *userarg, void *));
>>
>>
>> struct getdns_dict *
>> getdns_dict_create_with_extended_memory_functions(
>> void *userarg,
>> void *(*malloc) (void *userarg, size_t),
>> void *(*realloc) (void *userarg, void *, size_t),
>> void (*free) (void *userarg, void *));
>>
>>
>> What do you think? Is it too much? Should we choose one type of custom
>> memory functions and if so, which one (extended or not)? Should we hide
>> the dict_create_* and list_create_* functions?
>>
>> -- Willem
>> _______________________________________________
>> getdns-api mailing list
>> getdns-api at vpnc.org
>
>
> _______________________________________________
> getdns-api mailing list
> getdns-api at vpnc.org
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 496 bytes
Desc: Message signed with OpenPGP using GPGMail
URL: <http://getdnsapi.net/pipermail/spec/attachments/20131120/530f1fed/attachment.bin>
-------------- next part --------------
_______________________________________________
getdns-api mailing list
getdns-api at vpnc.org
More information about the spec
mailing list