Commit ab198e52 authored by unknown's avatar unknown

Update error handling of new scan

Still known bugs :-(


ndb/include/kernel/signaldata/ScanTab.hpp:
  Add close flag
ndb/include/ndbapi/NdbConnection.hpp:
  Moved mehtod outside
ndb/include/ndbapi/NdbScanOperation.hpp:
  Removed err code from
ndb/src/common/debugger/signaldata/ScanTab.cpp:
  Updated printer
ndb/src/kernel/blocks/dblqh/DblqhMain.cpp:
  New error inserts for SCAN
ndb/src/kernel/blocks/dbtc/Dbtc.hpp:
  Update handling of frag timeouts
ndb/src/kernel/blocks/dbtc/DbtcMain.cpp:
  Update handling of frag timeouts
ndb/src/kernel/blocks/dbtup/DbtupBuffer.cpp:
  Don't send empty TRANSID_AI's
ndb/src/ndbapi/NdbConnectionScan.cpp:
  Update error handling of scan
ndb/src/ndbapi/NdbScanOperation.cpp:
  Update error handling of scan
ndb/src/ndbapi/Ndbif.cpp:
  Update error handling of scan
parent 9ff4d240
...@@ -367,7 +367,7 @@ public: ...@@ -367,7 +367,7 @@ public:
/** /**
* Length of signal * Length of signal
*/ */
STATIC_CONST( SignalLength = 4 ); STATIC_CONST( SignalLength = 5 );
private: private:
...@@ -380,7 +380,7 @@ private: ...@@ -380,7 +380,7 @@ private:
UintR transId1; // DATA 1 UintR transId1; // DATA 1
UintR transId2; // DATA 2 UintR transId2; // DATA 2
UintR errorCode; // DATA 3 UintR errorCode; // DATA 3
// UintR sendScanNextReqWithClose; // DATA 4 UintR closeNeeded; // DATA 4
}; };
......
...@@ -633,17 +633,7 @@ private: ...@@ -633,17 +633,7 @@ private:
#ifdef VM_TRACE #ifdef VM_TRACE
void printState(); void printState();
#endif #endif
bool checkState_TransId(const Uint32 * transId) const;
bool checkState_TransId(const Uint32 * transId) const {
const Uint32 tTmp1 = transId[0];
const Uint32 tTmp2 = transId[1];
Uint64 tRecTransId = (Uint64)tTmp1 + ((Uint64)tTmp2 << 32);
bool b = theStatus == Connected && theTransactionId == tRecTransId;
#ifdef NDB_NO_DROPPED_SIGNAL
if(!b) abort();
#endif
return b;
}
}; };
inline inline
...@@ -678,6 +668,19 @@ NdbConnection::checkMagicNumber() ...@@ -678,6 +668,19 @@ NdbConnection::checkMagicNumber()
} }
} }
inline
bool
NdbConnection::checkState_TransId(const Uint32 * transId) const {
const Uint32 tTmp1 = transId[0];
const Uint32 tTmp2 = transId[1];
Uint64 tRecTransId = (Uint64)tTmp1 + ((Uint64)tTmp2 << 32);
bool b = theStatus == Connected && theTransactionId == tRecTransId;
#ifdef NDB_NO_DROPPED_SIGNAL
if(!b) abort();
#endif
return b;
}
/************************************************************************************************ /************************************************************************************************
void setTransactionId(Uint64 aTransactionId); void setTransactionId(Uint64 aTransactionId);
......
...@@ -146,7 +146,7 @@ protected: ...@@ -146,7 +146,7 @@ protected:
int send_next_scan(Uint32 cnt, bool close); int send_next_scan(Uint32 cnt, bool close);
void receiver_delivered(NdbReceiver*); void receiver_delivered(NdbReceiver*);
void receiver_completed(NdbReceiver*); void receiver_completed(NdbReceiver*);
void execCLOSE_SCAN_REP(Uint32 errCode); void execCLOSE_SCAN_REP();
NdbOperation* takeOverScanOp(OperationType opType, NdbConnection*); NdbOperation* takeOverScanOp(OperationType opType, NdbConnection*);
......
...@@ -119,8 +119,8 @@ printSCANTABREF(FILE * output, const Uint32 * theData, Uint32 len, Uint16 receiv ...@@ -119,8 +119,8 @@ printSCANTABREF(FILE * output, const Uint32 * theData, Uint32 len, Uint16 receiv
sig->transId1, sig->transId2); sig->transId1, sig->transId2);
fprintf(output, " Errorcode: %u\n", sig->errorCode); fprintf(output, " Errorcode: %u\n", sig->errorCode);
// fprintf(output, " sendScanNextReqWithClose: %u\n", sig->sendScanNextReqWithClose); fprintf(output, " closeNeeded: %u\n", sig->closeNeeded);
return false; return false;
} }
......
...@@ -6785,7 +6785,8 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal) ...@@ -6785,7 +6785,8 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal)
if (findTransaction(transid1, transid2, senderData) != ZOK){ if (findTransaction(transid1, transid2, senderData) != ZOK){
jam(); jam();
DEBUG("Received SCAN_NEXTREQ in LQH with close flag when closed"); DEBUG(senderData <<
" Received SCAN_NEXTREQ in LQH with close flag when closed");
ndbrequire(nextReq->closeFlag == ZTRUE); ndbrequire(nextReq->closeFlag == ZTRUE);
return; return;
} }
...@@ -6825,6 +6826,10 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal) ...@@ -6825,6 +6826,10 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal)
return; return;
}//if }//if
if(ERROR_INSERTED(5036)){
return;
}
scanptr.i = tcConnectptr.p->tcScanRec; scanptr.i = tcConnectptr.p->tcScanRec;
ndbrequire(scanptr.i != RNIL); ndbrequire(scanptr.i != RNIL);
c_scanRecordPool.getPtr(scanptr); c_scanRecordPool.getPtr(scanptr);
...@@ -6841,6 +6846,10 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal) ...@@ -6841,6 +6846,10 @@ void Dblqh::execSCAN_NEXTREQ(Signal* signal)
if(ERROR_INSERTED(5034)){ if(ERROR_INSERTED(5034)){
CLEAR_ERROR_INSERT_VALUE; CLEAR_ERROR_INSERT_VALUE;
} }
if(ERROR_INSERTED(5036)){
CLEAR_ERROR_INSERT_VALUE;
return;
}
closeScanRequestLab(signal); closeScanRequestLab(signal);
return; return;
}//if }//if
...@@ -8517,6 +8526,11 @@ void Dblqh::sendKeyinfo20(Signal* signal, ...@@ -8517,6 +8526,11 @@ void Dblqh::sendKeyinfo20(Signal* signal,
* ------------------------------------------------------------------------ */ * ------------------------------------------------------------------------ */
void Dblqh::sendScanFragConf(Signal* signal, Uint32 scanCompleted) void Dblqh::sendScanFragConf(Signal* signal, Uint32 scanCompleted)
{ {
if(ERROR_INSERTED(5037)){
CLEAR_ERROR_INSERT_VALUE;
return;
}
scanptr.p->scanTcWaiting = ZFALSE; scanptr.p->scanTcWaiting = ZFALSE;
ScanFragConf * conf = (ScanFragConf*)&signal->theData[0]; ScanFragConf * conf = (ScanFragConf*)&signal->theData[0];
......
...@@ -1194,6 +1194,9 @@ public: ...@@ -1194,6 +1194,9 @@ public:
// Scan is on ordered index // Scan is on ordered index
Uint8 rangeScan; Uint8 rangeScan;
// Close is ordered
bool m_close_scan_req;
}; };
typedef Ptr<ScanRecord> ScanRecordPtr; typedef Ptr<ScanRecord> ScanRecordPtr;
...@@ -1414,15 +1417,15 @@ private: ...@@ -1414,15 +1417,15 @@ private:
Uint32 buddyPtr, Uint32 buddyPtr,
UintR transid1, UintR transid1,
UintR transid2); UintR transid2);
void initScanrec(Signal* signal, void initScanrec(ScanRecordPtr, const class ScanTabReq*,
const UintR scanParallel, const UintR scanParallel,
const UintR noOprecPerFrag); const UintR noOprecPerFrag);
void initScanfragrec(Signal* signal); void initScanfragrec(Signal* signal);
void releaseScanResources(ScanRecordPtr); void releaseScanResources(ScanRecordPtr);
void seizeScanrec(Signal* signal); ScanRecordPtr seizeScanrec(Signal* signal);
void sendScanFragReq(Signal* signal); void sendScanFragReq(Signal* signal, ScanRecord*, ScanFragRec*);
void sendScanTabConf(Signal* signal); void sendScanTabConf(Signal* signal, ScanRecord*);
void close_scan_req(Signal*, ScanRecordPtr); void close_scan_req(Signal*, ScanRecordPtr, bool received_req);
void close_scan_req_send_conf(Signal*, ScanRecordPtr); void close_scan_req_send_conf(Signal*, ScanRecordPtr);
void checkGcp(Signal* signal); void checkGcp(Signal* signal);
...@@ -1557,11 +1560,11 @@ private: ...@@ -1557,11 +1560,11 @@ private:
void systemErrorLab(Signal* signal); void systemErrorLab(Signal* signal);
void sendSignalErrorRefuseLab(Signal* signal); void sendSignalErrorRefuseLab(Signal* signal);
void scanTabRefLab(Signal* signal, Uint32 errCode); void scanTabRefLab(Signal* signal, Uint32 errCode);
void diFcountReqLab(Signal* signal); void diFcountReqLab(Signal* signal, ScanRecordPtr);
void signalErrorRefuseLab(Signal* signal); void signalErrorRefuseLab(Signal* signal);
void abort080Lab(Signal* signal); void abort080Lab(Signal* signal);
void packKeyData000Lab(Signal* signal, BlockReference TBRef); void packKeyData000Lab(Signal* signal, BlockReference TBRef);
void abortScanLab(Signal* signal, Uint32 errCode); void abortScanLab(Signal* signal, ScanRecordPtr, Uint32 errCode);
void sendAbortedAfterTimeout(Signal* signal, int Tcheck); void sendAbortedAfterTimeout(Signal* signal, int Tcheck);
void abort010Lab(Signal* signal); void abort010Lab(Signal* signal);
void abort015Lab(Signal* signal); void abort015Lab(Signal* signal);
...@@ -1589,7 +1592,7 @@ private: ...@@ -1589,7 +1592,7 @@ private:
void attrinfo020Lab(Signal* signal); void attrinfo020Lab(Signal* signal);
void scanReleaseResourcesLab(Signal* signal); void scanReleaseResourcesLab(Signal* signal);
void scanCompletedLab(Signal* signal); void scanCompletedLab(Signal* signal);
void scanFragError(Signal* signal, Uint32 errorCode); void scanError(Signal* signal, ScanRecordPtr, Uint32 errorCode);
void diverify010Lab(Signal* signal); void diverify010Lab(Signal* signal);
void intstartphase2x010Lab(Signal* signal); void intstartphase2x010Lab(Signal* signal);
void intstartphase3x010Lab(Signal* signal); void intstartphase3x010Lab(Signal* signal);
...@@ -1699,7 +1702,6 @@ private: ...@@ -1699,7 +1702,6 @@ private:
ApiConnectRecordPtr timeOutptr; ApiConnectRecordPtr timeOutptr;
ScanRecord *scanRecord; ScanRecord *scanRecord;
ScanRecordPtr scanptr;
UintR cscanrecFileSize; UintR cscanrecFileSize;
UnsafeArrayPool<ScanFragRec> c_scan_frag_pool; UnsafeArrayPool<ScanFragRec> c_scan_frag_pool;
......
This diff is collapsed.
...@@ -54,6 +54,9 @@ void Dbtup::execSEND_PACKED(Signal* signal) ...@@ -54,6 +54,9 @@ void Dbtup::execSEND_PACKED(Signal* signal)
void Dbtup::bufferTRANSID_AI(Signal* signal, BlockReference aRef, void Dbtup::bufferTRANSID_AI(Signal* signal, BlockReference aRef,
Uint32 Tlen) Uint32 Tlen)
{ {
if(Tlen == 3)
return;
Uint32 hostId = refToNode(aRef); Uint32 hostId = refToNode(aRef);
Uint32 Theader = ((refToBlock(aRef) << 16)+(Tlen-3)); Uint32 Theader = ((refToBlock(aRef) << 16)+(Tlen-3));
......
...@@ -61,7 +61,14 @@ NdbConnection::receiveSCAN_TABREF(NdbApiSignal* aSignal){ ...@@ -61,7 +61,14 @@ NdbConnection::receiveSCAN_TABREF(NdbApiSignal* aSignal){
const ScanTabRef * ref = CAST_CONSTPTR(ScanTabRef, aSignal->getDataPtr()); const ScanTabRef * ref = CAST_CONSTPTR(ScanTabRef, aSignal->getDataPtr());
if(checkState_TransId(&ref->transId1)){ if(checkState_TransId(&ref->transId1)){
theScanningOp->execCLOSE_SCAN_REP(ref->errorCode); theScanningOp->theError.code = ref->errorCode;
if(!ref->closeNeeded){
theScanningOp->execCLOSE_SCAN_REP();
return 0;
}
assert(theScanningOp->m_sent_receivers_count);
theScanningOp->m_sent_receivers_count--;
theScanningOp->m_conf_receivers_count++;
return 0; return 0;
} }
return -1; return -1;
...@@ -88,11 +95,10 @@ NdbConnection::receiveSCAN_TABCONF(NdbApiSignal* aSignal, ...@@ -88,11 +95,10 @@ NdbConnection::receiveSCAN_TABCONF(NdbApiSignal* aSignal,
if(checkState_TransId(&conf->transId1)){ if(checkState_TransId(&conf->transId1)){
if (conf->requestInfo == ScanTabConf::EndOfData) { if (conf->requestInfo == ScanTabConf::EndOfData) {
theScanningOp->execCLOSE_SCAN_REP(0); theScanningOp->execCLOSE_SCAN_REP();
return 0; return 0;
} }
int noComp = -1;
for(Uint32 i = 0; i<len; i += 3){ for(Uint32 i = 0; i<len; i += 3){
Uint32 ptrI = * ops++; Uint32 ptrI = * ops++;
Uint32 tcPtrI = * ops++; Uint32 tcPtrI = * ops++;
...@@ -108,15 +114,13 @@ NdbConnection::receiveSCAN_TABCONF(NdbApiSignal* aSignal, ...@@ -108,15 +114,13 @@ NdbConnection::receiveSCAN_TABCONF(NdbApiSignal* aSignal,
/** /**
* *
*/ */
noComp++;
theScanningOp->receiver_delivered(tOp); theScanningOp->receiver_delivered(tOp);
} else if(info == ScanTabConf::EndOfData){ } else if(info == ScanTabConf::EndOfData){
noComp++;
theScanningOp->receiver_completed(tOp); theScanningOp->receiver_completed(tOp);
} }
} }
} }
return noComp; return 0;
} }
return -1; return -1;
......
...@@ -124,7 +124,7 @@ NdbScanOperation::init(NdbTableImpl* tab, NdbConnection* myConnection) ...@@ -124,7 +124,7 @@ NdbScanOperation::init(NdbTableImpl* tab, NdbConnection* myConnection)
theTotalBoundAI_Len = 0; theTotalBoundAI_Len = 0;
theBoundATTRINFO = NULL; theBoundATTRINFO = NULL;
return 0; return 0;
} }
...@@ -135,6 +135,8 @@ NdbResultSet* NdbScanOperation::readTuples(NdbScanOperation::LockMode lm, ...@@ -135,6 +135,8 @@ NdbResultSet* NdbScanOperation::readTuples(NdbScanOperation::LockMode lm,
m_ordered = 0; m_ordered = 0;
Uint32 fragCount = m_currentTable->m_fragmentCount; Uint32 fragCount = m_currentTable->m_fragmentCount;
ndbout_c("batch: %d parallell: %d fragCount: %d",
batch, parallell, fragCount);
if(batch + parallell == 0){ // Max speed if(batch + parallell == 0){ // Max speed
batch = 16; batch = 16;
...@@ -153,6 +155,9 @@ NdbResultSet* NdbScanOperation::readTuples(NdbScanOperation::LockMode lm, ...@@ -153,6 +155,9 @@ NdbResultSet* NdbScanOperation::readTuples(NdbScanOperation::LockMode lm,
parallell = fragCount; parallell = fragCount;
else if(parallell == 0) else if(parallell == 0)
parallell = fragCount; parallell = fragCount;
ndbout_c("batch: %d parallell: %d fragCount: %d",
batch, parallell, fragCount);
assert(parallell > 0); assert(parallell > 0);
...@@ -486,6 +491,11 @@ int NdbScanOperation::nextResult(bool fetchAllowed) ...@@ -486,6 +491,11 @@ int NdbScanOperation::nextResult(bool fetchAllowed)
last = m_api_receivers_count; last = m_api_receivers_count;
do { do {
if(theError.code){
setErrorCode(theError.code);
return -1;
}
Uint32 cnt = m_conf_receivers_count; Uint32 cnt = m_conf_receivers_count;
Uint32 sent = m_sent_receivers_count; Uint32 sent = m_sent_receivers_count;
...@@ -502,12 +512,17 @@ int NdbScanOperation::nextResult(bool fetchAllowed) ...@@ -502,12 +512,17 @@ int NdbScanOperation::nextResult(bool fetchAllowed)
*/ */
theNdb->theWaiter.m_node = nodeId; theNdb->theWaiter.m_node = nodeId;
theNdb->theWaiter.m_state = WAIT_SCAN; theNdb->theWaiter.m_state = WAIT_SCAN;
ndbout_c("%d : api: %d conf: %d sent: %d",
__LINE__,
m_api_receivers_count,
m_conf_receivers_count,
m_sent_receivers_count);
int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT); int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT);
if (return_code == 0 && seq == tp->getNodeSequence(nodeId)) { if (return_code == 0 && seq == tp->getNodeSequence(nodeId)) {
continue; continue;
} else { } else {
idx = last; idx = last;
retVal = -1; //return_code; retVal = -2; //return_code;
} }
} else if(retVal == 2){ } else if(retVal == 2){
/** /**
...@@ -516,6 +531,11 @@ int NdbScanOperation::nextResult(bool fetchAllowed) ...@@ -516,6 +531,11 @@ int NdbScanOperation::nextResult(bool fetchAllowed)
if(send_next_scan(0, true) == 0){ // Close scan if(send_next_scan(0, true) == 0){ // Close scan
theNdb->theWaiter.m_node = nodeId; theNdb->theWaiter.m_node = nodeId;
theNdb->theWaiter.m_state = WAIT_SCAN; theNdb->theWaiter.m_state = WAIT_SCAN;
ndbout_c("%d : api: %d conf: %d sent: %d",
__LINE__,
m_api_receivers_count,
m_conf_receivers_count,
m_sent_receivers_count);
int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT); int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT);
if (return_code == 0 && seq == tp->getNodeSequence(nodeId)) { if (return_code == 0 && seq == tp->getNodeSequence(nodeId)) {
return 1; return 1;
...@@ -633,6 +653,12 @@ NdbScanOperation::doSend(int ProcessorId) ...@@ -633,6 +653,12 @@ NdbScanOperation::doSend(int ProcessorId)
void NdbScanOperation::closeScan() void NdbScanOperation::closeScan()
{ {
ndbout_c("closeScan %d : api: %d conf: %d sent: %d",
__LINE__,
m_api_receivers_count,
m_conf_receivers_count,
m_sent_receivers_count);
do { do {
TransporterFacade* tp = TransporterFacade::instance(); TransporterFacade* tp = TransporterFacade::instance();
Guard guard(tp->theMutexPtr); Guard guard(tp->theMutexPtr);
...@@ -651,6 +677,11 @@ void NdbScanOperation::closeScan() ...@@ -651,6 +677,11 @@ void NdbScanOperation::closeScan()
while(m_sent_receivers_count){ while(m_sent_receivers_count){
theNdb->theWaiter.m_node = nodeId; theNdb->theWaiter.m_node = nodeId;
theNdb->theWaiter.m_state = WAIT_SCAN; theNdb->theWaiter.m_state = WAIT_SCAN;
ndbout_c("%d : api: %d conf: %d sent: %d",
__LINE__,
m_api_receivers_count,
m_conf_receivers_count,
m_sent_receivers_count);
int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT); int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT);
switch(return_code){ switch(return_code){
case 0: case 0:
...@@ -679,6 +710,11 @@ void NdbScanOperation::closeScan() ...@@ -679,6 +710,11 @@ void NdbScanOperation::closeScan()
do { do {
theNdb->theWaiter.m_node = nodeId; theNdb->theWaiter.m_node = nodeId;
theNdb->theWaiter.m_state = WAIT_SCAN; theNdb->theWaiter.m_state = WAIT_SCAN;
ndbout_c("%d : api: %d conf: %d sent: %d",
__LINE__,
m_api_receivers_count,
m_conf_receivers_count,
m_sent_receivers_count);
int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT); int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT);
switch(return_code){ switch(return_code){
case 0: case 0:
...@@ -701,22 +737,7 @@ void NdbScanOperation::closeScan() ...@@ -701,22 +737,7 @@ void NdbScanOperation::closeScan()
} }
void void
NdbScanOperation::execCLOSE_SCAN_REP(Uint32 errCode){ NdbScanOperation::execCLOSE_SCAN_REP(){
/**
* We will receive no further signals from this scan
*/
if(!errCode){
/**
* Normal termination
*/
theNdbCon->theCommitStatus = NdbConnection::Committed;
theNdbCon->theCompletionStatus = NdbConnection::CompletedSuccess;
} else {
/**
* Something is fishy
*/
abort();
}
m_api_receivers_count = 0; m_api_receivers_count = 0;
m_conf_receivers_count = 0; m_conf_receivers_count = 0;
m_sent_receivers_count = 0; m_sent_receivers_count = 0;
...@@ -1206,7 +1227,7 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){ ...@@ -1206,7 +1227,7 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){
Uint32 nodeId = theNdbCon->theDBnode; Uint32 nodeId = theNdbCon->theDBnode;
if(seq == tp->getNodeSequence(nodeId) && !send_next_scan_ordered(u_idx)){ if(seq == tp->getNodeSequence(nodeId) && !send_next_scan_ordered(u_idx)){
Uint32 tmp = m_sent_receivers_count; Uint32 tmp = m_sent_receivers_count;
while(m_sent_receivers_count > 0){ while(m_sent_receivers_count > 0 && !theError.code){
theNdb->theWaiter.m_node = nodeId; theNdb->theWaiter.m_node = nodeId;
theNdb->theWaiter.m_state = WAIT_SCAN; theNdb->theWaiter.m_state = WAIT_SCAN;
int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT); int return_code = theNdb->receiveResponse(WAITFOR_SCAN_TIMEOUT);
...@@ -1223,12 +1244,16 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){ ...@@ -1223,12 +1244,16 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){
memcpy(arr, m_conf_receivers, u_last * sizeof(char*)); memcpy(arr, m_conf_receivers, u_last * sizeof(char*));
if(DEBUG_NEXT_RESULT) ndbout_c("sent: %d recv: %d", tmp, u_last); if(DEBUG_NEXT_RESULT) ndbout_c("sent: %d recv: %d", tmp, u_last);
if(theError.code){
setErrorCode(theError.code);
return -1;
}
} }
} else { } else {
return 2; return 2;
} }
} }
if(DEBUG_NEXT_RESULT) ndbout_c("u=[%d %d] s=[%d %d]", if(DEBUG_NEXT_RESULT) ndbout_c("u=[%d %d] s=[%d %d]",
u_idx, u_last, u_idx, u_last,
s_idx, s_last); s_idx, s_last);
...@@ -1279,9 +1304,12 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){ ...@@ -1279,9 +1304,12 @@ NdbIndexScanOperation::next_result_ordered(bool fetchAllowed){
Guard guard(tp->theMutexPtr); Guard guard(tp->theMutexPtr);
Uint32 seq = theNdbCon->theNodeSequence; Uint32 seq = theNdbCon->theNodeSequence;
Uint32 nodeId = theNdbCon->theDBnode; Uint32 nodeId = theNdbCon->theDBnode;
if(seq == tp->getNodeSequence(nodeId) && send_next_scan(0, true) == 0){ if(seq == tp->getNodeSequence(nodeId) &&
send_next_scan(0, true) == 0 &&
theError.code == 0){
return 1; return 1;
} }
setErrorCode(theError.code);
return -1; return -1;
} }
......
...@@ -705,23 +705,25 @@ Ndb::handleReceivedSignal(NdbApiSignal* aSignal, LinearSectionPtr ptr[3]) ...@@ -705,23 +705,25 @@ Ndb::handleReceivedSignal(NdbApiSignal* aSignal, LinearSectionPtr ptr[3])
{ {
tFirstDataPtr = int2void(tFirstData); tFirstDataPtr = int2void(tFirstData);
if (tFirstDataPtr == 0) goto InvalidSignal; if (tFirstDataPtr == 0) goto InvalidSignal;
tCon = void2con(tFirstDataPtr);
assert(tFirstDataPtr != 0 &&
void2con(tFirstDataPtr)->checkMagicNumber() == 0);
if (tWaitState == WAIT_SCAN){ if (tCon->checkMagicNumber() == 0){
tCon = void2con(tFirstDataPtr); tReturnCode = tCon->receiveSCAN_TABREF(aSignal);
if (tCon->checkMagicNumber() == 0){ if (tReturnCode != -1){
tReturnCode = tCon->receiveSCAN_TABREF(aSignal); theWaiter.m_state = NO_WAIT;
if (tReturnCode != -1){
theWaiter.m_state = NO_WAIT;
}
break;
} }
break;
} }
goto InvalidSignal; goto InvalidSignal;
} }
case GSN_SCAN_TABINFO: case GSN_SCAN_TABINFO:
{ {
goto InvalidSignal; goto InvalidSignal;
} }
case GSN_KEYINFO20: { case GSN_KEYINFO20: {
tFirstDataPtr = int2void(tFirstData); tFirstDataPtr = int2void(tFirstData);
if (tFirstDataPtr == 0) goto InvalidSignal; if (tFirstDataPtr == 0) goto InvalidSignal;
......
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