Commit 53f760a0 authored by stewart@mysql.com's avatar stewart@mysql.com

BUG#17928 testBackup fails in error handling testcases

Reproduced failure of NFMaster on my laptop, this is the fix with some added
debug information to help people in the future when they trigger asserts in
AsyncFile (ndbfs helper threads).
parent ae70201a
...@@ -3819,19 +3819,37 @@ Backup::checkFile(Signal* signal, BackupFilePtr filePtr) ...@@ -3819,19 +3819,37 @@ Backup::checkFile(Signal* signal, BackupFilePtr filePtr)
FsAppendReq::SignalLength, JBA); FsAppendReq::SignalLength, JBA);
return; return;
}//if }//if
filePtr.p->fileRunning = 0; #ifdef DEBUG_ABORT
filePtr.p->fileClosing = 1; Uint32 running= filePtr.p->fileRunning;
Uint32 closing= filePtr.p->fileClosing;
FsCloseReq * req = (FsCloseReq *)signal->getDataPtrSend(); #endif
req->filePointer = filePtr.p->filePointer;
req->userPointer = filePtr.i; if(!filePtr.p->fileClosing)
req->userReference = reference(); {
req->fileFlag = 0; filePtr.p->fileRunning = 0;
filePtr.p->fileClosing = 1;
FsCloseReq * req = (FsCloseReq *)signal->getDataPtrSend();
req->filePointer = filePtr.p->filePointer;
req->userPointer = filePtr.i;
req->userReference = reference();
req->fileFlag = 0;
#ifdef DEBUG_ABORT
ndbout_c("***** a FSCLOSEREQ filePtr.i = %u run=%d cl=%d", filePtr.i,
running, closing);
#endif
sendSignal(NDBFS_REF, GSN_FSCLOSEREQ, signal, FsCloseReq::SignalLength, JBA);
}
else
{
#ifdef DEBUG_ABORT #ifdef DEBUG_ABORT
ndbout_c("***** a FSCLOSEREQ filePtr.i = %u", filePtr.i); ndbout_c("***** a NOT SENDING FSCLOSEREQ filePtr.i = %u run=%d cl=%d",
filePtr.i,
running, closing);
#endif #endif
sendSignal(NDBFS_REF, GSN_FSCLOSEREQ, signal, FsCloseReq::SignalLength, JBA);
}
} }
...@@ -4082,9 +4100,7 @@ Backup::closeFiles(Signal* sig, BackupRecordPtr ptr) ...@@ -4082,9 +4100,7 @@ Backup::closeFiles(Signal* sig, BackupRecordPtr ptr)
jam(); jam();
continue; continue;
}//if }//if
filePtr.p->fileClosing = 1;
if(filePtr.p->fileRunning == 1){ if(filePtr.p->fileRunning == 1){
jam(); jam();
#ifdef DEBUG_ABORT #ifdef DEBUG_ABORT
...@@ -4093,7 +4109,10 @@ Backup::closeFiles(Signal* sig, BackupRecordPtr ptr) ...@@ -4093,7 +4109,10 @@ Backup::closeFiles(Signal* sig, BackupRecordPtr ptr)
filePtr.p->operation.dataBuffer.eof(); filePtr.p->operation.dataBuffer.eof();
} else { } else {
jam(); jam();
filePtr.p->fileClosing = 1;
filePtr.p->operation.dataBuffer.eof();
checkFile(sig, filePtr); // make sure we write everything before closing
FsCloseReq * req = (FsCloseReq *)sig->getDataPtrSend(); FsCloseReq * req = (FsCloseReq *)sig->getDataPtrSend();
req->filePointer = filePtr.p->filePointer; req->filePointer = filePtr.p->filePointer;
req->userPointer = filePtr.i; req->userPointer = filePtr.i;
...@@ -4555,7 +4574,6 @@ Backup::execLCP_PREPARE_REQ(Signal* signal) ...@@ -4555,7 +4574,6 @@ Backup::execLCP_PREPARE_REQ(Signal* signal)
jam(); jam();
BackupFilePtr filePtr; BackupFilePtr filePtr;
c_backupFilePool.getPtr(filePtr, ptr.p->dataFilePtr); c_backupFilePool.getPtr(filePtr, ptr.p->dataFilePtr);
filePtr.p->fileClosing = 1;
filePtr.p->operation.dataBuffer.eof(); filePtr.p->operation.dataBuffer.eof();
} }
...@@ -4647,7 +4665,6 @@ Backup::execEND_LCPREQ(Signal* signal) ...@@ -4647,7 +4665,6 @@ Backup::execEND_LCPREQ(Signal* signal)
BackupFilePtr filePtr; BackupFilePtr filePtr;
c_backupFilePool.getPtr(filePtr, ptr.p->dataFilePtr); c_backupFilePool.getPtr(filePtr, ptr.p->dataFilePtr);
filePtr.p->fileClosing = 1;
filePtr.p->operation.dataBuffer.eof(); filePtr.p->operation.dataBuffer.eof();
return; return;
} }
......
...@@ -228,6 +228,7 @@ AsyncFile::run() ...@@ -228,6 +228,7 @@ AsyncFile::run()
endReq(); endReq();
return; return;
default: default:
DEBUG(ndbout_c("Invalid Request"));
abort(); abort();
break; break;
}//switch }//switch
...@@ -676,6 +677,7 @@ AsyncFile::extendfile(Request* request) { ...@@ -676,6 +677,7 @@ AsyncFile::extendfile(Request* request) {
return 0; return 0;
#else #else
request = request; request = request;
DEBUG(ndbout_c("no pwrite"));
abort(); abort();
return -1; return -1;
#endif #endif
...@@ -792,6 +794,7 @@ AsyncFile::writeBuffer(const char * buf, size_t size, off_t offset, ...@@ -792,6 +794,7 @@ AsyncFile::writeBuffer(const char * buf, size_t size, off_t offset,
bytes_written = return_value; bytes_written = return_value;
if(bytes_written == 0){ if(bytes_written == 0){
DEBUG(ndbout_c("no bytes written"));
abort(); abort();
} }
...@@ -830,8 +833,10 @@ AsyncFile::closeReq(Request * request) ...@@ -830,8 +833,10 @@ AsyncFile::closeReq(Request * request)
#else #else
if (-1 == ::close(theFd)) { if (-1 == ::close(theFd)) {
#ifndef DBUG_OFF #ifndef DBUG_OFF
if (theFd == -1) if (theFd == -1) {
DEBUG(ndbout_c("close on fd = -1"));
abort(); abort();
}
#endif #endif
request->error = errno; request->error = errno;
} }
...@@ -899,6 +904,7 @@ AsyncFile::appendReq(Request * request){ ...@@ -899,6 +904,7 @@ AsyncFile::appendReq(Request * request){
return; return;
} }
if(n == 0){ if(n == 0){
DEBUG(ndbout_c("append with n=0"));
abort(); abort();
} }
size -= n; size -= n;
......
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