diff options
author | Otto Moerbeek <otto@cvs.openbsd.org> | 2009-10-10 18:36:53 +0000 |
---|---|---|
committer | Otto Moerbeek <otto@cvs.openbsd.org> | 2009-10-10 18:36:53 +0000 |
commit | 698769ed30ea8eccbfd9c7c793f8de3e9a1aff6b (patch) | |
tree | 390f9bd45e24378cbd4a031fed5eb23735101c4e /lib/libc/stdlib/malloc.3 | |
parent | 4bde2b27a7bbd18d670ad4fd00bef4fdb933185e (diff) |
rewrite the history section, prompted by Paul Stoeber; ok deraadt@ jmc@
Diffstat (limited to 'lib/libc/stdlib/malloc.3')
-rw-r--r-- | lib/libc/stdlib/malloc.3 | 53 |
1 files changed, 28 insertions, 25 deletions
diff --git a/lib/libc/stdlib/malloc.3 b/lib/libc/stdlib/malloc.3 index 75b8c69eb74..e0edd9446e9 100644 --- a/lib/libc/stdlib/malloc.3 +++ b/lib/libc/stdlib/malloc.3 @@ -30,9 +30,9 @@ .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF .\" SUCH DAMAGE. .\" -.\" $OpenBSD: malloc.3,v 1.62 2009/02/13 23:36:17 jmc Exp $ +.\" $OpenBSD: malloc.3,v 1.63 2009/10/10 18:36:52 otto Exp $ .\" -.Dd $Mdocdate: February 13 2009 $ +.Dd $Mdocdate: October 10 2009 $ .Dt MALLOC 3 .Os .Sh NAME @@ -425,26 +425,29 @@ The function conforms to .St -ansiC . .Sh HISTORY -The present implementation of -.Fn malloc -started out as a filesystem on a drum -attached to a 20-bit binary challenged computer built with discrete germanium -transistors, and it has since graduated to handle primary storage rather than -secondary. -.Pp -The main difference from other -.Fn malloc -implementations are believed to be that -the free pages are not accessed until allocated. -Most -.Fn malloc -implementations will store a data structure containing a, -possibly double-, linked list in the free chunks of memory, used to tie -all the free memory together. -That is a quite suboptimal thing to do. -Every time the free-list is traversed, all the otherwise unused, and very -likely paged out, pages get faulted into primary memory, just to see what -lies after them in the list. -.Pp -On systems which are paging, this can increase the page-faults -of a process by a factor of five. +The +.Nm +family of functions first appeared in +.At v7 . +A new implementation by Chris Kingsley was introduced in +.Bx 4.2 , +followed by a complete rewrite by Poul-Henning Kamp which appeared in +.Fx 2.2 +and was included in +.Ox 2.0 . +These implementations were all +.Xr sbrk 2 +based. +In +.Ox 3.8 , +Thierry Deval rewrote +.Nm +to use the +.Xr mmap 2 +system call, +making the page addresses returned by +.Nm +random. +A rewrite by Otto Moerbeek introducing a new central data stucture and more +randomization appeared in +.Ox 4.4 . |