From cc94cafe1a75f50cb5c4a505cc9adb499a748a14 Mon Sep 17 00:00:00 2001 From: negoyal Date: Mon, 7 Jun 2021 16:46:41 -0700 Subject: [PATCH] Small bugfix in the parallel extent read path. --- fdbserver/VersionedBTree.actor.cpp | 338 ++++++++++++++--------------- 1 file changed, 168 insertions(+), 170 deletions(-) diff --git a/fdbserver/VersionedBTree.actor.cpp b/fdbserver/VersionedBTree.actor.cpp index 2692bb2008..4ba81e85d3 100644 --- a/fdbserver/VersionedBTree.actor.cpp +++ b/fdbserver/VersionedBTree.actor.cpp @@ -374,10 +374,10 @@ public: (initialPageID == invalidLogicalPageID && readOffset == 0 && endPage == invalidLogicalPageID)); } - debug_printf_always("FIFOQueue::Cursor(%s) initialized\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) initialized\n", toString().c_str()); if (mode == WRITE && initialPageID != invalidLogicalPageID) { - debug_printf_always("FIFOQueue::Cursor(%s) init. Adding new page %u\n", toString().c_str(), initialPageID); + debug_printf("FIFOQueue::Cursor(%s) init. Adding new page %u\n", toString().c_str(), initialPageID); addNewPage(initialPageID, 0, true, initExtentInfo, tailPageNewExtent, prevExtentEndPageID); } } @@ -454,24 +454,24 @@ public: void startNextPageLoad(LogicalPageID id) { nextPageID = id; - debug_printf_always( + debug_printf( "FIFOQueue::Cursor(%s) loadPage start id=%s\n", toString().c_str(), ::toString(nextPageID).c_str()); nextPageReader = waitOrError(queue->pager->readPage(nextPageID, true), queue->pagerError); } Future loadExtent() { ASSERT(mode == POP | mode == READONLY); - debug_printf_always("FIFOQueue::Cursor(%s) loadExtent\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) loadExtent\n", toString().c_str()); return map(queue->pager->readExtent(pageID), [=](Reference p) { page = p; - debug_printf_always("FIFOQueue::Cursor(%s) loadExtent done. Page: %p\n", toString().c_str(), page->begin()); + debug_printf("FIFOQueue::Cursor(%s) loadExtent done. Page: %p\n", toString().c_str(), page->begin()); return Void(); }); } void writePage() { ASSERT(mode == WRITE); - debug_printf_always("FIFOQueue::Cursor(%s) writePage\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) writePage\n", toString().c_str()); VALGRIND_MAKE_MEM_DEFINED(raw()->begin(), offset); VALGRIND_MAKE_MEM_DEFINED(raw()->begin() + offset, queue->dataBytesPerPage - raw()->endOffset); queue->pager->updatePage(pageID, page); @@ -495,7 +495,7 @@ public: LogicalPageID prevExtentEndPageID = invalidLogicalPageID) { ASSERT(mode == WRITE); ASSERT(newPageID != invalidLogicalPageID); - debug_printf_always("FIFOQueue::Cursor(%s) Adding page %s initPage=%d initExtentInfo=%d newExtentPage=%d\n", + debug_printf("FIFOQueue::Cursor(%s) Adding page %s initPage=%d initExtentInfo=%d newExtentPage=%d\n", toString().c_str(), ::toString(newPageID).c_str(), initializeNewPage, @@ -505,7 +505,7 @@ public: // Update existing page/newLastPageID and write, if it exists if (page) { setNext(newPageID, newOffset); - debug_printf_always("FIFOQueue::Cursor(%s) Linked new page %s:%d\n", + debug_printf("FIFOQueue::Cursor(%s) Linked new page %s:%d\n", toString().c_str(), ::toString(newPageID).c_str(), newOffset); @@ -514,7 +514,7 @@ public: prevExtentEndPageID = p->extentEndPageID; if (pageID == prevExtentEndPageID) newExtentPage = true; - debug_printf_always( + debug_printf( "FIFOQueue::Cursor(%s) Linked new page. pageID %u, newPageID %u, prevExtentEndPageID %u\n", toString().c_str(), pageID, @@ -535,7 +535,7 @@ public: } if (initializeNewPage) { - debug_printf_always("FIFOQueue::Cursor(%s) Initializing new page. usesExtents: %d, initializeExtentInfo: %d\n", + debug_printf("FIFOQueue::Cursor(%s) Initializing new page. usesExtents: %d, initializeExtentInfo: %d\n", toString().c_str(), queue->usesExtents, initializeExtentInfo); @@ -546,7 +546,7 @@ public: p->endOffset = 0; // For extent based queue, update the index of current page within the extent if (queue->usesExtents) { - debug_printf_always("FIFOQueue::Cursor(%s) Adding page %s init=%d pageCount %d\n", + debug_printf("FIFOQueue::Cursor(%s) Adding page %s init=%d pageCount %d\n", toString().c_str(), ::toString(newPageID).c_str(), initializeNewPage, @@ -556,7 +556,7 @@ public: int pagesPerExtent = queue->pagesPerExtent; if (newExtentPage) { p->extentEndPageID = newPageID + pagesPerExtent - 1; - debug_printf_always("FIFOQueue::Cursor(%s) newExtentPage. newPageID %u, pagesPerExtent %d, " + debug_printf("FIFOQueue::Cursor(%s) newExtentPage. newPageID %u, pagesPerExtent %d, " "ExtentEndPageID: %s\n", toString().c_str(), newPageID, @@ -564,14 +564,14 @@ public: ::toString(p->extentEndPageID).c_str()); } else { p->extentEndPageID = prevExtentEndPageID; - debug_printf_always("FIFOQueue::Cursor(%s) Copied ExtentEndPageID: %s\n", + debug_printf("FIFOQueue::Cursor(%s) Copied ExtentEndPageID: %s\n", toString().c_str(), ::toString(p->extentEndPageID).c_str()); } } } } else { - debug_printf_always("FIFOQueue::Cursor(%s) Clearing new page\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) Clearing new page\n", toString().c_str()); page.clear(); } } @@ -593,7 +593,7 @@ public: } } - debug_printf_always("FIFOQueue::Cursor(%s) write(%s) mustWait=%d needNewPage=%d\n", + debug_printf("FIFOQueue::Cursor(%s) write(%s) mustWait=%d needNewPage=%d\n", self->toString().c_str(), ::toString(item).c_str(), mustWait, @@ -621,7 +621,7 @@ public: // If we need a new page, add one. if (needNewPage) { - debug_printf_always("FIFOQueue::Cursor(%s) write(%s) page is full, adding new page\n", + debug_printf("FIFOQueue::Cursor(%s) write(%s) page is full, adding new page\n", self->toString().c_str(), ::toString(item).c_str(), ::toString(self->pageID).c_str(), @@ -653,7 +653,7 @@ public: ++self->queue->numPages; } - debug_printf_always( + debug_printf( "FIFOQueue::Cursor(%s) write(%s) writing\n", self->toString().c_str(), ::toString(item).c_str()); auto p = self->raw(); Codec::writeToBytes(p->begin() + self->offset, item); @@ -687,12 +687,12 @@ public: bool load) { // Lock the mutex if it wasn't already if (!locked) { - debug_printf_always("FIFOQueue::Cursor(%s) waitThenReadNext locking mutex\n", self->toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) waitThenReadNext locking mutex\n", self->toString().c_str()); wait(self->mutex.take()); } if (load) { - debug_printf_always("FIFOQueue::Cursor(%s) waitThenReadNext waiting for page load\n", + debug_printf("FIFOQueue::Cursor(%s) waitThenReadNext waiting for page load\n", self->toString().c_str()); wait(success(self->nextPageReader)); } @@ -701,7 +701,7 @@ public: // If this actor instance locked the mutex, then unlock it. if (!locked) { - debug_printf_always("FIFOQueue::Cursor(%s) waitThenReadNext unlocking mutex\n", self->toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) waitThenReadNext unlocking mutex\n", self->toString().c_str()); self->mutex.release(); } @@ -713,7 +713,7 @@ public: // recursive call Future> readNext(const Optional& upperBound = {}, bool locked = false) { if ((mode != POP && mode != READONLY) || pageID == invalidLogicalPageID || pageID == endPageID) { - debug_printf_always("FIFOQueue::Cursor(%s) readNext returning nothing\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) readNext returning nothing\n", toString().c_str()); return Optional(); } @@ -724,13 +724,13 @@ public: // We now know pageID is valid and should be used, but page might not point to it yet if (!page) { - debug_printf_always("FIFOQueue::Cursor(%s) loading\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) loading\n", toString().c_str()); // If the next pageID loading or loaded is not the page we should be reading then restart the load // nextPageID coud be different because it could be invalid or it could be no longer relevant // if the previous commit added new pages to the front of the queue. if (pageID != nextPageID) { - debug_printf_always("FIFOQueue::Cursor(%s) reloading\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) reloading\n", toString().c_str()); startNextPageLoad(pageID); } @@ -752,13 +752,13 @@ public: } auto p = raw(); - debug_printf_always("FIFOQueue::Cursor(%s) readNext reading at current position\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) readNext reading at current position\n", toString().c_str()); ASSERT(offset < p->endOffset); int bytesRead; const T result = Codec::readFromBytes(p->begin() + offset, bytesRead); if (upperBound.present() && upperBound.get() < result) { - debug_printf_always("FIFOQueue::Cursor(%s) not popping %s, exceeds upper bound %s\n", + debug_printf("FIFOQueue::Cursor(%s) not popping %s, exceeds upper bound %s\n", toString().c_str(), ::toString(result).c_str(), ::toString(upperBound.get()).c_str()); @@ -770,13 +770,13 @@ public: if (mode == POP) { --queue->numEntries; } - debug_printf_always("FIFOQueue::Cursor(%s) after read of %s\n", toString().c_str(), ::toString(result).c_str()); + debug_printf("FIFOQueue::Cursor(%s) after read of %s\n", toString().c_str(), ::toString(result).c_str()); ASSERT(offset <= p->endOffset); // If this page is exhausted, start reading the next page for the next readNext() to use, unless it's the // tail page if (offset == p->endOffset) { - debug_printf_always("FIFOQueue::Cursor(%s) Page exhausted\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) Page exhausted\n", toString().c_str()); LogicalPageID oldPageID = pageID; pageID = p->nextPageID; offset = p->nextOffset; @@ -790,7 +790,7 @@ public: --queue->numPages; } page.clear(); - debug_printf_always("FIFOQueue::Cursor(%s) readNext page exhausted, moved to new page\n", toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) readNext page exhausted, moved to new page\n", toString().c_str()); if (mode == POP && !queue->usesExtents) { // Freeing the old page must happen after advancing the cursor and clearing the page reference @@ -805,7 +805,7 @@ public: } } - debug_printf_always("FIFOQueue(%s) %s(upperBound=%s) -> %s\n", + debug_printf("FIFOQueue(%s) %s(upperBound=%s) -> %s\n", queue->name.c_str(), (mode == POP ? "pop" : "peek"), ::toString(upperBound).c_str(), @@ -824,7 +824,7 @@ public: // Create a new queue at newPageID void create(IPager2* p, LogicalPageID newPageID, std::string queueName, QueueID id, bool extent) { - debug_printf_always("FIFOQueue(%s) create from page %s. usesExtents %d\n", + debug_printf("FIFOQueue(%s) create from page %s. usesExtents %d\n", queueName.c_str(), toString(newPageID).c_str(), extent); @@ -841,12 +841,12 @@ public: tailWriter.init(this, Cursor::WRITE, newPageID, true, true); headWriter.init(this, Cursor::WRITE); newTailPage = invalidLogicalPageID; - debug_printf_always("FIFOQueue(%s) created\n", queueName.c_str()); + debug_printf("FIFOQueue(%s) created\n", queueName.c_str()); } // Load an existing queue from its queue state void recover(IPager2* p, const QueueState& qs, std::string queueName, bool loadExtents = true) { - debug_printf_always("FIFOQueue(%s) recover from queue state %s\n", queueName.c_str(), qs.toString().c_str()); + debug_printf("FIFOQueue(%s) recover from queue state %s\n", queueName.c_str(), qs.toString().c_str()); pager = p; pagerError = pager->getError(); name = queueName; @@ -867,14 +867,14 @@ public: qs.prevExtentEndPageID); headWriter.init(this, Cursor::WRITE); newTailPage = invalidLogicalPageID; - debug_printf_always("FIFOQueue(%s) recovered\n", queueName.c_str()); + debug_printf("FIFOQueue(%s) recovered\n", queueName.c_str()); } // Reset the head reader (this is used only for extent based remap queue after recovering the remap // queue contents via fastpath extent reads) void resetHeadReader() { headReader.resetRead(); - debug_printf_always("FIFOQueue(%s) read cursor reset\n", name.c_str()); + debug_printf("FIFOQueue(%s) read cursor reset\n", name.c_str()); } // Fast path extent peekAll (this zooms through the queue reading extents at a time) @@ -884,9 +884,9 @@ public: state Cursor c; c.initReadOnly(self->headReader, true); - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt begin\n", c.toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) peekAllExt begin\n", c.toString().c_str()); if (c.pageID == invalidLogicalPageID || c.pageID == c.endPageID) { - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt returning nothing\n", c.toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) peekAllExt returning nothing\n", c.toString().c_str()); res.sendError(end_of_stream()); return Void(); } @@ -896,7 +896,7 @@ public: loop { // We now know we are pointing to PageID and it should be read and used, but it may not be loaded yet. if (!c.page) { - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt going to Load Extent %s.\n", + debug_printf("FIFOQueue::Cursor(%s) peekAllExt going to Load Extent %s.\n", c.toString().c_str(), ::toString(c.pageID).c_str()); wait(c.loadExtent()); @@ -912,19 +912,20 @@ public: // Position the page pointer to current page in the extent Reference page = c.page->subPage(pageIdx++ * self->pager->getPhysicalPageSize(), self->pager->getLogicalPageSize()); - debug_printf_always("FIFOQueue::Cursor(%s) peekALLExt %s. Offset %d, CalculateChecksum %d ChecksumInPage %d\n", - c.toString().c_str(), - toString(c.pageID).c_str(), - c.pageID * self->pager->getPhysicalPageSize(), - page->calculateChecksum(c.pageID), - page->getChecksum()); + debug_printf("FIFOQueue::Cursor(%s) peekALLExt %s. Offset %d, CalculateChecksum %d ChecksumInPage %d\n", + c.toString().c_str(), + toString(c.pageID).c_str(), + c.pageID * self->pager->getPhysicalPageSize(), + page->calculateChecksum(c.pageID), + page->getChecksum()); if (!page->verifyChecksum(c.pageID)) { - debug_printf_always("FIFOQueue::Cursor(%s) peekALLExt checksum failed for %s. Offset %d, CalculateChecksum %d ChecksumInPage %d\n", + debug_printf("FIFOQueue::Cursor(%s) peekALLExt checksum failed for %s. Offset %d, " + "CalculateChecksum %d ChecksumInPage %d\n", c.toString().c_str(), - toString(c.pageID).c_str(), - c.pageID * self->pager->getPhysicalPageSize(), - page->calculateChecksum(c.pageID), - page->getChecksum()); + toString(c.pageID).c_str(), + c.pageID * self->pager->getPhysicalPageSize(), + page->calculateChecksum(c.pageID), + page->getChecksum()); Error e = checksum_failed(); TraceEvent(SevError, "FIFOQueueChecksumFailed") .detail("PageID", c.pageID) @@ -953,9 +954,9 @@ public: if (c.offset == p->endOffset) { c.pageID = p->nextPageID; c.offset = p->nextOffset; - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt page exhausted, moved to new page\n", + debug_printf("FIFOQueue::Cursor(%s) peekAllExt page exhausted, moved to new page\n", c.toString().c_str()); - debug_printf_always("FIFOQueue:: nextPageID=%s, extentCurPageID=%s, extentEndPageID=%s\n", + debug_printf("FIFOQueue:: nextPageID=%s, extentCurPageID=%s, extentEndPageID=%s\n", ::toString(p->nextPageID).c_str(), ::toString(p->extentCurPageID).c_str(), ::toString(p->extentEndPageID).c_str()); @@ -965,7 +966,7 @@ public: // Check if we have reached the end of the queue if (c.pageID == invalidLogicalPageID || c.pageID == c.endPageID) { - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt Queue exhausted\n", c.toString().c_str()); + debug_printf("FIFOQueue::Cursor(%s) peekAllExt Queue exhausted\n", c.toString().c_str()); res.send(results); // Since we have reached the end of the queue, verify that the number of entries read matches @@ -986,7 +987,7 @@ public: // Check if we have reached the end of current extent if (p->extentCurPageID == p->extentEndPageID) { c.page.clear(); - debug_printf_always("FIFOQueue::Cursor(%s) peekAllExt extent exhausted, moved to new extent\n", + debug_printf("FIFOQueue::Cursor(%s) peekAllExt extent exhausted, moved to new extent\n", c.toString().c_str()); entriesRead += results.size(); @@ -1052,17 +1053,17 @@ public: s.tailPageNewExtent = tailPageNewExtent; s.prevExtentEndPageID = prevExtentEndPageID; - debug_printf_always("FIFOQueue(%s) getState(): %s\n", name.c_str(), s.toString().c_str()); + debug_printf("FIFOQueue(%s) getState(): %s\n", name.c_str(), s.toString().c_str()); return s; } void pushBack(const T& item) { - debug_printf_always("FIFOQueue(%s) pushBack(%s)\n", name.c_str(), toString(item).c_str()); + debug_printf("FIFOQueue(%s) pushBack(%s)\n", name.c_str(), toString(item).c_str()); tailWriter.write(item); } void pushFront(const T& item) { - debug_printf_always("FIFOQueue(%s) pushFront(%s)\n", name.c_str(), toString(item).c_str()); + debug_printf("FIFOQueue(%s) pushFront(%s)\n", name.c_str(), toString(item).c_str()); headWriter.write(item); } @@ -1073,7 +1074,7 @@ public: // Wait until all previously started operations on each cursor are done and the new tail page is ready Future notBusy() { auto f = headWriter.notBusy() && headReader.notBusy() && tailWriter.notBusy() && ready(newTailPage); - debug_printf_always("FIFOQueue(%s) notBusy future ready=%d\n", name.c_str(), f.isReady()); + debug_printf("FIFOQueue(%s) notBusy future ready=%d\n", name.c_str(), f.isReady()); return f; } @@ -1091,7 +1092,7 @@ public: // This creates a circular dependency with 1 or more queues when those queues are used by the pager // to manage free page IDs. ACTOR static Future preFlush_impl(FIFOQueue* self) { - debug_printf_always("FIFOQueue(%s) preFlush begin\n", self->name.c_str()); + debug_printf("FIFOQueue(%s) preFlush begin\n", self->name.c_str()); wait(self->notBusy()); // Completion of the pending operations as of the start of notBusy() could have began new operations, @@ -1110,7 +1111,7 @@ public: // has had items added to it, then get a new tail page ID. if (self->newTailPage.isReady() && self->newTailPage.get() == invalidLogicalPageID) { if (self->tailWriter.pendingTailWrites()) { - debug_printf_always("FIFOQueue(%s) preFlush starting to get new page ID\n", self->name.c_str()); + debug_printf("FIFOQueue(%s) preFlush starting to get new page ID\n", self->name.c_str()); if (self->usesExtents) { if (self->tailWriter.pageID == invalidLogicalPageID) { self->newTailPage = self->pager->newExtentPageID(self->queueID); @@ -1118,7 +1119,7 @@ public: self->prevExtentEndPageID = invalidLogicalPageID; } else { auto p = self->tailWriter.raw(); - debug_printf_always( + debug_printf( "FIFOQueue(%s) newTailPage tailWriterPage %u extentCurPageID %u, extentEndPageID %u\n", self->name.c_str(), self->tailWriter.pageID, @@ -1134,7 +1135,7 @@ public: self->prevExtentEndPageID = invalidLogicalPageID; } } - debug_printf_always("FIFOQueue(%s) newTailPage tailPageNewExtent:%d prevExtentEndPageID: %u " + debug_printf("FIFOQueue(%s) newTailPage tailPageNewExtent:%d prevExtentEndPageID: %u " "tailWriterPage %u\n", self->name.c_str(), self->tailPageNewExtent, @@ -1148,7 +1149,7 @@ public: auto p = self->tailWriter.raw(); self->prevExtentEndPageID = p->extentEndPageID; self->tailPageNewExtent = false; - debug_printf_always("FIFOQueue(%s) newTailPage tailPageNewExtent: %d prevExtentEndPageID: %u " + debug_printf("FIFOQueue(%s) newTailPage tailPageNewExtent: %d prevExtentEndPageID: %u " "tailWriterPage %u\n", self->name.c_str(), self->tailPageNewExtent, @@ -1159,14 +1160,14 @@ public: } } - debug_printf_always("FIFOQueue(%s) preFlush returning %d\n", self->name.c_str(), workPending); + debug_printf("FIFOQueue(%s) preFlush returning %d\n", self->name.c_str(), workPending); return workPending; } Future preFlush() { return preFlush_impl(this); } void finishFlush() { - debug_printf_always("FIFOQueue(%s) finishFlush start\n", name.c_str()); + debug_printf("FIFOQueue(%s) finishFlush start\n", name.c_str()); ASSERT(!isBusy()); bool initTailWriter = true; @@ -1196,7 +1197,7 @@ public: headReader.endPageID = tailWriter.pageID; // Reset the write cursors - debug_printf_always("FIFOQueue(%s) Reset tailWriter cursor. tailPageNewExtent: %d\n", name.c_str(), tailPageNewExtent); + debug_printf("FIFOQueue(%s) Reset tailWriter cursor. tailPageNewExtent: %d\n", name.c_str(), tailPageNewExtent); tailWriter.init(this, Cursor::WRITE, tailWriter.pageID, @@ -1207,7 +1208,7 @@ public: prevExtentEndPageID); headWriter.init(this, Cursor::WRITE); - debug_printf_always("FIFOQueue(%s) finishFlush end\n", name.c_str()); + debug_printf("FIFOQueue(%s) finishFlush end\n", name.c_str()); } ACTOR static Future flush_impl(FIFOQueue* self) { @@ -1554,7 +1555,7 @@ public: // that is currently evictable and exists in the oversized portion of the cache eviction order due // to previously failed evictions. if (&entry == &toEvict) { - debug_printf_always("Cannot evict target index %s\n", toString(index).c_str()); + debug_printf("Cannot evict target index %s\n", toString(index).c_str()); break; } @@ -1801,14 +1802,14 @@ public: wait(store(fileSize, self->pageFile->size())); } - debug_printf_always( + debug_printf( "DWALPager(%s) recover exists=%d fileSize=%" PRId64 "\n", self->filename.c_str(), exists, fileSize); // TODO: If the file exists but appears to never have been successfully committed is this an error or // should recovery proceed with a new pager instance? // If there are at least 2 pages then try to recover the existing file if (exists && fileSize >= (self->smallestPhysicalBlock * 2)) { - debug_printf_always("DWALPager(%s) recovering using existing file\n", self->filename.c_str()); + debug_printf("DWALPager(%s) recovering using existing file\n", self->filename.c_str()); state bool recoveredHeader = false; @@ -1862,18 +1863,18 @@ public: self->extentUsedList.recover(self, self->pHeader->extentUsedList, "ExtentUsedListRecovered"); self->remapQueue.recover(self, self->pHeader->remapQueue, "RemapQueueRecovered"); - debug_printf_always("DWALPager(%s) Queue recovery complete.\n", self->filename.c_str()); + debug_printf("DWALPager(%s) Queue recovery complete.\n", self->filename.c_str()); // remapQueue entries are recovered using a fast path reading extents at a time // we first issue disk reads for remapQueue extents obtained from extentUsedList Standalone> extents = wait(self->extentUsedList.peekAll()); - debug_printf_always("DWALPager(%s) ExtentUsedList size: %d.\n", self->filename.c_str(), extents.size()); + debug_printf("DWALPager(%s) ExtentUsedList size: %d.\n", self->filename.c_str(), extents.size()); if (extents.size() > 1) { QueueID remapQueueID = self->remapQueue.queueID; for (int i = 1; i < extents.size() - 1; i++) { if (extents[i].queueID == remapQueueID) { LogicalPageID extID = extents[i].extentID; - debug_printf_always("DWALPager Extents: ID: %s ", toString(extID).c_str()); + debug_printf("DWALPager Extents: ID: %s ", toString(extID).c_str()); self->readExtent(extID); } } @@ -1888,11 +1889,10 @@ public: try { loop choose { when(Standalone> remaps = waitNext(remapStream.getFuture())) { - debug_printf_always( - "DWALPager(%s) recovery. remaps size: %d, queueEntries: %d\n", - self->filename.c_str(), - remaps.size(), - self->remapQueue.numEntries); + debug_printf("DWALPager(%s) recovery. remaps size: %d, queueEntries: %d\n", + self->filename.c_str(), + remaps.size(), + self->remapQueue.numEntries); for (auto& r : remaps) { self->remappedPages[r.originalPageID][r.version] = r.newPageID; } @@ -1905,11 +1905,11 @@ public: } } - debug_printf_always("DWALPager(%s) recovery complete. RemappedPagesMap: %s\n", + debug_printf("DWALPager(%s) recovery complete. RemappedPagesMap: %s\n", self->filename.c_str(), toString(self->remappedPages).c_str()); - debug_printf_always("DWALPager(%s) recovery complete. destroy extent cache\n", self->filename.c_str()); + debug_printf("DWALPager(%s) recovery complete. destroy extent cache\n", self->filename.c_str()); wait(self->extentCache.clear()); // If the header was recovered from the backup at Page 1 then write and sync it to Page 0 before continuing. @@ -1922,7 +1922,7 @@ public: wait(self->operations.signalAndCollapse()); // Sync header wait(self->pageFile->sync()); - debug_printf_always("DWALPager(%s) Header recovery complete.\n", self->filename.c_str()); + debug_printf("DWALPager(%s) Header recovery complete.\n", self->filename.c_str()); } // Update the last committed header with the one that was recovered (which is the last known committed @@ -1945,7 +1945,7 @@ public: // committed. A new pager will be created in its place. // TODO: Is the right behavior? - debug_printf_always("DWALPager(%s) creating new pager\n", self->filename.c_str()); + debug_printf("DWALPager(%s) creating new pager\n", self->filename.c_str()); self->headerPage = self->newPageBuffer(); self->pHeader = (Header*)self->headerPage->begin(); @@ -2003,7 +2003,7 @@ public: wait(self->commit()); } - debug_printf_always("DWALPager(%s) recovered. committedVersion=%" PRId64 " logicalPageSize=%d physicalPageSize=%d\n", + debug_printf("DWALPager(%s) recovered. committedVersion=%" PRId64 " logicalPageSize=%d physicalPageSize=%d\n", self->filename.c_str(), self->pHeader->committedVersion, self->logicalPageSize, @@ -2023,12 +2023,12 @@ public: self->extentUsedList.numEntries); // TODO this is overreserving. is that a problem? Standalone> extents = wait(self->extentUsedList.peekAll()); - debug_printf_always("DWALPager(%s) ExtentUsedList size: %d.\n", self->filename.c_str(), extents.size()); + debug_printf("DWALPager(%s) ExtentUsedList size: %d.\n", self->filename.c_str(), extents.size()); if (extents.size() > 1) { for (int i = 1; i < extents.size() - 1; i++) { if (extents[i].queueID == queueID) { LogicalPageID extID = extents[i].extentID; - debug_printf_always("DWALPager Extents: ID: %s ", toString(extID).c_str()); + debug_printf("DWALPager Extents: ID: %s ", toString(extID).c_str()); extentIDs.push_back(extentIDs.arena(), extID); } } @@ -2070,7 +2070,7 @@ public: // First try the free list Optional freePageID = wait(self->freeList.pop()); if (freePageID.present()) { - debug_printf_always("DWALPager(%s) newPageID() returning %s from free list\n", + debug_printf("DWALPager(%s) newPageID() returning %s from free list\n", self->filename.c_str(), toString(freePageID.get()).c_str()); return freePageID.get(); @@ -2082,7 +2082,7 @@ public: Optional delayedFreePageID = wait(self->delayedFreeList.pop(DelayedFreePage{ self->effectiveOldestVersion(), 0 })); if (delayedFreePageID.present()) { - debug_printf_always("DWALPager(%s) newPageID() returning %s from delayed free list\n", + debug_printf("DWALPager(%s) newPageID() returning %s from delayed free list\n", self->filename.c_str(), toString(delayedFreePageID.get()).c_str()); return delayedFreePageID.get().pageID; @@ -2090,7 +2090,7 @@ public: // Lastly, add a new page to the pager LogicalPageID id = self->newLastPageID(); - debug_printf_always( + debug_printf( "DWALPager(%s) newPageID() returning %s at end of file\n", self->filename.c_str(), toString(id).c_str()); return id; }; @@ -2110,7 +2110,7 @@ public: // First try the free list Optional freeExtentID = wait(self->extentFreeList.pop()); if (freeExtentID.present()) { - debug_printf_always("DWALPager(%s) remapQueue newExtentPageID() returning %s from free list\n", + debug_printf("DWALPager(%s) remapQueue newExtentPageID() returning %s from free list\n", self->filename.c_str(), toString(freeExtentID.get()).c_str()); self->extentUsedList.pushBack({ queueID, freeExtentID.get() }); @@ -2120,7 +2120,7 @@ public: // Lastly, add a new extent to the pager LogicalPageID id = self->newLastExtentID(); - debug_printf_always("DWALPager(%s) remapQueue newExtentPageID() returning %s at end of file\n", + debug_printf("DWALPager(%s) remapQueue newExtentPageID() returning %s at end of file\n", self->filename.c_str(), toString(id).c_str()); self->extentUsedList.pushBack({ queueID, id }); @@ -2140,7 +2140,7 @@ public: Future newExtentPageID(QueueID queueID) override { return newExtentPageID_impl(this, queueID); } Future writePhysicalPage(PhysicalPageID pageID, Reference page, bool header = false) { - debug_printf_always("DWALPager(%s) op=%s %s ptr=%p\n", + debug_printf("DWALPager(%s) op=%s %s ptr=%p\n", filename.c_str(), (header ? "writePhysicalHeader" : "writePhysical"), toString(pageID).c_str(), @@ -2149,11 +2149,11 @@ public: ++g_redwoodMetrics.pagerDiskWrite; VALGRIND_MAKE_MEM_DEFINED(page->begin(), page->size()); page->updateChecksum(pageID); - debug_printf_always("DWALPager(%s) writePhysicalPage %s CalculatedChecksum=%d ChecksumInPage=%d\n", - filename.c_str(), - toString(pageID).c_str(), - page->calculateChecksum(pageID), - page->getChecksum()); + debug_printf("DWALPager(%s) writePhysicalPage %s CalculatedChecksum=%d ChecksumInPage=%d\n", + filename.c_str(), + toString(pageID).c_str(), + page->calculateChecksum(pageID), + page->getChecksum()); if (memoryOnly) { return Void(); @@ -2163,7 +2163,7 @@ public: int blockSize = header ? smallestPhysicalBlock : physicalPageSize; Future f = holdWhile(page, map(pageFile->write(page->begin(), blockSize, (int64_t)pageID * blockSize), [=](Void) { - debug_printf_always("DWALPager(%s) op=%s %s ptr=%p file offset=%d\n", + debug_printf("DWALPager(%s) op=%s %s ptr=%p file offset=%d\n", filename.c_str(), (header ? "writePhysicalHeaderComplete" : "writePhysicalComplete"), toString(pageID).c_str(), @@ -2183,7 +2183,7 @@ public: // Get the cache entry for this page, without counting it as a cache hit as we're replacing its contents now // or as a cache miss because there is no benefit to the page already being in cache PageCacheEntry& cacheEntry = pageCache.get(pageID, true, true); - debug_printf_always("DWALPager(%s) op=write %s cached=%d reading=%d writing=%d\n", + debug_printf("DWALPager(%s) op=write %s cached=%d reading=%d writing=%d\n", filename.c_str(), toString(pageID).c_str(), cacheEntry.initialized(), @@ -2222,14 +2222,14 @@ public: } Future atomicUpdatePage(LogicalPageID pageID, Reference data, Version v) override { - debug_printf_always("DWALPager(%s) op=writeAtomic %s @%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), v); + debug_printf("DWALPager(%s) op=writeAtomic %s @%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), v); Future f = map(newPageID(), [=](LogicalPageID newPageID) { updatePage(newPageID, data); // TODO: Possibly limit size of remap queue since it must be recovered on cold start RemappedPage r{ v, pageID, newPageID }; remapQueue.pushBack(r); remappedPages[pageID][v] = newPageID; - debug_printf_always("DWALPager(%s) pushed %s\n", filename.c_str(), RemappedPage(r).toString().c_str()); + debug_printf("DWALPager(%s) pushed %s\n", filename.c_str(), RemappedPage(r).toString().c_str()); return pageID; }); @@ -2240,7 +2240,7 @@ public: void freeUnmappedPage(LogicalPageID pageID, Version v) { // If v is older than the oldest version still readable then mark pageID as free as of the next commit if (v < effectiveOldestVersion()) { - debug_printf_always("DWALPager(%s) op=freeNow %s @%" PRId64 " oldestVersion=%" PRId64 "\n", + debug_printf("DWALPager(%s) op=freeNow %s @%" PRId64 " oldestVersion=%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), v, @@ -2248,7 +2248,7 @@ public: freeList.pushBack(pageID); } else { // Otherwise add it to the delayed free list - debug_printf_always("DWALPager(%s) op=freeLater %s @%" PRId64 " oldestVersion=%" PRId64 "\n", + debug_printf("DWALPager(%s) op=freeLater %s @%" PRId64 " oldestVersion=%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), v, @@ -2272,7 +2272,7 @@ public: // If the last change remap was also at v then change the remap to a delete, as it's essentially // the same as the original page being deleted at that version and newID being used from then on. if (iLast->first == v) { - debug_printf_always("DWALPager(%s) op=detachDelete originalID=%s newID=%s @%" PRId64 " oldestVersion=%" PRId64 + debug_printf("DWALPager(%s) op=detachDelete originalID=%s newID=%s @%" PRId64 " oldestVersion=%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), @@ -2282,7 +2282,7 @@ public: iLast->second = invalidLogicalPageID; remapQueue.pushBack(RemappedPage{ v, pageID, invalidLogicalPageID }); } else { - debug_printf_always("DWALPager(%s) op=detach originalID=%s newID=%s @%" PRId64 " oldestVersion=%" PRId64 "\n", + debug_printf("DWALPager(%s) op=detach originalID=%s newID=%s @%" PRId64 " oldestVersion=%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), toString(newID).c_str(), @@ -2300,7 +2300,7 @@ public: // so queue it for later deletion auto i = remappedPages.find(pageID); if (i != remappedPages.end()) { - debug_printf_always("DWALPager(%s) op=freeRemapped %s @%" PRId64 " oldestVersion=%" PRId64 "\n", + debug_printf("DWALPager(%s) op=freeRemapped %s @%" PRId64 " oldestVersion=%" PRId64 "\n", filename.c_str(), toString(pageID).c_str(), v, @@ -2318,7 +2318,7 @@ public: Optional freeExtent = wait(self->extentUsedList.pop()); // Optional freeExtentPageID = wait(self->extentUsedList.pop()); if (freeExtent.present()) { - debug_printf_always("DWALPager(%s) freeExtentPageID() popped %s from used list\n", + debug_printf("DWALPager(%s) freeExtentPageID() popped %s from used list\n", self->filename.c_str(), toString(freeExtent.get().extentID).c_str()); } @@ -2341,7 +2341,7 @@ public: state Reference page = header ? Reference(new ArenaPage(smallestPhysicalBlock, smallestPhysicalBlock)) : self->newPageBuffer(); - debug_printf_always("DWALPager(%s) op=readPhysicalStart %s ptr=%p\n", + debug_printf("DWALPager(%s) op=readPhysicalStart %s ptr=%p\n", self->filename.c_str(), toString(pageID).c_str(), page->begin()); @@ -2349,7 +2349,7 @@ public: int blockSize = header ? smallestPhysicalBlock : self->physicalPageSize; // TODO: Could a dispatched read try to write to page after it has been destroyed if this actor is cancelled? int readBytes = wait(self->pageFile->read(page->mutate(), blockSize, (int64_t)pageID * blockSize)); - debug_printf_always("DWALPager(%s) op=readPhysicalComplete %s ptr=%p bytes=%d\n", + debug_printf("DWALPager(%s) op=readPhysicalComplete %s ptr=%p bytes=%d\n", self->filename.c_str(), toString(pageID).c_str(), page->begin(), @@ -2358,7 +2358,7 @@ public: // Header reads are checked explicitly during recovery if (!header) { if (!page->verifyChecksum(pageID)) { - debug_printf_always( + debug_printf( "DWALPager(%s) checksum failed for %s\n", self->filename.c_str(), toString(pageID).c_str()); Error e = checksum_failed(); TraceEvent(SevError, "DWALPagerChecksumFailed") @@ -2397,23 +2397,23 @@ public: // Use cached page if present, without triggering a cache hit. // Otherwise, read the page and return it but don't add it to the cache if (!cacheable) { - debug_printf_always("DWALPager(%s) op=readUncached %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) op=readUncached %s\n", filename.c_str(), toString(pageID).c_str()); PageCacheEntry* pCacheEntry = pageCache.getIfExists(pageID); if (fromCache != nullptr) { *fromCache = pCacheEntry != nullptr; } if (pCacheEntry != nullptr) { - debug_printf_always("DWALPager(%s) op=readUncachedHit %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) op=readUncachedHit %s\n", filename.c_str(), toString(pageID).c_str()); return pCacheEntry->readFuture; } - debug_printf_always("DWALPager(%s) op=readUncachedMiss %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) op=readUncachedMiss %s\n", filename.c_str(), toString(pageID).c_str()); return forwardError(readPhysicalPage(this, (PhysicalPageID)pageID), errorPromise); } PageCacheEntry& cacheEntry = pageCache.get(pageID, noHit); - debug_printf_always("DWALPager(%s) op=read %s cached=%d reading=%d writing=%d noHit=%d\n", + debug_printf("DWALPager(%s) op=read %s cached=%d reading=%d writing=%d noHit=%d\n", filename.c_str(), toString(pageID).c_str(), cacheEntry.initialized(), @@ -2422,7 +2422,7 @@ public: noHit); if (!cacheEntry.initialized()) { - debug_printf_always("DWALPager(%s) issuing actual read of %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) issuing actual read of %s\n", filename.c_str(), toString(pageID).c_str()); cacheEntry.readFuture = forwardError(readPhysicalPage(this, (PhysicalPageID)pageID), errorPromise); cacheEntry.writeFuture = Void(); } @@ -2437,20 +2437,20 @@ public: auto j = i->second.upper_bound(v); if (j != i->second.begin()) { --j; - debug_printf_always("DWALPager(%s) op=lookupRemapped %s @%" PRId64 " -> %s\n", + debug_printf("DWALPager(%s) op=lookupRemapped %s @%" PRId64 " -> %s\n", filename.c_str(), toString(pageID).c_str(), v, toString(j->second).c_str()); pageID = j->second; if (pageID == invalidLogicalPageID) - debug_printf_always( + debug_printf( "DWALPager(%s) remappedPagesMap: %s\n", filename.c_str(), toString(remappedPages).c_str()); ASSERT(pageID != invalidLogicalPageID); } } else { - debug_printf_always("DWALPager(%s) op=lookupNotRemapped %s @%" PRId64 " (not remapped)\n", + debug_printf("DWALPager(%s) op=lookupNotRemapped %s @%" PRId64 " (not remapped)\n", filename.c_str(), toString(pageID).c_str(), v); @@ -2496,13 +2496,14 @@ public: auto parallelReads = readSize / physicalReadSize; auto lastReadSize = readSize % physicalReadSize; - debug_printf_always("DWALPager(%s) op=readPhysicalExtentStart %s readSize %d offset %d physicalReadSize %d parallelReads %d\n", - self->filename.c_str(), - toString(pageID).c_str(), - readSize, - (int64_t)pageID * (self->physicalPageSize), - physicalReadSize, - parallelReads); + debug_printf( + "DWALPager(%s) op=readPhysicalExtentStart %s readSize %d offset %d physicalReadSize %d parallelReads %d\n", + self->filename.c_str(), + toString(pageID).c_str(), + readSize, + (int64_t)pageID * (self->physicalPageSize), + physicalReadSize, + parallelReads); // we split the extent read into a number of parallel disk reads based on the determined physical // disk read size. All those reads are issued in parallel and their futures are stored into the following @@ -2511,32 +2512,29 @@ public: int i; int64_t startOffset = (int64_t)pageID * (self->physicalPageSize); int64_t currentOffset; - for (i = 0; i < parallelReads; i++) - { + for (i = 0; i < parallelReads; i++) { currentOffset = i * physicalReadSize; - debug_printf_always("DWALPager(%s) current offset %d\n", - self->filename.c_str(), - currentOffset); - reads.push_back(self->pageFile->read(extent->mutate() + currentOffset, - physicalReadSize, - startOffset + currentOffset)); + debug_printf("DWALPager(%s) current offset %d\n", self->filename.c_str(), currentOffset); + reads.push_back( + self->pageFile->read(extent->mutate() + currentOffset, physicalReadSize, startOffset + currentOffset)); } // Handle the last read separately as it may be smaller than physicalReadSize if (lastReadSize) { - currentOffset = i * lastReadSize; - debug_printf_always("DWALPager(%s) iter %d current offset %d lastReadSize %d\n", - self->filename.c_str(), - i, currentOffset, lastReadSize); - reads.push_back(self->pageFile->read(extent->mutate() + currentOffset, - lastReadSize, - startOffset + currentOffset)); + currentOffset = i * physicalReadSize; + debug_printf("DWALPager(%s) iter %d current offset %d lastReadSize %d\n", + self->filename.c_str(), + i, + currentOffset, + lastReadSize); + reads.push_back( + self->pageFile->read(extent->mutate() + currentOffset, lastReadSize, startOffset + currentOffset)); } // wait for all the parallel read futures for the given extent wait(waitForAll(reads)); - debug_printf_always("DWALPager(%s) op=readPhysicalExtentComplete %s ptr=%p bytes=%d file offset=%d\n", + debug_printf("DWALPager(%s) op=readPhysicalExtentComplete %s ptr=%p bytes=%d file offset=%d\n", self->filename.c_str(), toString(pageID).c_str(), extent->begin(), @@ -2547,10 +2545,10 @@ public: } Future> readExtent(LogicalPageID pageID) override { - debug_printf_always("DWALPager(%s) op=readExtent %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) op=readExtent %s\n", filename.c_str(), toString(pageID).c_str()); PageCacheEntry* pCacheEntry = extentCache.getIfExists(pageID); if (pCacheEntry != nullptr) { - debug_printf_always("DWALPager(%s) Cache Entry exists for %s\n", filename.c_str(), toString(pageID).c_str()); + debug_printf("DWALPager(%s) Cache Entry exists for %s\n", filename.c_str(), toString(pageID).c_str()); return pCacheEntry->readFuture; } @@ -2559,7 +2557,7 @@ public: int readSize = physicalExtentSize; bool headExt = false; bool tailExt = false; - debug_printf_always("DWALPager(%s) #extentPages: %d, headPageID: %s, tailPageID: %s\n", + debug_printf("DWALPager(%s) #extentPages: %d, headPageID: %s, tailPageID: %s\n", filename.c_str(), pagesPerExtent, toString(headPageID).c_str(), @@ -2580,7 +2578,7 @@ public: cacheEntry.writeFuture = Void(); cacheEntry.readFuture = forwardError(readPhysicalExtent(this, (PhysicalPageID)pageID, readSize), errorPromise); - debug_printf_always("DWALPager(%s) Set the cacheEntry readFuture for page: %s\n", + debug_printf("DWALPager(%s) Set the cacheEntry readFuture for page: %s\n", filename.c_str(), toString(pageID).c_str()); } @@ -2607,7 +2605,7 @@ public: // are allowing active snapshots to temporarily delay page reuse. Version effectiveOldestVersion() { if (snapshots.empty()) { - debug_printf_always("DWALPager(%s) snapshots list empty\n", filename.c_str()); + debug_printf("DWALPager(%s) snapshots list empty\n", filename.c_str()); return pLastCommittedHeader->oldestVersion; } return std::min(pLastCommittedHeader->oldestVersion, snapshots.front().version); @@ -2680,7 +2678,7 @@ public: (secondAfterOldestRetainedVersion || secondType == RemappedPage::NONE)); state bool freeOriginalID = (firstType == RemappedPage::FREE || firstType == RemappedPage::DETACH); - debug_printf_always("DWALPager(%s) remapCleanup %s secondType=%c mapEntry=%s oldestRetainedVersion=%" PRId64 " \n", + debug_printf("DWALPager(%s) remapCleanup %s secondType=%c mapEntry=%s oldestRetainedVersion=%" PRId64 " \n", self->filename.c_str(), p.toString().c_str(), secondType, @@ -2692,7 +2690,7 @@ public: ASSERT(self->remapDestinationsSimOnly.count(p.originalPageID) == 0); self->remapDestinationsSimOnly.insert(p.originalPageID); } - debug_printf_always("DWALPager(%s) remapCleanup copy %s\n", self->filename.c_str(), p.toString().c_str()); + debug_printf("DWALPager(%s) remapCleanup copy %s\n", self->filename.c_str(), p.toString().c_str()); // Read the data from the page that the original was mapped to Reference data = wait(self->readPage(p.newPageID, false, true)); @@ -2708,14 +2706,14 @@ public: // represented the remap and there wasn't a delete later in the queue at p for the same version then // erase the entry. if (!deleteAtSameVersion) { - debug_printf_always( + debug_printf( "DWALPager(%s) remapCleanup deleting map entry %s\n", self->filename.c_str(), p.toString().c_str()); // Erase the entry and set iVersionPagePair to the next entry or end iVersionPagePair = iPageMapPair->second.erase(iVersionPagePair); // If the map is now empty, delete it if (iPageMapPair->second.empty()) { - debug_printf_always( + debug_printf( "DWALPager(%s) remapCleanup deleting empty map %s\n", self->filename.c_str(), p.toString().c_str()); self->remappedPages.erase(iPageMapPair); } else if (freeNewID && secondType == RemappedPage::NONE && @@ -2729,13 +2727,13 @@ public: } if (freeNewID) { - debug_printf_always("DWALPager(%s) remapCleanup freeNew %s\n", self->filename.c_str(), p.toString().c_str()); + debug_printf("DWALPager(%s) remapCleanup freeNew %s\n", self->filename.c_str(), p.toString().c_str()); self->freeUnmappedPage(p.newPageID, 0); ++g_redwoodMetrics.pagerRemapFree; } if (freeOriginalID) { - debug_printf_always("DWALPager(%s) remapCleanup freeOriginal %s\n", self->filename.c_str(), p.toString().c_str()); + debug_printf("DWALPager(%s) remapCleanup freeOriginal %s\n", self->filename.c_str(), p.toString().c_str()); self->freeUnmappedPage(p.originalPageID, 0); ++g_redwoodMetrics.pagerRemapFree; } @@ -2756,7 +2754,7 @@ public: // Cutoff is the version we can pop to state RemappedPage cutoff(oldestRetainedVersion - self->remapCleanupWindow); - debug_printf_always("DWALPager(%s) remapCleanup cutoff %s oldestRetailedVersion=%" PRId64 " \n", + debug_printf("DWALPager(%s) remapCleanup cutoff %s oldestRetailedVersion=%" PRId64 " \n", self->filename.c_str(), ::toString(cutoff).c_str(), oldestRetainedVersion); @@ -2770,7 +2768,7 @@ public: state int sinceYield = 0; loop { state Optional p = wait(self->remapQueue.pop(cutoff)); - debug_printf_always("DWALPager(%s) remapCleanup popped %s\n", self->filename.c_str(), ::toString(p).c_str()); + debug_printf("DWALPager(%s) remapCleanup popped %s\n", self->filename.c_str(), ::toString(p).c_str()); // Stop if we have reached the cutoff version, which is the start of the cleanup coalescing window if (!p.present()) { @@ -2794,7 +2792,7 @@ public: } } - debug_printf_always("DWALPager(%s) remapCleanup stopped (stop=%d)\n", self->filename.c_str(), self->remapCleanupStop); + debug_printf("DWALPager(%s) remapCleanup stopped (stop=%d)\n", self->filename.c_str(), self->remapCleanupStop); signal.send(Void()); wait(tasks.getResult()); return Void(); @@ -2816,7 +2814,7 @@ public: loop { state bool freeBusy = wait(self->freeList.preFlush()); state bool delayedFreeBusy = wait(self->delayedFreeList.preFlush()); - debug_printf_always("DWALPager(%s) flushQueues freeBusy=%d delayedFreeBusy=%d\n", + debug_printf("DWALPager(%s) flushQueues freeBusy=%d delayedFreeBusy=%d\n", self->filename.c_str(), freeBusy, delayedFreeBusy); @@ -2839,7 +2837,7 @@ public: } ACTOR static Future commit_impl(DWALPager* self) { - debug_printf_always("DWALPager(%s) commit begin\n", self->filename.c_str()); + debug_printf("DWALPager(%s) commit begin\n", self->filename.c_str()); // Write old committed header to Page 1 self->writeHeaderPage(1, self->lastCommittedHeaderPage); @@ -2857,9 +2855,9 @@ public: self->pHeader->delayedFreeList = self->delayedFreeList.getState(); // Wait for all outstanding writes to complete - debug_printf_always("DWALPager(%s) waiting for outstanding writes\n", self->filename.c_str()); + debug_printf("DWALPager(%s) waiting for outstanding writes\n", self->filename.c_str()); wait(self->operations.signalAndCollapse()); - debug_printf_always("DWALPager(%s) Syncing\n", self->filename.c_str()); + debug_printf("DWALPager(%s) Syncing\n", self->filename.c_str()); // Sync everything except the header if (g_network->getCurrentTask() > TaskPriority::DiskWrite) { @@ -2868,7 +2866,7 @@ public: if (!self->memoryOnly) { wait(self->pageFile->sync()); - debug_printf_always("DWALPager(%s) commit version %" PRId64 " sync 1\n", + debug_printf("DWALPager(%s) commit version %" PRId64 " sync 1\n", self->filename.c_str(), self->pHeader->committedVersion); } @@ -2881,7 +2879,7 @@ public: if (!self->memoryOnly) { wait(self->pageFile->sync()); - debug_printf_always("DWALPager(%s) commit version %" PRId64 " sync 2\n", + debug_printf("DWALPager(%s) commit version %" PRId64 " sync 2\n", self->filename.c_str(), self->pHeader->committedVersion); } @@ -2914,27 +2912,27 @@ public: void setMetaKey(KeyRef metaKey) override { pHeader->setMetaKey(metaKey); } ACTOR void shutdown(DWALPager* self, bool dispose) { - debug_printf_always("DWALPager(%s) shutdown cancel recovery\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown cancel recovery\n", self->filename.c_str()); self->recoverFuture.cancel(); - debug_printf_always("DWALPager(%s) shutdown cancel commit\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown cancel commit\n", self->filename.c_str()); self->commitFuture.cancel(); - debug_printf_always("DWALPager(%s) shutdown cancel remap\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown cancel remap\n", self->filename.c_str()); self->remapCleanupFuture.cancel(); if (self->errorPromise.canBeSet()) { - debug_printf_always("DWALPager(%s) shutdown sending error\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown sending error\n", self->filename.c_str()); self->errorPromise.sendError(actor_cancelled()); // Ideally this should be shutdown_in_progress } // Must wait for pending operations to complete, canceling them can cause a crash because the underlying // operations may be uncancellable and depend on memory from calling scope's page reference - debug_printf_always("DWALPager(%s) shutdown wait for operations\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown wait for operations\n", self->filename.c_str()); wait(self->operations.signal()); - debug_printf_always("DWALPager(%s) shutdown destroy page cache\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown destroy page cache\n", self->filename.c_str()); wait(self->pageCache.clear()); - debug_printf_always("DWALPager(%s) shutdown remappedPagesMap: %s\n", + debug_printf("DWALPager(%s) shutdown remappedPagesMap: %s\n", self->filename.c_str(), toString(self->remappedPages).c_str()); @@ -2942,7 +2940,7 @@ public: self->pageFile.clear(); if (dispose) { if (!self->memoryOnly) { - debug_printf_always("DWALPager(%s) shutdown deleting file\n", self->filename.c_str()); + debug_printf("DWALPager(%s) shutdown deleting file\n", self->filename.c_str()); wait(IAsyncFileSystem::filesystem()->incrementalDeleteFile(self->filename, true)); } } @@ -2991,7 +2989,7 @@ public: // Flush queues so there are no pending freelist operations wait(flushQueues(self)); - debug_printf_always("DWALPager getUserPageCount_cleanup\n"); + debug_printf("DWALPager getUserPageCount_cleanup\n"); self->freeList.getState(); self->delayedFreeList.getState(); self->extentFreeList.getState(); @@ -3008,7 +3006,7 @@ public: delayedFreeList.numEntries - ((((remapQueue.numPages - 1) / pagesPerExtent) + 1) * pagesPerExtent) - extentFreeList.numPages - (pagesPerExtent * extentFreeList.numEntries) - extentUsedList.numPages; - debug_printf_always("DWALPager(%s) userPages=%" PRId64 " totalPageCount=%" PRId64 " freeQueuePages=%" PRId64 + debug_printf("DWALPager(%s) userPages=%" PRId64 " totalPageCount=%" PRId64 " freeQueuePages=%" PRId64 " freeQueueCount=%" PRId64 " delayedFreeQueuePages=%" PRId64 " delayedFreeQueueCount=%" PRId64 " remapQueuePages=%" PRId64 " remapQueueCount=%" PRId64 "\n", filename.c_str(), @@ -3195,12 +3193,12 @@ public: }; void DWALPager::expireSnapshots(Version v) { - debug_printf_always("DWALPager(%s) expiring snapshots through %" PRId64 " snapshot count %d\n", + debug_printf("DWALPager(%s) expiring snapshots through %" PRId64 " snapshot count %d\n", filename.c_str(), v, (int)snapshots.size()); while (snapshots.size() > 1 && snapshots.front().version < v && snapshots.front().snapshot->isSoleOwner()) { - debug_printf_always("DWALPager(%s) expiring snapshot for %" PRId64 " soleOwner=%d\n", + debug_printf("DWALPager(%s) expiring snapshot for %" PRId64 " soleOwner=%d\n", filename.c_str(), snapshots.front().version, snapshots.front().snapshot->isSoleOwner());