[Caml-list] What should the "size" in "caml_alloc_custom" be?

99 views
Skip to first unread message

lyn HONG

unread,
May 17, 2010, 2:00:37 PM5/17/10
to caml...@yquem.inria.fr
Hi all,

I have a question about "allocating custom blocks" in "iterfacing C with
object Ocaml". when we call function "caml_alloc_custom(ops, size, used,
max)" in the C side, if the structure we want to allocate has a pointer, is
the "size" going to be size of the structure itself only, or should we also
include the memory block that pointer points to?

Thanks,
Lin

Goswin von Brederlow

unread,
May 18, 2010, 2:58:02 AM5/18/10
to lyn HONG, caml...@yquem.inria.fr
lyn HONG <lynx...@gmail.com> writes:

The size is the number of ocaml words in the structure itself. The
pointer then points outside the ocaml heap to some C memory allocated by
malloc(). You should account for that size in the used/max pair.

MfG
Goswin

_______________________________________________
Caml-list mailing list. Subscription management:
http://yquem.inria.fr/cgi-bin/mailman/listinfo/caml-list
Archives: http://caml.inria.fr
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
Bug reports: http://caml.inria.fr/bin/caml-bugs

lyn HONG

unread,
May 18, 2010, 10:59:11 AM5/18/10
to caml...@yquem.inria.fr
On Tue, May 18, 2010 at 2:58 AM, Goswin von Brederlow <goswi...@web.de>wrote:

> lyn HONG <lynx...@gmail.com> writes:
>
> > Hi all,
> >
> > I have a question about "allocating custom blocks" in "iterfacing C with
> object
> > Ocaml". when we call function "caml_alloc_custom(ops, size, used, max)"
> in the
> > C side, if the structure we want to allocate has a pointer, is the
> "size"
> > going to be size of the structure itself only, or should we also include
> the
> > memory block that pointer points to?
> >
> > Thanks,
> > Lin
>
> The size is the number of ocaml words in the structure itself. The
> pointer then points outside the ocaml heap to some C memory allocated by
> malloc(). You should account for that size in the used/max pair.
>

> Thank you so much for the reply.
So when we free the memory, what do we do with the block that pointer points
to? Free it in the 'finalization function' associated to 'ops'?

Best,
Lin


> MfG
> Goswin
>

--
- lyn H

Goswin von Brederlow

unread,
May 18, 2010, 1:33:37 PM5/18/10
to lyn HONG, caml...@yquem.inria.fr
lyn HONG <lynx...@gmail.com> writes:

That depends on who allocted the memory and who is supposed to free
it.

In some cases a library will free the chunk when some cleanup function
is called and your binding for cleanup() should then invalidate the
pointer and other bindings should verify the pointer is still valid
before using it. In that case the 'finalization function' can either
call cleanup() when the pointer is still valid when ocaml declares the
block as unused, give a warning that cleanup() wasn't called and call it
or even give an error. I like the warning best.

In other cases the chunk is something you are supposed to free when you
are done with it. Then you just free() it.

I really depends on the situation. Make damn sure that neigther the
ocaml nor C code accesses the chunk after it has been freed, ever.
Also make sure it doesn't get leaked.

Richard Jones

unread,
May 20, 2010, 6:04:31 PM5/20/10
to lyn HONG, caml...@yquem.inria.fr

This example code might be helpful:

http://oirase.annexia.org/libguestfs-1.3.13/ocaml/guestfs_c.c.html
and more here: http://oirase.annexia.org/libguestfs-1.3.13/ocaml/

Rich.

--
Richard Jones
Red Hat

Reply all
Reply to author
Forward
0 new messages