Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 23 Sep 2007 11:18:08 +0000
From:      Andrea Campi <andrea+freebsd_current@webcom.it>
To:        current@freebsd.org
Subject:   jemalloc malloc_usable_size()
Message-ID:  <20070923111808.GD31406@webcom.it>

next in thread | raw e-mail | index | archive | help
Hi all,

for a university project, I have been working on a LD_PRELOAD wrapper
for the string.h functions, similar in concept to HeapShield [1]. In
short, I wrap all functions, determine the size of the usable
allocation, then (if available) I translate the original call into a
safer one (strcpy becomes strlcpy, and so on).

I have been mostly targeting 6.x, where I wrote my own code to figure
out the allocation size. On 7.x though, I figured I could use
malloc_usable_size(). However, I encountered a few problems.

First of all, jemalloc makes no effort (neither here nor in free(3))
to survive being called with non-malloc'ed pointers. If you do that
and asserts are on, you will get an abort, but if they are not your
process will likely die an horrible death--but there's no explicit
guarantee of that. I suppose that's fine (we are talking major WTFs
after all) in general, although it would be nice to have more control.
phkmalloc had more limit checking, so bad pointers (text / stack) were
reliably detected.

Worse, malloc_usable_size() fails if you pass it a pointer inside a
malloc'ed region. Again, you get an assert if that's enable, otherwise
you probably get a random value.
The reason for this is in arena_salloc, where the passed pointer is
compared to the calculated page, to determine whether we are dealing
with a small or large allocation.
Unfortunately, I don't see an easy fix for this.

Do you have any suggestion, or should I just give up on using
malloc_usable_size()?

As an aside: regardless of my purely educational exercise, what do you
guys think of putting such checks in the libc itself? The performance
impact is relatively small, and the benefits in terms of detecing and
preventing heap buffer overflows huge. That's all the more important
with jemalloc, which is (relatively) less safe that phkmalloc in fact
of such attacks.

Bye,
	Andrea

1: http://www.cs.umass.edu/~emery/pubs/06-28.pdf

-- 
If it's there, and you can see it, it's real.
If it's not there, and you can see it, it's virtual.
If it's there, and you can't see it, it's transparent.
If it's not there, and you can't see it, you erased it.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070923111808.GD31406>