2001-02-17 14:19:19 +02:00
|
|
|
/* Innobase relational database engine; Copyright (C) 2001 Innobase Oy
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License 2
|
|
|
|
as published by the Free Software Foundation in June 1991.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License 2
|
|
|
|
along with this program (in file COPYING); if not, write to the Free
|
|
|
|
Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
/******************************************************
|
|
|
|
The database buffer buf_pool
|
|
|
|
|
|
|
|
(c) 1995 Innobase Oy
|
|
|
|
|
|
|
|
Created 11/5/1995 Heikki Tuuri
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#include "buf0buf.h"
|
|
|
|
|
|
|
|
#ifdef UNIV_NONINL
|
|
|
|
#include "buf0buf.ic"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "mem0mem.h"
|
|
|
|
#include "btr0btr.h"
|
|
|
|
#include "fil0fil.h"
|
|
|
|
#include "lock0lock.h"
|
|
|
|
#include "btr0sea.h"
|
|
|
|
#include "ibuf0ibuf.h"
|
|
|
|
#include "dict0dict.h"
|
|
|
|
#include "log0recv.h"
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
#include "log0log.h"
|
2001-10-10 22:47:08 +03:00
|
|
|
#include "trx0undo.h"
|
|
|
|
#include "srv0srv.h"
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
IMPLEMENTATION OF THE BUFFER POOL
|
|
|
|
=================================
|
|
|
|
|
|
|
|
Performance improvement:
|
|
|
|
------------------------
|
|
|
|
Thread scheduling in NT may be so slow that the OS wait mechanism should
|
|
|
|
not be used even in waiting for disk reads to complete.
|
|
|
|
Rather, we should put waiting query threads to the queue of
|
|
|
|
waiting jobs, and let the OS thread do something useful while the i/o
|
|
|
|
is processed. In this way we could remove most OS thread switches in
|
|
|
|
an i/o-intensive benchmark like TPC-C.
|
|
|
|
|
|
|
|
A possibility is to put a user space thread library between the database
|
|
|
|
and NT. User space thread libraries might be very fast.
|
|
|
|
|
|
|
|
SQL Server 7.0 can be configured to use 'fibers' which are lightweight
|
|
|
|
threads in NT. These should be studied.
|
|
|
|
|
|
|
|
Buffer frames and blocks
|
|
|
|
------------------------
|
|
|
|
Following the terminology of Gray and Reuter, we call the memory
|
|
|
|
blocks where file pages are loaded buffer frames. For each buffer
|
|
|
|
frame there is a control block, or shortly, a block, in the buffer
|
|
|
|
control array. The control info which does not need to be stored
|
|
|
|
in the file along with the file page, resides in the control block.
|
|
|
|
|
|
|
|
Buffer pool struct
|
|
|
|
------------------
|
|
|
|
The buffer buf_pool contains a single mutex which protects all the
|
|
|
|
control data structures of the buf_pool. The content of a buffer frame is
|
|
|
|
protected by a separate read-write lock in its control block, though.
|
|
|
|
These locks can be locked and unlocked without owning the buf_pool mutex.
|
|
|
|
The OS events in the buf_pool struct can be waited for without owning the
|
|
|
|
buf_pool mutex.
|
|
|
|
|
|
|
|
The buf_pool mutex is a hot-spot in main memory, causing a lot of
|
|
|
|
memory bus traffic on multiprocessor systems when processors
|
|
|
|
alternately access the mutex. On our Pentium, the mutex is accessed
|
|
|
|
maybe every 10 microseconds. We gave up the solution to have mutexes
|
|
|
|
for each control block, for instance, because it seemed to be
|
|
|
|
complicated.
|
|
|
|
|
|
|
|
A solution to reduce mutex contention of the buf_pool mutex is to
|
|
|
|
create a separate mutex for the page hash table. On Pentium,
|
|
|
|
accessing the hash table takes 2 microseconds, about half
|
|
|
|
of the total buf_pool mutex hold time.
|
|
|
|
|
|
|
|
Control blocks
|
|
|
|
--------------
|
|
|
|
|
|
|
|
The control block contains, for instance, the bufferfix count
|
|
|
|
which is incremented when a thread wants a file page to be fixed
|
|
|
|
in a buffer frame. The bufferfix operation does not lock the
|
|
|
|
contents of the frame, however. For this purpose, the control
|
|
|
|
block contains a read-write lock.
|
|
|
|
|
|
|
|
The buffer frames have to be aligned so that the start memory
|
|
|
|
address of a frame is divisible by the universal page size, which
|
|
|
|
is a power of two.
|
|
|
|
|
|
|
|
We intend to make the buffer buf_pool size on-line reconfigurable,
|
|
|
|
that is, the buf_pool size can be changed without closing the database.
|
|
|
|
Then the database administarator may adjust it to be bigger
|
|
|
|
at night, for example. The control block array must
|
|
|
|
contain enough control blocks for the maximum buffer buf_pool size
|
|
|
|
which is used in the particular database.
|
|
|
|
If the buf_pool size is cut, we exploit the virtual memory mechanism of
|
|
|
|
the OS, and just refrain from using frames at high addresses. Then the OS
|
|
|
|
can swap them to disk.
|
|
|
|
|
|
|
|
The control blocks containing file pages are put to a hash table
|
|
|
|
according to the file address of the page.
|
|
|
|
We could speed up the access to an individual page by using
|
|
|
|
"pointer swizzling": we could replace the page references on
|
|
|
|
non-leaf index pages by direct pointers to the page, if it exists
|
|
|
|
in the buf_pool. We could make a separate hash table where we could
|
|
|
|
chain all the page references in non-leaf pages residing in the buf_pool,
|
|
|
|
using the page reference as the hash key,
|
|
|
|
and at the time of reading of a page update the pointers accordingly.
|
|
|
|
Drawbacks of this solution are added complexity and,
|
|
|
|
possibly, extra space required on non-leaf pages for memory pointers.
|
|
|
|
A simpler solution is just to speed up the hash table mechanism
|
|
|
|
in the database, using tables whose size is a power of 2.
|
|
|
|
|
|
|
|
Lists of blocks
|
|
|
|
---------------
|
|
|
|
|
|
|
|
There are several lists of control blocks. The free list contains
|
|
|
|
blocks which are currently not used.
|
|
|
|
|
|
|
|
The LRU-list contains all the blocks holding a file page
|
|
|
|
except those for which the bufferfix count is non-zero.
|
|
|
|
The pages are in the LRU list roughly in the order of the last
|
|
|
|
access to the page, so that the oldest pages are at the end of the
|
|
|
|
list. We also keep a pointer to near the end of the LRU list,
|
|
|
|
which we can use when we want to artificially age a page in the
|
|
|
|
buf_pool. This is used if we know that some page is not needed
|
|
|
|
again for some time: we insert the block right after the pointer,
|
|
|
|
causing it to be replaced sooner than would noramlly be the case.
|
|
|
|
Currently this aging mechanism is used for read-ahead mechanism
|
|
|
|
of pages, and it can also be used when there is a scan of a full
|
|
|
|
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
|
|
|
|
main memory, undisturbed.
|
|
|
|
|
|
|
|
The chain of modified blocks contains the blocks
|
|
|
|
holding file pages that have been modified in the memory
|
|
|
|
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.
|
|
|
|
|
|
|
|
Loading a file page
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
First, a victim block for replacement has to be found in the
|
|
|
|
buf_pool. It is taken from the free list or searched for from the
|
|
|
|
end of the LRU-list. An exclusive lock is reserved for the frame,
|
|
|
|
the io_fix field is set in the block fixing the block in buf_pool,
|
|
|
|
and the io-operation for loading the page is queued. The io-handler thread
|
|
|
|
releases the X-lock on the frame and resets the io_fix field
|
|
|
|
when the io operation completes.
|
|
|
|
|
|
|
|
A thread may request the above operation using the buf_page_get-
|
|
|
|
function. It may then continue to request a lock on the frame.
|
|
|
|
The lock is granted when the io-handler releases the x-lock.
|
|
|
|
|
|
|
|
Read-ahead
|
|
|
|
----------
|
|
|
|
|
|
|
|
The read-ahead mechanism is intended to be intelligent and
|
|
|
|
isolated from the semantically higher levels of the database
|
|
|
|
index management. From the higher level we only need the
|
|
|
|
information if a file page has a natural successor or
|
|
|
|
predecessor page. On the leaf level of a B-tree index,
|
|
|
|
these are the next and previous pages in the natural
|
|
|
|
order of the pages.
|
|
|
|
|
|
|
|
Let us first explain the read-ahead mechanism when the leafs
|
|
|
|
of a B-tree are scanned in an ascending or descending order.
|
|
|
|
When a read page is the first time referenced in the buf_pool,
|
|
|
|
the buffer manager checks if it is at the border of a so-called
|
|
|
|
linear read-ahead area. The tablespace is divided into these
|
|
|
|
areas of size 64 blocks, for example. So if the page is at the
|
|
|
|
border of such an area, the read-ahead mechanism checks if
|
|
|
|
all the other blocks in the area have been accessed in an
|
|
|
|
ascending or descending order. If this is the case, the system
|
|
|
|
looks at the natural successor or predecessor of the page,
|
|
|
|
checks if that is at the border of another area, and in this case
|
|
|
|
issues read-requests for all the pages in that area. Maybe
|
|
|
|
we could relax the condition that all the pages in the area
|
|
|
|
have to be accessed: if data is deleted from a table, there may
|
|
|
|
appear holes of unused pages in the area.
|
|
|
|
|
|
|
|
A different read-ahead mechanism is used when there appears
|
|
|
|
to be a random access pattern to a file.
|
|
|
|
If a new page is referenced in the buf_pool, and several pages
|
|
|
|
of its random access area (for instance, 32 consecutive pages
|
|
|
|
in a tablespace) have recently been referenced, we may predict
|
|
|
|
that the whole area may be needed in the near future, and issue
|
2003-01-06 22:07:25 +02:00
|
|
|
the read requests for the whole area.
|
|
|
|
|
|
|
|
AWE implementation
|
|
|
|
------------------
|
|
|
|
|
|
|
|
By a 'block' we mean the buffer header of type buf_block_t. By a 'page'
|
|
|
|
we mean the physical 16 kB memory area allocated from RAM for that block.
|
|
|
|
By a 'frame' we mean a 16 kB area in the virtual address space of the
|
|
|
|
process, in the frame_mem of buf_pool.
|
|
|
|
|
|
|
|
We can map pages to the frames of the buffer pool.
|
|
|
|
|
|
|
|
1) A buffer block allocated to use as a non-data page, e.g., to the lock
|
|
|
|
table, is always mapped to a frame.
|
|
|
|
2) A bufferfixed or io-fixed data page is always mapped to a frame.
|
|
|
|
3) When we need to map a block to frame, we look from the list
|
|
|
|
awe_LRU_free_mapped and try to unmap its last block, but note that
|
|
|
|
bufferfixed or io-fixed pages cannot be unmapped.
|
|
|
|
4) For every frame in the buffer pool there is always a block whose page is
|
|
|
|
mapped to it. When we create the buffer pool, we map the first elements
|
|
|
|
in the free list to the frames.
|
|
|
|
5) When we have AWE enabled, we disable adaptive hash indexes.
|
|
|
|
*/
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
buf_pool_t* buf_pool = NULL; /* The buffer buf_pool of the database */
|
|
|
|
|
2004-06-16 13:41:14 +03:00
|
|
|
ulint buf_dbg_counter = 0; /* This is used to insert validation
|
2001-02-17 14:19:19 +02:00
|
|
|
operations in excution in the
|
|
|
|
debug version */
|
|
|
|
ibool buf_debug_prints = FALSE; /* If this is set TRUE,
|
|
|
|
the program prints info whenever
|
|
|
|
read-ahead or flush occurs */
|
2001-05-01 20:57:49 +03:00
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Calculates a page checksum which is stored to the page when it is written
|
2003-06-15 01:04:28 +03:00
|
|
|
to a file. Note that we must be careful to calculate the same value on
|
|
|
|
32-bit and 64-bit architectures. */
|
2001-05-01 20:57:49 +03:00
|
|
|
|
|
|
|
ulint
|
2003-06-15 01:04:28 +03:00
|
|
|
buf_calc_page_new_checksum(
|
|
|
|
/*=======================*/
|
2001-05-01 20:57:49 +03:00
|
|
|
/* out: checksum */
|
|
|
|
byte* page) /* in: buffer page */
|
|
|
|
{
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
ulint checksum;
|
2001-05-01 20:57:49 +03:00
|
|
|
|
2003-10-07 17:28:59 +03:00
|
|
|
/* Since the field FIL_PAGE_FILE_FLUSH_LSN, and in versions <= 4.1.x
|
|
|
|
..._ARCH_LOG_NO, are written outside the buffer pool to the first
|
|
|
|
pages of data files, we have to skip them in the page checksum
|
|
|
|
calculation.
|
2003-06-15 01:04:28 +03:00
|
|
|
We must also skip the field FIL_PAGE_SPACE_OR_CHKSUM where the
|
|
|
|
checksum is stored, and also the last 8 bytes of page because
|
|
|
|
there we store the old formula checksum. */
|
|
|
|
|
|
|
|
checksum = ut_fold_binary(page + FIL_PAGE_OFFSET,
|
|
|
|
FIL_PAGE_FILE_FLUSH_LSN - FIL_PAGE_OFFSET)
|
|
|
|
+ ut_fold_binary(page + FIL_PAGE_DATA,
|
|
|
|
UNIV_PAGE_SIZE - FIL_PAGE_DATA
|
|
|
|
- FIL_PAGE_END_LSN_OLD_CHKSUM);
|
2003-10-07 17:28:59 +03:00
|
|
|
checksum = checksum & 0xFFFFFFFFUL;
|
2003-06-15 01:04:28 +03:00
|
|
|
|
|
|
|
return(checksum);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
In versions < 4.0.14 and < 4.1.1 there was a bug that the checksum only
|
|
|
|
looked at the first few bytes of the page. This calculates that old
|
|
|
|
checksum.
|
|
|
|
NOTE: we must first store the new formula checksum to
|
|
|
|
FIL_PAGE_SPACE_OR_CHKSUM before calculating and storing this old checksum
|
|
|
|
because this takes that field as an input! */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
buf_calc_page_old_checksum(
|
|
|
|
/*=======================*/
|
|
|
|
/* out: checksum */
|
|
|
|
byte* page) /* in: buffer page */
|
|
|
|
{
|
|
|
|
ulint checksum;
|
2002-03-21 18:03:09 +02:00
|
|
|
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
checksum = ut_fold_binary(page, FIL_PAGE_FILE_FLUSH_LSN);
|
2003-06-15 01:04:28 +03:00
|
|
|
|
2003-10-07 17:28:59 +03:00
|
|
|
checksum = checksum & 0xFFFFFFFFUL;
|
2001-05-01 20:57:49 +03:00
|
|
|
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
return(checksum);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Checks if a page is corrupt. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_page_is_corrupted(
|
|
|
|
/*==================*/
|
|
|
|
/* out: TRUE if corrupted */
|
|
|
|
byte* read_buf) /* in: a database page */
|
|
|
|
{
|
|
|
|
ulint checksum;
|
2003-06-15 01:04:28 +03:00
|
|
|
ulint old_checksum;
|
|
|
|
ulint checksum_field;
|
|
|
|
ulint old_checksum_field;
|
2003-11-03 19:11:09 +02:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
dulint current_lsn;
|
2003-11-03 19:11:09 +02:00
|
|
|
#endif
|
2003-06-15 01:04:28 +03:00
|
|
|
if (mach_read_from_4(read_buf + FIL_PAGE_LSN + 4)
|
|
|
|
!= mach_read_from_4(read_buf + UNIV_PAGE_SIZE
|
|
|
|
- FIL_PAGE_END_LSN_OLD_CHKSUM + 4)) {
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
/* Stored log sequence numbers at the start and the end
|
|
|
|
of page do not match */
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
if (recv_lsn_checks_on && log_peek_lsn(¤t_lsn)) {
|
|
|
|
if (ut_dulint_cmp(current_lsn,
|
|
|
|
mach_read_from_8(read_buf + FIL_PAGE_LSN))
|
|
|
|
< 0) {
|
|
|
|
ut_print_timestamp(stderr);
|
|
|
|
|
|
|
|
fprintf(stderr,
|
|
|
|
" InnoDB: Error: page %lu log sequence number %lu %lu\n"
|
|
|
|
"InnoDB: is in the future! Current system log sequence number %lu %lu.\n"
|
|
|
|
"InnoDB: Your database may be corrupt.\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_OFFSET),
|
|
|
|
(ulong) ut_dulint_get_high(
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
mach_read_from_8(read_buf + FIL_PAGE_LSN)),
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) ut_dulint_get_low(
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
mach_read_from_8(read_buf + FIL_PAGE_LSN)),
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) ut_dulint_get_high(current_lsn),
|
|
|
|
(ulong) ut_dulint_get_low(current_lsn));
|
srv0srv.c, os0file.c, log0recv.h, log0log.h, fil0fil.h, fsp0fsp.c, fil0fil.c:
Merge
trx0trx.c:
Print more info about a trx in SHOW INNODB status; try to find the bug reported by Plaxo
buf0buf.c:
Check that page log sequence numbers are not in the future
log0recv.c, log0log.c:
Fixed a bug: if you used big BLOBs, and your log files were relatively small, InnoDB could in a big BLOB operation temporarily write over the log produced AFTER the latest checkpoint. If InnoDB would crash at that moment, then the crash recovery would fail, because InnoDB would not be able to scan the log even up to the latest checkpoint. Starting from this version, InnoDB tries to ensure the latest checkpoint is young enough. If that is not possible, InnoDB prints a warning to the .err log
2003-07-25 22:26:39 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2003-06-15 01:04:28 +03:00
|
|
|
old_checksum = buf_calc_page_old_checksum(read_buf);
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
old_checksum_field = mach_read_from_4(read_buf + UNIV_PAGE_SIZE
|
|
|
|
- FIL_PAGE_END_LSN_OLD_CHKSUM);
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
/* There are 2 valid formulas for old_checksum_field:
|
|
|
|
1. Very old versions of InnoDB only stored 8 byte lsn to the start
|
|
|
|
and the end of the page.
|
|
|
|
2. Newer InnoDB versions store the old formula checksum there. */
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
if (old_checksum_field != mach_read_from_4(read_buf + FIL_PAGE_LSN)
|
|
|
|
&& old_checksum_field != old_checksum) {
|
|
|
|
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
checksum = buf_calc_page_new_checksum(read_buf);
|
|
|
|
checksum_field = mach_read_from_4(read_buf + FIL_PAGE_SPACE_OR_CHKSUM);
|
|
|
|
|
|
|
|
/* InnoDB versions < 4.0.14 and < 4.1.1 stored the space id
|
|
|
|
(always equal to 0), to FIL_PAGE_SPACE_SPACE_OR_CHKSUM */
|
|
|
|
|
|
|
|
if (checksum_field != 0 && checksum_field != checksum) {
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
return(FALSE);
|
2001-05-01 20:57:49 +03:00
|
|
|
}
|
|
|
|
|
2001-10-10 22:47:08 +03:00
|
|
|
/************************************************************************
|
|
|
|
Prints a page to stderr. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_page_print(
|
|
|
|
/*===========*/
|
|
|
|
byte* read_buf) /* in: a database page */
|
|
|
|
{
|
|
|
|
dict_index_t* index;
|
|
|
|
ulint checksum;
|
2003-06-15 01:04:28 +03:00
|
|
|
ulint old_checksum;
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2002-03-21 18:03:09 +02:00
|
|
|
ut_print_timestamp(stderr);
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr, " InnoDB: Page dump in ascii and hex (%lu bytes):\n",
|
|
|
|
(ulint)UNIV_PAGE_SIZE);
|
|
|
|
ut_print_buf(stderr, read_buf, UNIV_PAGE_SIZE);
|
|
|
|
fputs("InnoDB: End of page dump\n", stderr);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-06-15 01:04:28 +03:00
|
|
|
checksum = buf_calc_page_new_checksum(read_buf);
|
|
|
|
old_checksum = buf_calc_page_old_checksum(read_buf);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2002-03-21 18:03:09 +02:00
|
|
|
ut_print_timestamp(stderr);
|
2003-06-15 01:04:28 +03:00
|
|
|
fprintf(stderr,
|
|
|
|
" InnoDB: Page checksum %lu, prior-to-4.0.14-form checksum %lu\n"
|
|
|
|
"InnoDB: stored checksum %lu, prior-to-4.0.14-form stored checksum %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) checksum, (ulong) old_checksum,
|
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_SPACE_OR_CHKSUM),
|
|
|
|
(ulong) mach_read_from_4(read_buf + UNIV_PAGE_SIZE
|
2003-06-15 01:04:28 +03:00
|
|
|
- FIL_PAGE_END_LSN_OLD_CHKSUM));
|
2001-10-10 22:47:08 +03:00
|
|
|
fprintf(stderr,
|
2003-10-07 17:28:59 +03:00
|
|
|
"InnoDB: Page lsn %lu %lu, low 4 bytes of lsn at page end %lu\n"
|
|
|
|
"InnoDB: Page number (if stored to page already) %lu,\n"
|
|
|
|
"InnoDB: space id (if created with >= MySQL-4.1.1 and stored already) %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_LSN),
|
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_LSN + 4),
|
|
|
|
(ulong) mach_read_from_4(read_buf + UNIV_PAGE_SIZE
|
2003-10-07 17:28:59 +03:00
|
|
|
- FIL_PAGE_END_LSN_OLD_CHKSUM + 4),
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_OFFSET),
|
|
|
|
(ulong) mach_read_from_4(read_buf + FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID));
|
2003-10-07 17:28:59 +03:00
|
|
|
|
2001-10-10 22:47:08 +03:00
|
|
|
if (mach_read_from_2(read_buf + TRX_UNDO_PAGE_HDR + TRX_UNDO_PAGE_TYPE)
|
|
|
|
== TRX_UNDO_INSERT) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: Page may be an insert undo log page\n");
|
|
|
|
} else if (mach_read_from_2(read_buf + TRX_UNDO_PAGE_HDR
|
|
|
|
+ TRX_UNDO_PAGE_TYPE)
|
|
|
|
== TRX_UNDO_UPDATE) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: Page may be an update undo log page\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (fil_page_get_type(read_buf) == FIL_PAGE_INDEX) {
|
|
|
|
fprintf(stderr,
|
2003-10-07 17:28:59 +03:00
|
|
|
"InnoDB: Page may be an index page where index id is %lu %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) ut_dulint_get_high(btr_page_get_index_id(read_buf)),
|
|
|
|
(ulong) ut_dulint_get_low(btr_page_get_index_id(read_buf)));
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-03-04 14:05:23 +02:00
|
|
|
/* If the code is in ibbackup, dict_sys may be uninitialized,
|
|
|
|
i.e., NULL */
|
|
|
|
|
|
|
|
if (dict_sys != NULL) {
|
|
|
|
|
|
|
|
index = dict_index_find_on_id_low(
|
2001-10-10 22:47:08 +03:00
|
|
|
btr_page_get_index_id(read_buf));
|
2003-03-04 14:05:23 +02:00
|
|
|
if (index) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("InnoDB: (", stderr);
|
2004-10-01 11:51:59 +03:00
|
|
|
dict_index_name_print(stderr, NULL, index);
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs(")\n", stderr);
|
2003-03-04 14:05:23 +02:00
|
|
|
}
|
2001-10-10 22:47:08 +03:00
|
|
|
}
|
2002-10-29 23:16:46 +02:00
|
|
|
} else if (fil_page_get_type(read_buf) == FIL_PAGE_INODE) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("InnoDB: Page may be an 'inode' page\n", stderr);
|
2002-10-29 23:16:46 +02:00
|
|
|
} else if (fil_page_get_type(read_buf) == FIL_PAGE_IBUF_FREE_LIST) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("InnoDB: Page may be an insert buffer free list page\n",
|
|
|
|
stderr);
|
2001-10-10 22:47:08 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/************************************************************************
|
|
|
|
Initializes a buffer control block when the buf_pool is created. */
|
|
|
|
static
|
|
|
|
void
|
|
|
|
buf_block_init(
|
|
|
|
/*===========*/
|
|
|
|
buf_block_t* block, /* in: pointer to control block */
|
2003-01-06 22:07:25 +02:00
|
|
|
byte* frame) /* in: pointer to buffer frame, or NULL if in
|
|
|
|
the case of AWE there is no frame */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
|
|
|
block->state = BUF_BLOCK_NOT_USED;
|
|
|
|
|
|
|
|
block->frame = frame;
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
block->awe_info = NULL;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
block->modify_clock = ut_dulint_zero;
|
|
|
|
|
2001-06-24 19:33:50 +03:00
|
|
|
block->file_page_was_freed = FALSE;
|
|
|
|
|
2002-10-29 23:16:46 +02:00
|
|
|
block->check_index_page_at_flush = FALSE;
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
block->in_free_list = FALSE;
|
|
|
|
block->in_LRU_list = FALSE;
|
|
|
|
|
|
|
|
block->n_pointers = 0;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
rw_lock_create(&(block->lock));
|
|
|
|
ut_ad(rw_lock_validate(&(block->lock)));
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
2001-02-17 14:19:19 +02:00
|
|
|
rw_lock_create(&(block->debug_latch));
|
|
|
|
rw_lock_set_level(&(block->debug_latch), SYNC_NO_ORDER_CHECK);
|
2004-03-12 17:14:51 +02:00
|
|
|
#endif /* UNIV_SYNC_DEBUG */
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
2003-01-06 22:07:25 +02:00
|
|
|
Creates the buffer pool. */
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_pool_t*
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool_init(
|
|
|
|
/*==========*/
|
2001-02-17 14:19:19 +02:00
|
|
|
/* out, own: buf_pool object, NULL if not
|
2003-01-06 22:07:25 +02:00
|
|
|
enough memory or error */
|
2001-02-17 14:19:19 +02:00
|
|
|
ulint max_size, /* in: maximum size of the buf_pool in
|
|
|
|
blocks */
|
2003-01-06 22:07:25 +02:00
|
|
|
ulint curr_size, /* in: current size to use, must be <=
|
2001-02-17 14:19:19 +02:00
|
|
|
max_size, currently must be equal to
|
|
|
|
max_size */
|
2003-01-06 22:07:25 +02:00
|
|
|
ulint n_frames) /* in: number of frames; if AWE is used,
|
|
|
|
this is the size of the address space window
|
|
|
|
where physical memory pages are mapped; if
|
|
|
|
AWE is not used then this must be the same
|
|
|
|
as max_size */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
|
|
|
byte* frame;
|
|
|
|
ulint i;
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
ut_a(max_size == curr_size);
|
2003-01-06 22:07:25 +02:00
|
|
|
ut_a(srv_use_awe || n_frames == max_size);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
2003-01-09 00:29:49 +02:00
|
|
|
if (n_frames > curr_size) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: AWE: Error: you must specify in my.cnf .._awe_mem_mb larger\n"
|
|
|
|
"InnoDB: than .._buffer_pool_size. Now the former is %lu pages,\n"
|
2003-12-20 03:41:04 +02:00
|
|
|
"InnoDB: the latter %lu pages.\n", (ulong) curr_size, (ulong) n_frames);
|
2003-01-09 00:29:49 +02:00
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_pool = mem_alloc(sizeof(buf_pool_t));
|
|
|
|
|
|
|
|
/* 1. Initialize general fields
|
|
|
|
---------------------------- */
|
|
|
|
mutex_create(&(buf_pool->mutex));
|
|
|
|
mutex_set_level(&(buf_pool->mutex), SYNC_BUF_POOL);
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
2003-01-06 22:07:25 +02:00
|
|
|
|
|
|
|
if (srv_use_awe) {
|
|
|
|
/*----------------------------------------*/
|
|
|
|
/* Allocate the virtual address space window, i.e., the
|
|
|
|
buffer pool frames */
|
|
|
|
|
|
|
|
buf_pool->frame_mem = os_awe_allocate_virtual_mem_window(
|
|
|
|
UNIV_PAGE_SIZE * (n_frames + 1));
|
|
|
|
|
|
|
|
/* Allocate the physical memory for AWE and the AWE info array
|
|
|
|
for buf_pool */
|
|
|
|
|
|
|
|
if ((curr_size % ((1024 * 1024) / UNIV_PAGE_SIZE)) != 0) {
|
|
|
|
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: AWE: Error: physical memory must be allocated in full megabytes.\n"
|
|
|
|
"InnoDB: Trying to allocate %lu database pages.\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) curr_size);
|
2003-01-06 22:07:25 +02:00
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!os_awe_allocate_physical_mem(&(buf_pool->awe_info),
|
|
|
|
curr_size / ((1024 * 1024) / UNIV_PAGE_SIZE))) {
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
/*----------------------------------------*/
|
|
|
|
} else {
|
2004-11-26 00:12:50 +02:00
|
|
|
buf_pool->frame_mem = ut_malloc_low(
|
|
|
|
UNIV_PAGE_SIZE * (n_frames + 1),
|
|
|
|
TRUE, FALSE);
|
2003-01-06 22:07:25 +02:00
|
|
|
}
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
if (buf_pool->frame_mem == NULL) {
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->blocks = ut_malloc(sizeof(buf_block_t) * max_size);
|
|
|
|
|
|
|
|
if (buf_pool->blocks == NULL) {
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->max_size = max_size;
|
|
|
|
buf_pool->curr_size = curr_size;
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_frames = n_frames;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/* Align pointer to the first frame */
|
|
|
|
|
|
|
|
frame = ut_align(buf_pool->frame_mem, UNIV_PAGE_SIZE);
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->frame_zero = frame;
|
2003-01-09 00:10:36 +02:00
|
|
|
buf_pool->high_end = frame + UNIV_PAGE_SIZE * n_frames;
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
if (srv_use_awe) {
|
|
|
|
/*----------------------------------------*/
|
|
|
|
/* Map an initial part of the allocated physical memory to
|
|
|
|
the window */
|
|
|
|
|
|
|
|
os_awe_map_physical_mem_to_window(buf_pool->frame_zero,
|
2003-10-07 17:28:59 +03:00
|
|
|
n_frames *
|
|
|
|
(UNIV_PAGE_SIZE / OS_AWE_X86_PAGE_SIZE),
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->awe_info);
|
|
|
|
/*----------------------------------------*/
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->blocks_of_frames = ut_malloc(sizeof(void*) * n_frames);
|
|
|
|
|
|
|
|
if (buf_pool->blocks_of_frames == NULL) {
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Init block structs and assign frames for them; in the case of
|
|
|
|
AWE there are less frames than blocks. Then we assign the frames
|
|
|
|
to the first blocks (we already mapped the memory above). We also
|
|
|
|
init the awe_info for every block. */
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
for (i = 0; i < max_size; i++) {
|
|
|
|
|
|
|
|
block = buf_pool_get_nth_block(buf_pool, i);
|
2003-01-06 22:07:25 +02:00
|
|
|
|
|
|
|
if (i < n_frames) {
|
|
|
|
frame = buf_pool->frame_zero + i * UNIV_PAGE_SIZE;
|
|
|
|
*(buf_pool->blocks_of_frames + i) = block;
|
|
|
|
} else {
|
|
|
|
frame = NULL;
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_block_init(block, frame);
|
2003-01-06 22:07:25 +02:00
|
|
|
|
|
|
|
if (srv_use_awe) {
|
|
|
|
/*----------------------------------------*/
|
|
|
|
block->awe_info = buf_pool->awe_info
|
|
|
|
+ i * (UNIV_PAGE_SIZE / OS_AWE_X86_PAGE_SIZE);
|
|
|
|
/*----------------------------------------*/
|
|
|
|
}
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
2003-01-06 22:07:25 +02:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_pool->page_hash = hash_create(2 * max_size);
|
|
|
|
|
|
|
|
buf_pool->n_pend_reads = 0;
|
2001-10-10 22:47:08 +03:00
|
|
|
|
|
|
|
buf_pool->last_printout_time = time(NULL);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_pool->n_pages_read = 0;
|
|
|
|
buf_pool->n_pages_written = 0;
|
|
|
|
buf_pool->n_pages_created = 0;
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_pages_awe_remapped = 0;
|
|
|
|
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
buf_pool->n_page_gets = 0;
|
|
|
|
buf_pool->n_page_gets_old = 0;
|
|
|
|
buf_pool->n_pages_read_old = 0;
|
2001-10-10 22:47:08 +03:00
|
|
|
buf_pool->n_pages_written_old = 0;
|
|
|
|
buf_pool->n_pages_created_old = 0;
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_pages_awe_remapped_old = 0;
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/* 2. Initialize flushing fields
|
|
|
|
---------------------------- */
|
|
|
|
UT_LIST_INIT(buf_pool->flush_list);
|
|
|
|
|
|
|
|
for (i = BUF_FLUSH_LRU; i <= BUF_FLUSH_LIST; i++) {
|
|
|
|
buf_pool->n_flush[i] = 0;
|
2001-09-17 18:17:38 +03:00
|
|
|
buf_pool->init_flush[i] = FALSE;
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_pool->no_flush[i] = os_event_create(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->LRU_flush_ended = 0;
|
|
|
|
|
|
|
|
buf_pool->ulint_clock = 1;
|
|
|
|
buf_pool->freed_page_clock = 0;
|
|
|
|
|
|
|
|
/* 3. Initialize LRU fields
|
|
|
|
---------------------------- */
|
|
|
|
UT_LIST_INIT(buf_pool->LRU);
|
|
|
|
|
|
|
|
buf_pool->LRU_old = NULL;
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
UT_LIST_INIT(buf_pool->awe_LRU_free_mapped);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/* Add control blocks to the free list */
|
|
|
|
UT_LIST_INIT(buf_pool->free);
|
2003-01-06 22:07:25 +02:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
for (i = 0; i < curr_size; i++) {
|
|
|
|
|
|
|
|
block = buf_pool_get_nth_block(buf_pool, i);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
if (block->frame) {
|
|
|
|
/* Wipe contents of frame to eliminate a Purify
|
|
|
|
warning */
|
|
|
|
|
2003-05-19 16:35:49 +03:00
|
|
|
#ifdef HAVE_purify
|
2003-01-06 22:07:25 +02:00
|
|
|
memset(block->frame, '\0', UNIV_PAGE_SIZE);
|
2003-05-19 16:35:49 +03:00
|
|
|
#endif
|
2003-01-06 22:07:25 +02:00
|
|
|
if (srv_use_awe) {
|
|
|
|
/* Add to the list of blocks mapped to
|
|
|
|
frames */
|
|
|
|
|
|
|
|
UT_LIST_ADD_LAST(awe_LRU_free_mapped,
|
|
|
|
buf_pool->awe_LRU_free_mapped, block);
|
|
|
|
}
|
|
|
|
}
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
UT_LIST_ADD_LAST(free, buf_pool->free, block);
|
2003-10-13 11:20:19 +03:00
|
|
|
block->in_free_list = TRUE;
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
if (srv_use_adaptive_hash_indexes) {
|
|
|
|
btr_search_sys_create(
|
|
|
|
curr_size * UNIV_PAGE_SIZE / sizeof(void*) / 64);
|
|
|
|
} else {
|
|
|
|
/* Create only a small dummy system */
|
|
|
|
btr_search_sys_create(1000);
|
|
|
|
}
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
return(buf_pool);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
2003-01-06 22:07:25 +02:00
|
|
|
Maps the page of block to a frame, if not mapped yet. Unmaps some page
|
|
|
|
from the end of the awe_LRU_free_mapped. */
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
void
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_awe_map_page_to_frame(
|
|
|
|
/*======================*/
|
|
|
|
buf_block_t* block, /* in: block whose page should be
|
|
|
|
mapped to a frame */
|
|
|
|
ibool add_to_mapped_list) /* in: TRUE if we in the case
|
|
|
|
we need to map the page should also
|
|
|
|
add the block to the
|
|
|
|
awe_LRU_free_mapped list */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_block_t* bck;
|
|
|
|
|
2004-05-27 15:27:43 +03:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
2003-01-06 22:07:25 +02:00
|
|
|
ut_ad(mutex_own(&(buf_pool->mutex)));
|
2004-05-27 15:27:43 +03:00
|
|
|
#endif /* UNIV_SYNC_DEBUG */
|
2003-01-06 22:07:25 +02:00
|
|
|
ut_ad(block);
|
|
|
|
|
|
|
|
if (block->frame) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Scan awe_LRU_free_mapped from the end and try to find a block
|
|
|
|
which is not bufferfixed or io-fixed */
|
|
|
|
|
|
|
|
bck = UT_LIST_GET_LAST(buf_pool->awe_LRU_free_mapped);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
while (bck) {
|
|
|
|
if (bck->state == BUF_BLOCK_FILE_PAGE
|
|
|
|
&& (bck->buf_fix_count != 0 || bck->io_fix != 0)) {
|
|
|
|
|
|
|
|
/* We have to skip this */
|
|
|
|
bck = UT_LIST_GET_PREV(awe_LRU_free_mapped, bck);
|
|
|
|
} else {
|
|
|
|
/* We can map block to the frame of bck */
|
|
|
|
|
|
|
|
os_awe_map_physical_mem_to_window(
|
|
|
|
bck->frame,
|
|
|
|
UNIV_PAGE_SIZE / OS_AWE_X86_PAGE_SIZE,
|
|
|
|
block->awe_info);
|
|
|
|
|
|
|
|
block->frame = bck->frame;
|
|
|
|
|
|
|
|
*(buf_pool->blocks_of_frames
|
|
|
|
+ (((ulint)(block->frame
|
|
|
|
- buf_pool->frame_zero))
|
|
|
|
>> UNIV_PAGE_SIZE_SHIFT))
|
|
|
|
= block;
|
|
|
|
|
|
|
|
bck->frame = NULL;
|
|
|
|
UT_LIST_REMOVE(awe_LRU_free_mapped,
|
|
|
|
buf_pool->awe_LRU_free_mapped,
|
|
|
|
bck);
|
|
|
|
|
|
|
|
if (add_to_mapped_list) {
|
|
|
|
UT_LIST_ADD_FIRST(awe_LRU_free_mapped,
|
|
|
|
buf_pool->awe_LRU_free_mapped,
|
|
|
|
block);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->n_pages_awe_remapped++;
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: AWE: Fatal error: cannot find a page to unmap\n"
|
|
|
|
"InnoDB: awe_LRU_free_mapped list length %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->awe_LRU_free_mapped));
|
2001-02-17 14:19:19 +02:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
ut_a(0);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Allocates a buffer block. */
|
|
|
|
UNIV_INLINE
|
|
|
|
buf_block_t*
|
|
|
|
buf_block_alloc(void)
|
|
|
|
/*=================*/
|
2003-01-06 22:07:25 +02:00
|
|
|
/* out, own: the allocated block; also if AWE
|
|
|
|
is used it is guaranteed that the page is
|
|
|
|
mapped to a frame */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
block = buf_LRU_get_free_block();
|
|
|
|
|
|
|
|
return(block);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Moves to the block to the start of the LRU list if there is a danger
|
|
|
|
that the block would drift out of the buffer pool. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
buf_block_make_young(
|
|
|
|
/*=================*/
|
|
|
|
buf_block_t* block) /* in: block to make younger */
|
|
|
|
{
|
|
|
|
if (buf_pool->freed_page_clock >= block->freed_page_clock
|
|
|
|
+ 1 + (buf_pool->curr_size / 1024)) {
|
|
|
|
|
|
|
|
/* There has been freeing activity in the LRU list:
|
|
|
|
best to move to the head of the LRU list */
|
|
|
|
|
|
|
|
buf_LRU_make_block_young(block);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Moves a page to the start of the buffer pool LRU list. This high-level
|
|
|
|
function can be used to prevent an important page from from slipping out of
|
|
|
|
the buffer pool. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_page_make_young(
|
|
|
|
/*=================*/
|
|
|
|
buf_frame_t* frame) /* in: buffer frame of a file page */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_block_align(frame);
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state == BUF_BLOCK_FILE_PAGE);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
buf_LRU_make_block_young(block);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Frees a buffer block which does not contain a file page. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
buf_block_free(
|
|
|
|
/*===========*/
|
|
|
|
buf_block_t* block) /* in, own: block to be freed */
|
|
|
|
{
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state != BUF_BLOCK_FILE_PAGE);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
buf_LRU_block_free_non_file_page(block);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Allocates a buffer frame. */
|
|
|
|
|
|
|
|
buf_frame_t*
|
|
|
|
buf_frame_alloc(void)
|
|
|
|
/*=================*/
|
|
|
|
/* out: buffer frame */
|
|
|
|
{
|
|
|
|
return(buf_block_alloc()->frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Frees a buffer frame which does not contain a file page. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_frame_free(
|
|
|
|
/*===========*/
|
|
|
|
buf_frame_t* frame) /* in: buffer frame */
|
|
|
|
{
|
|
|
|
buf_block_free(buf_block_align(frame));
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Returns the buffer control block if the page can be found in the buffer
|
|
|
|
pool. NOTE that it is possible that the page is not yet read
|
|
|
|
from disk, though. This is a very low-level function: use with care! */
|
|
|
|
|
|
|
|
buf_block_t*
|
|
|
|
buf_page_peek_block(
|
|
|
|
/*================*/
|
|
|
|
/* out: control block if found from page hash table,
|
|
|
|
otherwise NULL; NOTE that the page is not necessarily
|
|
|
|
yet read from disk! */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(block);
|
|
|
|
}
|
|
|
|
|
2002-10-29 23:16:46 +02:00
|
|
|
/************************************************************************
|
|
|
|
Resets the check_index_page_at_flush field of a page if found in the buffer
|
|
|
|
pool. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_reset_check_index_page_at_flush(
|
|
|
|
/*================================*/
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
if (block) {
|
|
|
|
block->check_index_page_at_flush = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/************************************************************************
|
|
|
|
Returns the current state of is_hashed of a page. FALSE if the page is
|
|
|
|
not in the pool. NOTE that this operation does not fix the page in the
|
|
|
|
pool if it is found there. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_page_peek_if_search_hashed(
|
|
|
|
/*===========================*/
|
|
|
|
/* out: TRUE if page hash index is built in search
|
|
|
|
system */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
ibool is_hashed;
|
|
|
|
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
if (!block) {
|
|
|
|
is_hashed = FALSE;
|
|
|
|
} else {
|
|
|
|
is_hashed = block->is_hashed;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(is_hashed);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Returns TRUE if the page can be found in the buffer pool hash table. NOTE
|
|
|
|
that it is possible that the page is not yet read from disk, though. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_page_peek(
|
|
|
|
/*==========*/
|
|
|
|
/* out: TRUE if found from page hash table,
|
|
|
|
NOTE that the page is not necessarily yet read
|
|
|
|
from disk! */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
if (buf_page_peek_block(space, offset)) {
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
2001-06-24 19:33:50 +03:00
|
|
|
/************************************************************************
|
|
|
|
Sets file_page_was_freed TRUE if the page is found in the buffer pool.
|
|
|
|
This function should be called when we free a file page and want the
|
|
|
|
debug version to check that it is not accessed any more unless
|
|
|
|
reallocated. */
|
|
|
|
|
|
|
|
buf_block_t*
|
|
|
|
buf_page_set_file_page_was_freed(
|
|
|
|
/*=============================*/
|
|
|
|
/* out: control block if found from page hash table,
|
|
|
|
otherwise NULL */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
if (block) {
|
|
|
|
block->file_page_was_freed = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(block);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Sets file_page_was_freed FALSE if the page is found in the buffer pool.
|
|
|
|
This function should be called when we free a file page and want the
|
|
|
|
debug version to check that it is not accessed any more unless
|
|
|
|
reallocated. */
|
|
|
|
|
|
|
|
buf_block_t*
|
|
|
|
buf_page_reset_file_page_was_freed(
|
|
|
|
/*===============================*/
|
|
|
|
/* out: control block if found from page hash table,
|
|
|
|
otherwise NULL */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset) /* in: page number */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
if (block) {
|
|
|
|
block->file_page_was_freed = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(block);
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/************************************************************************
|
|
|
|
This is the general function used to get access to a database page. */
|
|
|
|
|
|
|
|
buf_frame_t*
|
|
|
|
buf_page_get_gen(
|
|
|
|
/*=============*/
|
|
|
|
/* out: pointer to the frame or NULL */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset, /* in: page number */
|
|
|
|
ulint rw_latch,/* in: RW_S_LATCH, RW_X_LATCH, RW_NO_LATCH */
|
|
|
|
buf_frame_t* guess, /* in: guessed frame or NULL */
|
|
|
|
ulint mode, /* in: BUF_GET, BUF_GET_IF_IN_POOL,
|
|
|
|
BUF_GET_NO_LATCH, BUF_GET_NOWAIT */
|
2004-05-14 16:06:21 +03:00
|
|
|
const char* file, /* in: file name */
|
2001-02-17 14:19:19 +02:00
|
|
|
ulint line, /* in: line where called */
|
|
|
|
mtr_t* mtr) /* in: mini-transaction */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
ibool accessed;
|
|
|
|
ulint fix_type;
|
|
|
|
ibool success;
|
|
|
|
ibool must_read;
|
|
|
|
|
|
|
|
ut_ad(mtr);
|
|
|
|
ut_ad((rw_latch == RW_S_LATCH)
|
|
|
|
|| (rw_latch == RW_X_LATCH)
|
|
|
|
|| (rw_latch == RW_NO_LATCH));
|
|
|
|
ut_ad((mode != BUF_GET_NO_LATCH) || (rw_latch == RW_NO_LATCH));
|
|
|
|
ut_ad((mode == BUF_GET) || (mode == BUF_GET_IF_IN_POOL)
|
|
|
|
|| (mode == BUF_GET_NO_LATCH) || (mode == BUF_GET_NOWAIT));
|
|
|
|
#ifndef UNIV_LOG_DEBUG
|
|
|
|
ut_ad(!ibuf_inside() || ibuf_page(space, offset));
|
|
|
|
#endif
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
buf_pool->n_page_gets++;
|
2001-02-17 14:19:19 +02:00
|
|
|
loop:
|
|
|
|
mutex_enter_fast(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = NULL;
|
|
|
|
|
|
|
|
if (guess) {
|
|
|
|
block = buf_block_align(guess);
|
|
|
|
|
|
|
|
if ((offset != block->offset) || (space != block->space)
|
|
|
|
|| (block->state != BUF_BLOCK_FILE_PAGE)) {
|
|
|
|
|
|
|
|
block = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (block == NULL) {
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (block == NULL) {
|
|
|
|
/* Page not in buf_pool: needs to be read from file */
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
if (mode == BUF_GET_IF_IN_POOL) {
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
buf_read_page(space, offset);
|
|
|
|
|
2004-02-19 11:40:36 +02:00
|
|
|
#ifdef UNIV_DEBUG
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_dbg_counter++;
|
|
|
|
|
|
|
|
if (buf_dbg_counter % 37 == 0) {
|
|
|
|
ut_ad(buf_validate());
|
|
|
|
}
|
2004-02-19 11:40:36 +02:00
|
|
|
#endif
|
2001-02-17 14:19:19 +02:00
|
|
|
goto loop;
|
|
|
|
}
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state == BUF_BLOCK_FILE_PAGE);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
must_read = FALSE;
|
|
|
|
|
|
|
|
if (block->io_fix == BUF_IO_READ) {
|
|
|
|
|
|
|
|
must_read = TRUE;
|
|
|
|
|
|
|
|
if (mode == BUF_GET_IF_IN_POOL) {
|
|
|
|
|
|
|
|
/* The page is only being read to buffer */
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
/* If AWE is enabled and the page is not mapped to a frame, then
|
|
|
|
map it */
|
|
|
|
|
|
|
|
if (block->frame == NULL) {
|
|
|
|
ut_a(srv_use_awe);
|
|
|
|
|
|
|
|
/* We set second parameter TRUE because the block is in the
|
|
|
|
LRU list and we must put it to awe_LRU_free_mapped list once
|
|
|
|
mapped to a frame */
|
|
|
|
|
|
|
|
buf_awe_map_page_to_frame(block, TRUE);
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
buf_block_buf_fix_inc_debug(block, file, line);
|
|
|
|
#else
|
|
|
|
buf_block_buf_fix_inc(block);
|
|
|
|
#endif
|
|
|
|
buf_block_make_young(block);
|
|
|
|
|
|
|
|
/* Check if this is the first access to the page */
|
|
|
|
|
|
|
|
accessed = block->accessed;
|
|
|
|
|
|
|
|
block->accessed = TRUE;
|
|
|
|
|
2001-06-24 19:33:50 +03:00
|
|
|
#ifdef UNIV_DEBUG_FILE_ACCESSES
|
|
|
|
ut_a(block->file_page_was_freed == FALSE);
|
|
|
|
#endif
|
2001-02-17 14:19:19 +02:00
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
buf_dbg_counter++;
|
|
|
|
|
|
|
|
if (buf_dbg_counter % 5771 == 0) {
|
|
|
|
ut_ad(buf_validate());
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
ut_ad(block->buf_fix_count > 0);
|
|
|
|
ut_ad(block->state == BUF_BLOCK_FILE_PAGE);
|
|
|
|
|
|
|
|
if (mode == BUF_GET_NOWAIT) {
|
|
|
|
if (rw_latch == RW_S_LATCH) {
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_s_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_S_FIX;
|
|
|
|
} else {
|
|
|
|
ut_ad(rw_latch == RW_X_LATCH);
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_x_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_X_FIX;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!success) {
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block->buf_fix_count--;
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
rw_lock_s_unlock(&(block->debug_latch));
|
|
|
|
#endif
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
} else if (rw_latch == RW_NO_LATCH) {
|
|
|
|
|
|
|
|
if (must_read) {
|
2003-01-09 00:10:36 +02:00
|
|
|
/* Let us wait until the read operation
|
|
|
|
completes */
|
|
|
|
|
|
|
|
for (;;) {
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
if (block->io_fix == BUF_IO_READ) {
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
/* Sleep 20 milliseconds */
|
|
|
|
|
|
|
|
os_thread_sleep(20000);
|
|
|
|
} else {
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fix_type = MTR_MEMO_BUF_FIX;
|
|
|
|
} else if (rw_latch == RW_S_LATCH) {
|
|
|
|
|
2001-10-10 22:47:08 +03:00
|
|
|
rw_lock_s_lock_func(&(block->lock), 0, file, line);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_S_FIX;
|
|
|
|
} else {
|
2001-10-10 22:47:08 +03:00
|
|
|
rw_lock_x_lock_func(&(block->lock), 0, file, line);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_X_FIX;
|
|
|
|
}
|
|
|
|
|
|
|
|
mtr_memo_push(mtr, block, fix_type);
|
|
|
|
|
|
|
|
if (!accessed) {
|
|
|
|
/* In the case of a first access, try to apply linear
|
|
|
|
read-ahead */
|
|
|
|
|
|
|
|
buf_read_ahead_linear(space, offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a(ibuf_count_get(block->space, block->offset) == 0);
|
|
|
|
#endif
|
|
|
|
return(block->frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
This is the general function used to get optimistic access to a database
|
|
|
|
page. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_page_optimistic_get_func(
|
|
|
|
/*=========================*/
|
|
|
|
/* out: TRUE if success */
|
|
|
|
ulint rw_latch,/* in: RW_S_LATCH, RW_X_LATCH */
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_block_t* block, /* in: guessed buffer block */
|
|
|
|
buf_frame_t* guess, /* in: guessed frame; note that AWE may move
|
|
|
|
frames */
|
2001-02-17 14:19:19 +02:00
|
|
|
dulint modify_clock,/* in: modify clock value if mode is
|
|
|
|
..._GUESS_ON_CLOCK */
|
2004-05-14 16:06:21 +03:00
|
|
|
const char* file, /* in: file name */
|
2001-02-17 14:19:19 +02:00
|
|
|
ulint line, /* in: line where called */
|
|
|
|
mtr_t* mtr) /* in: mini-transaction */
|
|
|
|
{
|
|
|
|
ibool accessed;
|
|
|
|
ibool success;
|
|
|
|
ulint fix_type;
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
ut_ad(mtr && block);
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_ad((rw_latch == RW_S_LATCH) || (rw_latch == RW_X_LATCH));
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
/* If AWE is used, block may have a different frame now, e.g., NULL */
|
|
|
|
|
|
|
|
if (block->state != BUF_BLOCK_FILE_PAGE || block->frame != guess) {
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
buf_block_buf_fix_inc_debug(block, file, line);
|
|
|
|
#else
|
|
|
|
buf_block_buf_fix_inc(block);
|
|
|
|
#endif
|
|
|
|
buf_block_make_young(block);
|
|
|
|
|
|
|
|
/* Check if this is the first access to the page */
|
|
|
|
|
|
|
|
accessed = block->accessed;
|
|
|
|
|
|
|
|
block->accessed = TRUE;
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
ut_ad(!ibuf_inside() || ibuf_page(block->space, block->offset));
|
|
|
|
|
|
|
|
if (rw_latch == RW_S_LATCH) {
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_s_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_S_FIX;
|
|
|
|
} else {
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_x_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_X_FIX;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!success) {
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block->buf_fix_count--;
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
rw_lock_s_unlock(&(block->debug_latch));
|
|
|
|
#endif
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!UT_DULINT_EQ(modify_clock, block->modify_clock)) {
|
2004-03-12 17:14:51 +02:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
2001-02-17 14:19:19 +02:00
|
|
|
buf_page_dbg_add_level(block->frame, SYNC_NO_ORDER_CHECK);
|
2004-03-12 17:14:51 +02:00
|
|
|
#endif /* UNIV_SYNC_DEBUG */
|
2001-02-17 14:19:19 +02:00
|
|
|
if (rw_latch == RW_S_LATCH) {
|
|
|
|
rw_lock_s_unlock(&(block->lock));
|
|
|
|
} else {
|
|
|
|
rw_lock_x_unlock(&(block->lock));
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block->buf_fix_count--;
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
rw_lock_s_unlock(&(block->debug_latch));
|
|
|
|
#endif
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
mtr_memo_push(mtr, block, fix_type);
|
|
|
|
|
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
buf_dbg_counter++;
|
|
|
|
|
|
|
|
if (buf_dbg_counter % 5771 == 0) {
|
|
|
|
ut_ad(buf_validate());
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
ut_ad(block->buf_fix_count > 0);
|
|
|
|
ut_ad(block->state == BUF_BLOCK_FILE_PAGE);
|
|
|
|
|
2001-06-24 19:33:50 +03:00
|
|
|
#ifdef UNIV_DEBUG_FILE_ACCESSES
|
|
|
|
ut_a(block->file_page_was_freed == FALSE);
|
|
|
|
#endif
|
2001-02-17 14:19:19 +02:00
|
|
|
if (!accessed) {
|
|
|
|
/* In the case of a first access, try to apply linear
|
|
|
|
read-ahead */
|
|
|
|
|
|
|
|
buf_read_ahead_linear(buf_frame_get_space_id(guess),
|
|
|
|
buf_frame_get_page_no(guess));
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a(ibuf_count_get(block->space, block->offset) == 0);
|
|
|
|
#endif
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_page_gets++;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
This is used to get access to a known database page, when no waiting can be
|
2003-01-06 22:07:25 +02:00
|
|
|
done. For example, if a search in an adaptive hash index leads us to this
|
|
|
|
frame. */
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_page_get_known_nowait(
|
|
|
|
/*======================*/
|
|
|
|
/* out: TRUE if success */
|
|
|
|
ulint rw_latch,/* in: RW_S_LATCH, RW_X_LATCH */
|
|
|
|
buf_frame_t* guess, /* in: the known page frame */
|
|
|
|
ulint mode, /* in: BUF_MAKE_YOUNG or BUF_KEEP_OLD */
|
2004-05-14 16:06:21 +03:00
|
|
|
const char* file, /* in: file name */
|
2001-02-17 14:19:19 +02:00
|
|
|
ulint line, /* in: line where called */
|
|
|
|
mtr_t* mtr) /* in: mini-transaction */
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
ibool success;
|
|
|
|
ulint fix_type;
|
|
|
|
|
|
|
|
ut_ad(mtr);
|
|
|
|
ut_ad((rw_latch == RW_S_LATCH) || (rw_latch == RW_X_LATCH));
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
block = buf_block_align(guess);
|
|
|
|
|
2001-03-16 00:22:21 +02:00
|
|
|
if (block->state == BUF_BLOCK_REMOVE_HASH) {
|
|
|
|
/* Another thread is just freeing the block from the LRU list
|
|
|
|
of the buffer pool: do not try to access this page; this
|
|
|
|
attempt to access the page can only come through the hash
|
|
|
|
index because when the buffer block state is ..._REMOVE_HASH,
|
|
|
|
we have already removed it from the page address hash table
|
|
|
|
of the buffer pool. */
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state == BUF_BLOCK_FILE_PAGE);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
buf_block_buf_fix_inc_debug(block, file, line);
|
|
|
|
#else
|
|
|
|
buf_block_buf_fix_inc(block);
|
|
|
|
#endif
|
|
|
|
if (mode == BUF_MAKE_YOUNG) {
|
|
|
|
buf_block_make_young(block);
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
ut_ad(!ibuf_inside() || (mode == BUF_KEEP_OLD));
|
|
|
|
|
|
|
|
if (rw_latch == RW_S_LATCH) {
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_s_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_S_FIX;
|
|
|
|
} else {
|
2001-10-10 22:47:08 +03:00
|
|
|
success = rw_lock_x_lock_func_nowait(&(block->lock),
|
|
|
|
file, line);
|
2001-02-17 14:19:19 +02:00
|
|
|
fix_type = MTR_MEMO_PAGE_X_FIX;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!success) {
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block->buf_fix_count--;
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
|
|
|
rw_lock_s_unlock(&(block->debug_latch));
|
|
|
|
#endif
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
mtr_memo_push(mtr, block, fix_type);
|
|
|
|
|
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
buf_dbg_counter++;
|
|
|
|
|
|
|
|
if (buf_dbg_counter % 5771 == 0) {
|
|
|
|
ut_ad(buf_validate());
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
ut_ad(block->buf_fix_count > 0);
|
|
|
|
ut_ad(block->state == BUF_BLOCK_FILE_PAGE);
|
2001-06-24 19:33:50 +03:00
|
|
|
#ifdef UNIV_DEBUG_FILE_ACCESSES
|
|
|
|
ut_a(block->file_page_was_freed == FALSE);
|
|
|
|
#endif
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a((mode == BUF_KEEP_OLD)
|
|
|
|
|| (ibuf_count_get(block->space, block->offset) == 0));
|
|
|
|
#endif
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_page_gets++;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
2002-06-22 20:41:14 +03:00
|
|
|
/************************************************************************
|
|
|
|
Inits a page to the buffer buf_pool, for use in ibbackup --restore. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_page_init_for_backup_restore(
|
|
|
|
/*=============================*/
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset, /* in: offset of the page within space
|
|
|
|
in units of a page */
|
|
|
|
buf_block_t* block) /* in: block to init */
|
|
|
|
{
|
|
|
|
/* Set the state of the block */
|
|
|
|
block->magic_n = BUF_BLOCK_MAGIC_N;
|
|
|
|
|
|
|
|
block->state = BUF_BLOCK_FILE_PAGE;
|
|
|
|
block->space = space;
|
|
|
|
block->offset = offset;
|
|
|
|
|
|
|
|
block->lock_hash_val = 0;
|
|
|
|
block->lock_mutex = NULL;
|
|
|
|
|
|
|
|
block->freed_page_clock = 0;
|
|
|
|
|
|
|
|
block->newest_modification = ut_dulint_zero;
|
|
|
|
block->oldest_modification = ut_dulint_zero;
|
|
|
|
|
|
|
|
block->accessed = FALSE;
|
|
|
|
block->buf_fix_count = 0;
|
|
|
|
block->io_fix = 0;
|
|
|
|
|
|
|
|
block->n_hash_helps = 0;
|
|
|
|
block->is_hashed = FALSE;
|
|
|
|
block->n_fields = 1;
|
|
|
|
block->n_bytes = 0;
|
|
|
|
block->side = BTR_SEARCH_LEFT_SIDE;
|
|
|
|
|
|
|
|
block->file_page_was_freed = FALSE;
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/************************************************************************
|
|
|
|
Inits a page to the buffer buf_pool. */
|
|
|
|
static
|
|
|
|
void
|
|
|
|
buf_page_init(
|
|
|
|
/*==========*/
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset, /* in: offset of the page within space
|
|
|
|
in units of a page */
|
|
|
|
buf_block_t* block) /* in: block to init */
|
|
|
|
{
|
2004-03-12 17:14:51 +02:00
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_ad(mutex_own(&(buf_pool->mutex)));
|
2004-03-12 17:14:51 +02:00
|
|
|
#endif /* UNIV_SYNC_DEBUG */
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state != BUF_BLOCK_FILE_PAGE);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
/* Set the state of the block */
|
2002-06-22 20:41:14 +03:00
|
|
|
block->magic_n = BUF_BLOCK_MAGIC_N;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
block->state = BUF_BLOCK_FILE_PAGE;
|
|
|
|
block->space = space;
|
|
|
|
block->offset = offset;
|
|
|
|
|
2002-10-29 23:16:46 +02:00
|
|
|
block->check_index_page_at_flush = FALSE;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
block->lock_hash_val = lock_rec_hash(space, offset);
|
|
|
|
block->lock_mutex = NULL;
|
|
|
|
|
|
|
|
/* Insert into the hash table of file pages */
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
if (buf_page_hash_get(space, offset)) {
|
|
|
|
fprintf(stderr,
|
2003-12-20 03:41:04 +02:00
|
|
|
"InnoDB: Error: page %lu %lu already found from the hash table\n",
|
|
|
|
(ulong) space,
|
|
|
|
(ulong) offset);
|
2004-04-27 15:33:40 +03:00
|
|
|
#ifdef UNIV_DEBUG
|
2003-10-13 11:20:19 +03:00
|
|
|
buf_print();
|
|
|
|
buf_LRU_print();
|
|
|
|
buf_validate();
|
|
|
|
buf_LRU_validate();
|
2004-04-27 15:33:40 +03:00
|
|
|
#endif /* UNIV_DEBUG */
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(0);
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
HASH_INSERT(buf_block_t, hash, buf_pool->page_hash,
|
|
|
|
buf_page_address_fold(space, offset), block);
|
|
|
|
|
|
|
|
block->freed_page_clock = 0;
|
|
|
|
|
|
|
|
block->newest_modification = ut_dulint_zero;
|
|
|
|
block->oldest_modification = ut_dulint_zero;
|
|
|
|
|
|
|
|
block->accessed = FALSE;
|
|
|
|
block->buf_fix_count = 0;
|
|
|
|
block->io_fix = 0;
|
|
|
|
|
|
|
|
block->n_hash_helps = 0;
|
|
|
|
block->is_hashed = FALSE;
|
2001-12-14 18:50:43 +02:00
|
|
|
block->n_fields = 1;
|
|
|
|
block->n_bytes = 0;
|
|
|
|
block->side = BTR_SEARCH_LEFT_SIDE;
|
2001-06-24 19:33:50 +03:00
|
|
|
|
|
|
|
block->file_page_was_freed = FALSE;
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Function which inits a page for read to the buffer buf_pool. If the page is
|
2003-10-07 17:28:59 +03:00
|
|
|
(1) already in buf_pool, or
|
|
|
|
(2) if we specify to read only ibuf pages and the page is not an ibuf page, or
|
|
|
|
(3) if the space is deleted or being deleted,
|
|
|
|
then this function does nothing.
|
|
|
|
Sets the io_fix flag to BUF_IO_READ and sets a non-recursive exclusive lock
|
|
|
|
on the buffer frame. The io-handler must take care that the flag is cleared
|
|
|
|
and the lock released later. This is one of the functions which perform the
|
|
|
|
state transition NOT_USED => FILE_PAGE to a block (the other is
|
|
|
|
buf_page_create). */
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
buf_block_t*
|
|
|
|
buf_page_init_for_read(
|
|
|
|
/*===================*/
|
2003-10-07 17:28:59 +03:00
|
|
|
/* out: pointer to the block or NULL */
|
|
|
|
ulint* err, /* out: DB_SUCCESS or DB_TABLESPACE_DELETED */
|
|
|
|
ulint mode, /* in: BUF_READ_IBUF_PAGES_ONLY, ... */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ib_longlong tablespace_version,/* in: prevents reading from a wrong
|
|
|
|
version of the tablespace in case we have done
|
|
|
|
DISCARD + IMPORT */
|
|
|
|
ulint offset) /* in: page number */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
mtr_t mtr;
|
2003-10-07 17:28:59 +03:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_ad(buf_pool);
|
|
|
|
|
2003-10-07 17:28:59 +03:00
|
|
|
*err = DB_SUCCESS;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
if (mode == BUF_READ_IBUF_PAGES_ONLY) {
|
|
|
|
/* It is a read-ahead within an ibuf routine */
|
|
|
|
|
|
|
|
ut_ad(!ibuf_bitmap_page(offset));
|
|
|
|
ut_ad(ibuf_inside());
|
|
|
|
|
|
|
|
mtr_start(&mtr);
|
|
|
|
|
|
|
|
if (!ibuf_page_low(space, offset, &mtr)) {
|
|
|
|
|
|
|
|
mtr_commit(&mtr);
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ut_ad(mode == BUF_READ_ANY_PAGE);
|
|
|
|
}
|
|
|
|
|
|
|
|
block = buf_block_alloc();
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
2003-10-07 17:28:59 +03:00
|
|
|
if (fil_tablespace_deleted_or_being_deleted_in_mem(space,
|
|
|
|
tablespace_version)) {
|
|
|
|
*err = DB_TABLESPACE_DELETED;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (*err == DB_TABLESPACE_DELETED
|
|
|
|
|| NULL != buf_page_hash_get(space, offset)) {
|
|
|
|
|
|
|
|
/* The page belongs to a space which has been deleted or is
|
|
|
|
being deleted, or the page is already in buf_pool, return */
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
buf_block_free(block);
|
|
|
|
|
|
|
|
if (mode == BUF_READ_IBUF_PAGES_ONLY) {
|
|
|
|
|
|
|
|
mtr_commit(&mtr);
|
|
|
|
}
|
|
|
|
|
|
|
|
return(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
ut_ad(block);
|
|
|
|
|
|
|
|
buf_page_init(space, offset, block);
|
|
|
|
|
|
|
|
/* The block must be put to the LRU list, to the old blocks */
|
|
|
|
|
|
|
|
buf_LRU_add_block(block, TRUE); /* TRUE == to old blocks */
|
|
|
|
|
|
|
|
block->io_fix = BUF_IO_READ;
|
|
|
|
buf_pool->n_pend_reads++;
|
|
|
|
|
|
|
|
/* We set a pass-type x-lock on the frame because then the same
|
|
|
|
thread which called for the read operation (and is running now at
|
|
|
|
this point of code) can wait for the read to complete by waiting
|
|
|
|
for the x-lock on the frame; if the x-lock were recursive, the
|
|
|
|
same thread would illegally get the x-lock before the page read
|
|
|
|
is completed. The x-lock is cleared by the io-handler thread. */
|
|
|
|
|
|
|
|
rw_lock_x_lock_gen(&(block->lock), BUF_IO_READ);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
if (mode == BUF_READ_IBUF_PAGES_ONLY) {
|
|
|
|
|
|
|
|
mtr_commit(&mtr);
|
|
|
|
}
|
|
|
|
|
|
|
|
return(block);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Initializes a page to the buffer buf_pool. The page is usually not read
|
|
|
|
from a file even if it cannot be found in the buffer buf_pool. This is one
|
|
|
|
of the functions which perform to a block a state transition NOT_USED =>
|
|
|
|
FILE_PAGE (the other is buf_page_init_for_read above). */
|
|
|
|
|
|
|
|
buf_frame_t*
|
|
|
|
buf_page_create(
|
|
|
|
/*============*/
|
|
|
|
/* out: pointer to the frame, page bufferfixed */
|
|
|
|
ulint space, /* in: space id */
|
|
|
|
ulint offset, /* in: offset of the page within space in units of
|
|
|
|
a page */
|
|
|
|
mtr_t* mtr) /* in: mini-transaction handle */
|
|
|
|
{
|
|
|
|
buf_frame_t* frame;
|
|
|
|
buf_block_t* block;
|
|
|
|
buf_block_t* free_block = NULL;
|
|
|
|
|
|
|
|
ut_ad(mtr);
|
|
|
|
|
|
|
|
free_block = buf_LRU_get_free_block();
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
block = buf_page_hash_get(space, offset);
|
|
|
|
|
|
|
|
if (block != NULL) {
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a(ibuf_count_get(block->space, block->offset) == 0);
|
|
|
|
#endif
|
2001-06-24 19:33:50 +03:00
|
|
|
block->file_page_was_freed = FALSE;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/* Page can be found in buf_pool */
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
buf_block_free(free_block);
|
|
|
|
|
|
|
|
frame = buf_page_get_with_no_latch(space, offset, mtr);
|
|
|
|
|
|
|
|
return(frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If we get here, the page was not in buf_pool: init it there */
|
|
|
|
|
|
|
|
if (buf_debug_prints) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr, "Creating space %lu page %lu to buffer\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) space, (ulong) offset);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
block = free_block;
|
|
|
|
|
|
|
|
buf_page_init(space, offset, block);
|
|
|
|
|
|
|
|
/* The block must be put to the LRU list */
|
|
|
|
buf_LRU_add_block(block, FALSE);
|
|
|
|
|
|
|
|
#ifdef UNIV_SYNC_DEBUG
|
2004-05-14 16:06:21 +03:00
|
|
|
buf_block_buf_fix_inc_debug(block, __FILE__, __LINE__);
|
2001-02-17 14:19:19 +02:00
|
|
|
#else
|
|
|
|
buf_block_buf_fix_inc(block);
|
|
|
|
#endif
|
|
|
|
mtr_memo_push(mtr, block, MTR_MEMO_BUF_FIX);
|
|
|
|
|
|
|
|
block->accessed = TRUE;
|
|
|
|
|
|
|
|
buf_pool->n_pages_created++;
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
2002-11-07 21:04:26 +02:00
|
|
|
/* Delete possible entries for the page from the insert buffer:
|
|
|
|
such can exist if the page belonged to an index which was dropped */
|
|
|
|
|
2003-10-07 17:28:59 +03:00
|
|
|
ibuf_merge_or_delete_for_page(NULL, space, offset, TRUE);
|
2002-11-07 21:04:26 +02:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/* Flush pages from the end of the LRU list if necessary */
|
|
|
|
buf_flush_free_margin();
|
|
|
|
|
|
|
|
frame = block->frame;
|
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
buf_dbg_counter++;
|
|
|
|
|
|
|
|
if (buf_dbg_counter % 357 == 0) {
|
|
|
|
ut_ad(buf_validate());
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a(ibuf_count_get(block->space, block->offset) == 0);
|
|
|
|
#endif
|
|
|
|
return(frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
Completes an asynchronous read or write request of a file page to or from
|
|
|
|
the buffer pool. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_page_io_complete(
|
|
|
|
/*=================*/
|
|
|
|
buf_block_t* block) /* in: pointer to the block in question */
|
|
|
|
{
|
|
|
|
ulint io_type;
|
2002-03-21 18:03:09 +02:00
|
|
|
ulint read_page_no;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_ad(block);
|
|
|
|
|
2003-10-13 11:20:19 +03:00
|
|
|
ut_a(block->state == BUF_BLOCK_FILE_PAGE);
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
io_type = block->io_fix;
|
|
|
|
|
|
|
|
if (io_type == BUF_IO_READ) {
|
2002-03-21 18:03:09 +02:00
|
|
|
/* If this page is not uninitialized and not in the
|
|
|
|
doublewrite buffer, then the page number should be the
|
|
|
|
same as in block */
|
|
|
|
|
|
|
|
read_page_no = mach_read_from_4((block->frame)
|
|
|
|
+ FIL_PAGE_OFFSET);
|
|
|
|
if (read_page_no != 0
|
|
|
|
&& !trx_doublewrite_page_inside(read_page_no)
|
|
|
|
&& read_page_no != block->offset) {
|
|
|
|
|
|
|
|
fprintf(stderr,
|
|
|
|
"InnoDB: Error: page n:o stored in the page read in is %lu, should be %lu!\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) read_page_no, (ulong) block->offset);
|
2002-03-21 18:03:09 +02:00
|
|
|
}
|
2001-05-01 20:57:49 +03:00
|
|
|
/* From version 3.23.38 up we store the page checksum
|
2002-03-21 18:03:09 +02:00
|
|
|
to the 4 first bytes of the page end lsn field */
|
2001-05-01 20:57:49 +03:00
|
|
|
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
if (buf_page_is_corrupted(block->frame)) {
|
|
|
|
fprintf(stderr,
|
2002-03-21 18:03:09 +02:00
|
|
|
"InnoDB: Database page corruption on disk or a failed\n"
|
2003-12-20 03:41:04 +02:00
|
|
|
"InnoDB: file read of page %lu.\n", (ulong) block->offset);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs(
|
|
|
|
"InnoDB: You may have to recover from a backup.\n", stderr);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
|
|
|
buf_page_print(block->frame);
|
|
|
|
|
|
|
|
fprintf(stderr,
|
2002-03-21 18:03:09 +02:00
|
|
|
"InnoDB: Database page corruption on disk or a failed\n"
|
2003-12-20 03:41:04 +02:00
|
|
|
"InnoDB: file read of page %lu.\n", (ulong) block->offset);
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs(
|
|
|
|
"InnoDB: You may have to recover from a backup.\n", stderr);
|
|
|
|
fputs(
|
2002-03-21 18:03:09 +02:00
|
|
|
"InnoDB: It is also possible that your operating\n"
|
|
|
|
"InnoDB: system has corrupted its own file cache\n"
|
|
|
|
"InnoDB: and rebooting your computer removes the\n"
|
|
|
|
"InnoDB: error.\n"
|
|
|
|
"InnoDB: If the corrupt page is an index page\n"
|
|
|
|
"InnoDB: you can also try to fix the corruption\n"
|
|
|
|
"InnoDB: by dumping, dropping, and reimporting\n"
|
|
|
|
"InnoDB: the corrupt table. You can use CHECK\n"
|
|
|
|
"InnoDB: TABLE to scan your table for corruption.\n"
|
2004-09-08 14:24:13 +03:00
|
|
|
"InnoDB: See also "
|
|
|
|
"http://dev.mysql.com/doc/mysql/en/Forcing_recovery.html\n"
|
|
|
|
"InnoDB: about forcing recovery.\n", stderr);
|
2001-10-10 22:47:08 +03:00
|
|
|
|
2002-03-21 18:03:09 +02:00
|
|
|
if (srv_force_recovery < SRV_FORCE_IGNORE_CORRUPT) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs(
|
|
|
|
"InnoDB: Ending processing because of a corrupt database page.\n",
|
|
|
|
stderr);
|
2001-10-10 22:47:08 +03:00
|
|
|
exit(1);
|
|
|
|
}
|
2001-05-01 20:57:49 +03:00
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
if (recv_recovery_is_on()) {
|
2002-03-21 18:03:09 +02:00
|
|
|
recv_recover_page(FALSE, TRUE, block->frame,
|
|
|
|
block->space, block->offset);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!recv_no_ibuf_operations) {
|
|
|
|
ibuf_merge_or_delete_for_page(block->frame,
|
2003-10-07 17:28:59 +03:00
|
|
|
block->space, block->offset, TRUE);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a(ibuf_count_get(block->space, block->offset) == 0);
|
|
|
|
#endif
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
/* Because this thread which does the unlocking is not the same that
|
|
|
|
did the locking, we use a pass value != 0 in unlock, which simply
|
|
|
|
removes the newest lock debug record, without checking the thread
|
|
|
|
id. */
|
|
|
|
|
|
|
|
block->io_fix = 0;
|
|
|
|
|
|
|
|
if (io_type == BUF_IO_READ) {
|
|
|
|
/* NOTE that the call to ibuf may have moved the ownership of
|
|
|
|
the x-latch to this OS thread: do not let this confuse you in
|
|
|
|
debugging! */
|
|
|
|
|
|
|
|
ut_ad(buf_pool->n_pend_reads > 0);
|
|
|
|
buf_pool->n_pend_reads--;
|
|
|
|
buf_pool->n_pages_read++;
|
|
|
|
|
|
|
|
rw_lock_x_unlock_gen(&(block->lock), BUF_IO_READ);
|
|
|
|
|
|
|
|
if (buf_debug_prints) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("Has read ", stderr);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ut_ad(io_type == BUF_IO_WRITE);
|
|
|
|
|
|
|
|
/* Write means a flush operation: call the completion
|
|
|
|
routine in the flush system */
|
|
|
|
|
|
|
|
buf_flush_write_complete(block);
|
|
|
|
|
|
|
|
rw_lock_s_unlock_gen(&(block->lock), BUF_IO_WRITE);
|
|
|
|
|
|
|
|
buf_pool->n_pages_written++;
|
|
|
|
|
|
|
|
if (buf_debug_prints) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("Has written ", stderr);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
if (buf_debug_prints) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr, "page space %lu page no %lu\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) block->space, (ulong) block->offset);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Invalidates the file pages in the buffer pool when an archive recovery is
|
|
|
|
completed. All the file pages buffered must be in a replaceable state when
|
|
|
|
this function is called: not latched and not modified. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_pool_invalidate(void)
|
|
|
|
/*=====================*/
|
|
|
|
{
|
|
|
|
ibool freed;
|
|
|
|
|
|
|
|
ut_ad(buf_all_freed());
|
|
|
|
|
|
|
|
freed = TRUE;
|
|
|
|
|
|
|
|
while (freed) {
|
2003-05-16 16:27:50 +03:00
|
|
|
freed = buf_LRU_search_and_free_block(100);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
ut_ad(UT_LIST_GET_LEN(buf_pool->LRU) == 0);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Validates the buffer buf_pool data structure. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_validate(void)
|
|
|
|
/*==============*/
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
ulint i;
|
|
|
|
ulint n_single_flush = 0;
|
|
|
|
ulint n_lru_flush = 0;
|
|
|
|
ulint n_list_flush = 0;
|
|
|
|
ulint n_lru = 0;
|
|
|
|
ulint n_flush = 0;
|
|
|
|
ulint n_free = 0;
|
|
|
|
ulint n_page = 0;
|
|
|
|
|
|
|
|
ut_ad(buf_pool);
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
for (i = 0; i < buf_pool->curr_size; i++) {
|
|
|
|
|
|
|
|
block = buf_pool_get_nth_block(buf_pool, i);
|
|
|
|
|
|
|
|
if (block->state == BUF_BLOCK_FILE_PAGE) {
|
|
|
|
|
|
|
|
ut_a(buf_page_hash_get(block->space,
|
|
|
|
block->offset) == block);
|
|
|
|
n_page++;
|
|
|
|
|
|
|
|
#ifdef UNIV_IBUF_DEBUG
|
|
|
|
ut_a((block->io_fix == BUF_IO_READ)
|
|
|
|
|| ibuf_count_get(block->space, block->offset)
|
|
|
|
== 0);
|
|
|
|
#endif
|
|
|
|
if (block->io_fix == BUF_IO_WRITE) {
|
|
|
|
|
|
|
|
if (block->flush_type == BUF_FLUSH_LRU) {
|
|
|
|
n_lru_flush++;
|
|
|
|
ut_a(rw_lock_is_locked(&(block->lock),
|
|
|
|
RW_LOCK_SHARED));
|
|
|
|
} else if (block->flush_type ==
|
|
|
|
BUF_FLUSH_LIST) {
|
|
|
|
n_list_flush++;
|
|
|
|
} else if (block->flush_type ==
|
|
|
|
BUF_FLUSH_SINGLE_PAGE) {
|
|
|
|
n_single_flush++;
|
|
|
|
} else {
|
|
|
|
ut_error;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else if (block->io_fix == BUF_IO_READ) {
|
|
|
|
|
|
|
|
ut_a(rw_lock_is_locked(&(block->lock),
|
|
|
|
RW_LOCK_EX));
|
|
|
|
}
|
|
|
|
|
|
|
|
n_lru++;
|
|
|
|
|
|
|
|
if (ut_dulint_cmp(block->oldest_modification,
|
|
|
|
ut_dulint_zero) > 0) {
|
|
|
|
n_flush++;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else if (block->state == BUF_BLOCK_NOT_USED) {
|
|
|
|
n_free++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (n_lru + n_free > buf_pool->curr_size) {
|
2004-04-26 15:53:31 +03:00
|
|
|
fprintf(stderr, "n LRU %lu, n free %lu\n", (ulong) n_lru, (ulong) n_free);
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_error;
|
|
|
|
}
|
|
|
|
|
|
|
|
ut_a(UT_LIST_GET_LEN(buf_pool->LRU) == n_lru);
|
|
|
|
if (UT_LIST_GET_LEN(buf_pool->free) != n_free) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr, "Free list len %lu, free blocks %lu\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->free), (ulong) n_free);
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_error;
|
|
|
|
}
|
|
|
|
ut_a(UT_LIST_GET_LEN(buf_pool->flush_list) == n_flush);
|
|
|
|
|
|
|
|
ut_a(buf_pool->n_flush[BUF_FLUSH_SINGLE_PAGE] == n_single_flush);
|
|
|
|
ut_a(buf_pool->n_flush[BUF_FLUSH_LIST] == n_list_flush);
|
|
|
|
ut_a(buf_pool->n_flush[BUF_FLUSH_LRU] == n_lru_flush);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
ut_a(buf_LRU_validate());
|
|
|
|
ut_a(buf_flush_validate());
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Prints info of the buffer buf_pool data structure. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_print(void)
|
|
|
|
/*===========*/
|
|
|
|
{
|
|
|
|
dulint* index_ids;
|
|
|
|
ulint* counts;
|
|
|
|
ulint size;
|
|
|
|
ulint i;
|
|
|
|
ulint j;
|
|
|
|
dulint id;
|
|
|
|
ulint n_found;
|
|
|
|
buf_frame_t* frame;
|
|
|
|
dict_index_t* index;
|
|
|
|
|
|
|
|
ut_ad(buf_pool);
|
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
size = buf_pool->curr_size;
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
index_ids = mem_alloc(sizeof(dulint) * size);
|
|
|
|
counts = mem_alloc(sizeof(ulint) * size);
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr,
|
2004-04-26 15:53:31 +03:00
|
|
|
"buf_pool size %lu\n"
|
|
|
|
"database pages %lu\n"
|
|
|
|
"free pages %lu\n"
|
|
|
|
"modified database pages %lu\n"
|
|
|
|
"n pending reads %lu\n"
|
2004-04-06 16:14:43 +03:00
|
|
|
"n pending flush LRU %lu list %lu single page %lu\n"
|
|
|
|
"pages read %lu, created %lu, written %lu\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) size,
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->LRU),
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->free),
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->flush_list),
|
|
|
|
(ulong) buf_pool->n_pend_reads,
|
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_LRU],
|
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_LIST],
|
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_SINGLE_PAGE],
|
|
|
|
(ulong) buf_pool->n_pages_read, buf_pool->n_pages_created,
|
|
|
|
(ulong) buf_pool->n_pages_written);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
/* Count the number of blocks belonging to each index in the buffer */
|
|
|
|
|
|
|
|
n_found = 0;
|
|
|
|
|
|
|
|
for (i = 0 ; i < size; i++) {
|
|
|
|
counts[i] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < size; i++) {
|
|
|
|
frame = buf_pool_get_nth_block(buf_pool, i)->frame;
|
|
|
|
|
|
|
|
if (fil_page_get_type(frame) == FIL_PAGE_INDEX) {
|
|
|
|
|
|
|
|
id = btr_page_get_index_id(frame);
|
|
|
|
|
|
|
|
/* Look for the id in the index_ids array */
|
|
|
|
j = 0;
|
|
|
|
|
|
|
|
while (j < n_found) {
|
|
|
|
|
|
|
|
if (ut_dulint_cmp(index_ids[j], id) == 0) {
|
|
|
|
(counts[j])++;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (j == n_found) {
|
|
|
|
n_found++;
|
|
|
|
index_ids[j] = id;
|
|
|
|
counts[j] = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
for (i = 0; i < n_found; i++) {
|
|
|
|
index = dict_index_get_if_in_cache(index_ids[i]);
|
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr,
|
|
|
|
"Block count for index %lu in buffer is about %lu",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) ut_dulint_get_low(index_ids[i]),
|
|
|
|
(ulong) counts[i]);
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
if (index) {
|
2004-04-06 16:14:43 +03:00
|
|
|
putc(' ', stderr);
|
2004-10-01 11:51:59 +03:00
|
|
|
dict_index_name_print(stderr, NULL, index);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
putc('\n', stderr);
|
2001-02-17 14:19:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
mem_free(index_ids);
|
|
|
|
mem_free(counts);
|
|
|
|
|
|
|
|
ut_a(buf_validate());
|
|
|
|
}
|
|
|
|
|
2001-10-10 22:47:08 +03:00
|
|
|
/*************************************************************************
|
|
|
|
Returns the number of pending buf pool ios. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
buf_get_n_pending_ios(void)
|
|
|
|
/*=======================*/
|
|
|
|
{
|
|
|
|
return(buf_pool->n_pend_reads
|
|
|
|
+ buf_pool->n_flush[BUF_FLUSH_LRU]
|
|
|
|
+ buf_pool->n_flush[BUF_FLUSH_LIST]
|
|
|
|
+ buf_pool->n_flush[BUF_FLUSH_SINGLE_PAGE]);
|
|
|
|
}
|
|
|
|
|
2003-05-03 19:44:46 +03:00
|
|
|
/*************************************************************************
|
|
|
|
Returns the ratio in percents of modified pages in the buffer pool /
|
|
|
|
database pages in the buffer pool. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
buf_get_modified_ratio_pct(void)
|
|
|
|
/*============================*/
|
|
|
|
{
|
|
|
|
ulint ratio;
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
ratio = (100 * UT_LIST_GET_LEN(buf_pool->flush_list))
|
2003-05-17 16:23:46 +03:00
|
|
|
/ (1 + UT_LIST_GET_LEN(buf_pool->LRU)
|
|
|
|
+ UT_LIST_GET_LEN(buf_pool->free));
|
2003-05-03 19:44:46 +03:00
|
|
|
|
|
|
|
/* 1 + is there to avoid division by zero */
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(ratio);
|
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Prints info of the buffer i/o. */
|
|
|
|
|
|
|
|
void
|
2002-07-08 19:34:49 +03:00
|
|
|
buf_print_io(
|
|
|
|
/*=========*/
|
2004-04-06 16:14:43 +03:00
|
|
|
FILE* file) /* in/out: buffer where to print */
|
2001-02-17 14:19:19 +02:00
|
|
|
{
|
2001-10-10 22:47:08 +03:00
|
|
|
time_t current_time;
|
|
|
|
double time_elapsed;
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
ulint size;
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_ad(buf_pool);
|
2003-01-06 22:07:25 +02:00
|
|
|
size = buf_pool->curr_size;
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
mutex_enter(&(buf_pool->mutex));
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
if (srv_use_awe) {
|
2004-04-26 15:53:31 +03:00
|
|
|
fprintf(stderr,
|
2003-01-06 22:07:25 +02:00
|
|
|
"AWE: Buffer pool memory frames %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) buf_pool->n_frames);
|
2003-01-06 22:07:25 +02:00
|
|
|
|
2004-04-26 15:53:31 +03:00
|
|
|
fprintf(stderr,
|
2003-01-06 22:07:25 +02:00
|
|
|
"AWE: Database pages and free buffers mapped in frames %lu\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->awe_LRU_free_mapped));
|
2003-01-06 22:07:25 +02:00
|
|
|
}
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(file,
|
|
|
|
"Buffer pool size %lu\n"
|
|
|
|
"Free buffers %lu\n"
|
|
|
|
"Database pages %lu\n"
|
|
|
|
"Modified db pages %lu\n"
|
2004-04-26 15:53:31 +03:00
|
|
|
"Pending reads %lu\n"
|
2002-07-08 19:34:49 +03:00
|
|
|
"Pending writes: LRU %lu, flush list %lu, single page %lu\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) size,
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->free),
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->LRU),
|
|
|
|
(ulong) UT_LIST_GET_LEN(buf_pool->flush_list),
|
|
|
|
(ulong) buf_pool->n_pend_reads,
|
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_LRU]
|
|
|
|
+ buf_pool->init_flush[BUF_FLUSH_LRU],
|
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_LIST]
|
|
|
|
+ buf_pool->init_flush[BUF_FLUSH_LIST],
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) buf_pool->n_flush[BUF_FLUSH_SINGLE_PAGE]);
|
srv0srv.h Support raw disk partitions as data files
srv0start.c Support raw disk partitions as data files
srv0srv.c Support raw disk partitions as data files
row0purge.c < 4 GB rows, doublewrite, hang fixes
row0row.c < 4 GB rows, doublewrite, hang fixes
row0sel.c < 4 GB rows, doublewrite, hang fixes
row0uins.c < 4 GB rows, doublewrite, hang fixes
row0umod.c < 4 GB rows, doublewrite, hang fixes
row0undo.c < 4 GB rows, doublewrite, hang fixes
row0upd.c < 4 GB rows, doublewrite, hang fixes
srv0srv.c < 4 GB rows, doublewrite, hang fixes
srv0start.c < 4 GB rows, doublewrite, hang fixes
sync0rw.c < 4 GB rows, doublewrite, hang fixes
sync0sync.c < 4 GB rows, doublewrite, hang fixes
trx0purge.c < 4 GB rows, doublewrite, hang fixes
trx0rec.c < 4 GB rows, doublewrite, hang fixes
trx0sys.c < 4 GB rows, doublewrite, hang fixes
btr0btr.c < 4 GB rows, doublewrite, hang fixes
btr0cur.c < 4 GB rows, doublewrite, hang fixes
buf0buf.c < 4 GB rows, doublewrite, hang fixes
buf0flu.c < 4 GB rows, doublewrite, hang fixes
buf0rea.c < 4 GB rows, doublewrite, hang fixes
data0data.c < 4 GB rows, doublewrite, hang fixes
fil0fil.c < 4 GB rows, doublewrite, hang fixes
fsp0fsp.c < 4 GB rows, doublewrite, hang fixes
ibuf0ibuf.c < 4 GB rows, doublewrite, hang fixes
lock0lock.c < 4 GB rows, doublewrite, hang fixes
log0log.c < 4 GB rows, doublewrite, hang fixes
log0recv.c < 4 GB rows, doublewrite, hang fixes
os0file.c < 4 GB rows, doublewrite, hang fixes
page0cur.c < 4 GB rows, doublewrite, hang fixes
pars0pars.c < 4 GB rows, doublewrite, hang fixes
rem0cmp.c < 4 GB rows, doublewrite, hang fixes
rem0rec.c < 4 GB rows, doublewrite, hang fixes
row0ins.c < 4 GB rows, doublewrite, hang fixes
row0mysql.c < 4 GB rows, doublewrite, hang fixes
univ.i < 4 GB rows, doublewrite, hang fixes
data0data.ic < 4 GB rows, doublewrite, hang fixes
mach0data.ic < 4 GB rows, doublewrite, hang fixes
rem0rec.ic < 4 GB rows, doublewrite, hang fixes
row0upd.ic < 4 GB rows, doublewrite, hang fixes
trx0rec.ic < 4 GB rows, doublewrite, hang fixes
rem0cmp.h < 4 GB rows, doublewrite, hang fixes
rem0rec.h < 4 GB rows, doublewrite, hang fixes
row0ins.h < 4 GB rows, doublewrite, hang fixes
row0mysql.h < 4 GB rows, doublewrite, hang fixes
row0row.h < 4 GB rows, doublewrite, hang fixes
row0upd.h < 4 GB rows, doublewrite, hang fixes
srv0srv.h < 4 GB rows, doublewrite, hang fixes
sync0sync.h < 4 GB rows, doublewrite, hang fixes
trx0rec.h < 4 GB rows, doublewrite, hang fixes
trx0sys.h < 4 GB rows, doublewrite, hang fixes
trx0types.h < 4 GB rows, doublewrite, hang fixes
trx0undo.h < 4 GB rows, doublewrite, hang fixes
ut0dbg.h < 4 GB rows, doublewrite, hang fixes
ut0ut.h < 4 GB rows, doublewrite, hang fixes
btr0btr.h < 4 GB rows, doublewrite, hang fixes
btr0cur.h < 4 GB rows, doublewrite, hang fixes
buf0buf.h < 4 GB rows, doublewrite, hang fixes
buf0flu.h < 4 GB rows, doublewrite, hang fixes
data0data.h < 4 GB rows, doublewrite, hang fixes
dict0mem.h < 4 GB rows, doublewrite, hang fixes
fil0fil.h < 4 GB rows, doublewrite, hang fixes
fsp0fsp.h < 4 GB rows, doublewrite, hang fixes
os0file.h < 4 GB rows, doublewrite, hang fixes
2001-08-04 19:36:14 +03:00
|
|
|
|
2001-10-10 22:47:08 +03:00
|
|
|
current_time = time(NULL);
|
2002-08-06 22:59:13 +03:00
|
|
|
time_elapsed = 0.001 + difftime(current_time,
|
|
|
|
buf_pool->last_printout_time);
|
2001-10-10 22:47:08 +03:00
|
|
|
buf_pool->last_printout_time = current_time;
|
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(file,
|
|
|
|
"Pages read %lu, created %lu, written %lu\n"
|
|
|
|
"%.2f reads/s, %.2f creates/s, %.2f writes/s\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) buf_pool->n_pages_read,
|
|
|
|
(ulong) buf_pool->n_pages_created,
|
|
|
|
(ulong) buf_pool->n_pages_written,
|
2001-10-10 22:47:08 +03:00
|
|
|
(buf_pool->n_pages_read - buf_pool->n_pages_read_old)
|
|
|
|
/ time_elapsed,
|
|
|
|
(buf_pool->n_pages_created - buf_pool->n_pages_created_old)
|
|
|
|
/ time_elapsed,
|
|
|
|
(buf_pool->n_pages_written - buf_pool->n_pages_written_old)
|
|
|
|
/ time_elapsed);
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
|
2003-01-06 22:07:25 +02:00
|
|
|
if (srv_use_awe) {
|
2004-04-27 15:33:40 +03:00
|
|
|
fprintf(file, "AWE: %.2f page remaps/s\n",
|
2003-01-06 22:07:25 +02:00
|
|
|
(buf_pool->n_pages_awe_remapped
|
|
|
|
- buf_pool->n_pages_awe_remapped_old)
|
|
|
|
/ time_elapsed);
|
|
|
|
}
|
|
|
|
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
if (buf_pool->n_page_gets > buf_pool->n_page_gets_old) {
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(file, "Buffer pool hit rate %lu / 1000\n",
|
2003-12-20 03:41:04 +02:00
|
|
|
(ulong) (1000
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
- ((1000 *
|
|
|
|
(buf_pool->n_pages_read - buf_pool->n_pages_read_old))
|
2003-12-20 03:41:04 +02:00
|
|
|
/ (buf_pool->n_page_gets - buf_pool->n_page_gets_old))));
|
2001-10-10 22:47:08 +03:00
|
|
|
} else {
|
2004-04-06 16:14:43 +03:00
|
|
|
fputs("No buffer pool page gets since the last printout\n",
|
|
|
|
file);
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
buf_pool->n_page_gets_old = buf_pool->n_page_gets;
|
|
|
|
buf_pool->n_pages_read_old = buf_pool->n_pages_read;
|
2001-10-10 22:47:08 +03:00
|
|
|
buf_pool->n_pages_created_old = buf_pool->n_pages_created;
|
|
|
|
buf_pool->n_pages_written_old = buf_pool->n_pages_written;
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_pages_awe_remapped_old = buf_pool->n_pages_awe_remapped;
|
trx0roll.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0mysql.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0purge.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0sel.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0uins.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0umod.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
row0upd.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0start.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
sync0arr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
fil0fil.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ibuf0ibuf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
lock0lock.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
os0file.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0btr.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0sea.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.c Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
srv0srv.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0sys.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
trx0trx.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
btr0cur.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
buf0buf.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
data0data.h Fix the primary key update + BLOB bug, improve InnoDB Monitor prints
ha_innobase.cc Fix the auto-inc+REPLACE+replication bug, improve InnoDB Monitor prints
2001-08-29 19:42:23 +03:00
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
}
|
|
|
|
|
2002-08-06 22:59:13 +03:00
|
|
|
/**************************************************************************
|
|
|
|
Refreshes the statistics used to print per-second averages. */
|
|
|
|
|
|
|
|
void
|
|
|
|
buf_refresh_io_stats(void)
|
|
|
|
/*======================*/
|
|
|
|
{
|
|
|
|
buf_pool->last_printout_time = time(NULL);
|
|
|
|
buf_pool->n_page_gets_old = buf_pool->n_page_gets;
|
|
|
|
buf_pool->n_pages_read_old = buf_pool->n_pages_read;
|
|
|
|
buf_pool->n_pages_created_old = buf_pool->n_pages_created;
|
|
|
|
buf_pool->n_pages_written_old = buf_pool->n_pages_written;
|
2003-01-06 22:07:25 +02:00
|
|
|
buf_pool->n_pages_awe_remapped_old = buf_pool->n_pages_awe_remapped;
|
2002-08-06 22:59:13 +03:00
|
|
|
}
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Checks that all file pages in the buffer are in a replaceable state. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_all_freed(void)
|
|
|
|
/*===============*/
|
|
|
|
{
|
|
|
|
buf_block_t* block;
|
|
|
|
ulint i;
|
|
|
|
|
|
|
|
ut_ad(buf_pool);
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
for (i = 0; i < buf_pool->curr_size; i++) {
|
|
|
|
|
|
|
|
block = buf_pool_get_nth_block(buf_pool, i);
|
|
|
|
|
|
|
|
if (block->state == BUF_BLOCK_FILE_PAGE) {
|
|
|
|
|
|
|
|
if (!buf_flush_ready_for_replace(block)) {
|
|
|
|
|
2004-04-06 16:14:43 +03:00
|
|
|
fprintf(stderr,
|
|
|
|
"Page %lu %lu still fixed or dirty\n",
|
2004-04-26 15:53:31 +03:00
|
|
|
(ulong) block->space, (ulong) block->offset);
|
2001-02-17 14:19:19 +02:00
|
|
|
ut_error;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Checks that there currently are no pending i/o-operations for the buffer
|
|
|
|
pool. */
|
|
|
|
|
|
|
|
ibool
|
|
|
|
buf_pool_check_no_pending_io(void)
|
|
|
|
/*==============================*/
|
|
|
|
/* out: TRUE if there is no pending i/o */
|
|
|
|
{
|
|
|
|
ibool ret;
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
if (buf_pool->n_pend_reads + buf_pool->n_flush[BUF_FLUSH_LRU]
|
|
|
|
+ buf_pool->n_flush[BUF_FLUSH_LIST]
|
|
|
|
+ buf_pool->n_flush[BUF_FLUSH_SINGLE_PAGE]) {
|
|
|
|
ret = FALSE;
|
|
|
|
} else {
|
|
|
|
ret = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Gets the current length of the free list of buffer blocks. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
buf_get_free_list_len(void)
|
|
|
|
/*=======================*/
|
|
|
|
{
|
|
|
|
ulint len;
|
|
|
|
|
|
|
|
mutex_enter(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
len = UT_LIST_GET_LEN(buf_pool->free);
|
|
|
|
|
|
|
|
mutex_exit(&(buf_pool->mutex));
|
|
|
|
|
|
|
|
return(len);
|
|
|
|
}
|