Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
b7acbef6
Commit
b7acbef6
authored
Dec 12, 2007
by
marko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branches/zip: Document how the data structures of the buddy allocator
are interfaced with the buffer pool.
parent
6d604a10
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
20 additions
and
3 deletions
+20
-3
buf/buf0buf.c
buf/buf0buf.c
+20
-3
No files found.
buf/buf0buf.c
View file @
b7acbef6
...
@@ -128,8 +128,10 @@ in the database, using tables whose size is a power of 2.
...
@@ -128,8 +128,10 @@ in the database, using tables whose size is a power of 2.
Lists of blocks
Lists of blocks
---------------
---------------
There are several lists of control blocks. The free list contains
There are several lists of control blocks.
blocks which are currently not used.
The free list (buf_pool->free) contains blocks which are currently not
used.
The LRU-list contains all the blocks holding a file page
The LRU-list contains all the blocks holding a file page
except those for which the bufferfix count is non-zero.
except those for which the bufferfix count is non-zero.
...
@@ -146,11 +148,26 @@ table which cannot fit in the memory. Putting the pages near the
...
@@ -146,11 +148,26 @@ table which cannot fit in the memory. Putting the pages near the
of the LRU list, we make sure that most of the buf_pool stays in the
of the LRU list, we make sure that most of the buf_pool stays in the
main memory, undisturbed.
main memory, undisturbed.
The chain of modified blocks contains the blocks
The chain of modified blocks
(buf_pool->flush_list)
contains the blocks
holding file pages that have been modified in the memory
holding file pages that have been modified in the memory
but not written to disk yet. The block with the oldest modification
but not written to disk yet. The block with the oldest modification
which has not yet been written to disk is at the end of the chain.
which has not yet been written to disk is at the end of the chain.
The chain of unmodified compressed blocks (buf_pool->zip_clean)
contains the control blocks (buf_page_t) of those compressed pages
that are not in buf_pool->flush_list and for which no uncompressed
page has been allocated in the buffer pool. The control blocks for
uncompressed pages are accessible via buf_block_t objects that are
reachable via buf_pool->chunks[].
The chains of free memory blocks (buf_pool->zip_free[]) are used by
the buddy allocator (buf0buddy.c) to keep track of currently unused
memory blocks of size sizeof(buf_page_t)..UNIV_PAGE_SIZE / 2. These
blocks are inside the UNIV_PAGE_SIZE-sized memory blocks of type
BUF_BLOCK_MEMORY that the buddy allocator requests from the buffer
pool. The buddy allocator is solely used for allocating control
blocks for compressed pages (buf_page_t) and compressed page frames.
Loading a file page
Loading a file page
-------------------
-------------------
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment