CMU-CS-02-171
Computer Science Department
School of Computer Science, Carnegie Mellon University



CMU-CS-02-171

A Type Theory for Memory Allocation
and Data Loyout
(Extended Version)

Leaf Petersen, Robert Harper, Karl Crary, Frank Pfenning

August 2002

CMU-CS-02-171.ps
CMU-CS-02-171.pdf


Keywords: Typed compilation, ordered type theory, memory management, garbage collection, data layout


Ordered type theory is a natural extension of linear type theory in which variables in the context may be neither dropped nor re-ordered. This restriction gives rise to a natural notion of adjacency. We show that a language based on ordered types can use this property to give an exact accounting of the layout of data in memory. The fuse constructor from ordered logic describes adjacency of values in memory, and the mobility modal describes pointers into the heap. We choose a particular allocation model based on a common implementation scheme for copying garbage collection and show how this permits us to separate out the allocation and initialization of memory locations in such a way as to account for optimizations such as the coalescing of multiple calls to the allocator.

32 pages


Return to: SCS Technical Report Collection
School of Computer Science homepage

This page maintained by [email protected]