Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
39e68ea9
Commit
39e68ea9
authored
May 04, 2006
by
jonas@perch.ndb.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge perch.ndb.mysql.com:/home/jonas/src/51-work
into perch.ndb.mysql.com:/home/jonas/src/51-jonas
parents
0b38b42f
851132fb
Changes
4
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
282 additions
and
115 deletions
+282
-115
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
+179
-108
storage/ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp
storage/ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp
+37
-0
storage/ndb/src/kernel/blocks/pgman.cpp
storage/ndb/src/kernel/blocks/pgman.cpp
+48
-5
storage/ndb/src/kernel/blocks/pgman.hpp
storage/ndb/src/kernel/blocks/pgman.hpp
+18
-2
No files found.
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
View file @
39e68ea9
This diff is collapsed.
Click to expand it.
storage/ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp
View file @
39e68ea9
...
@@ -484,6 +484,14 @@ Dbtup::load_diskpage(Signal* signal,
...
@@ -484,6 +484,14 @@ Dbtup::load_diskpage(Signal* signal,
req
.
m_callback
.
m_callbackFunction
=
req
.
m_callback
.
m_callbackFunction
=
safe_cast
(
&
Dbtup
::
disk_page_load_callback
);
safe_cast
(
&
Dbtup
::
disk_page_load_callback
);
#ifdef ERROR_INSERTED
if
(
ERROR_INSERTED
(
4022
))
{
flags
|=
Page_cache_client
::
DELAY_REQ
;
req
.
m_delay_until_time
=
NdbTick_CurrentMillisecond
()
+
(
Uint64
)
3000
;
}
#endif
if
((
res
=
m_pgman
.
get_page
(
signal
,
req
,
flags
))
>
0
)
if
((
res
=
m_pgman
.
get_page
(
signal
,
req
,
flags
))
>
0
)
{
{
//ndbout_c("in cache");
//ndbout_c("in cache");
...
@@ -3119,6 +3127,35 @@ Dbtup::nr_delete(Signal* signal, Uint32 senderData,
...
@@ -3119,6 +3127,35 @@ Dbtup::nr_delete(Signal* signal, Uint32 senderData,
preq
.
m_callback
.
m_callbackFunction
=
preq
.
m_callback
.
m_callbackFunction
=
safe_cast
(
&
Dbtup
::
nr_delete_page_callback
);
safe_cast
(
&
Dbtup
::
nr_delete_page_callback
);
int
flags
=
Page_cache_client
::
COMMIT_REQ
;
int
flags
=
Page_cache_client
::
COMMIT_REQ
;
#ifdef ERROR_INSERT
if
(
ERROR_INSERTED
(
4023
)
||
ERROR_INSERTED
(
4024
))
{
int
rnd
=
rand
()
%
100
;
int
slp
=
0
;
if
(
ERROR_INSERTED
(
4024
))
{
slp
=
3000
;
}
else
if
(
rnd
>
90
)
{
slp
=
3000
;
}
else
if
(
rnd
>
70
)
{
slp
=
100
;
}
ndbout_c
(
"rnd: %d slp: %d"
,
rnd
,
slp
);
if
(
slp
)
{
flags
|=
Page_cache_client
::
DELAY_REQ
;
preq
.
m_delay_until_time
=
NdbTick_CurrentMillisecond
()
+
(
Uint64
)
slp
;
}
}
#endif
res
=
m_pgman
.
get_page
(
signal
,
preq
,
flags
);
res
=
m_pgman
.
get_page
(
signal
,
preq
,
flags
);
if
(
res
==
0
)
if
(
res
==
0
)
{
{
...
...
storage/ndb/src/kernel/blocks/pgman.cpp
View file @
39e68ea9
...
@@ -944,12 +944,16 @@ Pgman::process_callback(Signal* signal)
...
@@ -944,12 +944,16 @@ Pgman::process_callback(Signal* signal)
int
max_count
=
1
;
int
max_count
=
1
;
Page_sublist
&
pl_callback
=
*
m_page_sublist
[
Page_entry
::
SL_CALLBACK
];
Page_sublist
&
pl_callback
=
*
m_page_sublist
[
Page_entry
::
SL_CALLBACK
];
while
(
!
pl_callback
.
isEmpty
()
&&
--
max_count
>=
0
)
{
jam
();
Ptr
<
Page_entry
>
ptr
;
Ptr
<
Page_entry
>
ptr
;
pl_callback
.
first
(
ptr
);
pl_callback
.
first
(
ptr
);
if
(
!
process_callback
(
signal
,
ptr
))
while
(
!
ptr
.
isNull
()
&&
--
max_count
>=
0
)
{
jam
();
Ptr
<
Page_entry
>
curr
=
ptr
;
pl_callback
.
next
(
ptr
);
if
(
!
process_callback
(
signal
,
curr
))
{
{
jam
();
jam
();
break
;
break
;
...
@@ -987,6 +991,18 @@ Pgman::process_callback(Signal* signal, Ptr<Page_entry> ptr)
...
@@ -987,6 +991,18 @@ Pgman::process_callback(Signal* signal, Ptr<Page_entry> ptr)
#ifdef VM_TRACE
#ifdef VM_TRACE
debugOut
<<
"PGMAN: "
<<
req_ptr
<<
" : process_callback"
<<
endl
;
debugOut
<<
"PGMAN: "
<<
req_ptr
<<
" : process_callback"
<<
endl
;
#endif
#endif
#ifdef ERROR_INSERT
if
(
req_ptr
.
p
->
m_flags
&
Page_request
::
DELAY_REQ
)
{
Uint64
now
=
NdbTick_CurrentMillisecond
();
if
(
now
<
req_ptr
.
p
->
m_delay_until_time
)
{
break
;
}
}
#endif
b
=
globalData
.
getBlock
(
req_ptr
.
p
->
m_block
);
b
=
globalData
.
getBlock
(
req_ptr
.
p
->
m_block
);
callback
=
req_ptr
.
p
->
m_callback
;
callback
=
req_ptr
.
p
->
m_callback
;
...
@@ -1314,6 +1330,24 @@ Pgman::fsreadconf(Signal* signal, Ptr<Page_entry> ptr)
...
@@ -1314,6 +1330,24 @@ Pgman::fsreadconf(Signal* signal, Ptr<Page_entry> ptr)
state
|=
Page_entry
::
MAPPED
;
state
|=
Page_entry
::
MAPPED
;
set_page_state
(
ptr
,
state
);
set_page_state
(
ptr
,
state
);
{
/**
* Update lsn record on page
* as it can be modified/flushed wo/ update_lsn has been called
* (e.g. prealloc) and it then would get lsn 0, which is bad
* when running undo and following SR
*/
Ptr
<
GlobalPage
>
pagePtr
;
m_global_page_pool
.
getPtr
(
pagePtr
,
ptr
.
p
->
m_real_page_i
);
File_formats
::
Datafile
::
Data_page
*
page
=
(
File_formats
::
Datafile
::
Data_page
*
)
pagePtr
.
p
;
Uint64
lsn
=
0
;
lsn
+=
page
->
m_page_header
.
m_page_lsn_hi
;
lsn
<<=
32
;
lsn
+=
page
->
m_page_header
.
m_page_lsn_lo
;
ptr
.
p
->
m_lsn
=
lsn
;
}
ndbrequire
(
m_stats
.
m_current_io_waits
>
0
);
ndbrequire
(
m_stats
.
m_current_io_waits
>
0
);
m_stats
.
m_current_io_waits
--
;
m_stats
.
m_current_io_waits
--
;
...
@@ -1576,6 +1610,12 @@ Pgman::get_page(Signal* signal, Ptr<Page_entry> ptr, Page_request page_req)
...
@@ -1576,6 +1610,12 @@ Pgman::get_page(Signal* signal, Ptr<Page_entry> ptr, Page_request page_req)
bool
only_request
=
ptr
.
p
->
m_requests
.
isEmpty
();
bool
only_request
=
ptr
.
p
->
m_requests
.
isEmpty
();
if
(
req_flags
&
Page_request
::
DELAY_REQ
)
{
jam
();
only_request
=
false
;
}
if
(
only_request
&&
if
(
only_request
&&
state
&
Page_entry
::
MAPPED
)
state
&
Page_entry
::
MAPPED
)
{
{
...
@@ -1623,6 +1663,9 @@ Pgman::get_page(Signal* signal, Ptr<Page_entry> ptr, Page_request page_req)
...
@@ -1623,6 +1663,9 @@ Pgman::get_page(Signal* signal, Ptr<Page_entry> ptr, Page_request page_req)
req_ptr
.
p
->
m_block
=
page_req
.
m_block
;
req_ptr
.
p
->
m_block
=
page_req
.
m_block
;
req_ptr
.
p
->
m_flags
=
page_req
.
m_flags
;
req_ptr
.
p
->
m_flags
=
page_req
.
m_flags
;
req_ptr
.
p
->
m_callback
=
page_req
.
m_callback
;
req_ptr
.
p
->
m_callback
=
page_req
.
m_callback
;
#ifdef ERROR_INSERT
req_ptr
.
p
->
m_delay_until_time
=
page_req
.
m_delay_until_time
;
#endif
state
|=
Page_entry
::
REQUEST
;
state
|=
Page_entry
::
REQUEST
;
if
(
only_request
&&
req_flags
&
Page_request
::
EMPTY_PAGE
)
if
(
only_request
&&
req_flags
&
Page_request
::
EMPTY_PAGE
)
...
...
storage/ndb/src/kernel/blocks/pgman.hpp
View file @
39e68ea9
...
@@ -256,12 +256,18 @@ private:
...
@@ -256,12 +256,18 @@ private:
,
DIRTY_REQ
=
0x0200
// make page dirty wo/ update_lsn
,
DIRTY_REQ
=
0x0200
// make page dirty wo/ update_lsn
,
UNLOCK_PAGE
=
0x0400
,
UNLOCK_PAGE
=
0x0400
,
CORR_REQ
=
0x0800
// correlated request (no LIRS update)
,
CORR_REQ
=
0x0800
// correlated request (no LIRS update)
#ifdef ERROR_INSERT
,
DELAY_REQ
=
0x1000
// Force request to be delayed
#endif
};
};
Uint16
m_block
;
Uint16
m_block
;
Uint16
m_flags
;
Uint16
m_flags
;
SimulatedBlock
::
Callback
m_callback
;
SimulatedBlock
::
Callback
m_callback
;
#ifdef ERROR_INSERT
Uint64
m_delay_until_time
;
#endif
Uint32
nextList
;
Uint32
nextList
;
Uint32
m_magic
;
Uint32
m_magic
;
};
};
...
@@ -508,6 +514,10 @@ public:
...
@@ -508,6 +514,10 @@ public:
struct
Request
{
struct
Request
{
Local_key
m_page
;
Local_key
m_page
;
SimulatedBlock
::
Callback
m_callback
;
SimulatedBlock
::
Callback
m_callback
;
#ifdef ERROR_INSERT
Uint64
m_delay_until_time
;
#endif
};
};
Ptr
<
GlobalPage
>
m_ptr
;
// TODO remove
Ptr
<
GlobalPage
>
m_ptr
;
// TODO remove
...
@@ -520,6 +530,9 @@ public:
...
@@ -520,6 +530,9 @@ public:
,
DIRTY_REQ
=
Pgman
::
Page_request
::
DIRTY_REQ
,
DIRTY_REQ
=
Pgman
::
Page_request
::
DIRTY_REQ
,
UNLOCK_PAGE
=
Pgman
::
Page_request
::
UNLOCK_PAGE
,
UNLOCK_PAGE
=
Pgman
::
Page_request
::
UNLOCK_PAGE
,
CORR_REQ
=
Pgman
::
Page_request
::
CORR_REQ
,
CORR_REQ
=
Pgman
::
Page_request
::
CORR_REQ
#ifdef ERROR_INSERT
,
DELAY_REQ
=
Pgman
::
Page_request
::
DELAY_REQ
#endif
};
};
/**
/**
...
@@ -588,6 +601,9 @@ Page_cache_client::get_page(Signal* signal, Request& req, Uint32 flags)
...
@@ -588,6 +601,9 @@ Page_cache_client::get_page(Signal* signal, Request& req, Uint32 flags)
page_req
.
m_block
=
m_block
;
page_req
.
m_block
=
m_block
;
page_req
.
m_flags
=
flags
;
page_req
.
m_flags
=
flags
;
page_req
.
m_callback
=
req
.
m_callback
;
page_req
.
m_callback
=
req
.
m_callback
;
#ifdef ERROR_INSERT
page_req
.
m_delay_until_time
=
req
.
m_delay_until_time
;
#endif
int
i
=
m_pgman
->
get_page
(
signal
,
entry_ptr
,
page_req
);
int
i
=
m_pgman
->
get_page
(
signal
,
entry_ptr
,
page_req
);
if
(
i
>
0
)
if
(
i
>
0
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment