ndb - bug#20185

  second try - handle CS_PREPARE_TO_COMMIT explicitly
parent ee0b2615
...@@ -7093,15 +7093,20 @@ Dbtc::nodeFailCheckTransactions(Signal* signal, ...@@ -7093,15 +7093,20 @@ Dbtc::nodeFailCheckTransactions(Signal* signal,
for (transPtr.i = transPtrI; transPtr.i < capiConnectFilesize; transPtr.i++) for (transPtr.i = transPtrI; transPtr.i < capiConnectFilesize; transPtr.i++)
{ {
ptrCheckGuard(transPtr, capiConnectFilesize, apiConnectRecord); ptrCheckGuard(transPtr, capiConnectFilesize, apiConnectRecord);
Uiint32 state = transPtr.p->apiConnectstate;
if (transPtr.p->m_transaction_nodes.get(failedNodeId)) if (transPtr.p->m_transaction_nodes.get(failedNodeId))
{ {
jam(); jam();
// Force timeout regardless of state // avoid assertion in timeoutfoundlab
c_appl_timeout_value = 1; if (state != CS_PREPARE_TO_COMMIT)
setApiConTimer(transPtr.i, TtcTimer - 2, __LINE__); {
timeOutFoundLab(signal, transPtr.i, ZNODEFAIL_BEFORE_COMMIT); // Force timeout regardless of state
c_appl_timeout_value = TapplTimeout; c_appl_timeout_value = 1;
setApiConTimer(transPtr.i, TtcTimer - 2, __LINE__);
timeOutFoundLab(signal, transPtr.i, ZNODEFAIL_BEFORE_COMMIT);
c_appl_timeout_value = TapplTimeout;
}
} }
// Send CONTINUEB to continue later // Send CONTINUEB to continue later
......
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