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
99ec0887
Commit
99ec0887
authored
20 years ago
by
joreland@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge joreland@bk-internal.mysql.com:/home/bk/mysql-4.1-ndb
into mysql.com:/home/jonas/src/ll
parents
e02ee413
2082e8b9
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
67 additions
and
30 deletions
+67
-30
ndb/include/ndbapi/NdbOperation.hpp
ndb/include/ndbapi/NdbOperation.hpp
+0
-2
ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
+27
-19
ndb/src/kernel/blocks/dbtc/DbtcMain.cpp
ndb/src/kernel/blocks/dbtc/DbtcMain.cpp
+2
-1
ndb/src/kernel/blocks/dbtup/Dbtup.hpp
ndb/src/kernel/blocks/dbtup/Dbtup.hpp
+5
-0
ndb/src/kernel/blocks/dbtup/DbtupDebug.cpp
ndb/src/kernel/blocks/dbtup/DbtupDebug.cpp
+7
-0
ndb/src/kernel/blocks/dbtup/DbtupPagMan.cpp
ndb/src/kernel/blocks/dbtup/DbtupPagMan.cpp
+5
-3
ndb/src/kernel/blocks/dbtup/DbtupSystemRestart.cpp
ndb/src/kernel/blocks/dbtup/DbtupSystemRestart.cpp
+21
-5
No files found.
ndb/include/ndbapi/NdbOperation.hpp
View file @
99ec0887
...
@@ -746,8 +746,6 @@ protected:
...
@@ -746,8 +746,6 @@ protected:
int
prepareSendInterpreted
();
// Help routine to prepare*
int
prepareSendInterpreted
();
// Help routine to prepare*
void
TCOPCONF
(
Uint32
anNdbColumnImplLen
);
// Handle TC[KEY/INDX]CONF signal
int
receiveTCKEYREF
(
NdbApiSignal
*
);
int
receiveTCKEYREF
(
NdbApiSignal
*
);
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
View file @
99ec0887
...
@@ -107,6 +107,7 @@ operator<<(NdbOut& out, Dblqh::ScanRecord::ScanType state){
...
@@ -107,6 +107,7 @@ operator<<(NdbOut& out, Dblqh::ScanRecord::ScanType state){
#endif
#endif
//#define MARKER_TRACE 1
//#define MARKER_TRACE 1
//#define TRACE_SCAN_TAKEOVER 1
const
Uint32
NR_ScanNo
=
0
;
const
Uint32
NR_ScanNo
=
0
;
...
@@ -1001,7 +1002,7 @@ void Dblqh::execLQHFRAGREQ(Signal* signal)
...
@@ -1001,7 +1002,7 @@ void Dblqh::execLQHFRAGREQ(Signal* signal)
}
else
{
}
else
{
fragptr
.
p
->
tableFragptr
=
fragptr
.
i
;
fragptr
.
p
->
tableFragptr
=
fragptr
.
i
;
}
}
if
(
tempTable
)
{
if
(
tempTable
)
{
//--------------------------------------------
//--------------------------------------------
// reqinfo bit 3-4 = 2 means temporary table
// reqinfo bit 3-4 = 2 means temporary table
...
@@ -3574,6 +3575,10 @@ void Dblqh::prepareContinueAfterBlockedLab(Signal* signal)
...
@@ -3574,6 +3575,10 @@ void Dblqh::prepareContinueAfterBlockedLab(Signal* signal)
key
.
scanNumber
=
KeyInfo20
::
getScanNo
(
regTcPtr
->
tcScanInfo
);
key
.
scanNumber
=
KeyInfo20
::
getScanNo
(
regTcPtr
->
tcScanInfo
);
key
.
fragPtrI
=
fragptr
.
i
;
key
.
fragPtrI
=
fragptr
.
i
;
c_scanTakeOverHash
.
find
(
scanptr
,
key
);
c_scanTakeOverHash
.
find
(
scanptr
,
key
);
#ifdef TRACE_SCAN_TAKEOVER
if
(
scanptr
.
i
==
RNIL
)
ndbout_c
(
"not finding (%d %d)"
,
key
.
scanNumber
,
key
.
fragPtrI
);
#endif
}
}
if
(
scanptr
.
i
==
RNIL
)
{
if
(
scanptr
.
i
==
RNIL
)
{
jam
();
jam
();
...
@@ -8273,7 +8278,7 @@ Uint32 Dblqh::initScanrec(const ScanFragReq* scanFragReq)
...
@@ -8273,7 +8278,7 @@ Uint32 Dblqh::initScanrec(const ScanFragReq* scanFragReq)
scanptr
.
p
->
scanLocalref
[
1
]
=
0
;
scanptr
.
p
->
scanLocalref
[
1
]
=
0
;
scanptr
.
p
->
scanLocalFragid
=
0
;
scanptr
.
p
->
scanLocalFragid
=
0
;
scanptr
.
p
->
scanTcWaiting
=
ZTRUE
;
scanptr
.
p
->
scanTcWaiting
=
ZTRUE
;
scanptr
.
p
->
scanNumber
=
ZNIL
;
scanptr
.
p
->
scanNumber
=
~
0
;
for
(
Uint32
i
=
0
;
i
<
scanConcurrentOperations
;
i
++
)
{
for
(
Uint32
i
=
0
;
i
<
scanConcurrentOperations
;
i
++
)
{
jam
();
jam
();
...
@@ -8328,6 +8333,11 @@ Uint32 Dblqh::initScanrec(const ScanFragReq* scanFragReq)
...
@@ -8328,6 +8333,11 @@ Uint32 Dblqh::initScanrec(const ScanFragReq* scanFragReq)
#ifdef VM_TRACE
#ifdef VM_TRACE
ScanRecordPtr
tmp
;
ScanRecordPtr
tmp
;
ndbrequire
(
!
c_scanTakeOverHash
.
find
(
tmp
,
*
scanptr
.
p
));
ndbrequire
(
!
c_scanTakeOverHash
.
find
(
tmp
,
*
scanptr
.
p
));
#endif
#ifdef TRACE_SCAN_TAKEOVER
ndbout_c
(
"adding (%d %d) table: %d fragId: %d frag.i: %d tableFragptr: %d"
,
scanptr
.
p
->
scanNumber
,
scanptr
.
p
->
fragPtrI
,
tabptr
.
i
,
scanFragReq
->
fragmentNo
,
fragptr
.
i
,
fragptr
.
p
->
tableFragptr
);
#endif
#endif
c_scanTakeOverHash
.
add
(
scanptr
);
c_scanTakeOverHash
.
add
(
scanptr
);
}
}
...
@@ -8419,6 +8429,9 @@ void Dblqh::finishScanrec(Signal* signal)
...
@@ -8419,6 +8429,9 @@ void Dblqh::finishScanrec(Signal* signal)
if
(
scanptr
.
p
->
scanKeyinfoFlag
){
if
(
scanptr
.
p
->
scanKeyinfoFlag
){
jam
();
jam
();
ScanRecordPtr
tmp
;
ScanRecordPtr
tmp
;
#ifdef TRACE_SCAN_TAKEOVER
ndbout_c
(
"removing (%d %d)"
,
scanptr
.
p
->
scanNumber
,
scanptr
.
p
->
fragPtrI
);
#endif
c_scanTakeOverHash
.
remove
(
tmp
,
*
scanptr
.
p
);
c_scanTakeOverHash
.
remove
(
tmp
,
*
scanptr
.
p
);
ndbrequire
(
tmp
.
p
==
scanptr
.
p
);
ndbrequire
(
tmp
.
p
==
scanptr
.
p
);
}
}
...
@@ -8462,6 +8475,9 @@ void Dblqh::finishScanrec(Signal* signal)
...
@@ -8462,6 +8475,9 @@ void Dblqh::finishScanrec(Signal* signal)
ndbrequire
(
!
c_scanTakeOverHash
.
find
(
tmp
,
*
restart
.
p
));
ndbrequire
(
!
c_scanTakeOverHash
.
find
(
tmp
,
*
restart
.
p
));
#endif
#endif
c_scanTakeOverHash
.
add
(
restart
);
c_scanTakeOverHash
.
add
(
restart
);
#ifdef TRACE_SCAN_TAKEOVER
ndbout_c
(
"adding-r (%d %d)"
,
restart
.
p
->
scanNumber
,
restart
.
p
->
fragPtrI
);
#endif
}
}
scanptr
=
restart
;
scanptr
=
restart
;
...
@@ -12036,18 +12052,18 @@ void Dblqh::writeLogfileLab(Signal* signal)
...
@@ -12036,18 +12052,18 @@ void Dblqh::writeLogfileLab(Signal* signal)
/* WRITE. */
/* WRITE. */
/*---------------------------------------------------------------------------*/
/*---------------------------------------------------------------------------*/
switch
(
logFilePtr
.
p
->
fileChangeState
)
{
switch
(
logFilePtr
.
p
->
fileChangeState
)
{
#if 0
case LogFileRecord::BOTH_WRITES_ONGOING:
jam();
ndbout_c("not crashing!!");
// Fall-through
#endif
case
LogFileRecord
:
:
NOT_ONGOING
:
case
LogFileRecord
:
:
NOT_ONGOING
:
jam
();
jam
();
checkGcpCompleted
(
signal
,
checkGcpCompleted
(
signal
,
((
lfoPtr
.
p
->
lfoPageNo
+
lfoPtr
.
p
->
noPagesRw
)
-
1
),
((
lfoPtr
.
p
->
lfoPageNo
+
lfoPtr
.
p
->
noPagesRw
)
-
1
),
lfoPtr
.
p
->
lfoWordWritten
);
lfoPtr
.
p
->
lfoWordWritten
);
break
;
break
;
#if 0
case LogFileRecord::BOTH_WRITES_ONGOING:
jam();
ndbout_c("not crashing!!");
// Fall-through
#endif
case
LogFileRecord
:
:
WRITE_PAGE_ZERO_ONGOING
:
case
LogFileRecord
:
:
WRITE_PAGE_ZERO_ONGOING
:
case
LogFileRecord
:
:
LAST_WRITE_ONGOING
:
case
LogFileRecord
:
:
LAST_WRITE_ONGOING
:
jam
();
jam
();
...
@@ -13135,20 +13151,11 @@ void Dblqh::execSTART_FRAGREQ(Signal* signal)
...
@@ -13135,20 +13151,11 @@ void Dblqh::execSTART_FRAGREQ(Signal* signal)
ptrCheckGuard
(
tabptr
,
ctabrecFileSize
,
tablerec
);
ptrCheckGuard
(
tabptr
,
ctabrecFileSize
,
tablerec
);
if
(
!
getFragmentrec
(
signal
,
fragId
))
{
if
(
!
getFragmentrec
(
signal
,
fragId
))
{
jam
();
startFragRefLab
(
signal
);
/* ----------------------------------------------------------------------
return
;
* FRAGMENT WAS NOT DEFINED YET. PUT IT IN. IF NO LOCAL CHECKPOINT EXISTED
* THEN THE FRAGMENT HAS ALREADY BEEN ADDED.
* ---------------------------------------------------------------------- */
if
(
!
insertFragrec
(
signal
,
fragId
))
{
jam
();
startFragRefLab
(
signal
);
return
;
}
//if
}
//if
}
//if
tabptr
.
p
->
tableStatus
=
Tablerec
::
TABLE_DEFINED
;
tabptr
.
p
->
tableStatus
=
Tablerec
::
TABLE_DEFINED
;
initFragrec
(
signal
,
tabptr
.
i
,
fragId
,
ZPRIMARY_NODE
);
initFragrecSr
(
signal
);
initFragrecSr
(
signal
);
if
(
startFragReq
->
lcpNo
==
ZNIL
)
{
if
(
startFragReq
->
lcpNo
==
ZNIL
)
{
jam
();
jam
();
...
@@ -16418,6 +16425,7 @@ void Dblqh::initFragrec(Signal* signal,
...
@@ -16418,6 +16425,7 @@ void Dblqh::initFragrec(Signal* signal,
fragptr
.
p
->
execSrNoReplicas
=
0
;
fragptr
.
p
->
execSrNoReplicas
=
0
;
fragptr
.
p
->
fragDistributionKey
=
0
;
fragptr
.
p
->
fragDistributionKey
=
0
;
fragptr
.
p
->
activeTcCounter
=
0
;
fragptr
.
p
->
activeTcCounter
=
0
;
fragptr
.
p
->
tableFragptr
=
RNIL
;
}
//Dblqh::initFragrec()
}
//Dblqh::initFragrec()
/* ==========================================================================
/* ==========================================================================
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dbtc/DbtcMain.cpp
View file @
99ec0887
...
@@ -5280,8 +5280,9 @@ void Dbtc::execTCROLLBACKREQ(Signal* signal)
...
@@ -5280,8 +5280,9 @@ void Dbtc::execTCROLLBACKREQ(Signal* signal)
signal
->
theData
[
1
]
=
apiConnectptr
.
p
->
transid
[
0
];
signal
->
theData
[
1
]
=
apiConnectptr
.
p
->
transid
[
0
];
signal
->
theData
[
2
]
=
apiConnectptr
.
p
->
transid
[
1
];
signal
->
theData
[
2
]
=
apiConnectptr
.
p
->
transid
[
1
];
signal
->
theData
[
3
]
=
ZROLLBACKNOTALLOWED
;
signal
->
theData
[
3
]
=
ZROLLBACKNOTALLOWED
;
signal
->
theData
[
4
]
=
apiConnectptr
.
p
->
apiConnectstate
;
sendSignal
(
apiConnectptr
.
p
->
ndbapiBlockref
,
GSN_TCROLLBACKREF
,
sendSignal
(
apiConnectptr
.
p
->
ndbapiBlockref
,
GSN_TCROLLBACKREF
,
signal
,
4
,
JBB
);
signal
,
5
,
JBB
);
break
;
break
;
/* SEND A REFUSAL SIGNAL*/
/* SEND A REFUSAL SIGNAL*/
case
CS_ABORTING
:
case
CS_ABORTING
:
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dbtup/Dbtup.hpp
View file @
99ec0887
...
@@ -2322,10 +2322,15 @@ private:
...
@@ -2322,10 +2322,15 @@ private:
// Counters for num UNDO log records executed
// Counters for num UNDO log records executed
Uint32
cSrUndoRecords
[
9
];
Uint32
cSrUndoRecords
[
9
];
STATIC_CONST
(
MAX_PARALLELL_TUP_SRREQ
=
2
);
Uint32
c_sr_free_page_0
;
Uint32
c_errorInsert4000TableId
;
Uint32
c_errorInsert4000TableId
;
void
initGlobalTemporaryVars
();
void
initGlobalTemporaryVars
();
void
reportMemoryUsage
(
Signal
*
signal
,
int
incDec
);
void
reportMemoryUsage
(
Signal
*
signal
,
int
incDec
);
#ifdef VM_TRACE
#ifdef VM_TRACE
struct
Th
{
struct
Th
{
Uint32
data
[
1
];
Uint32
data
[
1
];
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dbtup/DbtupDebug.cpp
View file @
99ec0887
...
@@ -201,6 +201,10 @@ Dbtup::execDUMP_STATE_ORD(Signal* signal)
...
@@ -201,6 +201,10 @@ Dbtup::execDUMP_STATE_ORD(Signal* signal)
ndbrequire
(
chunk
.
pageCount
<=
alloc
);
ndbrequire
(
chunk
.
pageCount
<=
alloc
);
if
(
chunk
.
pageCount
!=
0
){
if
(
chunk
.
pageCount
!=
0
){
chunks
.
push_back
(
chunk
);
chunks
.
push_back
(
chunk
);
if
(
chunk
.
pageCount
!=
alloc
)
{
ndbout_c
(
" Tried to allocate %d - only allocated %d - free: %d"
,
alloc
,
chunk
.
pageCount
,
free
);
}
}
else
{
}
else
{
ndbout_c
(
" Failed to alloc %d pages with %d pages free"
,
ndbout_c
(
" Failed to alloc %d pages with %d pages free"
,
alloc
,
free
);
alloc
,
free
);
...
@@ -212,6 +216,9 @@ Dbtup::execDUMP_STATE_ORD(Signal* signal)
...
@@ -212,6 +216,9 @@ Dbtup::execDUMP_STATE_ORD(Signal* signal)
ptrCheckGuard
(
pagePtr
,
cnoOfPage
,
page
);
ptrCheckGuard
(
pagePtr
,
cnoOfPage
,
page
);
pagePtr
.
p
->
pageWord
[
ZPAGE_STATE_POS
]
=
~
ZFREE_COMMON
;
pagePtr
.
p
->
pageWord
[
ZPAGE_STATE_POS
]
=
~
ZFREE_COMMON
;
}
}
if
(
alloc
==
1
&&
free
>
0
)
ndbrequire
(
chunk
.
pageCount
==
alloc
);
}
}
break
;
break
;
}
}
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dbtup/DbtupPagMan.cpp
View file @
99ec0887
...
@@ -139,19 +139,21 @@ void Dbtup::initializePage()
...
@@ -139,19 +139,21 @@ void Dbtup::initializePage()
ptrAss
(
pagePtr
,
page
);
ptrAss
(
pagePtr
,
page
);
pagePtr
.
p
->
pageWord
[
ZPAGE_STATE_POS
]
=
~
ZFREE_COMMON
;
pagePtr
.
p
->
pageWord
[
ZPAGE_STATE_POS
]
=
~
ZFREE_COMMON
;
returnCommonArea
(
1
,
cnoOfPage
-
1
);
cnoOfAllocatedPages
=
1
+
MAX_PARALLELL_TUP_SRREQ
;
cnoOfAllocatedPages
=
1
;
returnCommonArea
(
cnoOfAllocatedPages
,
cnoOfPage
-
cnoOfAllocatedPages
);
c_sr_free_page_0
=
~
0
;
}
//Dbtup::initializePage()
}
//Dbtup::initializePage()
void
Dbtup
::
allocConsPages
(
Uint32
noOfPagesToAllocate
,
void
Dbtup
::
allocConsPages
(
Uint32
noOfPagesToAllocate
,
Uint32
&
noOfPagesAllocated
,
Uint32
&
noOfPagesAllocated
,
Uint32
&
allocPageRef
)
Uint32
&
allocPageRef
)
{
{
if
(
noOfPagesToAllocate
==
0
)
{
if
(
noOfPagesToAllocate
==
0
)
{
ljam
();
ljam
();
noOfPagesAllocated
=
0
;
noOfPagesAllocated
=
0
;
return
;
return
;
}
//if
}
//if
Uint32
firstListToCheck
=
nextHigherTwoLog
(
noOfPagesToAllocate
-
1
);
Uint32
firstListToCheck
=
nextHigherTwoLog
(
noOfPagesToAllocate
-
1
);
for
(
Uint32
i
=
firstListToCheck
;
i
<
16
;
i
++
)
{
for
(
Uint32
i
=
firstListToCheck
;
i
<
16
;
i
++
)
{
ljam
();
ljam
();
...
...
This diff is collapsed.
Click to expand it.
ndb/src/kernel/blocks/dbtup/DbtupSystemRestart.cpp
View file @
99ec0887
...
@@ -92,12 +92,25 @@ void Dbtup::rfrReadRestartInfoLab(Signal* signal, RestartInfoRecordPtr riPtr)
...
@@ -92,12 +92,25 @@ void Dbtup::rfrReadRestartInfoLab(Signal* signal, RestartInfoRecordPtr riPtr)
seizeDiskBufferSegmentRecord
(
dbsiPtr
);
seizeDiskBufferSegmentRecord
(
dbsiPtr
);
riPtr
.
p
->
sriDataBufferSegmentP
=
dbsiPtr
.
i
;
riPtr
.
p
->
sriDataBufferSegmentP
=
dbsiPtr
.
i
;
Uint32
retPageRef
;
Uint32
retPageRef
=
RNIL
;
Uint32
noAllocPages
=
1
;
Uint32
noAllocPages
=
1
;
Uint32
noOfPagesAllocated
;
Uint32
noOfPagesAllocated
;
allocConsPages
(
noAllocPages
,
noOfPagesAllocated
,
retPageRef
);
{
ndbrequire
(
noOfPagesAllocated
==
1
);
/**
* Use low pages for 0-pages during SR
* bitmask of free pages is kept in c_sr_free_page_0
*/
Uint32
tmp
=
c_sr_free_page_0
;
for
(
Uint32
i
=
1
;
i
<
(
1
+
MAX_PARALLELL_TUP_SRREQ
);
i
++
){
if
(
tmp
&
(
1
<<
i
)){
retPageRef
=
i
;
c_sr_free_page_0
=
tmp
&
(
~
(
1
<<
i
));
break
;
}
}
ndbrequire
(
retPageRef
!=
RNIL
);
}
dbsiPtr
.
p
->
pdxDataPage
[
0
]
=
retPageRef
;
dbsiPtr
.
p
->
pdxDataPage
[
0
]
=
retPageRef
;
dbsiPtr
.
p
->
pdxNumDataPages
=
1
;
dbsiPtr
.
p
->
pdxNumDataPages
=
1
;
dbsiPtr
.
p
->
pdxFilePage
=
0
;
dbsiPtr
.
p
->
pdxFilePage
=
0
;
...
@@ -150,7 +163,10 @@ Dbtup::rfrInitRestartInfoLab(Signal* signal, DiskBufferSegmentInfoPtr dbsiPtr)
...
@@ -150,7 +163,10 @@ Dbtup::rfrInitRestartInfoLab(Signal* signal, DiskBufferSegmentInfoPtr dbsiPtr)
/* LETS REMOVE IT AND REUSE THE SEGMENT FOR REAL DATA PAGES */
/* LETS REMOVE IT AND REUSE THE SEGMENT FOR REAL DATA PAGES */
/* REMOVE ONE PAGE ONLY, PAGEP IS ALREADY SET TO THE RESTART INFO PAGE */
/* REMOVE ONE PAGE ONLY, PAGEP IS ALREADY SET TO THE RESTART INFO PAGE */
/************************************************************************/
/************************************************************************/
returnCommonArea
(
pagePtr
.
i
,
1
);
{
ndbrequire
(
pagePtr
.
i
>
0
&&
pagePtr
.
i
<=
MAX_PARALLELL_TUP_SRREQ
);
c_sr_free_page_0
|=
(
1
<<
pagePtr
.
i
);
}
Uint32
undoFileVersion
=
TzeroDataPage
[
ZSRI_UNDO_FILE_VER
];
Uint32
undoFileVersion
=
TzeroDataPage
[
ZSRI_UNDO_FILE_VER
];
lliPtr
.
i
=
(
undoFileVersion
<<
2
)
+
(
regTabPtr
.
i
&
0x3
);
lliPtr
.
i
=
(
undoFileVersion
<<
2
)
+
(
regTabPtr
.
i
&
0x3
);
...
...
This diff is collapsed.
Click to expand it.
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