Twizzler: a Data-Centric OS for Non-Volatile Memory
Appeared in 2020 USENIX Annual Technical Conference (USENIX ATC 20). Won Best Presentation award.
Abstract
Byte-addressable, non-volatile memory (NVM) presents an opportunity to rethink the entire system stack. We present Twizzler, an operating system redesign for this near-future. Twizzler removes the kernel from the I/O path, provides programs with memory-style access to persistent data using small (64 bit), object-relative cross-object pointers, and enables simple and efficient long-term sharing of data both between applications and between runs of an application. Twizzler provides a clean-slate programming model for persistent data, realizing the vision of Unix in a world of persistent RAM.
We show that Twizzler is simpler, more extensible, and more secure than existing I/O models and implementations by building software for Twizzler and evaluating it on NVM DIMMs. Most persistent pointer operations in Twizzler impose less than 0.5 ns added latency. Twizzler operations are up to 13× faster than Unix, and SQLite queries are up to 4.2× faster than on PMDK. YCSB workloads ran 1.1–2.9× faster on Twizzler than on native and NVM-optimized SQLite backends.
Publication date:
July 2020
        Authors:
        
            
                Daniel Bittman
            
        
            
                Peter Alvaro
            
        
            
                Pankaj Mehra
            
        
            
                Darrell D. E. Long
            
        
            
                Ethan L. Miller
            
        
    
        Projects:
        
            Storage Class Memories
        
            Operating Systems Support for NVM
        
    
Available media
            
                Full paper text:
                
                    PDF
                
                
                    
Presentation:
                    slides
                     | 
                    video
                
            
        
Bibtex entry
@inproceedings{bittman-atc20,
  author       = {Daniel Bittman and Peter Alvaro and Pankaj Mehra and Darrell D. E. Long and Ethan L. Miller},
  title        = {Twizzler: a Data-Centric {OS} for Non-Volatile Memory},
  booktitle    = {2020 USENIX Annual Technical Conference (USENIX ATC 20)},
  month        = jul,
  year         = {2020},
}
    
