Наши партнеры








Книги по Linux (с отзывами читателей)

Библиотека сайта rus-linux.net

After this documentation was released in July 2003, I was approached by Prentice Hall and asked to write a book on the Linux VM under the Bruce Peren's Open Book Series.

The book is available and called simply "Understanding The Linux Virtual Memory Manager". There is a lot of additional material in the book that is not available here, including details on later 2.4 kernels, introductions to 2.6, a whole new chapter on the shared memory filesystem, coverage of TLB management, a lot more code commentary, countless other additions and clarifications and a CD with lots of cool stuff on it. This material (although now dated and lacking in comparison to the book) will remain available although I obviously encourge you to buy the book from your favourite book store :-) . As the book is under the Bruce Perens Open Book Series, it will be available 90 days after appearing on the book shelves which means it is not available right now. When it is available, it will be downloadable from http://www.phptr.com/perens so check there for more information.

To be fully clear, this webpage is not the actual book.
next up previous contents index
Next: List of Tables Up: understand-html Previous: Contents   Contents   Index


List of Figures

  • 2.1. Example Patch
  • 3.1. Relationship Between Nodes, Zones and Pages
  • 4.1. Linear Address Bit Size Macros
  • 4.2. Linear Address Size and Mask Macros
  • 4.3. Page Table Layout
  • 4.4. Call Graph: paging_init()
  • 5.1. Kernel Address Space
  • 5.2. Data Structures related to the Address Space
  • 5.3. Memory Region Flags
  • 5.5. Call Graph: get_unmapped_area()
  • 5.6. Call Graph: insert_vm_struct()
  • 5.7. Call Graph: sys_mremap()
  • 5.8. Call Graph: move_vma()
  • 5.9. Call Graph: move_page_tables()
  • 5.10. Call Graph: sys_mlock()
  • 5.11. Call Graph: do_munmap()
  • 5.12. Call Graph: do_page_fault()
  • 5.13. Call Graph: handle_mm_fault()
  • 5.14. Call Graph: do_no_page()
  • 5.15. Call Graph: do_swap_page()
  • 5.16. Call Graph: do_wp_page()
  • 5.17. do_page_fault Flow Diagram
  • 6.1. Call Graph: setup_memory()
  • 6.2. Call Graph: __alloc_bootmem()
  • 6.3. Call Graph: mem_init()
  • 7.1. Free page block management
  • 7.2. Allocating physical pages
  • 7.3. Call Graph: alloc_pages()
  • 7.4. Call Graph: __free_pages()
  • 8.1. vmalloc Address Space
  • 8.2. Call Graph: vmalloc()
  • 8.3. Call Graph: vfree()
  • 9.1. Layout of the Slab Allocator
  • 9.2. Call Graph: kmem_cache_create()
  • 9.3. Call Graph: kmem_cache_reap()
  • 9.4. Call Graph: kmem_cache_shrink()
  • 9.5. Call Graph: __kmem_cache_shrink()
  • 9.6. Call Graph: kmem_cache_destroy()
  • 9.7. Page to Cache and Slab Relationship
  • 9.8. Slab With Descriptor On-Slab
  • 9.9. Slab With Descriptor Off-Slab
  • 9.10. Call Graph: kmem_cache_grow()
  • 9.11. Initialised kmem_bufctl_t Array
  • 9.12. Call Graph: kmem_slab_destroy()
  • 9.13. Call Graph: kmem_cache_alloc()
  • 9.14. Call Graph: kmalloc()
  • 9.15. Call Graph: kfree()
  • 10.1. >Call Graph: kmap()
  • 10.2. >Call Graph: kunmap()
  • 10.3. >Call Graph: create_bounce()
  • 10.4. >Call Graph: bounce_end_io_read/write()
  • 10.5. >Acquiring Pages from Emergency Pools
  • 11.1. >Call Graph: kswapd()
  • 11.2. >Call Graph: generic_file_read()
  • 11.3. >Call Graph: add_to_page_cache()
  • 11.4. >Call Graph: shrink_caches()
  • 11.5. >Call Graph: swap_out()
  • 11.6. >Page Cache LRU List
  • 12.1. >Storing Swap Entry Information in swp_entry_t
  • 12.2. >Call Graph: get_swap_page()
  • 12.3. >Adding a Page to the Swap Cache
  • 12.4. >Call Graph: add_to_swap_cache()
  • 12.5. >Call Graph: sys_writepage()
  • 13.1. >Call Graph: out_of_memory()


Mel 2004-02-15