90 likes | 101 Views
This research explores the performance of memory-mapped file system calls in Linux compared to read system calls. It investigates slowdowns and inconsistencies when reading large files on systems with limited memory and proposes theories to fix the problems. The study identifies the causes of slowdowns as the read-ahead mechanism used by memory-mapped files and timing inconsistencies due to race conditions. The goal is to develop a patch to improve the performance of memory-mapped file system calls.
E N D
CS Honors Research:Memory Mapped files in LinuxCheckpoint 1 Kousha Najafi Prof: Eddie Kohler Grad Student: Steve VanDeBogart 12.7.07
Research Topic • Explore Linux memory-mapped-file system call performance. • Find and Resolve inconstancies when compared to read system call
mmap vs read (Forwards old) Reading 256MB file on system with 128MB memory
mmap vs read (Forwards) Reading 256MB file on system with 128MB memory
mmap vs read (Backwards old) Reading 256MB file on system with 128MB memory
mmap vs read (Backwards) Reading 256MB file on system with 128MB memory
Previous Checkpoints • Figure out what causes the slowdown • Figure out what causes the inconsistencies • Come up with theory to fix problem • Try to code a patch to fix problem
Checkpoint Progress • Figure out what causes the slowdown • Slowdown is probably due to the read-ahead mechanism used by mmap. • Figure out what causes the inconsistencies • Seems to be caused by a random race condition involved with calling the read-ahead functions.
Checkpoints Revisions • Figure out read-ahead slowdown • Figure out race condition that causes timing inconsistencies • Come up with theory to fix problem