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
79e80aac
Commit
79e80aac
authored
Jan 17, 2007
by
tomas@poseidon.mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug#25387 - added comments in code suggestion during review
parent
ec0969f9
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
88 additions
and
7 deletions
+88
-7
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
+28
-5
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
+60
-2
No files found.
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
View file @
79e80aac
...
@@ -559,6 +559,8 @@ NdbEventOperationImpl::execute_nolock()
...
@@ -559,6 +559,8 @@ NdbEventOperationImpl::execute_nolock()
m_state
=
EO_EXECUTING
;
m_state
=
EO_EXECUTING
;
mi_type
=
m_eventImpl
->
mi_type
;
mi_type
=
m_eventImpl
->
mi_type
;
m_ndb
->
theEventBuffer
->
add_op
();
m_ndb
->
theEventBuffer
->
add_op
();
// add kernel reference
// removed on TE_STOP, TE_CLUSTER_FAILURE, or error below
m_ref_count
++
;
m_ref_count
++
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
int
r
=
NdbDictionaryImpl
::
getImpl
(
*
myDict
).
executeSubscribeEvent
(
*
this
);
int
r
=
NdbDictionaryImpl
::
getImpl
(
*
myDict
).
executeSubscribeEvent
(
*
this
);
...
@@ -571,8 +573,8 @@ NdbEventOperationImpl::execute_nolock()
...
@@ -571,8 +573,8 @@ NdbEventOperationImpl::execute_nolock()
if
(
r
!=
0
)
{
if
(
r
!=
0
)
{
break
;
break
;
}
}
//
blob event op now holds reference
//
add blob reference to main op
//
clear
ed by TE_STOP or TE_CLUSTER_FAILURE
//
remov
ed by TE_STOP or TE_CLUSTER_FAILURE
m_ref_count
++
;
m_ref_count
++
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
blob_op
=
blob_op
->
m_next
;
blob_op
=
blob_op
->
m_next
;
...
@@ -583,7 +585,9 @@ NdbEventOperationImpl::execute_nolock()
...
@@ -583,7 +585,9 @@ NdbEventOperationImpl::execute_nolock()
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
}
}
//Error
// Error
// remove kernel reference
// added above
m_ref_count
--
;
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
m_ref_count
,
this
));
m_state
=
EO_ERROR
;
m_state
=
EO_ERROR
;
...
@@ -1227,6 +1231,8 @@ NdbEventBuffer::nextEvent()
...
@@ -1227,6 +1231,8 @@ NdbEventBuffer::nextEvent()
EventBufData_list
::
Gci_ops
*
gci_ops
=
m_available_data
.
first_gci_ops
();
EventBufData_list
::
Gci_ops
*
gci_ops
=
m_available_data
.
first_gci_ops
();
while
(
gci_ops
&&
op
->
getGCI
()
>
gci_ops
->
m_gci
)
while
(
gci_ops
&&
op
->
getGCI
()
>
gci_ops
->
m_gci
)
{
{
// moved to next gci, check if any references have been
// released when completing the last gci
deleteUsedEventOperations
();
deleteUsedEventOperations
();
gci_ops
=
m_available_data
.
next_gci_ops
();
gci_ops
=
m_available_data
.
next_gci_ops
();
}
}
...
@@ -1254,6 +1260,8 @@ NdbEventBuffer::nextEvent()
...
@@ -1254,6 +1260,8 @@ NdbEventBuffer::nextEvent()
#endif
#endif
// free all "per gci unique" collected operations
// free all "per gci unique" collected operations
// completed gci, check if any references have been
// released when completing the gci
EventBufData_list
::
Gci_ops
*
gci_ops
=
m_available_data
.
first_gci_ops
();
EventBufData_list
::
Gci_ops
*
gci_ops
=
m_available_data
.
first_gci_ops
();
while
(
gci_ops
)
while
(
gci_ops
)
{
{
...
@@ -1290,6 +1298,8 @@ NdbEventBuffer::deleteUsedEventOperations()
...
@@ -1290,6 +1298,8 @@ NdbEventBuffer::deleteUsedEventOperations()
{
{
NdbEventOperationImpl
*
op
=
&
op_f
->
m_impl
;
NdbEventOperationImpl
*
op
=
&
op_f
->
m_impl
;
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
// remove gci reference
// added in inserDataL
op
->
m_ref_count
--
;
op
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
if
(
op
->
m_ref_count
==
0
)
if
(
op
->
m_ref_count
==
0
)
...
@@ -1807,14 +1817,17 @@ NdbEventBuffer::insertDataL(NdbEventOperationImpl *op,
...
@@ -1807,14 +1817,17 @@ NdbEventBuffer::insertDataL(NdbEventOperationImpl *op,
{
{
op
->
m_node_bit_mask
.
clear
();
op
->
m_node_bit_mask
.
clear
();
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
// remove kernel reference
// added in execute_nolock
op
->
m_ref_count
--
;
op
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"_TE_CLUSTER_FAILURE: m_ref_count: %u for op: %p"
,
DBUG_PRINT
(
"info"
,
(
"_TE_CLUSTER_FAILURE: m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
op
->
m_ref_count
,
op
));
if
(
op
->
theMainOp
)
if
(
op
->
theMainOp
)
{
{
// blob event op, need to clear ref count in main op
DBUG_ASSERT
(
op
->
m_ref_count
==
0
);
DBUG_ASSERT
(
op
->
m_ref_count
==
0
);
DBUG_ASSERT
(
op
->
theMainOp
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
theMainOp
->
m_ref_count
>
0
);
// remove blob reference in main op
// added in execute_no_lock
op
->
theMainOp
->
m_ref_count
--
;
op
->
theMainOp
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
theMainOp
->
m_ref_count
,
op
->
theMainOp
));
op
->
theMainOp
->
m_ref_count
,
op
->
theMainOp
));
...
@@ -1826,14 +1839,17 @@ NdbEventBuffer::insertDataL(NdbEventOperationImpl *op,
...
@@ -1826,14 +1839,17 @@ NdbEventBuffer::insertDataL(NdbEventOperationImpl *op,
if
(
op
->
m_node_bit_mask
.
isclear
())
if
(
op
->
m_node_bit_mask
.
isclear
())
{
{
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
// remove kernel reference
// added in execute_no_lock
op
->
m_ref_count
--
;
op
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"_TE_STOP: m_ref_count: %u for op: %p"
,
DBUG_PRINT
(
"info"
,
(
"_TE_STOP: m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
op
->
m_ref_count
,
op
));
if
(
op
->
theMainOp
)
if
(
op
->
theMainOp
)
{
{
// blob event op, need to clear ref count in main op
DBUG_ASSERT
(
op
->
m_ref_count
==
0
);
DBUG_ASSERT
(
op
->
m_ref_count
==
0
);
DBUG_ASSERT
(
op
->
theMainOp
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
theMainOp
->
m_ref_count
>
0
);
// remove blob reference in main op
// added in execute_no_lock
op
->
theMainOp
->
m_ref_count
--
;
op
->
theMainOp
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
theMainOp
->
m_ref_count
,
op
->
theMainOp
));
op
->
theMainOp
->
m_ref_count
,
op
->
theMainOp
));
...
@@ -2586,6 +2602,8 @@ EventBufData_list::add_gci_op(Gci_op g)
...
@@ -2586,6 +2602,8 @@ EventBufData_list::add_gci_op(Gci_op g)
#ifndef DBUG_OFF
#ifndef DBUG_OFF
i
=
m_gci_op_count
;
i
=
m_gci_op_count
;
#endif
#endif
// add gci reference
// removed in deleteUsedOperations
g
.
op
->
m_ref_count
++
;
g
.
op
->
m_ref_count
++
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
g
.
op
->
m_ref_count
,
g
.
op
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
g
.
op
->
m_ref_count
,
g
.
op
));
m_gci_op_list
[
m_gci_op_count
++
]
=
g
;
m_gci_op_list
[
m_gci_op_count
++
]
=
g
;
...
@@ -2654,6 +2672,8 @@ NdbEventBuffer::createEventOperation(const char* eventName,
...
@@ -2654,6 +2672,8 @@ NdbEventBuffer::createEventOperation(const char* eventName,
delete
tOp
;
delete
tOp
;
DBUG_RETURN
(
NULL
);
DBUG_RETURN
(
NULL
);
}
}
// add user reference
// removed in dropEventOperation
getEventOperationImpl
(
tOp
)
->
m_ref_count
=
1
;
getEventOperationImpl
(
tOp
)
->
m_ref_count
=
1
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
getEventOperationImpl
(
tOp
)
->
m_ref_count
,
getEventOperationImpl
(
tOp
)));
getEventOperationImpl
(
tOp
)
->
m_ref_count
,
getEventOperationImpl
(
tOp
)));
...
@@ -2706,6 +2726,9 @@ NdbEventBuffer::dropEventOperation(NdbEventOperation* tOp)
...
@@ -2706,6 +2726,9 @@ NdbEventBuffer::dropEventOperation(NdbEventOperation* tOp)
}
}
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
DBUG_ASSERT
(
op
->
m_ref_count
>
0
);
// remove user reference
// added in createEventOperation
// user error to use reference after this
op
->
m_ref_count
--
;
op
->
m_ref_count
--
;
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
DBUG_PRINT
(
"info"
,
(
"m_ref_count: %u for op: %p"
,
op
->
m_ref_count
,
op
));
if
(
op
->
m_ref_count
==
0
)
if
(
op
->
m_ref_count
==
0
)
...
...
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
View file @
79e80aac
...
@@ -400,7 +400,59 @@ public:
...
@@ -400,7 +400,59 @@ public:
Uint32
m_eventId
;
Uint32
m_eventId
;
Uint32
m_oid
;
Uint32
m_oid
;
/*
m_node_bit_mask keeps track of which ndb nodes have reference to
an event op
- add - TE_ACTIVE
- remove - TE_STOP, TE_NODE_FAILURE, TE_CLUSTER_FAILURE
TE_NODE_FAILURE and TE_CLUSTER_FAILURE are created as events
and added to all event ops listed as active or pending delete
in m_dropped_ev_op using insertDataL, includeing the blob
event ops referenced by a regular event op.
- NdbEventBuffer::report_node_failure
- NdbEventBuffer::completeClusterFailed
TE_ACTIVE is sent from the kernel on initial execute/start of the
event op, but is also internally generetad on node connect like
TE_NODE_FAILURE and TE_CLUSTER_FAILURE
- NdbEventBuffer::report_node_connected
when m_node_bit_mask becomes clear, the kernel reference is
removed from m_ref_count
*/
Bitmask
<
(
unsigned
int
)
_NDB_NODE_BITMASK_SIZE
>
m_node_bit_mask
;
Bitmask
<
(
unsigned
int
)
_NDB_NODE_BITMASK_SIZE
>
m_node_bit_mask
;
/*
m_ref_count keeps track of outstanding references to an event
operation impl object. To make sure that the object is not
deleted too early.
If on dropEventOperation there are still references to an
object it is queued for delete in NdbEventBuffer::m_dropped_ev_op
the following references exists for a _non_ blob event op:
* user reference
- add - NdbEventBuffer::createEventOperation
- remove - NdbEventBuffer::dropEventOperation
* kernel reference
- add - execute_nolock
- remove - TE_STOP, TE_CLUSTER_FAILURE
* blob reference
- add - execute_nolock on blob event
- remove - TE_STOP, TE_CLUSTER_FAILURE on blob event
* gci reference
- add - insertDataL/add_gci_op
- remove - NdbEventBuffer::deleteUsedEventOperations
the following references exists for a blob event op:
* kernel reference
- add - execute_nolock
- remove - TE_STOP, TE_CLUSTER_FAILURE
*/
int
m_ref_count
;
int
m_ref_count
;
bool
m_mergeEvents
;
bool
m_mergeEvents
;
...
@@ -557,8 +609,14 @@ private:
...
@@ -557,8 +609,14 @@ private:
Vector
<
EventBufData_chunk
*>
m_allocated_data
;
Vector
<
EventBufData_chunk
*>
m_allocated_data
;
unsigned
m_sz
;
unsigned
m_sz
;
// dropped event operations that have not yet
/*
// been deleted
dropped event operations (dropEventOperation) that have not yet
been deleted because of outstanding m_ref_count
check for delete is done on occations when the ref_count may have
changed by calling deleteUsedEventOperations:
- nextEvent - each time the user has completed processing a gci
*/
NdbEventOperationImpl
*
m_dropped_ev_op
;
NdbEventOperationImpl
*
m_dropped_ev_op
;
Uint32
m_active_op_count
;
Uint32
m_active_op_count
;
...
...
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