A garbage-collecting typed assembly language

  • Authors:
  • Chris Hawblitzel;Heng Huang;Lea Wittie;Juan Chen

  • Affiliations:
  • Microsoft Research;Dartmouth College;Bucknell University;Microsoft Research

  • Venue:
  • TLDI '07 Proceedings of the 2007 ACM SIGPLAN international workshop on Types in languages design and implementation
  • Year:
  • 2007

Quantified Score

Hi-index 0.00

Visualization

Abstract

Typed assembly languages usually support heap allocation safely, but often rely on an external garbage collector to deallocate objects from the heap and prevent unsafe dangling pointers. Even if the external garbage collector is provably correct, verifying the safety of the interaction between TAL programs and garbage collection is nontrivial. This paper introduces a typed assembly language whose type system is expressive enough to type-check a Cheney-queue copying garbage collector, so that ordinary programs and garbage collection can co-exist and interact inside a single typed language. The only built-in types for memory are linear types describing individual memory words, so that TAL programmers can define their own object layouts, method table layouts, heap layouts, and memory management techniques.