Bug#25387 - added comments in code suggestion during review

parent ec0969f9
...@@ -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
// cleared by TE_STOP or TE_CLUSTER_FAILURE // removed 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)
......
...@@ -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;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment