| File: | var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp |
| Warning: | line 3635, column 5 Value stored to 'rv' is never read |
Press '?' to see keyboard shortcuts
Keyboard shortcuts:
| 1 | /* This Source Code Form is subject to the terms of the Mozilla Public |
| 2 | * License, v. 2.0. If a copy of the MPL was not distributed with this |
| 3 | * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
| 4 | |
| 5 | #include <limits> |
| 6 | #include "CacheLog.h" |
| 7 | #include "CacheFileIOManager.h" |
| 8 | |
| 9 | #include "CacheHashUtils.h" |
| 10 | #include "CacheStorageService.h" |
| 11 | #include "CacheIndex.h" |
| 12 | #include "CacheFileUtils.h" |
| 13 | #include "nsError.h" |
| 14 | #include "nsThreadUtils.h" |
| 15 | #include "CacheFile.h" |
| 16 | #include "CacheObserver.h" |
| 17 | #include "nsIFile.h" |
| 18 | #include "CacheFileContextEvictor.h" |
| 19 | #include "nsITimer.h" |
| 20 | #include "nsIDirectoryEnumerator.h" |
| 21 | #include "nsEffectiveTLDService.h" |
| 22 | #include "nsIObserverService.h" |
| 23 | #include "nsISizeOf.h" |
| 24 | #include "mozilla/net/MozURL.h" |
| 25 | #include "mozilla/Telemetry.h" |
| 26 | #include "mozilla/DebugOnly.h" |
| 27 | #include "mozilla/Services.h" |
| 28 | #include "mozilla/SpinEventLoopUntil.h" |
| 29 | #include "mozilla/StaticPrefs_network.h" |
| 30 | #include "mozilla/StoragePrincipalHelper.h" |
| 31 | #include "nsDirectoryServiceUtils.h" |
| 32 | #include "nsAppDirectoryServiceDefs.h" |
| 33 | #include "private/pprio.h" |
| 34 | #include "mozilla/IntegerPrintfMacros.h" |
| 35 | #include "mozilla/Preferences.h" |
| 36 | #include "nsNetUtil.h" |
| 37 | #include "mozilla/glean/GleanMetrics.h" |
| 38 | |
| 39 | #ifdef MOZ_BACKGROUNDTASKS1 |
| 40 | # include "mozilla/BackgroundTasksRunner.h" |
| 41 | # include "nsIBackgroundTasks.h" |
| 42 | #endif |
| 43 | |
| 44 | // include files for ftruncate (or equivalent) |
| 45 | #if defined(XP_UNIX1) |
| 46 | # include <unistd.h> |
| 47 | #elif defined(XP_WIN) |
| 48 | # include <windows.h> |
| 49 | # undef CreateFile |
| 50 | # undef CREATE_NEW |
| 51 | #else |
| 52 | // XXX add necessary include file for ftruncate (or equivalent) |
| 53 | #endif |
| 54 | |
| 55 | namespace mozilla::net { |
| 56 | |
| 57 | #define kOpenHandlesLimit128 128 |
| 58 | #define kMetadataWriteDelay5000 5000 |
| 59 | #define kRemoveTrashStartDelay60000 60000 // in milliseconds |
| 60 | #define kSmartSizeUpdateInterval60000 60000 // in milliseconds |
| 61 | |
| 62 | #ifdef ANDROID |
| 63 | const uint32_t kMaxCacheSizeKB = 512 * 1024; // 512 MB |
| 64 | #else |
| 65 | const uint32_t kMaxCacheSizeKB = 1024 * 1024; // 1 GB |
| 66 | #endif |
| 67 | const uint32_t kMaxClearOnShutdownCacheSizeKB = 150 * 1024; // 150 MB |
| 68 | const auto kPurgeExtension = ".purge.bg_rm"_ns; |
| 69 | |
| 70 | bool CacheFileHandle::DispatchRelease() { |
| 71 | if (CacheFileIOManager::IsOnIOThreadOrCeased()) { |
| 72 | return false; |
| 73 | } |
| 74 | |
| 75 | nsCOMPtr<nsIEventTarget> ioTarget = CacheFileIOManager::IOTarget(); |
| 76 | if (!ioTarget) { |
| 77 | return false; |
| 78 | } |
| 79 | |
| 80 | nsresult rv = ioTarget->Dispatch( |
| 81 | NewNonOwningRunnableMethod("net::CacheFileHandle::Release", this, |
| 82 | &CacheFileHandle::Release), |
| 83 | nsIEventTarget::DISPATCH_NORMAL); |
| 84 | return NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1))); |
| 85 | } |
| 86 | |
| 87 | NS_IMPL_ADDREF(CacheFileHandle)MozExternalRefCountType CacheFileHandle::AddRef(void) { static_assert (!std::is_destructible_v<CacheFileHandle>, "Reference-counted class " "CacheFileHandle" " should not have a public destructor. " "Make this class's destructor non-public" ); do { static_assert( mozilla::detail::AssertionConditionType <decltype(int32_t(mRefCnt) >= 0)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(int32_t(mRefCnt) >= 0))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("int32_t(mRefCnt) >= 0" " (" "illegal refcnt" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 87); AnnotateMozCrashReason("MOZ_ASSERT" "(" "int32_t(mRefCnt) >= 0" ") (" "illegal refcnt" ")"); do { *((volatile int*)__null) = 87; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); do { static_assert( mozilla::detail::AssertionConditionType <decltype("CacheFileHandle" != nullptr)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!("CacheFileHandle" != nullptr ))), 0))) { do { } while (false); MOZ_ReportAssertionFailure( "\"CacheFileHandle\" != nullptr" " (" "Must specify a name" ")" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 87); AnnotateMozCrashReason("MOZ_ASSERT" "(" "\"CacheFileHandle\" != nullptr" ") (" "Must specify a name" ")"); do { *((volatile int*)__null ) = 87; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); if (!mRefCnt.isThreadSafe) _mOwningThread.AssertOwnership ("CacheFileHandle" " not thread-safe"); nsrefcnt count = ++mRefCnt ; NS_LogAddRef((this), (count), ("CacheFileHandle"), (uint32_t )(sizeof(*this))); return count; } |
| 88 | NS_IMETHODIMP_(MozExternalRefCountType)MozExternalRefCountType |
| 89 | CacheFileHandle::Release() { |
| 90 | nsrefcnt count = mRefCnt - 1; |
| 91 | if (DispatchRelease()) { |
| 92 | // Redispatched to the IO thread. |
| 93 | return count; |
| 94 | } |
| 95 | |
| 96 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 96); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 96; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 97 | |
| 98 | LOG(("CacheFileHandle::Release() [this=%p, refcnt=%" PRIuPTR "]", this,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Release() [this=%p, refcnt=%" "l" "u" "]", this, mRefCnt.get()); } } while (0) |
| 99 | mRefCnt.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Release() [this=%p, refcnt=%" "l" "u" "]", this, mRefCnt.get()); } } while (0); |
| 100 | MOZ_ASSERT(0 != mRefCnt, "dup release")do { static_assert( mozilla::detail::AssertionConditionType< decltype(0 != mRefCnt)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(0 != mRefCnt))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("0 != mRefCnt" " (" "dup release" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 100); AnnotateMozCrashReason("MOZ_ASSERT" "(" "0 != mRefCnt" ") (" "dup release" ")"); do { *((volatile int*)__null) = 100 ; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); |
| 101 | count = --mRefCnt; |
| 102 | NS_LOG_RELEASE(this, count, "CacheFileHandle")NS_LogRelease((this), (count), ("CacheFileHandle")); |
| 103 | |
| 104 | if (0 == count) { |
| 105 | mRefCnt = 1; |
| 106 | delete (this); |
| 107 | return 0; |
| 108 | } |
| 109 | |
| 110 | return count; |
| 111 | } |
| 112 | |
| 113 | NS_INTERFACE_MAP_BEGIN(CacheFileHandle)nsresult CacheFileHandle::QueryInterface(const nsIID& aIID , void** aInstancePtr) { do { if (!(aInstancePtr)) { NS_DebugBreak (NS_DEBUG_ASSERTION, "QueryInterface requires a non-NULL destination!" , "aInstancePtr", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 113); MOZ_PretendNoReturn(); } } while (0); nsISupports* foundInterface ; |
| 114 | NS_INTERFACE_MAP_ENTRY(nsISupports)if (aIID.Equals(mozilla::detail::kImplementedIID<std::remove_reference_t <decltype(*this)>, nsISupports>)) foundInterface = static_cast <nsISupports*>(this); else |
| 115 | NS_INTERFACE_MAP_ENDfoundInterface = 0; nsresult status; if (!foundInterface) { do { static_assert( mozilla::detail::AssertionConditionType< decltype(!aIID.Equals((nsISupports::COMTypeInfo<nsISupports , void>::kIID)))>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!aIID.Equals((nsISupports::COMTypeInfo <nsISupports, void>::kIID))))), 0))) { do { } while (false ); MOZ_ReportAssertionFailure("!aIID.Equals((nsISupports::COMTypeInfo<nsISupports, void>::kIID))" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 115); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!aIID.Equals((nsISupports::COMTypeInfo<nsISupports, void>::kIID))" ")"); do { *((volatile int*)__null) = 115; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); status = NS_NOINTERFACE ; } else { (foundInterface)->AddRef(); status = NS_OK; } * aInstancePtr = foundInterface; return status; } |
| 116 | |
| 117 | CacheFileHandle::CacheFileHandle(const SHA1Sum::Hash* aHash, bool aPriority, |
| 118 | PinningStatus aPinning) |
| 119 | : mHash(aHash), |
| 120 | mIsDoomed(false), |
| 121 | mClosed(false), |
| 122 | mPriority(aPriority), |
| 123 | mSpecialFile(false), |
| 124 | mInvalid(false), |
| 125 | mFileExists(false), |
| 126 | mDoomWhenFoundPinned(false), |
| 127 | mDoomWhenFoundNonPinned(false), |
| 128 | mKilled(false), |
| 129 | mPinning(aPinning), |
| 130 | mFileSize(-1), |
| 131 | mFD(nullptr) { |
| 132 | // If we initialize mDoomed in the initialization list, that initialization is |
| 133 | // not guaranteeded to be atomic. Whereas this assignment here is guaranteed |
| 134 | // to be atomic. TSan will see this (atomic) assignment and be satisfied |
| 135 | // that cross-thread accesses to mIsDoomed are properly synchronized. |
| 136 | mIsDoomed = false; |
| 137 | LOG((do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::CacheFileHandle() [this=%p, hash=%08x%08x%08x%08x%08x]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 138 | "CacheFileHandle::CacheFileHandle() [this=%p, hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::CacheFileHandle() [this=%p, hash=%08x%08x%08x%08x%08x]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 139 | this, LOGSHA1(aHash)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::CacheFileHandle() [this=%p, hash=%08x%08x%08x%08x%08x]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0); |
| 140 | } |
| 141 | |
| 142 | CacheFileHandle::CacheFileHandle(const nsACString& aKey, bool aPriority, |
| 143 | PinningStatus aPinning) |
| 144 | : mHash(nullptr), |
| 145 | mIsDoomed(false), |
| 146 | mClosed(false), |
| 147 | mPriority(aPriority), |
| 148 | mSpecialFile(true), |
| 149 | mInvalid(false), |
| 150 | mFileExists(false), |
| 151 | mDoomWhenFoundPinned(false), |
| 152 | mDoomWhenFoundNonPinned(false), |
| 153 | mKilled(false), |
| 154 | mPinning(aPinning), |
| 155 | mFileSize(-1), |
| 156 | mFD(nullptr), |
| 157 | mKey(aKey) { |
| 158 | // See comment above about the initialization of mIsDoomed. |
| 159 | mIsDoomed = false; |
| 160 | LOG(("CacheFileHandle::CacheFileHandle() [this=%p, key=%s]", this,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::CacheFileHandle() [this=%p, key=%s]" , this, TPromiseFlatString<char>(aKey).get()); } } while (0) |
| 161 | PromiseFlatCString(aKey).get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::CacheFileHandle() [this=%p, key=%s]" , this, TPromiseFlatString<char>(aKey).get()); } } while (0); |
| 162 | } |
| 163 | |
| 164 | CacheFileHandle::~CacheFileHandle() { |
| 165 | LOG(("CacheFileHandle::~CacheFileHandle() [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::~CacheFileHandle() [this=%p]" , this); } } while (0); |
| 166 | |
| 167 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 167); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 167; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 168 | |
| 169 | RefPtr<CacheFileIOManager> ioMan = CacheFileIOManager::gInstance; |
| 170 | if (!IsClosed() && ioMan) { |
| 171 | ioMan->CloseHandleInternal(this); |
| 172 | } |
| 173 | } |
| 174 | |
| 175 | void CacheFileHandle::Log() { |
| 176 | nsAutoCString leafName; |
| 177 | if (mFile) { |
| 178 | mFile->GetNativeLeafName(leafName); |
| 179 | } |
| 180 | |
| 181 | if (mSpecialFile) { |
| 182 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 183 | ("CacheFileHandle::Log() - special file [this=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 184 | "isDoomed=%d, priority=%d, closed=%d, invalid=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 185 | "pinning=%" PRIu32 ", fileExists=%d, fileSize=%" PRId64do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 186 | ", leafName=%s, key=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 187 | this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool(mInvalid),do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 188 | static_cast<uint32_t>(mPinning), bool(mFileExists), int64_t(mFileSize),do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 189 | leafName.get(), mKey.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - special file [this=%p, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0); |
| 190 | } else { |
| 191 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 192 | ("CacheFileHandle::Log() - entry file [this=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 193 | "hash=%08x%08x%08x%08x%08x, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 194 | "isDoomed=%d, priority=%d, closed=%d, invalid=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 195 | "pinning=%" PRIu32 ", fileExists=%d, fileSize=%" PRId64do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 196 | ", leafName=%s, key=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 197 | this, LOGSHA1(mHash), bool(mIsDoomed), bool(mPriority), bool(mClosed),do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 198 | bool(mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists),do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0) |
| 199 | int64_t(mFileSize), leafName.get(), mKey.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::Log() - entry file [this=%p, " "hash=%08x%08x%08x%08x%08x, " "isDoomed=%d, priority=%d, closed=%d, invalid=%d, " "pinning=%" "u" ", fileExists=%d, fileSize=%" "l" "d" ", leafName=%s, key=%s]" , this, PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(mHash ))[4]), bool(mIsDoomed), bool(mPriority), bool(mClosed), bool (mInvalid), static_cast<uint32_t>(mPinning), bool(mFileExists ), int64_t(mFileSize), leafName.get(), mKey.get()); } } while (0); |
| 200 | } |
| 201 | } |
| 202 | |
| 203 | uint32_t CacheFileHandle::FileSizeInK() const { |
| 204 | MOZ_ASSERT(mFileSize != -1)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mFileSize != -1)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mFileSize != -1))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mFileSize != -1" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 204); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mFileSize != -1" ")"); do { *((volatile int*)__null) = 204; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 205 | uint64_t size64 = mFileSize; |
| 206 | |
| 207 | size64 += 0x3FF; |
| 208 | size64 >>= 10; |
| 209 | |
| 210 | uint32_t size; |
| 211 | if (size64 >> 32) { |
| 212 | NS_WARNING(NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileHandle::FileSizeInK() - FileSize is too large, " "truncating to PR_UINT32_MAX", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 214) |
| 213 | "CacheFileHandle::FileSizeInK() - FileSize is too large, "NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileHandle::FileSizeInK() - FileSize is too large, " "truncating to PR_UINT32_MAX", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 214) |
| 214 | "truncating to PR_UINT32_MAX")NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileHandle::FileSizeInK() - FileSize is too large, " "truncating to PR_UINT32_MAX", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 214); |
| 215 | size = PR_UINT32_MAX4294967295U; |
| 216 | } else { |
| 217 | size = static_cast<uint32_t>(size64); |
| 218 | } |
| 219 | |
| 220 | return size; |
| 221 | } |
| 222 | |
| 223 | bool CacheFileHandle::SetPinned(bool aPinned) { |
| 224 | LOG(("CacheFileHandle::SetPinned [this=%p, pinned=%d]", this, aPinned))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandle::SetPinned [this=%p, pinned=%d]" , this, aPinned); } } while (0); |
| 225 | |
| 226 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 226); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 226; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 227 | |
| 228 | mPinning = aPinned ? PinningStatus::PINNED : PinningStatus::NON_PINNED; |
| 229 | |
| 230 | if ((MOZ_UNLIKELY(mDoomWhenFoundPinned)(__builtin_expect(!!(mDoomWhenFoundPinned), 0)) && aPinned) || |
| 231 | (MOZ_UNLIKELY(mDoomWhenFoundNonPinned)(__builtin_expect(!!(mDoomWhenFoundNonPinned), 0)) && !aPinned)) { |
| 232 | LOG((" dooming, when: pinned=%d, non-pinned=%d, found: pinned=%d",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " dooming, when: pinned=%d, non-pinned=%d, found: pinned=%d" , bool(mDoomWhenFoundPinned), bool(mDoomWhenFoundNonPinned), aPinned ); } } while (0) |
| 233 | bool(mDoomWhenFoundPinned), bool(mDoomWhenFoundNonPinned), aPinned))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " dooming, when: pinned=%d, non-pinned=%d, found: pinned=%d" , bool(mDoomWhenFoundPinned), bool(mDoomWhenFoundNonPinned), aPinned ); } } while (0); |
| 234 | |
| 235 | mDoomWhenFoundPinned = false; |
| 236 | mDoomWhenFoundNonPinned = false; |
| 237 | |
| 238 | return false; |
| 239 | } |
| 240 | |
| 241 | return true; |
| 242 | } |
| 243 | |
| 244 | // Memory reporting |
| 245 | |
| 246 | size_t CacheFileHandle::SizeOfExcludingThis( |
| 247 | mozilla::MallocSizeOf mallocSizeOf) const { |
| 248 | size_t n = 0; |
| 249 | nsCOMPtr<nsISizeOf> sizeOf; |
| 250 | |
| 251 | sizeOf = do_QueryInterface(mFile); |
| 252 | if (sizeOf) { |
| 253 | n += sizeOf->SizeOfIncludingThis(mallocSizeOf); |
| 254 | } |
| 255 | |
| 256 | n += mallocSizeOf(mFD); |
| 257 | n += mKey.SizeOfExcludingThisIfUnshared(mallocSizeOf); |
| 258 | return n; |
| 259 | } |
| 260 | |
| 261 | size_t CacheFileHandle::SizeOfIncludingThis( |
| 262 | mozilla::MallocSizeOf mallocSizeOf) const { |
| 263 | return mallocSizeOf(this) + SizeOfExcludingThis(mallocSizeOf); |
| 264 | } |
| 265 | |
| 266 | /****************************************************************************** |
| 267 | * CacheFileHandles::HandleHashKey |
| 268 | *****************************************************************************/ |
| 269 | |
| 270 | void CacheFileHandles::HandleHashKey::AddHandle(CacheFileHandle* aHandle) { |
| 271 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 271); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 271; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 272 | |
| 273 | mHandles.InsertElementAt(0, aHandle); |
| 274 | } |
| 275 | |
| 276 | void CacheFileHandles::HandleHashKey::RemoveHandle(CacheFileHandle* aHandle) { |
| 277 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 277); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 277; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 278 | |
| 279 | DebugOnly<bool> found{}; |
| 280 | found = mHandles.RemoveElement(aHandle); |
| 281 | MOZ_ASSERT(found)do { static_assert( mozilla::detail::AssertionConditionType< decltype(found)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(found))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("found", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 281); AnnotateMozCrashReason("MOZ_ASSERT" "(" "found" ")"); do { *((volatile int*)__null) = 281; __attribute__((nomerge) ) ::abort(); } while (false); } } while (false); |
| 282 | } |
| 283 | |
| 284 | already_AddRefed<CacheFileHandle> |
| 285 | CacheFileHandles::HandleHashKey::GetNewestHandle() { |
| 286 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 286); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 286; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 287 | |
| 288 | RefPtr<CacheFileHandle> handle; |
| 289 | if (mHandles.Length()) { |
| 290 | handle = mHandles[0]; |
| 291 | } |
| 292 | |
| 293 | return handle.forget(); |
| 294 | } |
| 295 | |
| 296 | void CacheFileHandles::HandleHashKey::GetHandles( |
| 297 | nsTArray<RefPtr<CacheFileHandle>>& aResult) { |
| 298 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 298); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 298; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 299 | |
| 300 | for (uint32_t i = 0; i < mHandles.Length(); ++i) { |
| 301 | CacheFileHandle* handle = mHandles[i]; |
| 302 | aResult.AppendElement(handle); |
| 303 | } |
| 304 | } |
| 305 | |
| 306 | #ifdef DEBUG1 |
| 307 | |
| 308 | void CacheFileHandles::HandleHashKey::AssertHandlesState() { |
| 309 | for (uint32_t i = 0; i < mHandles.Length(); ++i) { |
| 310 | CacheFileHandle* handle = mHandles[i]; |
| 311 | MOZ_ASSERT(handle->IsDoomed())do { static_assert( mozilla::detail::AssertionConditionType< decltype(handle->IsDoomed())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(handle->IsDoomed()))), 0) )) { do { } while (false); MOZ_ReportAssertionFailure("handle->IsDoomed()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 311); AnnotateMozCrashReason("MOZ_ASSERT" "(" "handle->IsDoomed()" ")"); do { *((volatile int*)__null) = 311; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 312 | } |
| 313 | } |
| 314 | |
| 315 | #endif |
| 316 | |
| 317 | size_t CacheFileHandles::HandleHashKey::SizeOfExcludingThis( |
| 318 | mozilla::MallocSizeOf mallocSizeOf) const { |
| 319 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsOnIOThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsOnIOThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 319); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThread()" ")"); do { *((volatile int*)__null) = 319; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 320 | |
| 321 | size_t n = 0; |
| 322 | n += mallocSizeOf(mHash.get()); |
| 323 | for (uint32_t i = 0; i < mHandles.Length(); ++i) { |
| 324 | n += mHandles[i]->SizeOfIncludingThis(mallocSizeOf); |
| 325 | } |
| 326 | |
| 327 | return n; |
| 328 | } |
| 329 | |
| 330 | /****************************************************************************** |
| 331 | * CacheFileHandles |
| 332 | *****************************************************************************/ |
| 333 | |
| 334 | CacheFileHandles::CacheFileHandles() { |
| 335 | LOG(("CacheFileHandles::CacheFileHandles() [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::CacheFileHandles() [this=%p]" , this); } } while (0); |
| 336 | MOZ_COUNT_CTOR(CacheFileHandles)do { static_assert(std::is_class_v<CacheFileHandles>, "Token '" "CacheFileHandles" "' is not a class type."); static_assert( !std::is_base_of<nsISupports, CacheFileHandles>::value, "nsISupports classes don't need to call MOZ_COUNT_CTOR or " "MOZ_COUNT_DTOR" );; NS_LogCtor((void*)this, "CacheFileHandles", sizeof(*this) ); } while (0); |
| 337 | } |
| 338 | |
| 339 | CacheFileHandles::~CacheFileHandles() { |
| 340 | LOG(("CacheFileHandles::~CacheFileHandles() [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::~CacheFileHandles() [this=%p]" , this); } } while (0); |
| 341 | MOZ_COUNT_DTOR(CacheFileHandles)do { static_assert(std::is_class_v<CacheFileHandles>, "Token '" "CacheFileHandles" "' is not a class type."); static_assert( !std::is_base_of<nsISupports, CacheFileHandles>::value, "nsISupports classes don't need to call MOZ_COUNT_CTOR or " "MOZ_COUNT_DTOR" );; NS_LogDtor((void*)this, "CacheFileHandles", sizeof(*this) ); } while (0); |
| 342 | } |
| 343 | |
| 344 | nsresult CacheFileHandles::GetHandle(const SHA1Sum::Hash* aHash, |
| 345 | CacheFileHandle** _retval) { |
| 346 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 346); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 346; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 347 | MOZ_ASSERT(aHash)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHash)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(aHash))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("aHash", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 347); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHash" ")"); do { *((volatile int*)__null) = 347; __attribute__((nomerge) ) ::abort(); } while (false); } } while (false); |
| 348 | |
| 349 | #ifdef DEBUG_HANDLES |
| 350 | LOG(("CacheFileHandles::GetHandle() [hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 351 | LOGSHA1(aHash)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0); |
| 352 | #endif |
| 353 | |
| 354 | // find hash entry for key |
| 355 | HandleHashKey* entry = mTable.GetEntry(*aHash); |
| 356 | if (!entry) { |
| 357 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle entries found", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4])); } } while (0) |
| 358 | ("CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle entries found", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4])); } } while (0) |
| 359 | "no handle entries found",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle entries found", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4])); } } while (0) |
| 360 | LOGSHA1(aHash)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle entries found", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4])); } } while (0); |
| 361 | return NS_ERROR_NOT_AVAILABLE; |
| 362 | } |
| 363 | |
| 364 | #ifdef DEBUG_HANDLES |
| 365 | Log(entry); |
| 366 | #endif |
| 367 | |
| 368 | // Check if the entry is doomed |
| 369 | RefPtr<CacheFileHandle> handle = entry->GetNewestHandle(); |
| 370 | if (!handle) { |
| 371 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle found %p, entry %p", PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 372 | ("CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle found %p, entry %p", PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 373 | "no handle found %p, entry %p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle found %p, entry %p", PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 374 | LOGSHA1(aHash), handle.get(), entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "no handle found %p, entry %p", PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast< const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0); |
| 375 | return NS_ERROR_NOT_AVAILABLE; |
| 376 | } |
| 377 | |
| 378 | if (handle->IsDoomed()) { |
| 379 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found doomed handle %p, entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 380 | ("CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found doomed handle %p, entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 381 | "found doomed handle %p, entry %p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found doomed handle %p, entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 382 | LOGSHA1(aHash), handle.get(), entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found doomed handle %p, entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0); |
| 383 | return NS_ERROR_NOT_AVAILABLE; |
| 384 | } |
| 385 | |
| 386 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found handle %p, entry %p", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4]), handle.get(), entry); } } while ( 0) |
| 387 | ("CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found handle %p, entry %p", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4]), handle.get(), entry); } } while ( 0) |
| 388 | "found handle %p, entry %p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found handle %p, entry %p", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4]), handle.get(), entry); } } while ( 0) |
| 389 | LOGSHA1(aHash), handle.get(), entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::GetHandle() hash=%08x%08x%08x%08x%08x " "found handle %p, entry %p", PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[4]), handle.get(), entry); } } while ( 0); |
| 390 | |
| 391 | handle.forget(_retval); |
| 392 | return NS_OK; |
| 393 | } |
| 394 | |
| 395 | already_AddRefed<CacheFileHandle> CacheFileHandles::NewHandle( |
| 396 | const SHA1Sum::Hash* aHash, bool aPriority, |
| 397 | CacheFileHandle::PinningStatus aPinning) { |
| 398 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 398); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 398; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 399 | MOZ_ASSERT(aHash)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHash)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(aHash))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("aHash", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 399); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHash" ")"); do { *((volatile int*)__null) = 399; __attribute__((nomerge) ) ::abort(); } while (false); } } while (false); |
| 400 | |
| 401 | #ifdef DEBUG_HANDLES |
| 402 | LOG(("CacheFileHandles::NewHandle() [hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 403 | LOGSHA1(aHash)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0); |
| 404 | #endif |
| 405 | |
| 406 | // find hash entry for key |
| 407 | HandleHashKey* entry = mTable.PutEntry(*aHash); |
| 408 | |
| 409 | #ifdef DEBUG_HANDLES |
| 410 | Log(entry); |
| 411 | #endif |
| 412 | |
| 413 | #ifdef DEBUG1 |
| 414 | entry->AssertHandlesState(); |
| 415 | #endif |
| 416 | |
| 417 | RefPtr<CacheFileHandle> handle = |
| 418 | new CacheFileHandle(entry->Hash(), aPriority, aPinning); |
| 419 | entry->AddHandle(handle); |
| 420 | |
| 421 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() hash=%08x%08x%08x%08x%08x " "created new handle %p, entry=%p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 422 | ("CacheFileHandles::NewHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() hash=%08x%08x%08x%08x%08x " "created new handle %p, entry=%p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 423 | "created new handle %p, entry=%p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() hash=%08x%08x%08x%08x%08x " "created new handle %p, entry=%p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0) |
| 424 | LOGSHA1(aHash), handle.get(), entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::NewHandle() hash=%08x%08x%08x%08x%08x " "created new handle %p, entry=%p", PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHash))[4]), handle.get(), entry); } } while (0); |
| 425 | return handle.forget(); |
| 426 | } |
| 427 | |
| 428 | void CacheFileHandles::RemoveHandle(CacheFileHandle* aHandle) { |
| 429 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 429); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 429; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 430 | MOZ_ASSERT(aHandle)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHandle)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aHandle))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("aHandle", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 430); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHandle" ")" ); do { *((volatile int*)__null) = 430; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 431 | |
| 432 | if (!aHandle) { |
| 433 | return; |
| 434 | } |
| 435 | |
| 436 | #ifdef DEBUG_HANDLES |
| 437 | LOG((do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() [handle=%p, hash=%08x%08x%08x%08x%08x]" , aHandle, PR_htonl((reinterpret_cast<const uint32_t*>( aHandle->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 438 | "CacheFileHandles::RemoveHandle() [handle=%p, hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() [handle=%p, hash=%08x%08x%08x%08x%08x]" , aHandle, PR_htonl((reinterpret_cast<const uint32_t*>( aHandle->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 439 | aHandle, LOGSHA1(aHandle->Hash())))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() [handle=%p, hash=%08x%08x%08x%08x%08x]" , aHandle, PR_htonl((reinterpret_cast<const uint32_t*>( aHandle->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0); |
| 440 | #endif |
| 441 | |
| 442 | // find hash entry for key |
| 443 | HandleHashKey* entry = mTable.GetEntry(*aHandle->Hash()); |
| 444 | if (!entry) { |
| 445 | MOZ_ASSERT(CacheFileIOManager::IsShutdown(),do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsShutdown())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsShutdown ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsShutdown()" " (" "Should find entry when removing a handle before shutdown" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 446); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsShutdown()" ") (" "Should find entry when removing a handle before shutdown" ")"); do { *((volatile int*)__null) = 446; __attribute__((nomerge )) ::abort(); } while (false); } } while (false) |
| 446 | "Should find entry when removing a handle before shutdown")do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsShutdown())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsShutdown ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsShutdown()" " (" "Should find entry when removing a handle before shutdown" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 446); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsShutdown()" ") (" "Should find entry when removing a handle before shutdown" ")"); do { *((volatile int*)__null) = 446; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 447 | |
| 448 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "no entries found", PR_htonl((reinterpret_cast<const uint32_t *>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 449 | ("CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "no entries found", PR_htonl((reinterpret_cast<const uint32_t *>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 450 | "no entries found",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "no entries found", PR_htonl((reinterpret_cast<const uint32_t *>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 451 | LOGSHA1(aHandle->Hash())))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "no entries found", PR_htonl((reinterpret_cast<const uint32_t *>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast< const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0); |
| 452 | return; |
| 453 | } |
| 454 | |
| 455 | #ifdef DEBUG_HANDLES |
| 456 | Log(entry); |
| 457 | #endif |
| 458 | |
| 459 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "removing handle %p", PR_htonl((reinterpret_cast<const uint32_t *>(entry->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), aHandle); } } while (0) |
| 460 | ("CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "removing handle %p", PR_htonl((reinterpret_cast<const uint32_t *>(entry->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), aHandle); } } while (0) |
| 461 | "removing handle %p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "removing handle %p", PR_htonl((reinterpret_cast<const uint32_t *>(entry->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), aHandle); } } while (0) |
| 462 | LOGSHA1(entry->Hash()), aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "removing handle %p", PR_htonl((reinterpret_cast<const uint32_t *>(entry->Hash()))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), aHandle); } } while (0); |
| 463 | entry->RemoveHandle(aHandle); |
| 464 | |
| 465 | if (entry->IsEmpty()) { |
| 466 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "list is empty, removing entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), entry); } } while (0) |
| 467 | ("CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "list is empty, removing entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), entry); } } while (0) |
| 468 | "list is empty, removing entry %p",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "list is empty, removing entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), entry); } } while (0) |
| 469 | LOGSHA1(entry->Hash()), entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::RemoveHandle() hash=%08x%08x%08x%08x%08x " "list is empty, removing entry %p", PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(entry->Hash()))[4]), entry); } } while (0); |
| 470 | mTable.RemoveEntry(entry); |
| 471 | } |
| 472 | } |
| 473 | |
| 474 | void CacheFileHandles::GetAllHandles( |
| 475 | nsTArray<RefPtr<CacheFileHandle>>* _retval) { |
| 476 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 476); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 476; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 477 | for (auto iter = mTable.Iter(); !iter.Done(); iter.Next()) { |
| 478 | iter.Get()->GetHandles(*_retval); |
| 479 | } |
| 480 | } |
| 481 | |
| 482 | void CacheFileHandles::GetActiveHandles( |
| 483 | nsTArray<RefPtr<CacheFileHandle>>* _retval) { |
| 484 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 484); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 484; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 485 | for (auto iter = mTable.Iter(); !iter.Done(); iter.Next()) { |
| 486 | RefPtr<CacheFileHandle> handle = iter.Get()->GetNewestHandle(); |
| 487 | MOZ_ASSERT(handle)do { static_assert( mozilla::detail::AssertionConditionType< decltype(handle)>::isValid, "invalid assertion condition") ; if ((__builtin_expect(!!(!(!!(handle))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("handle", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 487); AnnotateMozCrashReason("MOZ_ASSERT" "(" "handle" ")") ; do { *((volatile int*)__null) = 487; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 488 | |
| 489 | if (!handle->IsDoomed()) { |
| 490 | _retval->AppendElement(handle); |
| 491 | } |
| 492 | } |
| 493 | } |
| 494 | |
| 495 | void CacheFileHandles::ClearAll() { |
| 496 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 496); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 496; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 497 | mTable.Clear(); |
| 498 | } |
| 499 | |
| 500 | uint32_t CacheFileHandles::HandleCount() { return mTable.Count(); } |
| 501 | |
| 502 | #ifdef DEBUG_HANDLES |
| 503 | void CacheFileHandles::Log(CacheFileHandlesEntry* entry) { |
| 504 | LOG(("CacheFileHandles::Log() BEGIN [entry=%p]", entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::Log() BEGIN [entry=%p]" , entry); } } while (0); |
| 505 | |
| 506 | nsTArray<RefPtr<CacheFileHandle>> array; |
| 507 | aEntry->GetHandles(array); |
| 508 | |
| 509 | for (uint32_t i = 0; i < array.Length(); ++i) { |
| 510 | CacheFileHandle* handle = array[i]; |
| 511 | handle->Log(); |
| 512 | } |
| 513 | |
| 514 | LOG(("CacheFileHandles::Log() END [entry=%p]", entry))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileHandles::Log() END [entry=%p]" , entry); } } while (0); |
| 515 | } |
| 516 | #endif |
| 517 | |
| 518 | // Memory reporting |
| 519 | |
| 520 | size_t CacheFileHandles::SizeOfExcludingThis( |
| 521 | mozilla::MallocSizeOf mallocSizeOf) const { |
| 522 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsOnIOThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsOnIOThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 522); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThread()" ")"); do { *((volatile int*)__null) = 522; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 523 | |
| 524 | return mTable.SizeOfExcludingThis(mallocSizeOf); |
| 525 | } |
| 526 | |
| 527 | // Events |
| 528 | |
| 529 | class ShutdownEvent : public Runnable, nsITimerCallback { |
| 530 | NS_DECL_ISUPPORTS_INHERITEDpublic: virtual nsresult QueryInterface(const nsIID& aIID , void** aInstancePtr) override; virtual MozExternalRefCountType AddRef(void) override; virtual MozExternalRefCountType Release (void) override; |
| 531 | public: |
| 532 | ShutdownEvent() : Runnable("net::ShutdownEvent") {} |
| 533 | |
| 534 | protected: |
| 535 | ~ShutdownEvent() = default; |
| 536 | |
| 537 | public: |
| 538 | NS_IMETHODvirtual nsresult Run() override { |
| 539 | CacheFileIOManager::gInstance->ShutdownInternal(); |
| 540 | |
| 541 | mNotified = true; |
| 542 | |
| 543 | NS_DispatchToMainThread( |
| 544 | NS_NewRunnableFunction("CacheFileIOManager::ShutdownEvent::Run", []() { |
| 545 | // This empty runnable is dispatched just in case the MT event loop |
| 546 | // becomes empty - we need to process a task to break out of |
| 547 | // SpinEventLoopUntil. |
| 548 | })); |
| 549 | |
| 550 | return NS_OK; |
| 551 | } |
| 552 | |
| 553 | NS_IMETHODvirtual nsresult Notify(nsITimer* timer) override { |
| 554 | if (mNotified) { |
| 555 | return NS_OK; |
| 556 | } |
| 557 | |
| 558 | // If there is any IO blocking on the IO thread, this will |
| 559 | // try to cancel it. |
| 560 | CacheFileIOManager::gInstance->mIOThread->CancelBlockingIO(); |
| 561 | |
| 562 | // After this runs the first time, the browser_cache_max_shutdown_io_lag |
| 563 | // time has elapsed. The CacheIO thread may pick up more blocking IO tasks |
| 564 | // so we want to block those too if necessary. |
| 565 | mTimer->SetDelay( |
| 566 | StaticPrefs::browser_cache_shutdown_io_time_between_cancellations_ms()); |
| 567 | return NS_OK; |
| 568 | } |
| 569 | |
| 570 | void PostAndWait() { |
| 571 | nsresult rv = CacheFileIOManager::gInstance->mIOThread->Dispatch( |
| 572 | this, |
| 573 | CacheIOThread::WRITE); // When writes and closing of handles is done |
| 574 | MOZ_ASSERT(NS_SUCCEEDED(rv))do { static_assert( mozilla::detail::AssertionConditionType< decltype(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) )))>::isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) ))))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 574); AnnotateMozCrashReason("MOZ_ASSERT" "(" "((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" ")"); do { *((volatile int*)__null) = 574; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 575 | |
| 576 | // If we failed to post the even there's no reason to go into the loop |
| 577 | // because mNotified will never be set to true. |
| 578 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 579 | NS_WARNING("Posting ShutdownEvent task failed")NS_DebugBreak(NS_DEBUG_WARNING, "Posting ShutdownEvent task failed" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 579); |
| 580 | return; |
| 581 | } |
| 582 | |
| 583 | rv = NS_NewTimerWithCallback( |
| 584 | getter_AddRefs(mTimer), this, |
| 585 | StaticPrefs::browser_cache_max_shutdown_io_lag() * 1000, |
| 586 | nsITimer::TYPE_REPEATING_SLACK); |
| 587 | MOZ_ASSERT(NS_SUCCEEDED(rv))do { static_assert( mozilla::detail::AssertionConditionType< decltype(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) )))>::isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) ))))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 587); AnnotateMozCrashReason("MOZ_ASSERT" "(" "((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" ")"); do { *((volatile int*)__null) = 587; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 588 | |
| 589 | mozilla::SpinEventLoopUntil("CacheFileIOManager::ShutdownEvent"_ns, |
| 590 | [&]() { return bool(mNotified); }); |
| 591 | |
| 592 | if (mTimer) { |
| 593 | mTimer->Cancel(); |
| 594 | mTimer = nullptr; |
| 595 | } |
| 596 | } |
| 597 | |
| 598 | protected: |
| 599 | Atomic<bool> mNotified{false}; |
| 600 | nsCOMPtr<nsITimer> mTimer; |
| 601 | }; |
| 602 | |
| 603 | NS_IMPL_ISUPPORTS_INHERITED(ShutdownEvent, Runnable, nsITimerCallback)nsresult ShutdownEvent::QueryInterface(const nsIID& aIID, void** aInstancePtr) { do { if (!(aInstancePtr)) { NS_DebugBreak (NS_DEBUG_ASSERTION, "QueryInterface requires a non-NULL destination!" , "aInstancePtr", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 603); MOZ_PretendNoReturn(); } } while (0); nsresult rv = NS_ERROR_FAILURE ; static_assert(1 > 0, "Need more arguments to NS_INTERFACE_TABLE_INHERITED" ); static const QITableEntry table[] = { {&mozilla::detail ::kImplementedIID<ShutdownEvent, nsITimerCallback>, int32_t ( reinterpret_cast<char*>(static_cast<nsITimerCallback *>((ShutdownEvent*)0x1000)) - reinterpret_cast<char*> ((ShutdownEvent*)0x1000))}, { nullptr, 0 } } ; static_assert( std::size(table) > 1, "need at least 1 interface"); rv = NS_TableDrivenQI (static_cast<void*>(this), aIID, aInstancePtr, table); if (((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) return rv; return Runnable::QueryInterface(aIID, aInstancePtr); } MozExternalRefCountType ShutdownEvent::AddRef(void) { static_assert(!std::is_destructible_v <ShutdownEvent>, "Reference-counted class " "ShutdownEvent" " should not have a public destructor. " "Make this class's destructor non-public" ); nsrefcnt r = Runnable::AddRef(); if constexpr (::mozilla:: detail::ShouldLogInheritedRefcnt<ShutdownEvent>) { NS_LogAddRef ((this), (r), ("ShutdownEvent"), (uint32_t)(sizeof(*this))); } return r; } MozExternalRefCountType ShutdownEvent::Release(void ) { nsrefcnt r = Runnable::Release(); if constexpr (::mozilla ::detail::ShouldLogInheritedRefcnt<ShutdownEvent>) { NS_LogRelease ((this), (r), ("ShutdownEvent")); } return r; } |
| 604 | |
| 605 | // Class responsible for reporting IO performance stats |
| 606 | class IOPerfReportEvent { |
| 607 | public: |
| 608 | explicit IOPerfReportEvent(CacheFileUtils::CachePerfStats::EDataType aType) |
| 609 | : mType(aType), mEventCounter(0) {} |
| 610 | |
| 611 | void Start(CacheIOThread* aIOThread) { |
| 612 | mStartTime = TimeStamp::Now(); |
| 613 | mEventCounter = aIOThread->EventCounter(); |
| 614 | } |
| 615 | |
| 616 | void Report(CacheIOThread* aIOThread) { |
| 617 | if (mStartTime.IsNull()) { |
| 618 | return; |
| 619 | } |
| 620 | |
| 621 | // Single IO operations can take less than 1ms. So we use microseconds to |
| 622 | // keep a good resolution of data. |
| 623 | uint32_t duration = (TimeStamp::Now() - mStartTime).ToMicroseconds(); |
| 624 | |
| 625 | // This is a simple prefiltering of values that might differ a lot from the |
| 626 | // average value. Do not add the value to the filtered stats when the event |
| 627 | // had to wait in a long queue. |
| 628 | uint32_t eventCounter = aIOThread->EventCounter(); |
| 629 | bool shortOnly = eventCounter - mEventCounter >= 5; |
| 630 | |
| 631 | CacheFileUtils::CachePerfStats::AddValue(mType, duration, shortOnly); |
| 632 | } |
| 633 | |
| 634 | protected: |
| 635 | CacheFileUtils::CachePerfStats::EDataType mType; |
| 636 | TimeStamp mStartTime; |
| 637 | uint32_t mEventCounter; |
| 638 | }; |
| 639 | |
| 640 | class OpenFileEvent : public Runnable, public IOPerfReportEvent { |
| 641 | public: |
| 642 | OpenFileEvent(const nsACString& aKey, uint32_t aFlags, |
| 643 | CacheFileIOListener* aCallback) |
| 644 | : Runnable("net::OpenFileEvent"), |
| 645 | IOPerfReportEvent(CacheFileUtils::CachePerfStats::IO_OPEN), |
| 646 | mFlags(aFlags), |
| 647 | mCallback(aCallback), |
| 648 | mKey(aKey) { |
| 649 | mIOMan = CacheFileIOManager::gInstance; |
| 650 | if (!(mFlags & CacheFileIOManager::SPECIAL_FILE)) { |
| 651 | Start(mIOMan->mIOThread); |
| 652 | } |
| 653 | } |
| 654 | |
| 655 | protected: |
| 656 | ~OpenFileEvent() = default; |
| 657 | |
| 658 | public: |
| 659 | NS_IMETHODvirtual nsresult Run() override { |
| 660 | nsresult rv = NS_OK; |
| 661 | |
| 662 | if (!(mFlags & CacheFileIOManager::SPECIAL_FILE)) { |
| 663 | SHA1Sum sum; |
| 664 | sum.update(mKey.BeginReading(), mKey.Length()); |
| 665 | sum.finish(mHash); |
| 666 | } |
| 667 | |
| 668 | if (!mIOMan) { |
| 669 | rv = NS_ERROR_NOT_INITIALIZED; |
| 670 | } else { |
| 671 | if (mFlags & CacheFileIOManager::SPECIAL_FILE) { |
| 672 | rv = mIOMan->OpenSpecialFileInternal(mKey, mFlags, |
| 673 | getter_AddRefs(mHandle)); |
| 674 | } else { |
| 675 | rv = mIOMan->OpenFileInternal(&mHash, mKey, mFlags, |
| 676 | getter_AddRefs(mHandle)); |
| 677 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 678 | Report(mIOMan->mIOThread); |
| 679 | } |
| 680 | } |
| 681 | mIOMan = nullptr; |
| 682 | if (mHandle) { |
| 683 | if (mHandle->Key().IsEmpty()) { |
| 684 | mHandle->Key() = mKey; |
| 685 | } |
| 686 | } |
| 687 | } |
| 688 | |
| 689 | mCallback->OnFileOpened(mHandle, rv); |
| 690 | return NS_OK; |
| 691 | } |
| 692 | |
| 693 | protected: |
| 694 | SHA1Sum::Hash mHash{}; |
| 695 | uint32_t mFlags; |
| 696 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 697 | RefPtr<CacheFileIOManager> mIOMan; |
| 698 | RefPtr<CacheFileHandle> mHandle; |
| 699 | nsCString mKey; |
| 700 | }; |
| 701 | |
| 702 | class ReadEvent : public Runnable, public IOPerfReportEvent { |
| 703 | public: |
| 704 | ReadEvent(CacheFileHandle* aHandle, int64_t aOffset, char* aBuf, |
| 705 | int32_t aCount, CacheFileIOListener* aCallback) |
| 706 | : Runnable("net::ReadEvent"), |
| 707 | IOPerfReportEvent(CacheFileUtils::CachePerfStats::IO_READ), |
| 708 | mHandle(aHandle), |
| 709 | mOffset(aOffset), |
| 710 | mBuf(aBuf), |
| 711 | mCount(aCount), |
| 712 | mCallback(aCallback) { |
| 713 | if (!mHandle->IsSpecialFile()) { |
| 714 | Start(CacheFileIOManager::gInstance->mIOThread); |
| 715 | } |
| 716 | } |
| 717 | |
| 718 | protected: |
| 719 | ~ReadEvent() = default; |
| 720 | |
| 721 | public: |
| 722 | NS_IMETHODvirtual nsresult Run() override { |
| 723 | nsresult rv; |
| 724 | |
| 725 | if (mHandle->IsClosed() || (mCallback && mCallback->IsKilled())) { |
| 726 | rv = NS_ERROR_NOT_INITIALIZED; |
| 727 | } else { |
| 728 | rv = CacheFileIOManager::gInstance->ReadInternal(mHandle, mOffset, mBuf, |
| 729 | mCount); |
| 730 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 731 | Report(CacheFileIOManager::gInstance->mIOThread); |
| 732 | } |
| 733 | } |
| 734 | |
| 735 | mCallback->OnDataRead(mHandle, mBuf, rv); |
| 736 | return NS_OK; |
| 737 | } |
| 738 | |
| 739 | protected: |
| 740 | RefPtr<CacheFileHandle> mHandle; |
| 741 | int64_t mOffset; |
| 742 | char* mBuf; |
| 743 | int32_t mCount; |
| 744 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 745 | }; |
| 746 | |
| 747 | class WriteEvent : public Runnable, public IOPerfReportEvent { |
| 748 | public: |
| 749 | WriteEvent(CacheFileHandle* aHandle, int64_t aOffset, const char* aBuf, |
| 750 | int32_t aCount, bool aValidate, bool aTruncate, |
| 751 | CacheFileIOListener* aCallback) |
| 752 | : Runnable("net::WriteEvent"), |
| 753 | IOPerfReportEvent(CacheFileUtils::CachePerfStats::IO_WRITE), |
| 754 | mHandle(aHandle), |
| 755 | mOffset(aOffset), |
| 756 | mBuf(aBuf), |
| 757 | mCount(aCount), |
| 758 | mValidate(aValidate), |
| 759 | mTruncate(aTruncate), |
| 760 | mCallback(aCallback) { |
| 761 | if (!mHandle->IsSpecialFile()) { |
| 762 | Start(CacheFileIOManager::gInstance->mIOThread); |
| 763 | } |
| 764 | } |
| 765 | |
| 766 | protected: |
| 767 | ~WriteEvent() { |
| 768 | if (!mCallback && mBuf) { |
| 769 | free(const_cast<char*>(mBuf)); |
| 770 | } |
| 771 | } |
| 772 | |
| 773 | public: |
| 774 | NS_IMETHODvirtual nsresult Run() override { |
| 775 | nsresult rv; |
| 776 | |
| 777 | if (mHandle->IsClosed() || (mCallback && mCallback->IsKilled())) { |
| 778 | // We usually get here only after the internal shutdown |
| 779 | // (i.e. mShuttingDown == true). Pretend write has succeeded |
| 780 | // to avoid any past-shutdown file dooming. |
| 781 | rv = (CacheObserver::IsPastShutdownIOLag() || |
| 782 | CacheFileIOManager::gInstance->mShuttingDown) |
| 783 | ? NS_OK |
| 784 | : NS_ERROR_NOT_INITIALIZED; |
| 785 | } else { |
| 786 | rv = CacheFileIOManager::gInstance->WriteInternal( |
| 787 | mHandle, mOffset, mBuf, mCount, mValidate, mTruncate); |
| 788 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 789 | Report(CacheFileIOManager::gInstance->mIOThread); |
| 790 | } |
| 791 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0))) && !mCallback) { |
| 792 | // No listener is going to handle the error, doom the file |
| 793 | CacheFileIOManager::gInstance->DoomFileInternal(mHandle); |
| 794 | } |
| 795 | } |
| 796 | if (mCallback) { |
| 797 | mCallback->OnDataWritten(mHandle, mBuf, rv); |
| 798 | } else { |
| 799 | free(const_cast<char*>(mBuf)); |
| 800 | mBuf = nullptr; |
| 801 | } |
| 802 | |
| 803 | return NS_OK; |
| 804 | } |
| 805 | |
| 806 | protected: |
| 807 | RefPtr<CacheFileHandle> mHandle; |
| 808 | int64_t mOffset; |
| 809 | const char* mBuf; |
| 810 | int32_t mCount; |
| 811 | bool mValidate : 1; |
| 812 | bool mTruncate : 1; |
| 813 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 814 | }; |
| 815 | |
| 816 | class DoomFileEvent : public Runnable { |
| 817 | public: |
| 818 | DoomFileEvent(CacheFileHandle* aHandle, CacheFileIOListener* aCallback) |
| 819 | : Runnable("net::DoomFileEvent"), |
| 820 | mCallback(aCallback), |
| 821 | mHandle(aHandle) {} |
| 822 | |
| 823 | protected: |
| 824 | ~DoomFileEvent() = default; |
| 825 | |
| 826 | public: |
| 827 | NS_IMETHODvirtual nsresult Run() override { |
| 828 | nsresult rv; |
| 829 | |
| 830 | if (mHandle->IsClosed()) { |
| 831 | rv = NS_ERROR_NOT_INITIALIZED; |
| 832 | } else { |
| 833 | rv = CacheFileIOManager::gInstance->DoomFileInternal(mHandle); |
| 834 | } |
| 835 | |
| 836 | if (mCallback) { |
| 837 | mCallback->OnFileDoomed(mHandle, rv); |
| 838 | } |
| 839 | |
| 840 | return NS_OK; |
| 841 | } |
| 842 | |
| 843 | protected: |
| 844 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 845 | nsCOMPtr<nsIEventTarget> mTarget; |
| 846 | RefPtr<CacheFileHandle> mHandle; |
| 847 | }; |
| 848 | |
| 849 | class DoomFileByKeyEvent : public Runnable { |
| 850 | public: |
| 851 | DoomFileByKeyEvent(const nsACString& aKey, CacheFileIOListener* aCallback) |
| 852 | : Runnable("net::DoomFileByKeyEvent"), mCallback(aCallback) { |
| 853 | SHA1Sum sum; |
| 854 | sum.update(aKey.BeginReading(), aKey.Length()); |
| 855 | sum.finish(mHash); |
| 856 | |
| 857 | mIOMan = CacheFileIOManager::gInstance; |
| 858 | } |
| 859 | |
| 860 | protected: |
| 861 | ~DoomFileByKeyEvent() = default; |
| 862 | |
| 863 | public: |
| 864 | NS_IMETHODvirtual nsresult Run() override { |
| 865 | nsresult rv; |
| 866 | |
| 867 | if (!mIOMan) { |
| 868 | rv = NS_ERROR_NOT_INITIALIZED; |
| 869 | } else { |
| 870 | rv = mIOMan->DoomFileByKeyInternal(&mHash); |
| 871 | mIOMan = nullptr; |
| 872 | } |
| 873 | |
| 874 | if (mCallback) { |
| 875 | mCallback->OnFileDoomed(nullptr, rv); |
| 876 | } |
| 877 | |
| 878 | return NS_OK; |
| 879 | } |
| 880 | |
| 881 | protected: |
| 882 | SHA1Sum::Hash mHash{}; |
| 883 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 884 | RefPtr<CacheFileIOManager> mIOMan; |
| 885 | }; |
| 886 | |
| 887 | class ReleaseNSPRHandleEvent : public Runnable { |
| 888 | public: |
| 889 | explicit ReleaseNSPRHandleEvent(CacheFileHandle* aHandle) |
| 890 | : Runnable("net::ReleaseNSPRHandleEvent"), mHandle(aHandle) {} |
| 891 | |
| 892 | protected: |
| 893 | ~ReleaseNSPRHandleEvent() = default; |
| 894 | |
| 895 | public: |
| 896 | NS_IMETHODvirtual nsresult Run() override { |
| 897 | if (!mHandle->IsClosed()) { |
| 898 | CacheFileIOManager::gInstance->MaybeReleaseNSPRHandleInternal(mHandle); |
| 899 | } |
| 900 | |
| 901 | return NS_OK; |
| 902 | } |
| 903 | |
| 904 | protected: |
| 905 | RefPtr<CacheFileHandle> mHandle; |
| 906 | }; |
| 907 | |
| 908 | class TruncateSeekSetEOFEvent : public Runnable { |
| 909 | public: |
| 910 | TruncateSeekSetEOFEvent(CacheFileHandle* aHandle, int64_t aTruncatePos, |
| 911 | int64_t aEOFPos, CacheFileIOListener* aCallback) |
| 912 | : Runnable("net::TruncateSeekSetEOFEvent"), |
| 913 | mHandle(aHandle), |
| 914 | mTruncatePos(aTruncatePos), |
| 915 | mEOFPos(aEOFPos), |
| 916 | mCallback(aCallback) {} |
| 917 | |
| 918 | protected: |
| 919 | ~TruncateSeekSetEOFEvent() = default; |
| 920 | |
| 921 | public: |
| 922 | NS_IMETHODvirtual nsresult Run() override { |
| 923 | nsresult rv; |
| 924 | |
| 925 | if (mHandle->IsClosed() || (mCallback && mCallback->IsKilled())) { |
| 926 | rv = NS_ERROR_NOT_INITIALIZED; |
| 927 | } else { |
| 928 | rv = CacheFileIOManager::gInstance->TruncateSeekSetEOFInternal( |
| 929 | mHandle, mTruncatePos, mEOFPos); |
| 930 | } |
| 931 | |
| 932 | if (mCallback) { |
| 933 | mCallback->OnEOFSet(mHandle, rv); |
| 934 | } |
| 935 | |
| 936 | return NS_OK; |
| 937 | } |
| 938 | |
| 939 | protected: |
| 940 | RefPtr<CacheFileHandle> mHandle; |
| 941 | int64_t mTruncatePos; |
| 942 | int64_t mEOFPos; |
| 943 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 944 | }; |
| 945 | |
| 946 | class RenameFileEvent : public Runnable { |
| 947 | public: |
| 948 | RenameFileEvent(CacheFileHandle* aHandle, const nsACString& aNewName, |
| 949 | CacheFileIOListener* aCallback) |
| 950 | : Runnable("net::RenameFileEvent"), |
| 951 | mHandle(aHandle), |
| 952 | mNewName(aNewName), |
| 953 | mCallback(aCallback) {} |
| 954 | |
| 955 | protected: |
| 956 | ~RenameFileEvent() = default; |
| 957 | |
| 958 | public: |
| 959 | NS_IMETHODvirtual nsresult Run() override { |
| 960 | nsresult rv; |
| 961 | |
| 962 | if (mHandle->IsClosed()) { |
| 963 | rv = NS_ERROR_NOT_INITIALIZED; |
| 964 | } else { |
| 965 | rv = CacheFileIOManager::gInstance->RenameFileInternal(mHandle, mNewName); |
| 966 | } |
| 967 | |
| 968 | if (mCallback) { |
| 969 | mCallback->OnFileRenamed(mHandle, rv); |
| 970 | } |
| 971 | |
| 972 | return NS_OK; |
| 973 | } |
| 974 | |
| 975 | protected: |
| 976 | RefPtr<CacheFileHandle> mHandle; |
| 977 | nsCString mNewName; |
| 978 | nsCOMPtr<CacheFileIOListener> mCallback; |
| 979 | }; |
| 980 | |
| 981 | class InitIndexEntryEvent : public Runnable { |
| 982 | public: |
| 983 | InitIndexEntryEvent(CacheFileHandle* aHandle, |
| 984 | OriginAttrsHash aOriginAttrsHash, bool aAnonymous, |
| 985 | bool aPinning) |
| 986 | : Runnable("net::InitIndexEntryEvent"), |
| 987 | mHandle(aHandle), |
| 988 | mOriginAttrsHash(aOriginAttrsHash), |
| 989 | mAnonymous(aAnonymous), |
| 990 | mPinning(aPinning) {} |
| 991 | |
| 992 | protected: |
| 993 | ~InitIndexEntryEvent() = default; |
| 994 | |
| 995 | public: |
| 996 | NS_IMETHODvirtual nsresult Run() override { |
| 997 | if (mHandle->IsClosed() || mHandle->IsDoomed()) { |
| 998 | return NS_OK; |
| 999 | } |
| 1000 | |
| 1001 | CacheIndex::InitEntry(mHandle->Hash(), mOriginAttrsHash, mAnonymous, |
| 1002 | mPinning); |
| 1003 | |
| 1004 | // We cannot set the filesize before we init the entry. If we're opening |
| 1005 | // an existing entry file, frecency will be set after parsing the entry |
| 1006 | // file, but we must set the filesize here since nobody is going to set it |
| 1007 | // if there is no write to the file. |
| 1008 | uint32_t sizeInK = mHandle->FileSizeInK(); |
| 1009 | CacheIndex::UpdateEntry(mHandle->Hash(), nullptr, nullptr, nullptr, nullptr, |
| 1010 | nullptr, &sizeInK); |
| 1011 | |
| 1012 | return NS_OK; |
| 1013 | } |
| 1014 | |
| 1015 | protected: |
| 1016 | RefPtr<CacheFileHandle> mHandle; |
| 1017 | OriginAttrsHash mOriginAttrsHash; |
| 1018 | bool mAnonymous; |
| 1019 | bool mPinning; |
| 1020 | }; |
| 1021 | |
| 1022 | class UpdateIndexEntryEvent : public Runnable { |
| 1023 | public: |
| 1024 | UpdateIndexEntryEvent(CacheFileHandle* aHandle, const uint32_t* aFrecency, |
| 1025 | const bool* aHasAltData, const uint16_t* aOnStartTime, |
| 1026 | const uint16_t* aOnStopTime, |
| 1027 | const uint8_t* aContentType) |
| 1028 | : Runnable("net::UpdateIndexEntryEvent"), |
| 1029 | mHandle(aHandle), |
| 1030 | mHasFrecency(false), |
| 1031 | mHasHasAltData(false), |
| 1032 | mHasOnStartTime(false), |
| 1033 | mHasOnStopTime(false), |
| 1034 | mHasContentType(false), |
| 1035 | mFrecency(0), |
| 1036 | mHasAltData(false), |
| 1037 | mOnStartTime(0), |
| 1038 | mOnStopTime(0), |
| 1039 | mContentType(nsICacheEntry::CONTENT_TYPE_UNKNOWN) { |
| 1040 | if (aFrecency) { |
| 1041 | mHasFrecency = true; |
| 1042 | mFrecency = *aFrecency; |
| 1043 | } |
| 1044 | if (aHasAltData) { |
| 1045 | mHasHasAltData = true; |
| 1046 | mHasAltData = *aHasAltData; |
| 1047 | } |
| 1048 | if (aOnStartTime) { |
| 1049 | mHasOnStartTime = true; |
| 1050 | mOnStartTime = *aOnStartTime; |
| 1051 | } |
| 1052 | if (aOnStopTime) { |
| 1053 | mHasOnStopTime = true; |
| 1054 | mOnStopTime = *aOnStopTime; |
| 1055 | } |
| 1056 | if (aContentType) { |
| 1057 | mHasContentType = true; |
| 1058 | mContentType = *aContentType; |
| 1059 | } |
| 1060 | } |
| 1061 | |
| 1062 | protected: |
| 1063 | ~UpdateIndexEntryEvent() = default; |
| 1064 | |
| 1065 | public: |
| 1066 | NS_IMETHODvirtual nsresult Run() override { |
| 1067 | if (mHandle->IsClosed() || mHandle->IsDoomed()) { |
| 1068 | return NS_OK; |
| 1069 | } |
| 1070 | |
| 1071 | CacheIndex::UpdateEntry(mHandle->Hash(), |
| 1072 | mHasFrecency ? &mFrecency : nullptr, |
| 1073 | mHasHasAltData ? &mHasAltData : nullptr, |
| 1074 | mHasOnStartTime ? &mOnStartTime : nullptr, |
| 1075 | mHasOnStopTime ? &mOnStopTime : nullptr, |
| 1076 | mHasContentType ? &mContentType : nullptr, nullptr); |
| 1077 | return NS_OK; |
| 1078 | } |
| 1079 | |
| 1080 | protected: |
| 1081 | RefPtr<CacheFileHandle> mHandle; |
| 1082 | |
| 1083 | bool mHasFrecency; |
| 1084 | bool mHasHasAltData; |
| 1085 | bool mHasOnStartTime; |
| 1086 | bool mHasOnStopTime; |
| 1087 | bool mHasContentType; |
| 1088 | |
| 1089 | uint32_t mFrecency; |
| 1090 | bool mHasAltData; |
| 1091 | uint16_t mOnStartTime; |
| 1092 | uint16_t mOnStopTime; |
| 1093 | uint8_t mContentType; |
| 1094 | }; |
| 1095 | |
| 1096 | class MetadataWriteScheduleEvent : public Runnable { |
| 1097 | public: |
| 1098 | enum EMode { SCHEDULE, UNSCHEDULE, SHUTDOWN } mMode; |
| 1099 | |
| 1100 | RefPtr<CacheFile> mFile; |
| 1101 | RefPtr<CacheFileIOManager> mIOMan; |
| 1102 | |
| 1103 | MetadataWriteScheduleEvent(CacheFileIOManager* aManager, CacheFile* aFile, |
| 1104 | EMode aMode) |
| 1105 | : Runnable("net::MetadataWriteScheduleEvent"), |
| 1106 | mMode(aMode), |
| 1107 | mFile(aFile), |
| 1108 | mIOMan(aManager) {} |
| 1109 | |
| 1110 | virtual ~MetadataWriteScheduleEvent() = default; |
| 1111 | |
| 1112 | NS_IMETHODvirtual nsresult Run() override { |
| 1113 | RefPtr<CacheFileIOManager> ioMan = CacheFileIOManager::gInstance; |
| 1114 | if (!ioMan) { |
| 1115 | NS_WARNING(NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager already gone in " "MetadataWriteScheduleEvent::Run()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1117) |
| 1116 | "CacheFileIOManager already gone in "NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager already gone in " "MetadataWriteScheduleEvent::Run()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1117) |
| 1117 | "MetadataWriteScheduleEvent::Run()")NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager already gone in " "MetadataWriteScheduleEvent::Run()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1117); |
| 1118 | return NS_OK; |
| 1119 | } |
| 1120 | |
| 1121 | switch (mMode) { |
| 1122 | case SCHEDULE: |
| 1123 | ioMan->ScheduleMetadataWriteInternal(mFile); |
| 1124 | break; |
| 1125 | case UNSCHEDULE: |
| 1126 | ioMan->UnscheduleMetadataWriteInternal(mFile); |
| 1127 | break; |
| 1128 | case SHUTDOWN: |
| 1129 | ioMan->ShutdownMetadataWriteSchedulingInternal(); |
| 1130 | break; |
| 1131 | } |
| 1132 | return NS_OK; |
| 1133 | } |
| 1134 | }; |
| 1135 | |
| 1136 | StaticRefPtr<CacheFileIOManager> CacheFileIOManager::gInstance; |
| 1137 | |
| 1138 | NS_IMPL_ISUPPORTS(CacheFileIOManager, nsITimerCallback, nsINamed)MozExternalRefCountType CacheFileIOManager::AddRef(void) { static_assert (!std::is_destructible_v<CacheFileIOManager>, "Reference-counted class " "CacheFileIOManager" " should not have a public destructor. " "Make this class's destructor non-public"); do { static_assert ( mozilla::detail::AssertionConditionType<decltype(int32_t (mRefCnt) >= 0)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(int32_t(mRefCnt) >= 0))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("int32_t(mRefCnt) >= 0" " (" "illegal refcnt" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1138); AnnotateMozCrashReason("MOZ_ASSERT" "(" "int32_t(mRefCnt) >= 0" ") (" "illegal refcnt" ")"); do { *((volatile int*)__null) = 1138; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); do { static_assert( mozilla::detail::AssertionConditionType <decltype("CacheFileIOManager" != nullptr)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!("CacheFileIOManager" != nullptr ))), 0))) { do { } while (false); MOZ_ReportAssertionFailure( "\"CacheFileIOManager\" != nullptr" " (" "Must specify a name" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1138); AnnotateMozCrashReason("MOZ_ASSERT" "(" "\"CacheFileIOManager\" != nullptr" ") (" "Must specify a name" ")"); do { *((volatile int*)__null ) = 1138; __attribute__((nomerge)) ::abort(); } while (false) ; } } while (false); if (!mRefCnt.isThreadSafe) _mOwningThread .AssertOwnership("CacheFileIOManager" " not thread-safe"); nsrefcnt count = ++mRefCnt; NS_LogAddRef((this), (count), ("CacheFileIOManager" ), (uint32_t)(sizeof(*this))); return count; } MozExternalRefCountType CacheFileIOManager::Release(void) { do { static_assert( mozilla ::detail::AssertionConditionType<decltype(int32_t(mRefCnt) > 0)>::isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(int32_t(mRefCnt) > 0))), 0))) { do { } while (false ); MOZ_ReportAssertionFailure("int32_t(mRefCnt) > 0" " (" "dup release" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1138); AnnotateMozCrashReason("MOZ_ASSERT" "(" "int32_t(mRefCnt) > 0" ") (" "dup release" ")"); do { *((volatile int*)__null) = 1138 ; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); do { static_assert( mozilla::detail::AssertionConditionType <decltype("CacheFileIOManager" != nullptr)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!("CacheFileIOManager" != nullptr ))), 0))) { do { } while (false); MOZ_ReportAssertionFailure( "\"CacheFileIOManager\" != nullptr" " (" "Must specify a name" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1138); AnnotateMozCrashReason("MOZ_ASSERT" "(" "\"CacheFileIOManager\" != nullptr" ") (" "Must specify a name" ")"); do { *((volatile int*)__null ) = 1138; __attribute__((nomerge)) ::abort(); } while (false) ; } } while (false); if (!mRefCnt.isThreadSafe) _mOwningThread .AssertOwnership("CacheFileIOManager" " not thread-safe"); const char* const nametmp = "CacheFileIOManager"; nsrefcnt count = --mRefCnt; NS_LogRelease((this), (count), (nametmp)); if (count == 0) { mRefCnt = 1; delete (this); return 0; } return count ; } nsresult CacheFileIOManager::QueryInterface(const nsIID& aIID, void** aInstancePtr) { do { if (!(aInstancePtr)) { NS_DebugBreak (NS_DEBUG_ASSERTION, "QueryInterface requires a non-NULL destination!" , "aInstancePtr", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1138); MOZ_PretendNoReturn(); } } while (0); nsresult rv = NS_ERROR_FAILURE ; static_assert(2 > 0, "Need more arguments to NS_INTERFACE_TABLE" ); static const QITableEntry table[] = { {&mozilla::detail ::kImplementedIID<CacheFileIOManager, nsITimerCallback> , int32_t( reinterpret_cast<char*>(static_cast<nsITimerCallback *>((CacheFileIOManager*)0x1000)) - reinterpret_cast<char *>((CacheFileIOManager*)0x1000))}, {&mozilla::detail:: kImplementedIID<CacheFileIOManager, nsINamed>, int32_t( reinterpret_cast<char*>(static_cast<nsINamed*>(( CacheFileIOManager*)0x1000)) - reinterpret_cast<char*>( (CacheFileIOManager*)0x1000))}, {&mozilla::detail::kImplementedIID <CacheFileIOManager, nsISupports>, int32_t(reinterpret_cast <char*>(static_cast<nsISupports*>( static_cast< nsITimerCallback*>((CacheFileIOManager*)0x1000))) - reinterpret_cast <char*>((CacheFileIOManager*)0x1000))}, { nullptr, 0 } } ; static_assert(std::size(table) > 1, "need at least 1 interface" ); rv = NS_TableDrivenQI(static_cast<void*>(this), aIID , aInstancePtr, table); return rv; } |
| 1139 | |
| 1140 | CacheFileIOManager::CacheFileIOManager() |
| 1141 | |
| 1142 | { |
| 1143 | LOG(("CacheFileIOManager::CacheFileIOManager [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CacheFileIOManager [this=%p]" , this); } } while (0); |
| 1144 | MOZ_ASSERT(!gInstance, "multiple CacheFileIOManager instances!")do { static_assert( mozilla::detail::AssertionConditionType< decltype(!gInstance)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!gInstance))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("!gInstance" " (" "multiple CacheFileIOManager instances!" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1144); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!gInstance" ") (" "multiple CacheFileIOManager instances!" ")"); do { *( (volatile int*)__null) = 1144; __attribute__((nomerge)) ::abort (); } while (false); } } while (false); |
| 1145 | } |
| 1146 | |
| 1147 | CacheFileIOManager::~CacheFileIOManager() { |
| 1148 | LOG(("CacheFileIOManager::~CacheFileIOManager [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::~CacheFileIOManager [this=%p]" , this); } } while (0); |
| 1149 | } |
| 1150 | |
| 1151 | // static |
| 1152 | nsresult CacheFileIOManager::Init() { |
| 1153 | LOG(("CacheFileIOManager::Init()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Init()" ); } } while (0); |
| 1154 | |
| 1155 | MOZ_ASSERT(NS_IsMainThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(NS_IsMainThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(NS_IsMainThread()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("NS_IsMainThread()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1155); AnnotateMozCrashReason("MOZ_ASSERT" "(" "NS_IsMainThread()" ")"); do { *((volatile int*)__null) = 1155; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1156 | |
| 1157 | if (gInstance) { |
| 1158 | return NS_ERROR_ALREADY_INITIALIZED; |
| 1159 | } |
| 1160 | |
| 1161 | RefPtr<CacheFileIOManager> ioMan = new CacheFileIOManager(); |
| 1162 | |
| 1163 | nsresult rv = ioMan->InitInternal(); |
| 1164 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1164); return rv; } } while (false); |
| 1165 | |
| 1166 | gInstance = std::move(ioMan); |
| 1167 | return NS_OK; |
| 1168 | } |
| 1169 | |
| 1170 | nsresult CacheFileIOManager::InitInternal() { |
| 1171 | nsresult rv; |
| 1172 | |
| 1173 | mIOThread = new CacheIOThread(); |
| 1174 | |
| 1175 | rv = mIOThread->Init(); |
| 1176 | MOZ_ASSERT(NS_SUCCEEDED(rv), "Can't create background thread")do { static_assert( mozilla::detail::AssertionConditionType< decltype(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) )))>::isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1) ))))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" " (" "Can't create background thread" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1176); AnnotateMozCrashReason("MOZ_ASSERT" "(" "((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" ") (" "Can't create background thread" ")"); do { *((volatile int*)__null) = 1176; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); |
| 1177 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1177); return rv; } } while (false); |
| 1178 | |
| 1179 | mStartTime = TimeStamp::NowLoRes(); |
| 1180 | |
| 1181 | return NS_OK; |
| 1182 | } |
| 1183 | |
| 1184 | // static |
| 1185 | nsresult CacheFileIOManager::Shutdown() { |
| 1186 | LOG(("CacheFileIOManager::Shutdown() [gInstance=%p]", gInstance.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Shutdown() [gInstance=%p]" , gInstance.get()); } } while (0); |
| 1187 | |
| 1188 | MOZ_ASSERT(NS_IsMainThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(NS_IsMainThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(NS_IsMainThread()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("NS_IsMainThread()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1188); AnnotateMozCrashReason("MOZ_ASSERT" "(" "NS_IsMainThread()" ")"); do { *((volatile int*)__null) = 1188; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1189 | |
| 1190 | if (!gInstance) { |
| 1191 | return NS_ERROR_NOT_INITIALIZED; |
| 1192 | } |
| 1193 | |
| 1194 | Telemetry::AutoTimer<Telemetry::NETWORK_DISK_CACHE_SHUTDOWN_V2> shutdownTimer; |
| 1195 | |
| 1196 | CacheIndex::PreShutdown(); |
| 1197 | |
| 1198 | ShutdownMetadataWriteScheduling(); |
| 1199 | |
| 1200 | RefPtr<ShutdownEvent> ev = new ShutdownEvent(); |
| 1201 | ev->PostAndWait(); |
| 1202 | |
| 1203 | MOZ_ASSERT(gInstance->mHandles.HandleCount() == 0)do { static_assert( mozilla::detail::AssertionConditionType< decltype(gInstance->mHandles.HandleCount() == 0)>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(gInstance->mHandles.HandleCount() == 0))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("gInstance->mHandles.HandleCount() == 0" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1203); AnnotateMozCrashReason("MOZ_ASSERT" "(" "gInstance->mHandles.HandleCount() == 0" ")"); do { *((volatile int*)__null) = 1203; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1204 | MOZ_ASSERT(gInstance->mHandlesByLastUsed.Length() == 0)do { static_assert( mozilla::detail::AssertionConditionType< decltype(gInstance->mHandlesByLastUsed.Length() == 0)>:: isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(gInstance->mHandlesByLastUsed.Length() == 0))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("gInstance->mHandlesByLastUsed.Length() == 0" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1204); AnnotateMozCrashReason("MOZ_ASSERT" "(" "gInstance->mHandlesByLastUsed.Length() == 0" ")"); do { *((volatile int*)__null) = 1204; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1205 | |
| 1206 | if (gInstance->mIOThread) { |
| 1207 | gInstance->mIOThread->Shutdown(); |
| 1208 | } |
| 1209 | |
| 1210 | CacheIndex::Shutdown(); |
| 1211 | |
| 1212 | if (CacheObserver::ClearCacheOnShutdown()) { |
| 1213 | Telemetry::AutoTimer<Telemetry::NETWORK_DISK_CACHE2_SHUTDOWN_CLEAR_PRIVATE> |
| 1214 | totalTimer; |
| 1215 | gInstance->SyncRemoveAllCacheFiles(); |
| 1216 | } |
| 1217 | |
| 1218 | gInstance = nullptr; |
| 1219 | |
| 1220 | return NS_OK; |
| 1221 | } |
| 1222 | |
| 1223 | void CacheFileIOManager::ShutdownInternal() { |
| 1224 | LOG(("CacheFileIOManager::ShutdownInternal() [this=%p]", this))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::ShutdownInternal() [this=%p]" , this); } } while (0); |
| 1225 | |
| 1226 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1226); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 1226; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1227 | |
| 1228 | // No new handles can be created after this flag is set |
| 1229 | mShuttingDown = true; |
| 1230 | |
| 1231 | if (mTrashTimer) { |
| 1232 | mTrashTimer->Cancel(); |
| 1233 | mTrashTimer = nullptr; |
| 1234 | } |
| 1235 | |
| 1236 | // close all handles and delete all associated files |
| 1237 | nsTArray<RefPtr<CacheFileHandle>> handles; |
| 1238 | mHandles.GetAllHandles(&handles); |
| 1239 | handles.AppendElements(mSpecialHandles); |
| 1240 | |
| 1241 | for (uint32_t i = 0; i < handles.Length(); i++) { |
| 1242 | CacheFileHandle* h = handles[i]; |
| 1243 | h->mClosed = true; |
| 1244 | |
| 1245 | h->Log(); |
| 1246 | |
| 1247 | // Close completely written files. |
| 1248 | MaybeReleaseNSPRHandleInternal(h); |
| 1249 | // Don't bother removing invalid and/or doomed files to improve |
| 1250 | // shutdown perfomrance. |
| 1251 | // Doomed files are already in the doomed directory from which |
| 1252 | // we never reuse files and delete the dir on next session startup. |
| 1253 | // Invalid files don't have metadata and thus won't load anyway |
| 1254 | // (hashes won't match). |
| 1255 | |
| 1256 | if (!h->IsSpecialFile() && !h->mIsDoomed && !h->mFileExists) { |
| 1257 | CacheIndex::RemoveEntry(h->Hash()); |
| 1258 | } |
| 1259 | |
| 1260 | // Remove the handle from mHandles/mSpecialHandles |
| 1261 | if (h->IsSpecialFile()) { |
| 1262 | mSpecialHandles.RemoveElement(h); |
| 1263 | } else { |
| 1264 | mHandles.RemoveHandle(h); |
| 1265 | } |
| 1266 | |
| 1267 | // Pointer to the hash is no longer valid once the last handle with the |
| 1268 | // given hash is released. Null out the pointer so that we crash if there |
| 1269 | // is a bug in this code and we dereference the pointer after this point. |
| 1270 | if (!h->IsSpecialFile()) { |
| 1271 | h->mHash = nullptr; |
| 1272 | } |
| 1273 | } |
| 1274 | |
| 1275 | // Assert the table is empty. When we are here, no new handles can be added |
| 1276 | // and handles will no longer remove them self from this table and we don't |
| 1277 | // want to keep invalid handles here. Also, there is no lookup after this |
| 1278 | // point to happen. |
| 1279 | MOZ_ASSERT(mHandles.HandleCount() == 0)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mHandles.HandleCount() == 0)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mHandles.HandleCount() == 0) )), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mHandles.HandleCount() == 0" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1279); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mHandles.HandleCount() == 0" ")"); do { *((volatile int*)__null) = 1279; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1280 | |
| 1281 | // Release trash directory enumerator |
| 1282 | if (mTrashDirEnumerator) { |
| 1283 | mTrashDirEnumerator->Close(); |
| 1284 | mTrashDirEnumerator = nullptr; |
| 1285 | } |
| 1286 | |
| 1287 | if (mContextEvictor) { |
| 1288 | mContextEvictor->Shutdown(); |
| 1289 | mContextEvictor = nullptr; |
| 1290 | } |
| 1291 | } |
| 1292 | |
| 1293 | // static |
| 1294 | nsresult CacheFileIOManager::OnProfile() { |
| 1295 | LOG(("CacheFileIOManager::OnProfile() [gInstance=%p]", gInstance.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OnProfile() [gInstance=%p]" , gInstance.get()); } } while (0); |
| 1296 | |
| 1297 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1298 | if (!ioMan) { |
| 1299 | // CacheFileIOManager::Init() failed, probably could not create the IO |
| 1300 | // thread, just go with it... |
| 1301 | return NS_ERROR_NOT_INITIALIZED; |
| 1302 | } |
| 1303 | |
| 1304 | nsresult rv; |
| 1305 | |
| 1306 | nsCOMPtr<nsIFile> directory; |
| 1307 | |
| 1308 | CacheObserver::ParentDirOverride(getter_AddRefs(directory)); |
| 1309 | |
| 1310 | #if defined(MOZ_WIDGET_ANDROID) |
| 1311 | nsCOMPtr<nsIFile> profilelessDirectory; |
| 1312 | char* cachePath = getenv("CACHE_DIRECTORY"); |
| 1313 | if (!directory && cachePath && *cachePath) { |
| 1314 | rv = NS_NewNativeLocalFile(nsDependentCString(cachePath), |
| 1315 | getter_AddRefs(directory)); |
| 1316 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1317 | // Save this directory as the profileless path. |
| 1318 | rv = directory->Clone(getter_AddRefs(profilelessDirectory)); |
| 1319 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1319); return rv; } } while (false); |
| 1320 | |
| 1321 | // Add profile leaf name to the directory name to distinguish |
| 1322 | // multiple profiles Fennec supports. |
| 1323 | nsCOMPtr<nsIFile> profD; |
| 1324 | rv = NS_GetSpecialDirectory(NS_APP_USER_PROFILE_50_DIR"ProfD", |
| 1325 | getter_AddRefs(profD)); |
| 1326 | |
| 1327 | nsAutoCString leafName; |
| 1328 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1329 | rv = profD->GetNativeLeafName(leafName); |
| 1330 | } |
| 1331 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1332 | rv = directory->AppendNative(leafName); |
| 1333 | } |
| 1334 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 1335 | directory = nullptr; |
| 1336 | } |
| 1337 | } |
| 1338 | } |
| 1339 | #endif |
| 1340 | |
| 1341 | if (!directory) { |
| 1342 | rv = NS_GetSpecialDirectory(NS_APP_CACHE_PARENT_DIR"cachePDir", |
| 1343 | getter_AddRefs(directory)); |
| 1344 | } |
| 1345 | |
| 1346 | if (!directory) { |
| 1347 | rv = NS_GetSpecialDirectory(NS_APP_USER_PROFILE_LOCAL_50_DIR"ProfLD", |
| 1348 | getter_AddRefs(directory)); |
| 1349 | } |
| 1350 | |
| 1351 | if (directory) { |
| 1352 | rv = directory->Append(u"cache2"_ns); |
| 1353 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1353); return rv; } } while (false); |
| 1354 | } |
| 1355 | |
| 1356 | // All functions return a clone. |
| 1357 | ioMan->mCacheDirectory.swap(directory); |
| 1358 | |
| 1359 | #if defined(MOZ_WIDGET_ANDROID) |
| 1360 | if (profilelessDirectory) { |
| 1361 | rv = profilelessDirectory->Append(u"cache2"_ns); |
| 1362 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1362); return rv; } } while (false); |
| 1363 | } |
| 1364 | |
| 1365 | ioMan->mCacheProfilelessDirectory.swap(profilelessDirectory); |
| 1366 | #endif |
| 1367 | |
| 1368 | if (ioMan->mCacheDirectory) { |
| 1369 | CacheIndex::Init(ioMan->mCacheDirectory); |
| 1370 | } |
| 1371 | |
| 1372 | return NS_OK; |
| 1373 | } |
| 1374 | |
| 1375 | static bool inBackgroundTask() { |
| 1376 | MOZ_ASSERT(NS_IsMainThread(), "backgroundtasks are main thread only")do { static_assert( mozilla::detail::AssertionConditionType< decltype(NS_IsMainThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(NS_IsMainThread()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("NS_IsMainThread()" " (" "backgroundtasks are main thread only" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1376); AnnotateMozCrashReason("MOZ_ASSERT" "(" "NS_IsMainThread()" ") (" "backgroundtasks are main thread only" ")"); do { *((volatile int*)__null) = 1376; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); |
| 1377 | #if defined(MOZ_BACKGROUNDTASKS1) |
| 1378 | nsCOMPtr<nsIBackgroundTasks> backgroundTaskService = |
| 1379 | do_GetService("@mozilla.org/backgroundtasks;1"); |
| 1380 | if (!backgroundTaskService) { |
| 1381 | return false; |
| 1382 | } |
| 1383 | bool isBackgroundTask = false; |
| 1384 | backgroundTaskService->GetIsBackgroundTaskMode(&isBackgroundTask); |
| 1385 | return isBackgroundTask; |
| 1386 | #else |
| 1387 | return false; |
| 1388 | #endif |
| 1389 | } |
| 1390 | |
| 1391 | // static |
| 1392 | nsresult CacheFileIOManager::OnDelayedStartupFinished() { |
| 1393 | // If we don't clear the cache at shutdown, or we don't use a |
| 1394 | // background task then there's no need to dispatch a cleanup task |
| 1395 | // at startup |
| 1396 | if (!CacheObserver::ClearCacheOnShutdown()) { |
| 1397 | return NS_OK; |
| 1398 | } |
| 1399 | if (!StaticPrefs::network_cache_shutdown_purge_in_background_task()) { |
| 1400 | return NS_OK; |
| 1401 | } |
| 1402 | |
| 1403 | // If this is a background task already, there's no need to |
| 1404 | // dispatch another one. |
| 1405 | if (inBackgroundTask()) { |
| 1406 | return NS_OK; |
| 1407 | } |
| 1408 | |
| 1409 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1410 | nsCOMPtr<nsIEventTarget> target = IOTarget(); |
| 1411 | if (NS_WARN_IF(!ioMan || !target)NS_warn_if_impl(!ioMan || !target, "!ioMan || !target", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1411)) { |
| 1412 | return NS_ERROR_NOT_AVAILABLE; |
| 1413 | } |
| 1414 | |
| 1415 | return target->Dispatch( |
| 1416 | NS_NewRunnableFunction("CacheFileIOManager::OnDelayedStartupFinished", |
| 1417 | [ioMan = std::move(ioMan)] { |
| 1418 | ioMan->DispatchPurgeTask(""_ns, "0"_ns, |
| 1419 | kPurgeExtension); |
| 1420 | }), |
| 1421 | nsIEventTarget::DISPATCH_NORMAL); |
| 1422 | } |
| 1423 | |
| 1424 | // static |
| 1425 | nsresult CacheFileIOManager::OnIdleDaily() { |
| 1426 | // In case the background task process fails for some reason (bug 1848542) |
| 1427 | // We will remove the directories in the main process on a daily idle. |
| 1428 | if (!CacheObserver::ClearCacheOnShutdown()) { |
| 1429 | return NS_OK; |
| 1430 | } |
| 1431 | if (!StaticPrefs::network_cache_shutdown_purge_in_background_task()) { |
| 1432 | return NS_OK; |
| 1433 | } |
| 1434 | |
| 1435 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1436 | nsCOMPtr<nsIFile> parentDir; |
| 1437 | nsresult rv = ioMan->mCacheDirectory->GetParent(getter_AddRefs(parentDir)); |
| 1438 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0))) || !parentDir) { |
| 1439 | return NS_OK; |
| 1440 | } |
| 1441 | |
| 1442 | NS_DispatchBackgroundTask( |
| 1443 | NS_NewRunnableFunction( |
| 1444 | "CacheFileIOManager::CheckLeftoverFolders", |
| 1445 | [dir = std::move(parentDir)] { |
| 1446 | nsCOMPtr<nsIDirectoryEnumerator> directories; |
| 1447 | nsresult rv = dir->GetDirectoryEntries(getter_AddRefs(directories)); |
| 1448 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 1449 | return; |
| 1450 | } |
| 1451 | bool hasMoreElements = false; |
| 1452 | while ( |
| 1453 | NS_SUCCEEDED(directories->HasMoreElements(&hasMoreElements))((bool)(__builtin_expect(!!(!NS_FAILED_impl(directories->HasMoreElements (&hasMoreElements))), 1))) && |
| 1454 | hasMoreElements) { |
| 1455 | nsCOMPtr<nsIFile> subdir; |
| 1456 | rv = directories->GetNextFile(getter_AddRefs(subdir)); |
| 1457 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0))) || !subdir) { |
| 1458 | break; |
| 1459 | } |
| 1460 | nsAutoCString leafName; |
| 1461 | rv = subdir->GetNativeLeafName(leafName); |
| 1462 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 1463 | continue; |
| 1464 | } |
| 1465 | if (leafName.Find(kPurgeExtension) != kNotFound) { |
| 1466 | mozilla::glean::networking::residual_cache_folder_count.Add(1); |
| 1467 | rv = subdir->Remove(true); |
| 1468 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1469 | mozilla::glean::networking::residual_cache_folder_removal |
| 1470 | .Get("success"_ns) |
| 1471 | .Add(1); |
| 1472 | } else { |
| 1473 | mozilla::glean::networking::residual_cache_folder_removal |
| 1474 | .Get("failure"_ns) |
| 1475 | .Add(1); |
| 1476 | } |
| 1477 | } |
| 1478 | } |
| 1479 | |
| 1480 | return; |
| 1481 | }), |
| 1482 | NS_DISPATCH_EVENT_MAY_BLOCKnsIEventTarget::DISPATCH_EVENT_MAY_BLOCK); |
| 1483 | |
| 1484 | return NS_OK; |
| 1485 | } |
| 1486 | |
| 1487 | // static |
| 1488 | already_AddRefed<nsIEventTarget> CacheFileIOManager::IOTarget() { |
| 1489 | nsCOMPtr<nsIEventTarget> target; |
| 1490 | if (gInstance && gInstance->mIOThread) { |
| 1491 | target = gInstance->mIOThread->Target(); |
| 1492 | } |
| 1493 | |
| 1494 | return target.forget(); |
| 1495 | } |
| 1496 | |
| 1497 | // static |
| 1498 | already_AddRefed<CacheIOThread> CacheFileIOManager::IOThread() { |
| 1499 | RefPtr<CacheIOThread> thread; |
| 1500 | if (gInstance) { |
| 1501 | thread = gInstance->mIOThread; |
| 1502 | } |
| 1503 | |
| 1504 | return thread.forget(); |
| 1505 | } |
| 1506 | |
| 1507 | // static |
| 1508 | bool CacheFileIOManager::IsOnIOThread() { |
| 1509 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1510 | if (ioMan && ioMan->mIOThread) { |
| 1511 | return ioMan->mIOThread->IsCurrentThread(); |
| 1512 | } |
| 1513 | |
| 1514 | return false; |
| 1515 | } |
| 1516 | |
| 1517 | // static |
| 1518 | bool CacheFileIOManager::IsOnIOThreadOrCeased() { |
| 1519 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1520 | if (ioMan && ioMan->mIOThread) { |
| 1521 | return ioMan->mIOThread->IsCurrentThread(); |
| 1522 | } |
| 1523 | |
| 1524 | // Ceased... |
| 1525 | return true; |
| 1526 | } |
| 1527 | |
| 1528 | // static |
| 1529 | bool CacheFileIOManager::IsShutdown() { |
| 1530 | if (!gInstance) { |
| 1531 | return true; |
| 1532 | } |
| 1533 | return gInstance->mShuttingDown; |
| 1534 | } |
| 1535 | |
| 1536 | // static |
| 1537 | nsresult CacheFileIOManager::ScheduleMetadataWrite(CacheFile* aFile) { |
| 1538 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1539 | NS_ENSURE_TRUE(ioMan, NS_ERROR_NOT_INITIALIZED)do { if ((__builtin_expect(!!(!(ioMan)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "ioMan" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1539); return NS_ERROR_NOT_INITIALIZED; } } while (false); |
| 1540 | |
| 1541 | NS_ENSURE_TRUE(!ioMan->mShuttingDown, NS_ERROR_NOT_INITIALIZED)do { if ((__builtin_expect(!!(!(!ioMan->mShuttingDown)), 0 ))) { NS_DebugBreak(NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "!ioMan->mShuttingDown" ") failed", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1541); return NS_ERROR_NOT_INITIALIZED; } } while (false); |
| 1542 | |
| 1543 | RefPtr<MetadataWriteScheduleEvent> event = new MetadataWriteScheduleEvent( |
| 1544 | ioMan, aFile, MetadataWriteScheduleEvent::SCHEDULE); |
| 1545 | nsCOMPtr<nsIEventTarget> target = ioMan->IOTarget(); |
| 1546 | NS_ENSURE_TRUE(target, NS_ERROR_UNEXPECTED)do { if ((__builtin_expect(!!(!(target)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "target" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1546); return NS_ERROR_UNEXPECTED; } } while (false); |
| 1547 | return target->Dispatch(event, nsIEventTarget::DISPATCH_NORMAL); |
| 1548 | } |
| 1549 | |
| 1550 | nsresult CacheFileIOManager::ScheduleMetadataWriteInternal(CacheFile* aFile) { |
| 1551 | MOZ_ASSERT(IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(IsOnIOThreadOrCeased())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(IsOnIOThreadOrCeased()))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1551); AnnotateMozCrashReason("MOZ_ASSERT" "(" "IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 1551; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1552 | |
| 1553 | nsresult rv; |
| 1554 | |
| 1555 | if (!mMetadataWritesTimer) { |
| 1556 | rv = NS_NewTimerWithCallback(getter_AddRefs(mMetadataWritesTimer), this, |
| 1557 | kMetadataWriteDelay5000, nsITimer::TYPE_ONE_SHOT); |
| 1558 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1558); return rv; } } while (false); |
| 1559 | } |
| 1560 | |
| 1561 | if (mScheduledMetadataWrites.IndexOf(aFile) != |
| 1562 | nsTArray<RefPtr<mozilla::net::CacheFile>>::NoIndex) { |
| 1563 | return NS_OK; |
| 1564 | } |
| 1565 | |
| 1566 | mScheduledMetadataWrites.AppendElement(aFile); |
| 1567 | |
| 1568 | return NS_OK; |
| 1569 | } |
| 1570 | |
| 1571 | // static |
| 1572 | nsresult CacheFileIOManager::UnscheduleMetadataWrite(CacheFile* aFile) { |
| 1573 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1574 | NS_ENSURE_TRUE(ioMan, NS_ERROR_NOT_INITIALIZED)do { if ((__builtin_expect(!!(!(ioMan)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "ioMan" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1574); return NS_ERROR_NOT_INITIALIZED; } } while (false); |
| 1575 | |
| 1576 | NS_ENSURE_TRUE(!ioMan->mShuttingDown, NS_ERROR_NOT_INITIALIZED)do { if ((__builtin_expect(!!(!(!ioMan->mShuttingDown)), 0 ))) { NS_DebugBreak(NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "!ioMan->mShuttingDown" ") failed", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1576); return NS_ERROR_NOT_INITIALIZED; } } while (false); |
| 1577 | |
| 1578 | RefPtr<MetadataWriteScheduleEvent> event = new MetadataWriteScheduleEvent( |
| 1579 | ioMan, aFile, MetadataWriteScheduleEvent::UNSCHEDULE); |
| 1580 | nsCOMPtr<nsIEventTarget> target = ioMan->IOTarget(); |
| 1581 | NS_ENSURE_TRUE(target, NS_ERROR_UNEXPECTED)do { if ((__builtin_expect(!!(!(target)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "target" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1581); return NS_ERROR_UNEXPECTED; } } while (false); |
| 1582 | return target->Dispatch(event, nsIEventTarget::DISPATCH_NORMAL); |
| 1583 | } |
| 1584 | |
| 1585 | void CacheFileIOManager::UnscheduleMetadataWriteInternal(CacheFile* aFile) { |
| 1586 | MOZ_ASSERT(IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(IsOnIOThreadOrCeased())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(IsOnIOThreadOrCeased()))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1586); AnnotateMozCrashReason("MOZ_ASSERT" "(" "IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 1586; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1587 | |
| 1588 | mScheduledMetadataWrites.RemoveElement(aFile); |
| 1589 | |
| 1590 | if (mScheduledMetadataWrites.Length() == 0 && mMetadataWritesTimer) { |
| 1591 | mMetadataWritesTimer->Cancel(); |
| 1592 | mMetadataWritesTimer = nullptr; |
| 1593 | } |
| 1594 | } |
| 1595 | |
| 1596 | // static |
| 1597 | nsresult CacheFileIOManager::ShutdownMetadataWriteScheduling() { |
| 1598 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1599 | NS_ENSURE_TRUE(ioMan, NS_ERROR_NOT_INITIALIZED)do { if ((__builtin_expect(!!(!(ioMan)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "ioMan" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1599); return NS_ERROR_NOT_INITIALIZED; } } while (false); |
| 1600 | |
| 1601 | RefPtr<MetadataWriteScheduleEvent> event = new MetadataWriteScheduleEvent( |
| 1602 | ioMan, nullptr, MetadataWriteScheduleEvent::SHUTDOWN); |
| 1603 | nsCOMPtr<nsIEventTarget> target = ioMan->IOTarget(); |
| 1604 | NS_ENSURE_TRUE(target, NS_ERROR_UNEXPECTED)do { if ((__builtin_expect(!!(!(target)), 0))) { NS_DebugBreak (NS_DEBUG_WARNING, "NS_ENSURE_TRUE(" "target" ") failed", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1604); return NS_ERROR_UNEXPECTED; } } while (false); |
| 1605 | return target->Dispatch(event, nsIEventTarget::DISPATCH_NORMAL); |
| 1606 | } |
| 1607 | |
| 1608 | void CacheFileIOManager::ShutdownMetadataWriteSchedulingInternal() { |
| 1609 | MOZ_ASSERT(IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(IsOnIOThreadOrCeased())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(IsOnIOThreadOrCeased()))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1609); AnnotateMozCrashReason("MOZ_ASSERT" "(" "IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 1609; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1610 | |
| 1611 | nsTArray<RefPtr<CacheFile>> files = std::move(mScheduledMetadataWrites); |
| 1612 | for (uint32_t i = 0; i < files.Length(); ++i) { |
| 1613 | CacheFile* file = files[i]; |
| 1614 | file->WriteMetadataIfNeeded(); |
| 1615 | } |
| 1616 | |
| 1617 | if (mMetadataWritesTimer) { |
| 1618 | mMetadataWritesTimer->Cancel(); |
| 1619 | mMetadataWritesTimer = nullptr; |
| 1620 | } |
| 1621 | } |
| 1622 | |
| 1623 | NS_IMETHODIMPnsresult |
| 1624 | CacheFileIOManager::Notify(nsITimer* aTimer) { |
| 1625 | MOZ_ASSERT(IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(IsOnIOThreadOrCeased())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(IsOnIOThreadOrCeased()))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1625); AnnotateMozCrashReason("MOZ_ASSERT" "(" "IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 1625; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1626 | MOZ_ASSERT(mMetadataWritesTimer == aTimer)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mMetadataWritesTimer == aTimer)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mMetadataWritesTimer == aTimer ))), 0))) { do { } while (false); MOZ_ReportAssertionFailure( "mMetadataWritesTimer == aTimer", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1626); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mMetadataWritesTimer == aTimer" ")"); do { *((volatile int*)__null) = 1626; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1627 | |
| 1628 | mMetadataWritesTimer = nullptr; |
| 1629 | |
| 1630 | nsTArray<RefPtr<CacheFile>> files = std::move(mScheduledMetadataWrites); |
| 1631 | for (uint32_t i = 0; i < files.Length(); ++i) { |
| 1632 | CacheFile* file = files[i]; |
| 1633 | file->WriteMetadataIfNeeded(); |
| 1634 | } |
| 1635 | |
| 1636 | return NS_OK; |
| 1637 | } |
| 1638 | |
| 1639 | NS_IMETHODIMPnsresult |
| 1640 | CacheFileIOManager::GetName(nsACString& aName) { |
| 1641 | aName.AssignLiteral("CacheFileIOManager"); |
| 1642 | return NS_OK; |
| 1643 | } |
| 1644 | |
| 1645 | // static |
| 1646 | nsresult CacheFileIOManager::OpenFile(const nsACString& aKey, uint32_t aFlags, |
| 1647 | CacheFileIOListener* aCallback) { |
| 1648 | LOG(("CacheFileIOManager::OpenFile() [key=%s, flags=%d, listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFile() [key=%s, flags=%d, listener=%p]" , TPromiseFlatString<char>(aKey).get(), aFlags, aCallback ); } } while (0) |
| 1649 | PromiseFlatCString(aKey).get(), aFlags, aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFile() [key=%s, flags=%d, listener=%p]" , TPromiseFlatString<char>(aKey).get(), aFlags, aCallback ); } } while (0); |
| 1650 | |
| 1651 | nsresult rv; |
| 1652 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1653 | |
| 1654 | if (!ioMan) { |
| 1655 | return NS_ERROR_NOT_INITIALIZED; |
| 1656 | } |
| 1657 | |
| 1658 | bool priority = aFlags & CacheFileIOManager::PRIORITY; |
| 1659 | RefPtr<OpenFileEvent> ev = new OpenFileEvent(aKey, aFlags, aCallback); |
| 1660 | rv = ioMan->mIOThread->Dispatch( |
| 1661 | ev, priority ? CacheIOThread::OPEN_PRIORITY : CacheIOThread::OPEN); |
| 1662 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1662); return rv; } } while (false); |
| 1663 | |
| 1664 | return NS_OK; |
| 1665 | } |
| 1666 | |
| 1667 | nsresult CacheFileIOManager::OpenFileInternal(const SHA1Sum::Hash* aHash, |
| 1668 | const nsACString& aKey, |
| 1669 | uint32_t aFlags, |
| 1670 | CacheFileHandle** _retval) { |
| 1671 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() [hash=%08x%08x%08x%08x%08x, " "key=%s, flags=%d]", PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[4]), TPromiseFlatString<char>(aKey).get() , aFlags); } } while (0) |
| 1672 | ("CacheFileIOManager::OpenFileInternal() [hash=%08x%08x%08x%08x%08x, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() [hash=%08x%08x%08x%08x%08x, " "key=%s, flags=%d]", PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[4]), TPromiseFlatString<char>(aKey).get() , aFlags); } } while (0) |
| 1673 | "key=%s, flags=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() [hash=%08x%08x%08x%08x%08x, " "key=%s, flags=%d]", PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[4]), TPromiseFlatString<char>(aKey).get() , aFlags); } } while (0) |
| 1674 | LOGSHA1(aHash), PromiseFlatCString(aKey).get(), aFlags))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() [hash=%08x%08x%08x%08x%08x, " "key=%s, flags=%d]", PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[0]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[1]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(aHash))[4]), TPromiseFlatString<char>(aKey).get() , aFlags); } } while (0); |
| 1675 | |
| 1676 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsOnIOThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsOnIOThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1676); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThread()" ")"); do { *((volatile int*)__null) = 1676; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1677 | |
| 1678 | nsresult rv; |
| 1679 | |
| 1680 | if (mShuttingDown) { |
| 1681 | return NS_ERROR_NOT_INITIALIZED; |
| 1682 | } |
| 1683 | |
| 1684 | CacheIOThread::Cancelable cancelable( |
| 1685 | true /* never called for special handles */); |
| 1686 | |
| 1687 | if (!mTreeCreated) { |
| 1688 | rv = CreateCacheTree(); |
| 1689 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) return rv; |
| 1690 | } |
| 1691 | |
| 1692 | CacheFileHandle::PinningStatus pinning = |
| 1693 | aFlags & PINNED ? CacheFileHandle::PinningStatus::PINNED |
| 1694 | : CacheFileHandle::PinningStatus::NON_PINNED; |
| 1695 | |
| 1696 | nsCOMPtr<nsIFile> file; |
| 1697 | rv = GetFile(aHash, getter_AddRefs(file)); |
| 1698 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1698); return rv; } } while (false); |
| 1699 | |
| 1700 | RefPtr<CacheFileHandle> handle; |
| 1701 | mHandles.GetHandle(aHash, getter_AddRefs(handle)); |
| 1702 | |
| 1703 | if ((aFlags & (OPEN | CREATE | CREATE_NEW)) == CREATE_NEW) { |
| 1704 | if (handle) { |
| 1705 | rv = DoomFileInternal(handle); |
| 1706 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1706); return rv; } } while (false); |
| 1707 | handle = nullptr; |
| 1708 | } |
| 1709 | |
| 1710 | handle = mHandles.NewHandle(aHash, aFlags & PRIORITY, pinning); |
| 1711 | |
| 1712 | bool exists; |
| 1713 | rv = file->Exists(&exists); |
| 1714 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1714); return rv; } } while (false); |
| 1715 | |
| 1716 | if (exists) { |
| 1717 | CacheIndex::RemoveEntry(aHash); |
| 1718 | |
| 1719 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file from " "disk"); } } while (0) |
| 1720 | ("CacheFileIOManager::OpenFileInternal() - Removing old file from "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file from " "disk"); } } while (0) |
| 1721 | "disk"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file from " "disk"); } } while (0); |
| 1722 | rv = file->Remove(false); |
| 1723 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 1724 | NS_WARNING("Cannot remove old entry from the disk")NS_DebugBreak(NS_DEBUG_WARNING, "Cannot remove old entry from the disk" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1724); |
| 1725 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 1726 | ("CacheFileIOManager::OpenFileInternal() - Removing old file failed"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 1727 | ". [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 1728 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 1729 | } |
| 1730 | } |
| 1731 | |
| 1732 | CacheIndex::AddEntry(aHash); |
| 1733 | handle->mFile.swap(file); |
| 1734 | handle->mFileSize = 0; |
| 1735 | } |
| 1736 | |
| 1737 | if (handle) { |
| 1738 | handle.swap(*_retval); |
| 1739 | return NS_OK; |
| 1740 | } |
| 1741 | |
| 1742 | bool exists, evictedAsPinned = false, evictedAsNonPinned = false; |
| 1743 | rv = file->Exists(&exists); |
| 1744 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1744); return rv; } } while (false); |
| 1745 | |
| 1746 | if (exists && mContextEvictor) { |
| 1747 | if (mContextEvictor->ContextsCount() == 0) { |
| 1748 | mContextEvictor = nullptr; |
| 1749 | } else { |
| 1750 | mContextEvictor->WasEvicted(aKey, file, &evictedAsPinned, |
| 1751 | &evictedAsNonPinned); |
| 1752 | } |
| 1753 | } |
| 1754 | |
| 1755 | if (!exists && (aFlags & (OPEN | CREATE | CREATE_NEW)) == OPEN) { |
| 1756 | return NS_ERROR_NOT_AVAILABLE; |
| 1757 | } |
| 1758 | |
| 1759 | if (exists) { |
| 1760 | // For existing files we determine the pinning status later, after the |
| 1761 | // metadata gets parsed. |
| 1762 | pinning = CacheFileHandle::PinningStatus::UNKNOWN; |
| 1763 | } |
| 1764 | |
| 1765 | handle = mHandles.NewHandle(aHash, aFlags & PRIORITY, pinning); |
| 1766 | if (exists) { |
| 1767 | // If this file has been found evicted through the context file evictor |
| 1768 | // above for any of pinned or non-pinned state, these calls ensure we doom |
| 1769 | // the handle ASAP we know the real pinning state after metadta has been |
| 1770 | // parsed. DoomFileInternal on the |handle| doesn't doom right now, since |
| 1771 | // the pinning state is unknown and we pass down a pinning restriction. |
| 1772 | if (evictedAsPinned) { |
| 1773 | rv = DoomFileInternal(handle, DOOM_WHEN_PINNED); |
| 1774 | MOZ_ASSERT(!handle->IsDoomed() && NS_SUCCEEDED(rv))do { static_assert( mozilla::detail::AssertionConditionType< decltype(!handle->IsDoomed() && ((bool)(__builtin_expect (!!(!NS_FAILED_impl(rv)), 1))))>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1774); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" ")"); do { *((volatile int*)__null) = 1774; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1775 | } |
| 1776 | if (evictedAsNonPinned) { |
| 1777 | rv = DoomFileInternal(handle, DOOM_WHEN_NON_PINNED); |
| 1778 | MOZ_ASSERT(!handle->IsDoomed() && NS_SUCCEEDED(rv))do { static_assert( mozilla::detail::AssertionConditionType< decltype(!handle->IsDoomed() && ((bool)(__builtin_expect (!!(!NS_FAILED_impl(rv)), 1))))>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1778); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!handle->IsDoomed() && ((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))" ")"); do { *((volatile int*)__null) = 1778; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1779 | } |
| 1780 | |
| 1781 | int64_t fileSize = -1; |
| 1782 | rv = file->GetFileSize(&fileSize); |
| 1783 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1783); return rv; } } while (false); |
| 1784 | |
| 1785 | handle->mFileSize = fileSize; |
| 1786 | handle->mFileExists = true; |
| 1787 | |
| 1788 | CacheIndex::EnsureEntryExists(aHash); |
| 1789 | } else { |
| 1790 | handle->mFileSize = 0; |
| 1791 | |
| 1792 | CacheIndex::AddEntry(aHash); |
| 1793 | } |
| 1794 | |
| 1795 | handle->mFile.swap(file); |
| 1796 | handle.swap(*_retval); |
| 1797 | return NS_OK; |
| 1798 | } |
| 1799 | |
| 1800 | nsresult CacheFileIOManager::OpenSpecialFileInternal( |
| 1801 | const nsACString& aKey, uint32_t aFlags, CacheFileHandle** _retval) { |
| 1802 | LOG(("CacheFileIOManager::OpenSpecialFileInternal() [key=%s, flags=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() [key=%s, flags=%d]" , TPromiseFlatString<char>(aKey).get(), aFlags); } } while (0) |
| 1803 | PromiseFlatCString(aKey).get(), aFlags))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() [key=%s, flags=%d]" , TPromiseFlatString<char>(aKey).get(), aFlags); } } while (0); |
| 1804 | |
| 1805 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsOnIOThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsOnIOThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1805); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThread()" ")"); do { *((volatile int*)__null) = 1805; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1806 | |
| 1807 | nsresult rv; |
| 1808 | |
| 1809 | if (mShuttingDown) { |
| 1810 | return NS_ERROR_NOT_INITIALIZED; |
| 1811 | } |
| 1812 | |
| 1813 | if (!mTreeCreated) { |
| 1814 | rv = CreateCacheTree(); |
| 1815 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) return rv; |
| 1816 | } |
| 1817 | |
| 1818 | nsCOMPtr<nsIFile> file; |
| 1819 | rv = GetSpecialFile(aKey, getter_AddRefs(file)); |
| 1820 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1820); return rv; } } while (false); |
| 1821 | |
| 1822 | RefPtr<CacheFileHandle> handle; |
| 1823 | for (uint32_t i = 0; i < mSpecialHandles.Length(); i++) { |
| 1824 | if (!mSpecialHandles[i]->IsDoomed() && mSpecialHandles[i]->Key() == aKey) { |
| 1825 | handle = mSpecialHandles[i]; |
| 1826 | break; |
| 1827 | } |
| 1828 | } |
| 1829 | |
| 1830 | if ((aFlags & (OPEN | CREATE | CREATE_NEW)) == CREATE_NEW) { |
| 1831 | if (handle) { |
| 1832 | rv = DoomFileInternal(handle); |
| 1833 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1833); return rv; } } while (false); |
| 1834 | handle = nullptr; |
| 1835 | } |
| 1836 | |
| 1837 | handle = new CacheFileHandle(aKey, aFlags & PRIORITY, |
| 1838 | CacheFileHandle::PinningStatus::NON_PINNED); |
| 1839 | mSpecialHandles.AppendElement(handle); |
| 1840 | |
| 1841 | bool exists; |
| 1842 | rv = file->Exists(&exists); |
| 1843 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1843); return rv; } } while (false); |
| 1844 | |
| 1845 | if (exists) { |
| 1846 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file from " "disk"); } } while (0) |
| 1847 | ("CacheFileIOManager::OpenSpecialFileInternal() - Removing file from "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file from " "disk"); } } while (0) |
| 1848 | "disk"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file from " "disk"); } } while (0); |
| 1849 | rv = file->Remove(false); |
| 1850 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 1851 | NS_WARNING("Cannot remove old entry from the disk")NS_DebugBreak(NS_DEBUG_WARNING, "Cannot remove old entry from the disk" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1851); |
| 1852 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file " "failed. [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 1853 | ("CacheFileIOManager::OpenSpecialFileInternal() - Removing file "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file " "failed. [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 1854 | "failed. [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file " "failed. [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 1855 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenSpecialFileInternal() - Removing file " "failed. [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0); |
| 1856 | } |
| 1857 | } |
| 1858 | |
| 1859 | handle->mFile.swap(file); |
| 1860 | handle->mFileSize = 0; |
| 1861 | } |
| 1862 | |
| 1863 | if (handle) { |
| 1864 | handle.swap(*_retval); |
| 1865 | return NS_OK; |
| 1866 | } |
| 1867 | |
| 1868 | bool exists; |
| 1869 | rv = file->Exists(&exists); |
| 1870 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1870); return rv; } } while (false); |
| 1871 | |
| 1872 | if (!exists && (aFlags & (OPEN | CREATE | CREATE_NEW)) == OPEN) { |
| 1873 | return NS_ERROR_NOT_AVAILABLE; |
| 1874 | } |
| 1875 | |
| 1876 | handle = new CacheFileHandle(aKey, aFlags & PRIORITY, |
| 1877 | CacheFileHandle::PinningStatus::NON_PINNED); |
| 1878 | mSpecialHandles.AppendElement(handle); |
| 1879 | |
| 1880 | if (exists) { |
| 1881 | int64_t fileSize = -1; |
| 1882 | rv = file->GetFileSize(&fileSize); |
| 1883 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1883); return rv; } } while (false); |
| 1884 | |
| 1885 | handle->mFileSize = fileSize; |
| 1886 | handle->mFileExists = true; |
| 1887 | } else { |
| 1888 | handle->mFileSize = 0; |
| 1889 | } |
| 1890 | |
| 1891 | handle->mFile.swap(file); |
| 1892 | handle.swap(*_retval); |
| 1893 | return NS_OK; |
| 1894 | } |
| 1895 | |
| 1896 | void CacheFileIOManager::CloseHandleInternal(CacheFileHandle* aHandle) { |
| 1897 | nsresult rv; |
| 1898 | LOG(("CacheFileIOManager::CloseHandleInternal() [handle=%p]", aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CloseHandleInternal() [handle=%p]" , aHandle); } } while (0); |
| 1899 | |
| 1900 | MOZ_ASSERT(!aHandle->IsClosed())do { static_assert( mozilla::detail::AssertionConditionType< decltype(!aHandle->IsClosed())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!aHandle->IsClosed()))), 0 ))) { do { } while (false); MOZ_ReportAssertionFailure("!aHandle->IsClosed()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1900); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!aHandle->IsClosed()" ")"); do { *((volatile int*)__null) = 1900; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1901 | |
| 1902 | aHandle->Log(); |
| 1903 | |
| 1904 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1904); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 1904; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 1905 | |
| 1906 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 1907 | |
| 1908 | // Maybe close file handle (can be legally bypassed after shutdown) |
| 1909 | rv = MaybeReleaseNSPRHandleInternal(aHandle); |
| 1910 | |
| 1911 | // Delete the file if the entry was doomed or invalid and |
| 1912 | // filedesc properly closed |
| 1913 | if ((aHandle->mIsDoomed || aHandle->mInvalid) && aHandle->mFileExists && |
| 1914 | NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1915 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CloseHandleInternal() - Removing file from " "disk"); } } while (0) |
| 1916 | ("CacheFileIOManager::CloseHandleInternal() - Removing file from "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CloseHandleInternal() - Removing file from " "disk"); } } while (0) |
| 1917 | "disk"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CloseHandleInternal() - Removing file from " "disk"); } } while (0); |
| 1918 | |
| 1919 | rv = aHandle->mFile->Remove(false); |
| 1920 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 1921 | aHandle->mFileExists = false; |
| 1922 | } else { |
| 1923 | LOG((" failed to remove the file [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " failed to remove the file [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 1924 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " failed to remove the file [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 1925 | } |
| 1926 | } |
| 1927 | |
| 1928 | if (!aHandle->IsSpecialFile() && !aHandle->mIsDoomed && |
| 1929 | (aHandle->mInvalid || !aHandle->mFileExists)) { |
| 1930 | CacheIndex::RemoveEntry(aHandle->Hash()); |
| 1931 | } |
| 1932 | |
| 1933 | // Don't remove handles after shutdown |
| 1934 | if (!mShuttingDown) { |
| 1935 | if (aHandle->IsSpecialFile()) { |
| 1936 | mSpecialHandles.RemoveElement(aHandle); |
| 1937 | } else { |
| 1938 | mHandles.RemoveHandle(aHandle); |
| 1939 | } |
| 1940 | } |
| 1941 | } |
| 1942 | |
| 1943 | // static |
| 1944 | nsresult CacheFileIOManager::Read(CacheFileHandle* aHandle, int64_t aOffset, |
| 1945 | char* aBuf, int32_t aCount, |
| 1946 | CacheFileIOListener* aCallback) { |
| 1947 | LOG(("CacheFileIOManager::Read() [handle=%p, offset=%" PRId64 ", count=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Read() [handle=%p, offset=%" "l" "d" ", count=%d, " "listener=%p]", aHandle, aOffset, aCount , aCallback); } } while (0) |
| 1948 | "listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Read() [handle=%p, offset=%" "l" "d" ", count=%d, " "listener=%p]", aHandle, aOffset, aCount , aCallback); } } while (0) |
| 1949 | aHandle, aOffset, aCount, aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Read() [handle=%p, offset=%" "l" "d" ", count=%d, " "listener=%p]", aHandle, aOffset, aCount , aCallback); } } while (0); |
| 1950 | |
| 1951 | if (CacheObserver::ShuttingDown()) { |
| 1952 | LOG((" no reads after shutdown"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " no reads after shutdown" ); } } while (0); |
| 1953 | return NS_ERROR_NOT_INITIALIZED; |
| 1954 | } |
| 1955 | |
| 1956 | nsresult rv; |
| 1957 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 1958 | |
| 1959 | if (aHandle->IsClosed() || !ioMan) { |
| 1960 | return NS_ERROR_NOT_INITIALIZED; |
| 1961 | } |
| 1962 | |
| 1963 | RefPtr<ReadEvent> ev = |
| 1964 | new ReadEvent(aHandle, aOffset, aBuf, aCount, aCallback); |
| 1965 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->IsPriority() |
| 1966 | ? CacheIOThread::READ_PRIORITY |
| 1967 | : CacheIOThread::READ); |
| 1968 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1968); return rv; } } while (false); |
| 1969 | |
| 1970 | return NS_OK; |
| 1971 | } |
| 1972 | |
| 1973 | nsresult CacheFileIOManager::ReadInternal(CacheFileHandle* aHandle, |
| 1974 | int64_t aOffset, char* aBuf, |
| 1975 | int32_t aCount) { |
| 1976 | LOG(("CacheFileIOManager::ReadInternal() [handle=%p, offset=%" PRId64do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::ReadInternal() [handle=%p, offset=%" "l" "d" ", count=%d]", aHandle, aOffset, aCount); } } while ( 0) |
| 1977 | ", count=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::ReadInternal() [handle=%p, offset=%" "l" "d" ", count=%d]", aHandle, aOffset, aCount); } } while ( 0) |
| 1978 | aHandle, aOffset, aCount))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::ReadInternal() [handle=%p, offset=%" "l" "d" ", count=%d]", aHandle, aOffset, aCount); } } while ( 0); |
| 1979 | |
| 1980 | nsresult rv; |
| 1981 | |
| 1982 | if (CacheObserver::ShuttingDown()) { |
| 1983 | LOG((" no reads after shutdown"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " no reads after shutdown" ); } } while (0); |
| 1984 | return NS_ERROR_NOT_INITIALIZED; |
| 1985 | } |
| 1986 | |
| 1987 | if (!aHandle->mFileExists) { |
| 1988 | NS_WARNING("Trying to read from non-existent file")NS_DebugBreak(NS_DEBUG_WARNING, "Trying to read from non-existent file" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1988); |
| 1989 | return NS_ERROR_NOT_AVAILABLE; |
| 1990 | } |
| 1991 | |
| 1992 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 1993 | |
| 1994 | if (!aHandle->mFD) { |
| 1995 | rv = OpenNSPRHandle(aHandle); |
| 1996 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 1996); return rv; } } while (false); |
| 1997 | } else { |
| 1998 | NSPRHandleUsed(aHandle); |
| 1999 | } |
| 2000 | |
| 2001 | // Check again, OpenNSPRHandle could figure out the file was gone. |
| 2002 | if (!aHandle->mFileExists) { |
| 2003 | NS_WARNING("Trying to read from non-existent file")NS_DebugBreak(NS_DEBUG_WARNING, "Trying to read from non-existent file" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2003); |
| 2004 | return NS_ERROR_NOT_AVAILABLE; |
| 2005 | } |
| 2006 | |
| 2007 | int64_t offset = PR_Seek64(aHandle->mFD, aOffset, PR_SEEK_SET); |
| 2008 | if (offset == -1) { |
| 2009 | return NS_ERROR_FAILURE; |
| 2010 | } |
| 2011 | |
| 2012 | int32_t bytesRead = PR_Read(aHandle->mFD, aBuf, aCount); |
| 2013 | if (bytesRead != aCount) { |
| 2014 | return NS_ERROR_FAILURE; |
| 2015 | } |
| 2016 | |
| 2017 | return NS_OK; |
| 2018 | } |
| 2019 | |
| 2020 | // static |
| 2021 | nsresult CacheFileIOManager::Write(CacheFileHandle* aHandle, int64_t aOffset, |
| 2022 | const char* aBuf, int32_t aCount, |
| 2023 | bool aValidate, bool aTruncate, |
| 2024 | CacheFileIOListener* aCallback) { |
| 2025 | LOG(("CacheFileIOManager::Write() [handle=%p, offset=%" PRId64 ", count=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Write() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d, listener=%p]" , aHandle, aOffset, aCount, aValidate, aTruncate, aCallback); } } while (0) |
| 2026 | "validate=%d, truncate=%d, listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Write() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d, listener=%p]" , aHandle, aOffset, aCount, aValidate, aTruncate, aCallback); } } while (0) |
| 2027 | aHandle, aOffset, aCount, aValidate, aTruncate, aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::Write() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d, listener=%p]" , aHandle, aOffset, aCount, aValidate, aTruncate, aCallback); } } while (0); |
| 2028 | |
| 2029 | MOZ_ASSERT(aCallback)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aCallback)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aCallback))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("aCallback", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2029); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aCallback" ")" ); do { *((volatile int*)__null) = 2029; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2030 | |
| 2031 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2032 | |
| 2033 | if (aHandle->IsClosed() || aCallback->IsKilled() || !ioMan) { |
| 2034 | return NS_ERROR_NOT_INITIALIZED; |
| 2035 | } |
| 2036 | |
| 2037 | RefPtr<WriteEvent> ev = new WriteEvent(aHandle, aOffset, aBuf, aCount, |
| 2038 | aValidate, aTruncate, aCallback); |
| 2039 | return ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 2040 | ? CacheIOThread::WRITE_PRIORITY |
| 2041 | : CacheIOThread::WRITE); |
| 2042 | } |
| 2043 | |
| 2044 | // static |
| 2045 | nsresult CacheFileIOManager::WriteWithoutCallback(CacheFileHandle* aHandle, |
| 2046 | int64_t aOffset, char* aBuf, |
| 2047 | int32_t aCount, |
| 2048 | bool aValidate, |
| 2049 | bool aTruncate) { |
| 2050 | LOG(("CacheFileIOManager::WriteWithoutCallback() [handle=%p, offset=%" PRId64do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteWithoutCallback() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2051 | ", count=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteWithoutCallback() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2052 | "validate=%d, truncate=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteWithoutCallback() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2053 | aHandle, aOffset, aCount, aValidate, aTruncate))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteWithoutCallback() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0); |
| 2054 | |
| 2055 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2056 | |
| 2057 | if (aHandle->IsClosed() || !ioMan) { |
| 2058 | // When no callback is provided, CacheFileIOManager is responsible for |
| 2059 | // releasing the buffer. We must release it even in case of failure. |
| 2060 | free(aBuf); |
| 2061 | return NS_ERROR_NOT_INITIALIZED; |
| 2062 | } |
| 2063 | |
| 2064 | RefPtr<WriteEvent> ev = new WriteEvent(aHandle, aOffset, aBuf, aCount, |
| 2065 | aValidate, aTruncate, nullptr); |
| 2066 | return ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 2067 | ? CacheIOThread::WRITE_PRIORITY |
| 2068 | : CacheIOThread::WRITE); |
| 2069 | } |
| 2070 | |
| 2071 | static nsresult TruncFile(PRFileDesc* aFD, int64_t aEOF) { |
| 2072 | #if defined(XP_UNIX1) |
| 2073 | if (ftruncate(PR_FileDesc2NativeHandle(aFD), aEOF) != 0) { |
| 2074 | NS_ERROR("ftruncate failed")do { NS_DebugBreak(NS_DEBUG_ASSERTION, "ftruncate failed", "Error" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2074); MOZ_PretendNoReturn(); } while (0); |
| 2075 | return NS_ERROR_FAILURE; |
| 2076 | } |
| 2077 | #elif defined(XP_WIN) |
| 2078 | int64_t cnt = PR_Seek64(aFD, aEOF, PR_SEEK_SET); |
| 2079 | if (cnt == -1) { |
| 2080 | return NS_ERROR_FAILURE; |
| 2081 | } |
| 2082 | if (!SetEndOfFile((HANDLE)PR_FileDesc2NativeHandle(aFD))) { |
| 2083 | NS_ERROR("SetEndOfFile failed")do { NS_DebugBreak(NS_DEBUG_ASSERTION, "SetEndOfFile failed", "Error", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2083); MOZ_PretendNoReturn(); } while (0); |
| 2084 | return NS_ERROR_FAILURE; |
| 2085 | } |
| 2086 | #else |
| 2087 | MOZ_ASSERT(false, "Not implemented!")do { static_assert( mozilla::detail::AssertionConditionType< decltype(false)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(false))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("false" " (" "Not implemented!" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2087); AnnotateMozCrashReason("MOZ_ASSERT" "(" "false" ") (" "Not implemented!" ")"); do { *((volatile int*)__null) = 2087 ; __attribute__((nomerge)) ::abort(); } while (false); } } while (false); |
| 2088 | return NS_ERROR_NOT_IMPLEMENTED; |
| 2089 | #endif |
| 2090 | |
| 2091 | return NS_OK; |
| 2092 | } |
| 2093 | |
| 2094 | nsresult CacheFileIOManager::WriteInternal(CacheFileHandle* aHandle, |
| 2095 | int64_t aOffset, const char* aBuf, |
| 2096 | int32_t aCount, bool aValidate, |
| 2097 | bool aTruncate) { |
| 2098 | LOG(("CacheFileIOManager::WriteInternal() [handle=%p, offset=%" PRId64do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2099 | ", count=%d, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2100 | "validate=%d, truncate=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0) |
| 2101 | aHandle, aOffset, aCount, aValidate, aTruncate))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() [handle=%p, offset=%" "l" "d" ", count=%d, " "validate=%d, truncate=%d]", aHandle, aOffset, aCount, aValidate, aTruncate); } } while (0); |
| 2102 | |
| 2103 | nsresult rv; |
| 2104 | |
| 2105 | if (aHandle->mKilled) { |
| 2106 | LOG((" handle already killed, nothing written"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " handle already killed, nothing written" ); } } while (0); |
| 2107 | return NS_OK; |
| 2108 | } |
| 2109 | |
| 2110 | if (CacheObserver::ShuttingDown() && (!aValidate || !aHandle->mFD)) { |
| 2111 | aHandle->mKilled = true; |
| 2112 | LOG((" killing the handle, nothing written"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " killing the handle, nothing written" ); } } while (0); |
| 2113 | return NS_OK; |
| 2114 | } |
| 2115 | |
| 2116 | if (CacheObserver::IsPastShutdownIOLag()) { |
| 2117 | LOG((" past the shutdown I/O lag, nothing written"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " past the shutdown I/O lag, nothing written" ); } } while (0); |
| 2118 | // Pretend the write has succeeded, otherwise upper layers will doom |
| 2119 | // the file and we end up with I/O anyway. |
| 2120 | return NS_OK; |
| 2121 | } |
| 2122 | |
| 2123 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 2124 | |
| 2125 | if (!aHandle->mFileExists) { |
| 2126 | rv = CreateFile(aHandle); |
| 2127 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2127); return rv; } } while (false); |
| 2128 | } |
| 2129 | |
| 2130 | if (!aHandle->mFD) { |
| 2131 | rv = OpenNSPRHandle(aHandle); |
| 2132 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2132); return rv; } } while (false); |
| 2133 | } else { |
| 2134 | NSPRHandleUsed(aHandle); |
| 2135 | } |
| 2136 | |
| 2137 | // Check again, OpenNSPRHandle could figure out the file was gone. |
| 2138 | if (!aHandle->mFileExists) { |
| 2139 | return NS_ERROR_NOT_AVAILABLE; |
| 2140 | } |
| 2141 | |
| 2142 | // When this operation would increase cache size, check whether the cache size |
| 2143 | // reached the hard limit and whether it would cause critical low disk space. |
| 2144 | if (aHandle->mFileSize < aOffset + aCount) { |
| 2145 | if (mOverLimitEvicting && mCacheSizeOnHardLimit) { |
| 2146 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - failing because cache size " "reached hard limit!"); } } while (0) |
| 2147 | ("CacheFileIOManager::WriteInternal() - failing because cache size "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - failing because cache size " "reached hard limit!"); } } while (0) |
| 2148 | "reached hard limit!"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - failing because cache size " "reached hard limit!"); } } while (0); |
| 2149 | return NS_ERROR_FILE_NO_DEVICE_SPACE; |
| 2150 | } |
| 2151 | |
| 2152 | int64_t freeSpace; |
| 2153 | rv = mCacheDirectory->GetDiskSpaceAvailable(&freeSpace); |
| 2154 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2154)) { |
| 2155 | freeSpace = -1; |
| 2156 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - GetDiskSpaceAvailable() " "failed! [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 2157 | ("CacheFileIOManager::WriteInternal() - GetDiskSpaceAvailable() "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - GetDiskSpaceAvailable() " "failed! [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 2158 | "failed! [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - GetDiskSpaceAvailable() " "failed! [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0) |
| 2159 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - GetDiskSpaceAvailable() " "failed! [rv=0x%08" "x" "]", static_cast<uint32_t>(rv) ); } } while (0); |
| 2160 | } else { |
| 2161 | freeSpace >>= 10; // bytes to kilobytes |
| 2162 | uint32_t limit = CacheObserver::DiskFreeSpaceHardLimit(); |
| 2163 | if (freeSpace - aOffset - aCount + aHandle->mFileSize < limit) { |
| 2164 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - Low free space, refusing " "to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]", freeSpace , limit); } } while (0) |
| 2165 | ("CacheFileIOManager::WriteInternal() - Low free space, refusing "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - Low free space, refusing " "to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]", freeSpace , limit); } } while (0) |
| 2166 | "to write! [freeSpace=%" PRId64 "kB, limit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - Low free space, refusing " "to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]", freeSpace , limit); } } while (0) |
| 2167 | freeSpace, limit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::WriteInternal() - Low free space, refusing " "to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]", freeSpace , limit); } } while (0); |
| 2168 | return NS_ERROR_FILE_NO_DEVICE_SPACE; |
| 2169 | } |
| 2170 | } |
| 2171 | } |
| 2172 | |
| 2173 | // Write invalidates the entry by default |
| 2174 | aHandle->mInvalid = true; |
| 2175 | |
| 2176 | int64_t offset = PR_Seek64(aHandle->mFD, aOffset, PR_SEEK_SET); |
| 2177 | if (offset == -1) { |
| 2178 | return NS_ERROR_FAILURE; |
| 2179 | } |
| 2180 | |
| 2181 | int32_t bytesWritten = PR_Write(aHandle->mFD, aBuf, aCount); |
| 2182 | |
| 2183 | if (bytesWritten != -1) { |
| 2184 | uint32_t oldSizeInK = aHandle->FileSizeInK(); |
| 2185 | int64_t writeEnd = aOffset + bytesWritten; |
| 2186 | |
| 2187 | if (aTruncate) { |
| 2188 | rv = TruncFile(aHandle->mFD, writeEnd); |
| 2189 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2189); return rv; } } while (false); |
| 2190 | |
| 2191 | aHandle->mFileSize = writeEnd; |
| 2192 | } else { |
| 2193 | if (aHandle->mFileSize < writeEnd) { |
| 2194 | aHandle->mFileSize = writeEnd; |
| 2195 | } |
| 2196 | } |
| 2197 | |
| 2198 | uint32_t newSizeInK = aHandle->FileSizeInK(); |
| 2199 | |
| 2200 | if (oldSizeInK != newSizeInK && !aHandle->IsDoomed() && |
| 2201 | !aHandle->IsSpecialFile()) { |
| 2202 | CacheIndex::UpdateEntry(aHandle->Hash(), nullptr, nullptr, nullptr, |
| 2203 | nullptr, nullptr, &newSizeInK); |
| 2204 | |
| 2205 | if (oldSizeInK < newSizeInK) { |
| 2206 | EvictIfOverLimitInternal(); |
| 2207 | } |
| 2208 | } |
| 2209 | |
| 2210 | CacheIndex::UpdateTotalBytesWritten(bytesWritten); |
| 2211 | } |
| 2212 | |
| 2213 | if (bytesWritten != aCount) { |
| 2214 | return NS_ERROR_FAILURE; |
| 2215 | } |
| 2216 | |
| 2217 | // Write was successful and this write validates the entry (i.e. metadata) |
| 2218 | if (aValidate) { |
| 2219 | aHandle->mInvalid = false; |
| 2220 | } |
| 2221 | |
| 2222 | return NS_OK; |
| 2223 | } |
| 2224 | |
| 2225 | // static |
| 2226 | nsresult CacheFileIOManager::DoomFile(CacheFileHandle* aHandle, |
| 2227 | CacheFileIOListener* aCallback) { |
| 2228 | LOG(("CacheFileIOManager::DoomFile() [handle=%p, listener=%p]", aHandle,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFile() [handle=%p, listener=%p]" , aHandle, aCallback); } } while (0) |
| 2229 | aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFile() [handle=%p, listener=%p]" , aHandle, aCallback); } } while (0); |
| 2230 | |
| 2231 | nsresult rv; |
| 2232 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2233 | |
| 2234 | if (aHandle->IsClosed() || !ioMan) { |
| 2235 | return NS_ERROR_NOT_INITIALIZED; |
| 2236 | } |
| 2237 | |
| 2238 | RefPtr<DoomFileEvent> ev = new DoomFileEvent(aHandle, aCallback); |
| 2239 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->IsPriority() |
| 2240 | ? CacheIOThread::OPEN_PRIORITY |
| 2241 | : CacheIOThread::OPEN); |
| 2242 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2242); return rv; } } while (false); |
| 2243 | |
| 2244 | return NS_OK; |
| 2245 | } |
| 2246 | |
| 2247 | nsresult CacheFileIOManager::DoomFileInternal( |
| 2248 | CacheFileHandle* aHandle, PinningDoomRestriction aPinningDoomRestriction) { |
| 2249 | LOG(("CacheFileIOManager::DoomFileInternal() [handle=%p]", aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileInternal() [handle=%p]" , aHandle); } } while (0); |
| 2250 | aHandle->Log(); |
| 2251 | |
| 2252 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2252); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 2252; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2253 | |
| 2254 | nsresult rv; |
| 2255 | |
| 2256 | if (aHandle->IsDoomed()) { |
| 2257 | return NS_OK; |
| 2258 | } |
| 2259 | |
| 2260 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 2261 | |
| 2262 | if (aPinningDoomRestriction > NO_RESTRICTION) { |
| 2263 | switch (aHandle->mPinning) { |
| 2264 | case CacheFileHandle::PinningStatus::NON_PINNED: |
| 2265 | if (MOZ_LIKELY(aPinningDoomRestriction != DOOM_WHEN_NON_PINNED)(__builtin_expect(!!(aPinningDoomRestriction != DOOM_WHEN_NON_PINNED ), 1))) { |
| 2266 | LOG((" not dooming, it's a non-pinned handle"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " not dooming, it's a non-pinned handle" ); } } while (0); |
| 2267 | return NS_OK; |
| 2268 | } |
| 2269 | // Doom now |
| 2270 | break; |
| 2271 | |
| 2272 | case CacheFileHandle::PinningStatus::PINNED: |
| 2273 | if (MOZ_UNLIKELY(aPinningDoomRestriction != DOOM_WHEN_PINNED)(__builtin_expect(!!(aPinningDoomRestriction != DOOM_WHEN_PINNED ), 0))) { |
| 2274 | LOG((" not dooming, it's a pinned handle"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " not dooming, it's a pinned handle" ); } } while (0); |
| 2275 | return NS_OK; |
| 2276 | } |
| 2277 | // Doom now |
| 2278 | break; |
| 2279 | |
| 2280 | case CacheFileHandle::PinningStatus::UNKNOWN: |
| 2281 | if (MOZ_LIKELY(aPinningDoomRestriction == DOOM_WHEN_NON_PINNED)(__builtin_expect(!!(aPinningDoomRestriction == DOOM_WHEN_NON_PINNED ), 1))) { |
| 2282 | LOG((" doom when non-pinned set"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " doom when non-pinned set" ); } } while (0); |
| 2283 | aHandle->mDoomWhenFoundNonPinned = true; |
| 2284 | } else if (MOZ_UNLIKELY(aPinningDoomRestriction == DOOM_WHEN_PINNED)(__builtin_expect(!!(aPinningDoomRestriction == DOOM_WHEN_PINNED ), 0))) { |
| 2285 | LOG((" doom when pinned set"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " doom when pinned set" ); } } while (0); |
| 2286 | aHandle->mDoomWhenFoundPinned = true; |
| 2287 | } |
| 2288 | |
| 2289 | LOG((" pinning status not known, deferring doom decision"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " pinning status not known, deferring doom decision" ); } } while (0); |
| 2290 | return NS_OK; |
| 2291 | } |
| 2292 | } |
| 2293 | |
| 2294 | if (aHandle->mFileExists) { |
| 2295 | // we need to move the current file to the doomed directory |
| 2296 | rv = MaybeReleaseNSPRHandleInternal(aHandle, true); |
| 2297 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2297); return rv; } } while (false); |
| 2298 | |
| 2299 | // find unused filename |
| 2300 | nsCOMPtr<nsIFile> file; |
| 2301 | rv = GetDoomedFile(getter_AddRefs(file)); |
| 2302 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2302); return rv; } } while (false); |
| 2303 | |
| 2304 | nsCOMPtr<nsIFile> parentDir; |
| 2305 | rv = file->GetParent(getter_AddRefs(parentDir)); |
| 2306 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2306); return rv; } } while (false); |
| 2307 | |
| 2308 | nsAutoCString leafName; |
| 2309 | rv = file->GetNativeLeafName(leafName); |
| 2310 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2310); return rv; } } while (false); |
| 2311 | |
| 2312 | rv = aHandle->mFile->MoveToNative(parentDir, leafName); |
| 2313 | if (NS_ERROR_FILE_NOT_FOUND == rv) { |
| 2314 | LOG((" file already removed under our hands"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " file already removed under our hands" ); } } while (0); |
| 2315 | aHandle->mFileExists = false; |
| 2316 | rv = NS_OK; |
| 2317 | } else { |
| 2318 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2318); return rv; } } while (false); |
| 2319 | aHandle->mFile.swap(file); |
| 2320 | } |
| 2321 | } |
| 2322 | |
| 2323 | if (!aHandle->IsSpecialFile()) { |
| 2324 | CacheIndex::RemoveEntry(aHandle->Hash()); |
| 2325 | } |
| 2326 | |
| 2327 | aHandle->mIsDoomed = true; |
| 2328 | |
| 2329 | if (!aHandle->IsSpecialFile()) { |
| 2330 | RefPtr<CacheStorageService> storageService = CacheStorageService::Self(); |
| 2331 | if (storageService) { |
| 2332 | nsAutoCString idExtension, url; |
| 2333 | nsCOMPtr<nsILoadContextInfo> info = |
| 2334 | CacheFileUtils::ParseKey(aHandle->Key(), &idExtension, &url); |
| 2335 | MOZ_ASSERT(info)do { static_assert( mozilla::detail::AssertionConditionType< decltype(info)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(info))), 0))) { do { } while (false ); MOZ_ReportAssertionFailure("info", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2335); AnnotateMozCrashReason("MOZ_ASSERT" "(" "info" ")"); do { *((volatile int*)__null) = 2335; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2336 | if (info) { |
| 2337 | storageService->CacheFileDoomed(info, idExtension, url); |
| 2338 | } |
| 2339 | } |
| 2340 | } |
| 2341 | |
| 2342 | return NS_OK; |
| 2343 | } |
| 2344 | |
| 2345 | // static |
| 2346 | nsresult CacheFileIOManager::DoomFileByKey(const nsACString& aKey, |
| 2347 | CacheFileIOListener* aCallback) { |
| 2348 | LOG(("CacheFileIOManager::DoomFileByKey() [key=%s, listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKey() [key=%s, listener=%p]" , TPromiseFlatString<char>(aKey).get(), aCallback); } } while (0) |
| 2349 | PromiseFlatCString(aKey).get(), aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKey() [key=%s, listener=%p]" , TPromiseFlatString<char>(aKey).get(), aCallback); } } while (0); |
| 2350 | |
| 2351 | nsresult rv; |
| 2352 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2353 | |
| 2354 | if (!ioMan) { |
| 2355 | return NS_ERROR_NOT_INITIALIZED; |
| 2356 | } |
| 2357 | |
| 2358 | RefPtr<DoomFileByKeyEvent> ev = new DoomFileByKeyEvent(aKey, aCallback); |
| 2359 | rv = ioMan->mIOThread->DispatchAfterPendingOpens(ev); |
| 2360 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2360); return rv; } } while (false); |
| 2361 | |
| 2362 | return NS_OK; |
| 2363 | } |
| 2364 | |
| 2365 | nsresult CacheFileIOManager::DoomFileByKeyInternal(const SHA1Sum::Hash* aHash) { |
| 2366 | LOG((do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 2367 | "CacheFileIOManager::DoomFileByKeyInternal() [hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0) |
| 2368 | LOGSHA1(aHash)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() [hash=%08x%08x%08x%08x%08x]" , PR_htonl((reinterpret_cast<const uint32_t*>(aHash))[0 ]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash)) [1]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[2]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[3]), PR_htonl((reinterpret_cast<const uint32_t*>(aHash ))[4])); } } while (0); |
| 2369 | |
| 2370 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2370); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 2370; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2371 | |
| 2372 | nsresult rv; |
| 2373 | |
| 2374 | if (mShuttingDown) { |
| 2375 | return NS_ERROR_NOT_INITIALIZED; |
| 2376 | } |
| 2377 | |
| 2378 | if (!mCacheDirectory) { |
| 2379 | return NS_ERROR_FILE_INVALID_PATH; |
| 2380 | } |
| 2381 | |
| 2382 | // Find active handle |
| 2383 | RefPtr<CacheFileHandle> handle; |
| 2384 | mHandles.GetHandle(aHash, getter_AddRefs(handle)); |
| 2385 | |
| 2386 | if (handle) { |
| 2387 | handle->Log(); |
| 2388 | |
| 2389 | return DoomFileInternal(handle); |
| 2390 | } |
| 2391 | |
| 2392 | CacheIOThread::Cancelable cancelable(true); |
| 2393 | |
| 2394 | // There is no handle for this file, delete the file if exists |
| 2395 | nsCOMPtr<nsIFile> file; |
| 2396 | rv = GetFile(aHash, getter_AddRefs(file)); |
| 2397 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2397); return rv; } } while (false); |
| 2398 | |
| 2399 | bool exists; |
| 2400 | rv = file->Exists(&exists); |
| 2401 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2401); return rv; } } while (false); |
| 2402 | |
| 2403 | if (!exists) { |
| 2404 | return NS_ERROR_NOT_AVAILABLE; |
| 2405 | } |
| 2406 | |
| 2407 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file from " "disk"); } } while (0) |
| 2408 | ("CacheFileIOManager::DoomFileByKeyInternal() - Removing file from "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file from " "disk"); } } while (0) |
| 2409 | "disk"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file from " "disk"); } } while (0); |
| 2410 | rv = file->Remove(false); |
| 2411 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 2412 | NS_WARNING("Cannot remove old entry from the disk")NS_DebugBreak(NS_DEBUG_WARNING, "Cannot remove old entry from the disk" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2412); |
| 2413 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file failed. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2414 | ("CacheFileIOManager::DoomFileByKeyInternal() - Removing file failed. "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file failed. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2415 | "[rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file failed. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2416 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::DoomFileByKeyInternal() - Removing file failed. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 2417 | } |
| 2418 | |
| 2419 | CacheIndex::RemoveEntry(aHash); |
| 2420 | |
| 2421 | return NS_OK; |
| 2422 | } |
| 2423 | |
| 2424 | // static |
| 2425 | nsresult CacheFileIOManager::ReleaseNSPRHandle(CacheFileHandle* aHandle) { |
| 2426 | LOG(("CacheFileIOManager::ReleaseNSPRHandle() [handle=%p]", aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::ReleaseNSPRHandle() [handle=%p]" , aHandle); } } while (0); |
| 2427 | |
| 2428 | nsresult rv; |
| 2429 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2430 | |
| 2431 | if (aHandle->IsClosed() || !ioMan) { |
| 2432 | return NS_ERROR_NOT_INITIALIZED; |
| 2433 | } |
| 2434 | |
| 2435 | RefPtr<ReleaseNSPRHandleEvent> ev = new ReleaseNSPRHandleEvent(aHandle); |
| 2436 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 2437 | ? CacheIOThread::WRITE_PRIORITY |
| 2438 | : CacheIOThread::WRITE); |
| 2439 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2439); return rv; } } while (false); |
| 2440 | |
| 2441 | return NS_OK; |
| 2442 | } |
| 2443 | |
| 2444 | nsresult CacheFileIOManager::MaybeReleaseNSPRHandleInternal( |
| 2445 | CacheFileHandle* aHandle, bool aIgnoreShutdownLag) { |
| 2446 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() [handle=%p, " "ignore shutdown=%d]", aHandle, aIgnoreShutdownLag); } } while (0) |
| 2447 | ("CacheFileIOManager::MaybeReleaseNSPRHandleInternal() [handle=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() [handle=%p, " "ignore shutdown=%d]", aHandle, aIgnoreShutdownLag); } } while (0) |
| 2448 | "ignore shutdown=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() [handle=%p, " "ignore shutdown=%d]", aHandle, aIgnoreShutdownLag); } } while (0) |
| 2449 | aHandle, aIgnoreShutdownLag))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() [handle=%p, " "ignore shutdown=%d]", aHandle, aIgnoreShutdownLag); } } while (0); |
| 2450 | |
| 2451 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2451); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 2451; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2452 | |
| 2453 | if (aHandle->mFD) { |
| 2454 | DebugOnly<bool> found{}; |
| 2455 | found = mHandlesByLastUsed.RemoveElement(aHandle); |
| 2456 | MOZ_ASSERT(found)do { static_assert( mozilla::detail::AssertionConditionType< decltype(found)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(found))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("found", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2456); AnnotateMozCrashReason("MOZ_ASSERT" "(" "found" ")") ; do { *((volatile int*)__null) = 2456; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2457 | } |
| 2458 | |
| 2459 | PRFileDesc* fd = aHandle->mFD; |
| 2460 | aHandle->mFD = nullptr; |
| 2461 | |
| 2462 | // Leak invalid (w/o metadata) and doomed handles immediately after shutdown. |
| 2463 | // Leak other handles when past the shutdown time maximum lag. |
| 2464 | if ( |
| 2465 | #ifndef DEBUG1 |
| 2466 | ((aHandle->mInvalid || aHandle->mIsDoomed) && |
| 2467 | MOZ_UNLIKELY(CacheObserver::ShuttingDown())(__builtin_expect(!!(CacheObserver::ShuttingDown()), 0))) || |
| 2468 | #endif |
| 2469 | MOZ_UNLIKELY(!aIgnoreShutdownLag &&(__builtin_expect(!!(!aIgnoreShutdownLag && CacheObserver ::IsPastShutdownIOLag()), 0)) |
| 2470 | CacheObserver::IsPastShutdownIOLag())(__builtin_expect(!!(!aIgnoreShutdownLag && CacheObserver ::IsPastShutdownIOLag()), 0))) { |
| 2471 | // Don't bother closing this file. Return a failure code from here will |
| 2472 | // cause any following IO operation on the file (mainly removal) to be |
| 2473 | // bypassed, which is what we want. |
| 2474 | // For mInvalid == true the entry will never be used, since it doesn't |
| 2475 | // have correct metadata, thus we don't need to worry about removing it. |
| 2476 | // For mIsDoomed == true the file is already in the doomed sub-dir and |
| 2477 | // will be removed on next session start. |
| 2478 | LOG((" past the shutdown I/O lag, leaking file handle"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " past the shutdown I/O lag, leaking file handle" ); } } while (0); |
| 2479 | return NS_ERROR_ILLEGAL_DURING_SHUTDOWN; |
| 2480 | } |
| 2481 | |
| 2482 | if (!fd) { |
| 2483 | // The filedesc has already been closed before, just let go. |
| 2484 | return NS_OK; |
| 2485 | } |
| 2486 | |
| 2487 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 2488 | |
| 2489 | PRStatus status = PR_Close(fd); |
| 2490 | if (status != PR_SUCCESS) { |
| 2491 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() " "failed to close [handle=%p, status=%u]", aHandle, status); } } while (0) |
| 2492 | ("CacheFileIOManager::MaybeReleaseNSPRHandleInternal() "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() " "failed to close [handle=%p, status=%u]", aHandle, status); } } while (0) |
| 2493 | "failed to close [handle=%p, status=%u]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() " "failed to close [handle=%p, status=%u]", aHandle, status); } } while (0) |
| 2494 | aHandle, status))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() " "failed to close [handle=%p, status=%u]", aHandle, status); } } while (0); |
| 2495 | return NS_ERROR_FAILURE; |
| 2496 | } |
| 2497 | |
| 2498 | LOG(("CacheFileIOManager::MaybeReleaseNSPRHandleInternal() DONE"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::MaybeReleaseNSPRHandleInternal() DONE" ); } } while (0); |
| 2499 | |
| 2500 | return NS_OK; |
| 2501 | } |
| 2502 | |
| 2503 | // static |
| 2504 | nsresult CacheFileIOManager::TruncateSeekSetEOF( |
| 2505 | CacheFileHandle* aHandle, int64_t aTruncatePos, int64_t aEOFPos, |
| 2506 | CacheFileIOListener* aCallback) { |
| 2507 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, " "truncatePos=%" "l" "d" ", " "EOFPos=%" "l" "d" ", listener=%p]" , aHandle, aTruncatePos, aEOFPos, aCallback); } } while (0) |
| 2508 | ("CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, " "truncatePos=%" "l" "d" ", " "EOFPos=%" "l" "d" ", listener=%p]" , aHandle, aTruncatePos, aEOFPos, aCallback); } } while (0) |
| 2509 | "truncatePos=%" PRId64 ", "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, " "truncatePos=%" "l" "d" ", " "EOFPos=%" "l" "d" ", listener=%p]" , aHandle, aTruncatePos, aEOFPos, aCallback); } } while (0) |
| 2510 | "EOFPos=%" PRId64 ", listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, " "truncatePos=%" "l" "d" ", " "EOFPos=%" "l" "d" ", listener=%p]" , aHandle, aTruncatePos, aEOFPos, aCallback); } } while (0) |
| 2511 | aHandle, aTruncatePos, aEOFPos, aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOF() [handle=%p, " "truncatePos=%" "l" "d" ", " "EOFPos=%" "l" "d" ", listener=%p]" , aHandle, aTruncatePos, aEOFPos, aCallback); } } while (0); |
| 2512 | |
| 2513 | nsresult rv; |
| 2514 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2515 | |
| 2516 | if (aHandle->IsClosed() || (aCallback && aCallback->IsKilled()) || !ioMan) { |
| 2517 | return NS_ERROR_NOT_INITIALIZED; |
| 2518 | } |
| 2519 | |
| 2520 | RefPtr<TruncateSeekSetEOFEvent> ev = |
| 2521 | new TruncateSeekSetEOFEvent(aHandle, aTruncatePos, aEOFPos, aCallback); |
| 2522 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 2523 | ? CacheIOThread::WRITE_PRIORITY |
| 2524 | : CacheIOThread::WRITE); |
| 2525 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2525); return rv; } } while (false); |
| 2526 | |
| 2527 | return NS_OK; |
| 2528 | } |
| 2529 | |
| 2530 | // static |
| 2531 | void CacheFileIOManager::GetCacheDirectory(nsIFile** result) { |
| 2532 | *result = nullptr; |
| 2533 | |
| 2534 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2535 | if (!ioMan || !ioMan->mCacheDirectory) { |
| 2536 | return; |
| 2537 | } |
| 2538 | |
| 2539 | ioMan->mCacheDirectory->Clone(result); |
| 2540 | } |
| 2541 | |
| 2542 | #if defined(MOZ_WIDGET_ANDROID) |
| 2543 | |
| 2544 | // static |
| 2545 | void CacheFileIOManager::GetProfilelessCacheDirectory(nsIFile** result) { |
| 2546 | *result = nullptr; |
| 2547 | |
| 2548 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2549 | if (!ioMan || !ioMan->mCacheProfilelessDirectory) { |
| 2550 | return; |
| 2551 | } |
| 2552 | |
| 2553 | ioMan->mCacheProfilelessDirectory->Clone(result); |
| 2554 | } |
| 2555 | |
| 2556 | #endif |
| 2557 | |
| 2558 | // static |
| 2559 | nsresult CacheFileIOManager::GetEntryInfo( |
| 2560 | const SHA1Sum::Hash* aHash, |
| 2561 | CacheStorageService::EntryInfoCallback* aCallback) { |
| 2562 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(CacheFileIOManager::IsOnIOThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("CacheFileIOManager::IsOnIOThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2562); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThread()" ")"); do { *((volatile int*)__null) = 2562; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2563 | |
| 2564 | nsresult rv; |
| 2565 | |
| 2566 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2567 | if (!ioMan) { |
| 2568 | return NS_ERROR_NOT_INITIALIZED; |
| 2569 | } |
| 2570 | |
| 2571 | nsAutoCString enhanceId; |
| 2572 | nsAutoCString uriSpec; |
| 2573 | |
| 2574 | RefPtr<CacheFileHandle> handle; |
| 2575 | ioMan->mHandles.GetHandle(aHash, getter_AddRefs(handle)); |
| 2576 | if (handle) { |
| 2577 | RefPtr<nsILoadContextInfo> info = |
| 2578 | CacheFileUtils::ParseKey(handle->Key(), &enhanceId, &uriSpec); |
| 2579 | |
| 2580 | MOZ_ASSERT(info)do { static_assert( mozilla::detail::AssertionConditionType< decltype(info)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(info))), 0))) { do { } while (false ); MOZ_ReportAssertionFailure("info", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2580); AnnotateMozCrashReason("MOZ_ASSERT" "(" "info" ")"); do { *((volatile int*)__null) = 2580; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2581 | if (!info) { |
| 2582 | return NS_OK; // ignore |
| 2583 | } |
| 2584 | |
| 2585 | RefPtr<CacheStorageService> service = CacheStorageService::Self(); |
| 2586 | if (!service) { |
| 2587 | return NS_ERROR_NOT_INITIALIZED; |
| 2588 | } |
| 2589 | |
| 2590 | // Invokes OnCacheEntryInfo when an existing entry is found |
| 2591 | if (service->GetCacheEntryInfo(info, enhanceId, uriSpec, aCallback)) { |
| 2592 | return NS_OK; |
| 2593 | } |
| 2594 | |
| 2595 | // When we are here, there is no existing entry and we need |
| 2596 | // to synchrnously load metadata from a disk file. |
| 2597 | } |
| 2598 | |
| 2599 | // Locate the actual file |
| 2600 | nsCOMPtr<nsIFile> file; |
| 2601 | ioMan->GetFile(aHash, getter_AddRefs(file)); |
| 2602 | |
| 2603 | // Read metadata from the file synchronously |
| 2604 | RefPtr<CacheFileMetadata> metadata = new CacheFileMetadata(); |
| 2605 | rv = metadata->SyncReadMetadata(file); |
| 2606 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 2607 | return NS_OK; |
| 2608 | } |
| 2609 | |
| 2610 | // Now get the context + enhance id + URL from the key. |
| 2611 | RefPtr<nsILoadContextInfo> info = |
| 2612 | CacheFileUtils::ParseKey(metadata->GetKey(), &enhanceId, &uriSpec); |
| 2613 | MOZ_ASSERT(info)do { static_assert( mozilla::detail::AssertionConditionType< decltype(info)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(info))), 0))) { do { } while (false ); MOZ_ReportAssertionFailure("info", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2613); AnnotateMozCrashReason("MOZ_ASSERT" "(" "info" ")"); do { *((volatile int*)__null) = 2613; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2614 | if (!info) { |
| 2615 | return NS_OK; |
| 2616 | } |
| 2617 | |
| 2618 | // Pick all data to pass to the callback. |
| 2619 | int64_t dataSize = metadata->Offset(); |
| 2620 | int64_t altDataSize = 0; |
| 2621 | uint32_t fetchCount = metadata->GetFetchCount(); |
| 2622 | uint32_t expirationTime = metadata->GetExpirationTime(); |
| 2623 | uint32_t lastModified = metadata->GetLastModified(); |
| 2624 | |
| 2625 | const char* altDataElement = |
| 2626 | metadata->GetElement(CacheFileUtils::kAltDataKey); |
| 2627 | if (altDataElement) { |
| 2628 | int64_t altDataOffset = std::numeric_limits<int64_t>::max(); |
| 2629 | if (NS_SUCCEEDED(CacheFileUtils::ParseAlternativeDataInfo(((bool)(__builtin_expect(!!(!NS_FAILED_impl(CacheFileUtils::ParseAlternativeDataInfo ( altDataElement, &altDataOffset, nullptr))), 1))) |
| 2630 | altDataElement, &altDataOffset, nullptr))((bool)(__builtin_expect(!!(!NS_FAILED_impl(CacheFileUtils::ParseAlternativeDataInfo ( altDataElement, &altDataOffset, nullptr))), 1))) && |
| 2631 | altDataOffset < dataSize) { |
| 2632 | dataSize = altDataOffset; |
| 2633 | altDataSize = metadata->Offset() - altDataOffset; |
| 2634 | } else { |
| 2635 | LOG(("CacheFileIOManager::GetEntryInfo() invalid alternative data info"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::GetEntryInfo() invalid alternative data info" ); } } while (0); |
| 2636 | return NS_OK; |
| 2637 | } |
| 2638 | } |
| 2639 | |
| 2640 | // Call directly on the callback. |
| 2641 | aCallback->OnEntryInfo(uriSpec, enhanceId, dataSize, altDataSize, fetchCount, |
| 2642 | lastModified, expirationTime, metadata->Pinned(), |
| 2643 | info); |
| 2644 | |
| 2645 | return NS_OK; |
| 2646 | } |
| 2647 | |
| 2648 | nsresult CacheFileIOManager::TruncateSeekSetEOFInternal( |
| 2649 | CacheFileHandle* aHandle, int64_t aTruncatePos, int64_t aEOFPos) { |
| 2650 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() [handle=%p, " "truncatePos=%" "l" "d" ", EOFPos=%" "l" "d" "]", aHandle, aTruncatePos , aEOFPos); } } while (0) |
| 2651 | ("CacheFileIOManager::TruncateSeekSetEOFInternal() [handle=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() [handle=%p, " "truncatePos=%" "l" "d" ", EOFPos=%" "l" "d" "]", aHandle, aTruncatePos , aEOFPos); } } while (0) |
| 2652 | "truncatePos=%" PRId64 ", EOFPos=%" PRId64 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() [handle=%p, " "truncatePos=%" "l" "d" ", EOFPos=%" "l" "d" "]", aHandle, aTruncatePos , aEOFPos); } } while (0) |
| 2653 | aHandle, aTruncatePos, aEOFPos))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() [handle=%p, " "truncatePos=%" "l" "d" ", EOFPos=%" "l" "d" "]", aHandle, aTruncatePos , aEOFPos); } } while (0); |
| 2654 | |
| 2655 | nsresult rv; |
| 2656 | |
| 2657 | if (aHandle->mKilled) { |
| 2658 | LOG((" handle already killed, file not truncated"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " handle already killed, file not truncated" ); } } while (0); |
| 2659 | return NS_OK; |
| 2660 | } |
| 2661 | |
| 2662 | if (CacheObserver::ShuttingDown() && !aHandle->mFD) { |
| 2663 | aHandle->mKilled = true; |
| 2664 | LOG((" killing the handle, file not truncated"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " killing the handle, file not truncated" ); } } while (0); |
| 2665 | return NS_OK; |
| 2666 | } |
| 2667 | |
| 2668 | CacheIOThread::Cancelable cancelable(!aHandle->IsSpecialFile()); |
| 2669 | |
| 2670 | if (!aHandle->mFileExists) { |
| 2671 | rv = CreateFile(aHandle); |
| 2672 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2672); return rv; } } while (false); |
| 2673 | } |
| 2674 | |
| 2675 | if (!aHandle->mFD) { |
| 2676 | rv = OpenNSPRHandle(aHandle); |
| 2677 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2677); return rv; } } while (false); |
| 2678 | } else { |
| 2679 | NSPRHandleUsed(aHandle); |
| 2680 | } |
| 2681 | |
| 2682 | // Check again, OpenNSPRHandle could figure out the file was gone. |
| 2683 | if (!aHandle->mFileExists) { |
| 2684 | return NS_ERROR_NOT_AVAILABLE; |
| 2685 | } |
| 2686 | |
| 2687 | // When this operation would increase cache size, check whether the cache size |
| 2688 | // reached the hard limit and whether it would cause critical low disk space. |
| 2689 | if (aHandle->mFileSize < aEOFPos) { |
| 2690 | if (mOverLimitEvicting && mCacheSizeOnHardLimit) { |
| 2691 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - failing because " "cache size reached hard limit!"); } } while (0) |
| 2692 | ("CacheFileIOManager::TruncateSeekSetEOFInternal() - failing because "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - failing because " "cache size reached hard limit!"); } } while (0) |
| 2693 | "cache size reached hard limit!"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - failing because " "cache size reached hard limit!"); } } while (0); |
| 2694 | return NS_ERROR_FILE_NO_DEVICE_SPACE; |
| 2695 | } |
| 2696 | |
| 2697 | int64_t freeSpace; |
| 2698 | rv = mCacheDirectory->GetDiskSpaceAvailable(&freeSpace); |
| 2699 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2699)) { |
| 2700 | freeSpace = -1; |
| 2701 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2702 | ("CacheFileIOManager::TruncateSeekSetEOFInternal() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2703 | "GetDiskSpaceAvailable() failed! [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2704 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0); |
| 2705 | } else { |
| 2706 | freeSpace >>= 10; // bytes to kilobytes |
| 2707 | uint32_t limit = CacheObserver::DiskFreeSpaceHardLimit(); |
| 2708 | if (freeSpace - aEOFPos + aHandle->mFileSize < limit) { |
| 2709 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - Low free space" ", refusing to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]" , freeSpace, limit); } } while (0) |
| 2710 | ("CacheFileIOManager::TruncateSeekSetEOFInternal() - Low free space"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - Low free space" ", refusing to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]" , freeSpace, limit); } } while (0) |
| 2711 | ", refusing to write! [freeSpace=%" PRId64 "kB, limit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - Low free space" ", refusing to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]" , freeSpace, limit); } } while (0) |
| 2712 | freeSpace, limit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TruncateSeekSetEOFInternal() - Low free space" ", refusing to write! [freeSpace=%" "l" "d" "kB, limit=%ukB]" , freeSpace, limit); } } while (0); |
| 2713 | return NS_ERROR_FILE_NO_DEVICE_SPACE; |
| 2714 | } |
| 2715 | } |
| 2716 | } |
| 2717 | |
| 2718 | // This operation always invalidates the entry |
| 2719 | aHandle->mInvalid = true; |
| 2720 | |
| 2721 | rv = TruncFile(aHandle->mFD, aTruncatePos); |
| 2722 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2722); return rv; } } while (false); |
| 2723 | |
| 2724 | if (aTruncatePos != aEOFPos) { |
| 2725 | rv = TruncFile(aHandle->mFD, aEOFPos); |
| 2726 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2726); return rv; } } while (false); |
| 2727 | } |
| 2728 | |
| 2729 | uint32_t oldSizeInK = aHandle->FileSizeInK(); |
| 2730 | aHandle->mFileSize = aEOFPos; |
| 2731 | uint32_t newSizeInK = aHandle->FileSizeInK(); |
| 2732 | |
| 2733 | if (oldSizeInK != newSizeInK && !aHandle->IsDoomed() && |
| 2734 | !aHandle->IsSpecialFile()) { |
| 2735 | CacheIndex::UpdateEntry(aHandle->Hash(), nullptr, nullptr, nullptr, nullptr, |
| 2736 | nullptr, &newSizeInK); |
| 2737 | |
| 2738 | if (oldSizeInK < newSizeInK) { |
| 2739 | EvictIfOverLimitInternal(); |
| 2740 | } |
| 2741 | } |
| 2742 | |
| 2743 | return NS_OK; |
| 2744 | } |
| 2745 | |
| 2746 | // static |
| 2747 | nsresult CacheFileIOManager::RenameFile(CacheFileHandle* aHandle, |
| 2748 | const nsACString& aNewName, |
| 2749 | CacheFileIOListener* aCallback) { |
| 2750 | LOG(("CacheFileIOManager::RenameFile() [handle=%p, newName=%s, listener=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFile() [handle=%p, newName=%s, listener=%p]" , aHandle, TPromiseFlatString<char>(aNewName).get(), aCallback ); } } while (0) |
| 2751 | aHandle, PromiseFlatCString(aNewName).get(), aCallback))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFile() [handle=%p, newName=%s, listener=%p]" , aHandle, TPromiseFlatString<char>(aNewName).get(), aCallback ); } } while (0); |
| 2752 | |
| 2753 | nsresult rv; |
| 2754 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2755 | |
| 2756 | if (aHandle->IsClosed() || !ioMan) { |
| 2757 | return NS_ERROR_NOT_INITIALIZED; |
| 2758 | } |
| 2759 | |
| 2760 | if (!aHandle->IsSpecialFile()) { |
| 2761 | return NS_ERROR_UNEXPECTED; |
| 2762 | } |
| 2763 | |
| 2764 | RefPtr<RenameFileEvent> ev = |
| 2765 | new RenameFileEvent(aHandle, aNewName, aCallback); |
| 2766 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 2767 | ? CacheIOThread::WRITE_PRIORITY |
| 2768 | : CacheIOThread::WRITE); |
| 2769 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2769); return rv; } } while (false); |
| 2770 | |
| 2771 | return NS_OK; |
| 2772 | } |
| 2773 | |
| 2774 | nsresult CacheFileIOManager::RenameFileInternal(CacheFileHandle* aHandle, |
| 2775 | const nsACString& aNewName) { |
| 2776 | LOG(("CacheFileIOManager::RenameFileInternal() [handle=%p, newName=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() [handle=%p, newName=%s]" , aHandle, TPromiseFlatString<char>(aNewName).get()); } } while (0) |
| 2777 | aHandle, PromiseFlatCString(aNewName).get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() [handle=%p, newName=%s]" , aHandle, TPromiseFlatString<char>(aNewName).get()); } } while (0); |
| 2778 | |
| 2779 | nsresult rv; |
| 2780 | |
| 2781 | MOZ_ASSERT(aHandle->IsSpecialFile())do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHandle->IsSpecialFile())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aHandle->IsSpecialFile()) )), 0))) { do { } while (false); MOZ_ReportAssertionFailure("aHandle->IsSpecialFile()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2781); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHandle->IsSpecialFile()" ")"); do { *((volatile int*)__null) = 2781; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2782 | |
| 2783 | if (aHandle->IsDoomed()) { |
| 2784 | return NS_ERROR_NOT_AVAILABLE; |
| 2785 | } |
| 2786 | |
| 2787 | // Doom old handle if it exists and is not doomed |
| 2788 | for (uint32_t i = 0; i < mSpecialHandles.Length(); i++) { |
| 2789 | if (!mSpecialHandles[i]->IsDoomed() && |
| 2790 | mSpecialHandles[i]->Key() == aNewName) { |
| 2791 | MOZ_ASSERT(aHandle != mSpecialHandles[i])do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHandle != mSpecialHandles[i])>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aHandle != mSpecialHandles[i ]))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("aHandle != mSpecialHandles[i]", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2791); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHandle != mSpecialHandles[i]" ")"); do { *((volatile int*)__null) = 2791; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2792 | rv = DoomFileInternal(mSpecialHandles[i]); |
| 2793 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2793); return rv; } } while (false); |
| 2794 | break; |
| 2795 | } |
| 2796 | } |
| 2797 | |
| 2798 | nsCOMPtr<nsIFile> file; |
| 2799 | rv = GetSpecialFile(aNewName, getter_AddRefs(file)); |
| 2800 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2800); return rv; } } while (false); |
| 2801 | |
| 2802 | bool exists; |
| 2803 | rv = file->Exists(&exists); |
| 2804 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2804); return rv; } } while (false); |
| 2805 | |
| 2806 | if (exists) { |
| 2807 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file from " "disk"); } } while (0) |
| 2808 | ("CacheFileIOManager::RenameFileInternal() - Removing old file from "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file from " "disk"); } } while (0) |
| 2809 | "disk"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file from " "disk"); } } while (0); |
| 2810 | rv = file->Remove(false); |
| 2811 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 2812 | NS_WARNING("Cannot remove file from the disk")NS_DebugBreak(NS_DEBUG_WARNING, "Cannot remove file from the disk" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2812); |
| 2813 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2814 | ("CacheFileIOManager::RenameFileInternal() - Removing old file failed"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2815 | ". [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 2816 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RenameFileInternal() - Removing old file failed" ". [rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 2817 | } |
| 2818 | } |
| 2819 | |
| 2820 | if (!aHandle->FileExists()) { |
| 2821 | aHandle->mKey = aNewName; |
| 2822 | return NS_OK; |
| 2823 | } |
| 2824 | |
| 2825 | rv = MaybeReleaseNSPRHandleInternal(aHandle, true); |
| 2826 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2826); return rv; } } while (false); |
| 2827 | |
| 2828 | rv = aHandle->mFile->MoveToNative(nullptr, aNewName); |
| 2829 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2829); return rv; } } while (false); |
| 2830 | |
| 2831 | aHandle->mKey = aNewName; |
| 2832 | return NS_OK; |
| 2833 | } |
| 2834 | |
| 2835 | // static |
| 2836 | nsresult CacheFileIOManager::EvictIfOverLimit() { |
| 2837 | LOG(("CacheFileIOManager::EvictIfOverLimit()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimit()" ); } } while (0); |
| 2838 | |
| 2839 | nsresult rv; |
| 2840 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 2841 | |
| 2842 | if (!ioMan) { |
| 2843 | return NS_ERROR_NOT_INITIALIZED; |
| 2844 | } |
| 2845 | |
| 2846 | nsCOMPtr<nsIRunnable> ev; |
| 2847 | ev = NewRunnableMethod("net::CacheFileIOManager::EvictIfOverLimitInternal", |
| 2848 | ioMan, &CacheFileIOManager::EvictIfOverLimitInternal); |
| 2849 | |
| 2850 | rv = ioMan->mIOThread->Dispatch(ev, CacheIOThread::EVICT); |
| 2851 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2851); return rv; } } while (false); |
| 2852 | |
| 2853 | return NS_OK; |
| 2854 | } |
| 2855 | |
| 2856 | nsresult CacheFileIOManager::EvictIfOverLimitInternal() { |
| 2857 | LOG(("CacheFileIOManager::EvictIfOverLimitInternal()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal()" ); } } while (0); |
| 2858 | |
| 2859 | nsresult rv; |
| 2860 | |
| 2861 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2861); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 2861; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2862 | |
| 2863 | if (mShuttingDown) { |
| 2864 | return NS_ERROR_NOT_INITIALIZED; |
| 2865 | } |
| 2866 | |
| 2867 | if (mOverLimitEvicting) { |
| 2868 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Eviction already " "running."); } } while (0) |
| 2869 | ("CacheFileIOManager::EvictIfOverLimitInternal() - Eviction already "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Eviction already " "running."); } } while (0) |
| 2870 | "running."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Eviction already " "running."); } } while (0); |
| 2871 | return NS_OK; |
| 2872 | } |
| 2873 | |
| 2874 | CacheIOThread::Cancelable cancelable(true); |
| 2875 | |
| 2876 | int64_t freeSpace; |
| 2877 | rv = mCacheDirectory->GetDiskSpaceAvailable(&freeSpace); |
| 2878 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2878)) { |
| 2879 | freeSpace = -1; |
| 2880 | |
| 2881 | // Do not change smart size. |
| 2882 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2883 | ("CacheFileIOManager::EvictIfOverLimitInternal() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2884 | "GetDiskSpaceAvailable() failed! [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2885 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0); |
| 2886 | } else { |
| 2887 | freeSpace >>= 10; // bytes to kilobytes |
| 2888 | UpdateSmartCacheSize(freeSpace); |
| 2889 | } |
| 2890 | |
| 2891 | uint32_t cacheUsage; |
| 2892 | rv = CacheIndex::GetCacheSize(&cacheUsage); |
| 2893 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2893); return rv; } } while (false); |
| 2894 | |
| 2895 | uint32_t cacheLimit = CacheObserver::DiskCacheCapacity(); |
| 2896 | uint32_t freeSpaceLimit = CacheObserver::DiskFreeSpaceSoftLimit(); |
| 2897 | |
| 2898 | if (cacheUsage <= cacheLimit && |
| 2899 | (freeSpace == -1 || freeSpace >= freeSpaceLimit)) { |
| 2900 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free " "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage, cacheLimit, freeSpace , freeSpaceLimit); } } while (0) |
| 2901 | ("CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free " "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage, cacheLimit, freeSpace , freeSpaceLimit); } } while (0) |
| 2902 | "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free " "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage, cacheLimit, freeSpace , freeSpaceLimit); } } while (0) |
| 2903 | "freeSpace=%" PRId64 "kB, freeSpaceLimit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free " "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage, cacheLimit, freeSpace , freeSpaceLimit); } } while (0) |
| 2904 | cacheUsage, cacheLimit, freeSpace, freeSpaceLimit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size and free " "space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage, cacheLimit, freeSpace , freeSpaceLimit); } } while (0); |
| 2905 | return NS_OK; |
| 2906 | } |
| 2907 | |
| 2908 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size exceeded " "limit. Starting overlimit eviction. [cacheSize=%ukB, limit=%ukB]" , cacheUsage, cacheLimit); } } while (0) |
| 2909 | ("CacheFileIOManager::EvictIfOverLimitInternal() - Cache size exceeded "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size exceeded " "limit. Starting overlimit eviction. [cacheSize=%ukB, limit=%ukB]" , cacheUsage, cacheLimit); } } while (0) |
| 2910 | "limit. Starting overlimit eviction. [cacheSize=%ukB, limit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size exceeded " "limit. Starting overlimit eviction. [cacheSize=%ukB, limit=%ukB]" , cacheUsage, cacheLimit); } } while (0) |
| 2911 | cacheUsage, cacheLimit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - Cache size exceeded " "limit. Starting overlimit eviction. [cacheSize=%ukB, limit=%ukB]" , cacheUsage, cacheLimit); } } while (0); |
| 2912 | |
| 2913 | nsCOMPtr<nsIRunnable> ev; |
| 2914 | ev = NewRunnableMethod("net::CacheFileIOManager::OverLimitEvictionInternal", |
| 2915 | this, &CacheFileIOManager::OverLimitEvictionInternal); |
| 2916 | |
| 2917 | rv = mIOThread->Dispatch(ev, CacheIOThread::EVICT); |
| 2918 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2918); return rv; } } while (false); |
| 2919 | |
| 2920 | mOverLimitEvicting = true; |
| 2921 | return NS_OK; |
| 2922 | } |
| 2923 | |
| 2924 | nsresult CacheFileIOManager::OverLimitEvictionInternal() { |
| 2925 | LOG(("CacheFileIOManager::OverLimitEvictionInternal()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal()" ); } } while (0); |
| 2926 | |
| 2927 | nsresult rv; |
| 2928 | |
| 2929 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2929); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 2929; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 2930 | |
| 2931 | // mOverLimitEvicting is accessed only on IO thread, so we can set it to false |
| 2932 | // here and set it to true again once we dispatch another event that will |
| 2933 | // continue with the eviction. The reason why we do so is that we can fail |
| 2934 | // early anywhere in this method and the variable will contain a correct |
| 2935 | // value. Otherwise we would need to set it to false on every failing place. |
| 2936 | mOverLimitEvicting = false; |
| 2937 | |
| 2938 | if (mShuttingDown) { |
| 2939 | return NS_ERROR_NOT_INITIALIZED; |
| 2940 | } |
| 2941 | |
| 2942 | while (true) { |
| 2943 | int64_t freeSpace; |
| 2944 | rv = mCacheDirectory->GetDiskSpaceAvailable(&freeSpace); |
| 2945 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2945)) { |
| 2946 | freeSpace = -1; |
| 2947 | |
| 2948 | // Do not change smart size. |
| 2949 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2950 | ("CacheFileIOManager::EvictIfOverLimitInternal() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2951 | "GetDiskSpaceAvailable() failed! [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 2952 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictIfOverLimitInternal() - " "GetDiskSpaceAvailable() failed! [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0); |
| 2953 | } else { |
| 2954 | freeSpace >>= 10; // bytes to kilobytes |
| 2955 | UpdateSmartCacheSize(freeSpace); |
| 2956 | } |
| 2957 | |
| 2958 | uint32_t cacheUsage; |
| 2959 | rv = CacheIndex::GetCacheSize(&cacheUsage); |
| 2960 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 2960); return rv; } } while (false); |
| 2961 | |
| 2962 | uint32_t cacheLimit = CacheObserver::DiskCacheCapacity(); |
| 2963 | uint32_t freeSpaceLimit = CacheObserver::DiskFreeSpaceSoftLimit(); |
| 2964 | |
| 2965 | if (cacheUsage > cacheLimit) { |
| 2966 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size over " "limit. [cacheSize=%ukB, limit=%ukB]", cacheUsage, cacheLimit ); } } while (0) |
| 2967 | ("CacheFileIOManager::OverLimitEvictionInternal() - Cache size over "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size over " "limit. [cacheSize=%ukB, limit=%ukB]", cacheUsage, cacheLimit ); } } while (0) |
| 2968 | "limit. [cacheSize=%ukB, limit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size over " "limit. [cacheSize=%ukB, limit=%ukB]", cacheUsage, cacheLimit ); } } while (0) |
| 2969 | cacheUsage, cacheLimit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size over " "limit. [cacheSize=%ukB, limit=%ukB]", cacheUsage, cacheLimit ); } } while (0); |
| 2970 | |
| 2971 | // We allow cache size to go over the specified limit. Eviction should |
| 2972 | // keep the size within the limit in a long run, but in case the eviction |
| 2973 | // is too slow, the cache could go way over the limit. To prevent this we |
| 2974 | // set flag mCacheSizeOnHardLimit when the size reaches 105% of the limit |
| 2975 | // and WriteInternal() and TruncateSeekSetEOFInternal() fail to cache |
| 2976 | // additional data. |
| 2977 | if ((cacheUsage - cacheLimit) > (cacheLimit / 20)) { |
| 2978 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size " "reached hard limit."); } } while (0) |
| 2979 | ("CacheFileIOManager::OverLimitEvictionInternal() - Cache size "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size " "reached hard limit."); } } while (0) |
| 2980 | "reached hard limit."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size " "reached hard limit."); } } while (0); |
| 2981 | mCacheSizeOnHardLimit = true; |
| 2982 | } else { |
| 2983 | mCacheSizeOnHardLimit = false; |
| 2984 | } |
| 2985 | } else if (freeSpace != -1 && freeSpace < freeSpaceLimit) { |
| 2986 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Free space under " "limit. [freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", freeSpace , freeSpaceLimit); } } while (0) |
| 2987 | ("CacheFileIOManager::OverLimitEvictionInternal() - Free space under "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Free space under " "limit. [freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", freeSpace , freeSpaceLimit); } } while (0) |
| 2988 | "limit. [freeSpace=%" PRId64 "kB, freeSpaceLimit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Free space under " "limit. [freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", freeSpace , freeSpaceLimit); } } while (0) |
| 2989 | freeSpace, freeSpaceLimit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Free space under " "limit. [freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", freeSpace , freeSpaceLimit); } } while (0); |
| 2990 | } else { |
| 2991 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size and " "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage , cacheLimit, freeSpace, freeSpaceLimit); } } while (0) |
| 2992 | ("CacheFileIOManager::OverLimitEvictionInternal() - Cache size and "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size and " "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage , cacheLimit, freeSpace, freeSpaceLimit); } } while (0) |
| 2993 | "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size and " "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage , cacheLimit, freeSpace, freeSpaceLimit); } } while (0) |
| 2994 | "freeSpace=%" PRId64 "kB, freeSpaceLimit=%ukB]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size and " "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage , cacheLimit, freeSpace, freeSpaceLimit); } } while (0) |
| 2995 | cacheUsage, cacheLimit, freeSpace, freeSpaceLimit))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Cache size and " "free space in limits. [cacheSize=%ukB, cacheSizeLimit=%ukB, " "freeSpace=%" "l" "d" "kB, freeSpaceLimit=%ukB]", cacheUsage , cacheLimit, freeSpace, freeSpaceLimit); } } while (0); |
| 2996 | |
| 2997 | mCacheSizeOnHardLimit = false; |
| 2998 | return NS_OK; |
| 2999 | } |
| 3000 | |
| 3001 | if (CacheIOThread::YieldAndRerun()) { |
| 3002 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Breaking loop " "for higher level events."); } } while (0) |
| 3003 | ("CacheFileIOManager::OverLimitEvictionInternal() - Breaking loop "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Breaking loop " "for higher level events."); } } while (0) |
| 3004 | "for higher level events."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - Breaking loop " "for higher level events."); } } while (0); |
| 3005 | mOverLimitEvicting = true; |
| 3006 | return NS_OK; |
| 3007 | } |
| 3008 | |
| 3009 | SHA1Sum::Hash hash; |
| 3010 | uint32_t cnt; |
| 3011 | static uint32_t consecutiveFailures = 0; |
| 3012 | rv = CacheIndex::GetEntryForEviction(false, &hash, &cnt); |
| 3013 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3013); return rv; } } while (false); |
| 3014 | |
| 3015 | rv = DoomFileByKeyInternal(&hash); |
| 3016 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 3017 | consecutiveFailures = 0; |
| 3018 | } else if (rv == NS_ERROR_NOT_AVAILABLE) { |
| 3019 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3020 | ("CacheFileIOManager::OverLimitEvictionInternal() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3021 | "DoomFileByKeyInternal() failed. [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3022 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0); |
| 3023 | // TODO index is outdated, start update |
| 3024 | |
| 3025 | // Make sure index won't return the same entry again |
| 3026 | CacheIndex::RemoveEntry(&hash); |
| 3027 | consecutiveFailures = 0; |
| 3028 | } else { |
| 3029 | // This shouldn't normally happen, but the eviction must not fail |
| 3030 | // completely if we ever encounter this problem. |
| 3031 | NS_WARNING(NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager::OverLimitEvictionInternal() - Unexpected " "failure of DoomFileByKeyInternal()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3033) |
| 3032 | "CacheFileIOManager::OverLimitEvictionInternal() - Unexpected "NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager::OverLimitEvictionInternal() - Unexpected " "failure of DoomFileByKeyInternal()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3033) |
| 3033 | "failure of DoomFileByKeyInternal()")NS_DebugBreak(NS_DEBUG_WARNING, "CacheFileIOManager::OverLimitEvictionInternal() - Unexpected " "failure of DoomFileByKeyInternal()", nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3033); |
| 3034 | |
| 3035 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3036 | ("CacheFileIOManager::OverLimitEvictionInternal() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3037 | "DoomFileByKeyInternal() failed. [rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0) |
| 3038 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OverLimitEvictionInternal() - " "DoomFileByKeyInternal() failed. [rv=0x%08" "x" "]", static_cast <uint32_t>(rv)); } } while (0); |
| 3039 | |
| 3040 | // Normally, CacheIndex::UpdateEntry() is called only to update newly |
| 3041 | // created/opened entries which are always fresh and UpdateEntry() expects |
| 3042 | // and checks this flag. The way we use UpdateEntry() here is a kind of |
| 3043 | // hack and we must make sure the flag is set by calling |
| 3044 | // EnsureEntryExists(). |
| 3045 | rv = CacheIndex::EnsureEntryExists(&hash); |
| 3046 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3046); return rv; } } while (false); |
| 3047 | |
| 3048 | // Move the entry at the end of both lists to make sure we won't end up |
| 3049 | // failing on one entry forever. |
| 3050 | uint32_t frecency = 0; |
| 3051 | rv = CacheIndex::UpdateEntry(&hash, &frecency, nullptr, nullptr, nullptr, |
| 3052 | nullptr, nullptr); |
| 3053 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3053); return rv; } } while (false); |
| 3054 | |
| 3055 | consecutiveFailures++; |
| 3056 | if (consecutiveFailures >= cnt) { |
| 3057 | // This doesn't necessarily mean that we've tried to doom every entry |
| 3058 | // but we've reached a sane number of tries. It is likely that another |
| 3059 | // eviction will start soon. And as said earlier, this normally doesn't |
| 3060 | // happen at all. |
| 3061 | return NS_OK; |
| 3062 | } |
| 3063 | } |
| 3064 | } |
| 3065 | |
| 3066 | MOZ_ASSERT_UNREACHABLE("We should never get here")do { static_assert( mozilla::detail::AssertionConditionType< decltype(false)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(false))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("false" " (" "MOZ_ASSERT_UNREACHABLE: " "We should never get here" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3066); AnnotateMozCrashReason("MOZ_ASSERT" "(" "false" ") (" "MOZ_ASSERT_UNREACHABLE: " "We should never get here" ")"); do { *((volatile int*)__null) = 3066; __attribute__((nomerge)) :: abort(); } while (false); } } while (false); |
| 3067 | return NS_OK; |
| 3068 | } |
| 3069 | |
| 3070 | // static |
| 3071 | nsresult CacheFileIOManager::EvictAll() { |
| 3072 | LOG(("CacheFileIOManager::EvictAll()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAll()" ); } } while (0); |
| 3073 | |
| 3074 | nsresult rv; |
| 3075 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 3076 | |
| 3077 | if (!ioMan) { |
| 3078 | return NS_ERROR_NOT_INITIALIZED; |
| 3079 | } |
| 3080 | |
| 3081 | nsCOMPtr<nsIRunnable> ev; |
| 3082 | ev = NewRunnableMethod("net::CacheFileIOManager::EvictAllInternal", ioMan, |
| 3083 | &CacheFileIOManager::EvictAllInternal); |
| 3084 | |
| 3085 | rv = ioMan->mIOThread->DispatchAfterPendingOpens(ev); |
| 3086 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3086)) { |
| 3087 | return rv; |
| 3088 | } |
| 3089 | |
| 3090 | return NS_OK; |
| 3091 | } |
| 3092 | |
| 3093 | namespace { |
| 3094 | |
| 3095 | class EvictionNotifierRunnable : public Runnable { |
| 3096 | public: |
| 3097 | EvictionNotifierRunnable() : Runnable("EvictionNotifierRunnable") {} |
| 3098 | NS_DECL_NSIRUNNABLEvirtual nsresult Run(void) override; |
| 3099 | }; |
| 3100 | |
| 3101 | NS_IMETHODIMPnsresult |
| 3102 | EvictionNotifierRunnable::Run() { |
| 3103 | nsCOMPtr<nsIObserverService> obsSvc = mozilla::services::GetObserverService(); |
| 3104 | if (obsSvc) { |
| 3105 | obsSvc->NotifyObservers(nullptr, "cacheservice:empty-cache", nullptr); |
| 3106 | } |
| 3107 | return NS_OK; |
| 3108 | } |
| 3109 | |
| 3110 | } // namespace |
| 3111 | |
| 3112 | nsresult CacheFileIOManager::EvictAllInternal() { |
| 3113 | LOG(("CacheFileIOManager::EvictAllInternal()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAllInternal()" ); } } while (0); |
| 3114 | |
| 3115 | nsresult rv; |
| 3116 | |
| 3117 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3117); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3117; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3118 | |
| 3119 | RefPtr<EvictionNotifierRunnable> r = new EvictionNotifierRunnable(); |
| 3120 | |
| 3121 | if (!mCacheDirectory) { |
| 3122 | // This is a kind of hack. Somebody called EvictAll() without a profile. |
| 3123 | // This happens in xpcshell tests that use cache without profile. We need |
| 3124 | // to notify observers in this case since the tests are waiting for it. |
| 3125 | NS_DispatchToMainThread(r); |
| 3126 | return NS_ERROR_FILE_INVALID_PATH; |
| 3127 | } |
| 3128 | |
| 3129 | if (mShuttingDown) { |
| 3130 | return NS_ERROR_NOT_INITIALIZED; |
| 3131 | } |
| 3132 | |
| 3133 | if (!mTreeCreated) { |
| 3134 | rv = CreateCacheTree(); |
| 3135 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3136 | return rv; |
| 3137 | } |
| 3138 | } |
| 3139 | |
| 3140 | // Doom all active handles |
| 3141 | nsTArray<RefPtr<CacheFileHandle>> handles; |
| 3142 | mHandles.GetActiveHandles(&handles); |
| 3143 | |
| 3144 | for (uint32_t i = 0; i < handles.Length(); ++i) { |
| 3145 | rv = DoomFileInternal(handles[i]); |
| 3146 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3146)) { |
| 3147 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAllInternal() - Cannot doom handle " "[handle=%p]", handles[i].get()); } } while (0) |
| 3148 | ("CacheFileIOManager::EvictAllInternal() - Cannot doom handle "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAllInternal() - Cannot doom handle " "[handle=%p]", handles[i].get()); } } while (0) |
| 3149 | "[handle=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAllInternal() - Cannot doom handle " "[handle=%p]", handles[i].get()); } } while (0) |
| 3150 | handles[i].get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictAllInternal() - Cannot doom handle " "[handle=%p]", handles[i].get()); } } while (0); |
| 3151 | } |
| 3152 | } |
| 3153 | |
| 3154 | nsCOMPtr<nsIFile> file; |
| 3155 | rv = mCacheDirectory->Clone(getter_AddRefs(file)); |
| 3156 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3156)) { |
| 3157 | return rv; |
| 3158 | } |
| 3159 | |
| 3160 | rv = file->AppendNative(nsLiteralCString(ENTRIES_DIR"entries")); |
| 3161 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3161)) { |
| 3162 | return rv; |
| 3163 | } |
| 3164 | |
| 3165 | // Trash current entries directory |
| 3166 | rv = TrashDirectory(file); |
| 3167 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3167)) { |
| 3168 | return rv; |
| 3169 | } |
| 3170 | |
| 3171 | // Files are now inaccessible in entries directory, notify observers. |
| 3172 | NS_DispatchToMainThread(r); |
| 3173 | |
| 3174 | // Create a new empty entries directory |
| 3175 | rv = CheckAndCreateDir(mCacheDirectory, ENTRIES_DIR"entries", false); |
| 3176 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3176)) { |
| 3177 | return rv; |
| 3178 | } |
| 3179 | |
| 3180 | CacheIndex::RemoveAll(); |
| 3181 | |
| 3182 | return NS_OK; |
| 3183 | } |
| 3184 | |
| 3185 | // static |
| 3186 | nsresult CacheFileIOManager::EvictByContext( |
| 3187 | nsILoadContextInfo* aLoadContextInfo, bool aPinned, |
| 3188 | const nsAString& aOrigin, const nsAString& aBaseDomain) { |
| 3189 | LOG(("CacheFileIOManager::EvictByContext() [loadContextInfo=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContext() [loadContextInfo=%p]" , aLoadContextInfo); } } while (0) |
| 3190 | aLoadContextInfo))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContext() [loadContextInfo=%p]" , aLoadContextInfo); } } while (0); |
| 3191 | |
| 3192 | nsresult rv; |
| 3193 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 3194 | |
| 3195 | if (!ioMan) { |
| 3196 | return NS_ERROR_NOT_INITIALIZED; |
| 3197 | } |
| 3198 | |
| 3199 | nsCOMPtr<nsIRunnable> ev; |
| 3200 | ev = |
| 3201 | NewRunnableMethod<nsCOMPtr<nsILoadContextInfo>, bool, nsString, nsString>( |
| 3202 | "net::CacheFileIOManager::EvictByContextInternal", ioMan, |
| 3203 | &CacheFileIOManager::EvictByContextInternal, aLoadContextInfo, |
| 3204 | aPinned, aOrigin, aBaseDomain); |
| 3205 | |
| 3206 | rv = ioMan->mIOThread->DispatchAfterPendingOpens(ev); |
| 3207 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3207)) { |
| 3208 | return rv; |
| 3209 | } |
| 3210 | |
| 3211 | return NS_OK; |
| 3212 | } |
| 3213 | |
| 3214 | nsresult CacheFileIOManager::EvictByContextInternal( |
| 3215 | nsILoadContextInfo* aLoadContextInfo, bool aPinned, |
| 3216 | const nsAString& aOrigin, const nsAString& aBaseDomain) { |
| 3217 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() [loadContextInfo=%p, " "pinned=%d]", aLoadContextInfo, aPinned); } } while (0) |
| 3218 | ("CacheFileIOManager::EvictByContextInternal() [loadContextInfo=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() [loadContextInfo=%p, " "pinned=%d]", aLoadContextInfo, aPinned); } } while (0) |
| 3219 | "pinned=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() [loadContextInfo=%p, " "pinned=%d]", aLoadContextInfo, aPinned); } } while (0) |
| 3220 | aLoadContextInfo, aPinned))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() [loadContextInfo=%p, " "pinned=%d]", aLoadContextInfo, aPinned); } } while (0); |
| 3221 | |
| 3222 | nsresult rv; |
| 3223 | |
| 3224 | if (aLoadContextInfo) { |
| 3225 | nsAutoCString suffix; |
| 3226 | aLoadContextInfo->OriginAttributesPtr()->CreateSuffix(suffix); |
| 3227 | LOG((" anonymous=%u, suffix=%s]", aLoadContextInfo->IsAnonymous(),do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " anonymous=%u, suffix=%s]" , aLoadContextInfo->IsAnonymous(), suffix.get()); } } while (0) |
| 3228 | suffix.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " anonymous=%u, suffix=%s]" , aLoadContextInfo->IsAnonymous(), suffix.get()); } } while (0); |
| 3229 | |
| 3230 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3230); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3230; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3231 | |
| 3232 | MOZ_ASSERT(!aLoadContextInfo->IsPrivate())do { static_assert( mozilla::detail::AssertionConditionType< decltype(!aLoadContextInfo->IsPrivate())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!aLoadContextInfo->IsPrivate ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("!aLoadContextInfo->IsPrivate()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3232); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!aLoadContextInfo->IsPrivate()" ")"); do { *((volatile int*)__null) = 3232; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3233 | if (aLoadContextInfo->IsPrivate()) { |
| 3234 | return NS_ERROR_INVALID_ARG; |
| 3235 | } |
| 3236 | } |
| 3237 | |
| 3238 | if (!mCacheDirectory) { |
| 3239 | // This is a kind of hack. Somebody called EvictAll() without a profile. |
| 3240 | // This happens in xpcshell tests that use cache without profile. We need |
| 3241 | // to notify observers in this case since the tests are waiting for it. |
| 3242 | // Also notify for aPinned == true, those are interested as well. |
| 3243 | if (!aLoadContextInfo) { |
| 3244 | RefPtr<EvictionNotifierRunnable> r = new EvictionNotifierRunnable(); |
| 3245 | NS_DispatchToMainThread(r); |
| 3246 | } |
| 3247 | return NS_ERROR_FILE_INVALID_PATH; |
| 3248 | } |
| 3249 | |
| 3250 | if (mShuttingDown) { |
| 3251 | return NS_ERROR_NOT_INITIALIZED; |
| 3252 | } |
| 3253 | |
| 3254 | if (!mTreeCreated) { |
| 3255 | rv = CreateCacheTree(); |
| 3256 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3257 | return rv; |
| 3258 | } |
| 3259 | } |
| 3260 | |
| 3261 | NS_ConvertUTF16toUTF8 origin(aOrigin); |
| 3262 | NS_ConvertUTF16toUTF8 baseDomain(aBaseDomain); |
| 3263 | |
| 3264 | // Doom all active handles that matches the load context |
| 3265 | nsTArray<RefPtr<CacheFileHandle>> handles; |
| 3266 | mHandles.GetActiveHandles(&handles); |
| 3267 | |
| 3268 | for (uint32_t i = 0; i < handles.Length(); ++i) { |
| 3269 | CacheFileHandle* handle = handles[i]; |
| 3270 | |
| 3271 | const bool shouldRemove = [&] { |
| 3272 | nsAutoCString uriSpec; |
| 3273 | RefPtr<nsILoadContextInfo> info = |
| 3274 | CacheFileUtils::ParseKey(handle->Key(), nullptr, &uriSpec); |
| 3275 | if (!info) { |
| 3276 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot parse key " "in " "handle! [handle=%p, key=%s]", handle, handle->Key( ).get()); } } while (0) |
| 3277 | ("CacheFileIOManager::EvictByContextInternal() - Cannot parse key "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot parse key " "in " "handle! [handle=%p, key=%s]", handle, handle->Key( ).get()); } } while (0) |
| 3278 | "in "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot parse key " "in " "handle! [handle=%p, key=%s]", handle, handle->Key( ).get()); } } while (0) |
| 3279 | "handle! [handle=%p, key=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot parse key " "in " "handle! [handle=%p, key=%s]", handle, handle->Key( ).get()); } } while (0) |
| 3280 | handle, handle->Key().get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot parse key " "in " "handle! [handle=%p, key=%s]", handle, handle->Key( ).get()); } } while (0); |
| 3281 | MOZ_CRASH("Unexpected error!")do { do { } while (false); MOZ_ReportCrash("" "Unexpected error!" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3281); AnnotateMozCrashReason("MOZ_CRASH(" "Unexpected error!" ")"); do { *((volatile int*)__null) = 3281; __attribute__((nomerge )) ::abort(); } while (false); } while (false); |
| 3282 | } |
| 3283 | |
| 3284 | // Filter by base domain. |
| 3285 | if (!aBaseDomain.IsEmpty()) { |
| 3286 | if (StoragePrincipalHelper::PartitionKeyHasBaseDomain( |
| 3287 | info->OriginAttributesPtr()->mPartitionKey, aBaseDomain)) { |
| 3288 | return true; |
| 3289 | } |
| 3290 | |
| 3291 | // If the partitionKey does not match, check the entry URI next. |
| 3292 | |
| 3293 | // Get host portion of uriSpec. |
| 3294 | nsCOMPtr<nsIURI> uri; |
| 3295 | rv = NS_NewURI(getter_AddRefs(uri), uriSpec); |
| 3296 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3296)) { |
| 3297 | return false; |
| 3298 | } |
| 3299 | nsAutoCString host; |
| 3300 | rv = uri->GetHost(host); |
| 3301 | // Some entries may not have valid hosts. We can skip them. |
| 3302 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0))) || host.IsEmpty()) { |
| 3303 | return false; |
| 3304 | } |
| 3305 | |
| 3306 | // Clear entry if the host belongs to the given base domain. |
| 3307 | bool hasRootDomain = false; |
| 3308 | rv = HasRootDomain(host, baseDomain, &hasRootDomain); |
| 3309 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3309)) { |
| 3310 | return false; |
| 3311 | } |
| 3312 | |
| 3313 | return hasRootDomain; |
| 3314 | } |
| 3315 | |
| 3316 | // Filter by LoadContextInfo. |
| 3317 | if (aLoadContextInfo && !info->EqualsIgnoringFPD(aLoadContextInfo)) { |
| 3318 | return false; |
| 3319 | } |
| 3320 | |
| 3321 | // Filter by origin. |
| 3322 | if (!origin.IsEmpty()) { |
| 3323 | RefPtr<MozURL> url; |
| 3324 | rv = MozURL::Init(getter_AddRefs(url), uriSpec); |
| 3325 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3326 | return false; |
| 3327 | } |
| 3328 | |
| 3329 | nsAutoCString urlOrigin; |
| 3330 | url->Origin(urlOrigin); |
| 3331 | |
| 3332 | if (!urlOrigin.Equals(origin)) { |
| 3333 | return false; |
| 3334 | } |
| 3335 | } |
| 3336 | return true; |
| 3337 | }(); |
| 3338 | |
| 3339 | if (!shouldRemove) { |
| 3340 | continue; |
| 3341 | } |
| 3342 | |
| 3343 | // handle will be doomed only when pinning status is known and equal or |
| 3344 | // doom decision will be deferred until pinning status is determined. |
| 3345 | rv = DoomFileInternal(handle, |
| 3346 | aPinned ? CacheFileIOManager::DOOM_WHEN_PINNED |
| 3347 | : CacheFileIOManager::DOOM_WHEN_NON_PINNED); |
| 3348 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3348)) { |
| 3349 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot doom handle" " [handle=%p]", handle); } } while (0) |
| 3350 | ("CacheFileIOManager::EvictByContextInternal() - Cannot doom handle"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot doom handle" " [handle=%p]", handle); } } while (0) |
| 3351 | " [handle=%p]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot doom handle" " [handle=%p]", handle); } } while (0) |
| 3352 | handle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::EvictByContextInternal() - Cannot doom handle" " [handle=%p]", handle); } } while (0); |
| 3353 | } |
| 3354 | } |
| 3355 | |
| 3356 | if (!aLoadContextInfo) { |
| 3357 | RefPtr<EvictionNotifierRunnable> r = new EvictionNotifierRunnable(); |
| 3358 | NS_DispatchToMainThread(r); |
| 3359 | } |
| 3360 | |
| 3361 | if (!mContextEvictor) { |
| 3362 | mContextEvictor = new CacheFileContextEvictor(); |
| 3363 | mContextEvictor->Init(mCacheDirectory); |
| 3364 | } |
| 3365 | |
| 3366 | mContextEvictor->AddContext(aLoadContextInfo, aPinned, aOrigin); |
| 3367 | |
| 3368 | return NS_OK; |
| 3369 | } |
| 3370 | |
| 3371 | // static |
| 3372 | nsresult CacheFileIOManager::CacheIndexStateChanged() { |
| 3373 | LOG(("CacheFileIOManager::CacheIndexStateChanged()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::CacheIndexStateChanged()" ); } } while (0); |
| 3374 | |
| 3375 | nsresult rv; |
| 3376 | |
| 3377 | // CacheFileIOManager lives longer than CacheIndex so gInstance must be |
| 3378 | // non-null here. |
| 3379 | MOZ_ASSERT(gInstance)do { static_assert( mozilla::detail::AssertionConditionType< decltype(gInstance)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(gInstance))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("gInstance", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3379); AnnotateMozCrashReason("MOZ_ASSERT" "(" "gInstance" ")" ); do { *((volatile int*)__null) = 3379; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3380 | |
| 3381 | // We have to re-distatch even if we are on IO thread to prevent reentering |
| 3382 | // the lock in CacheIndex |
| 3383 | nsCOMPtr<nsIRunnable> ev = NewRunnableMethod( |
| 3384 | "net::CacheFileIOManager::CacheIndexStateChangedInternal", |
| 3385 | gInstance.get(), &CacheFileIOManager::CacheIndexStateChangedInternal); |
| 3386 | |
| 3387 | nsCOMPtr<nsIEventTarget> ioTarget = IOTarget(); |
| 3388 | MOZ_ASSERT(ioTarget)do { static_assert( mozilla::detail::AssertionConditionType< decltype(ioTarget)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(ioTarget))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("ioTarget", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3388); AnnotateMozCrashReason("MOZ_ASSERT" "(" "ioTarget" ")" ); do { *((volatile int*)__null) = 3388; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3389 | |
| 3390 | rv = ioTarget->Dispatch(ev, nsIEventTarget::DISPATCH_NORMAL); |
| 3391 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3391)) { |
| 3392 | return rv; |
| 3393 | } |
| 3394 | |
| 3395 | return NS_OK; |
| 3396 | } |
| 3397 | |
| 3398 | void CacheFileIOManager::CacheIndexStateChangedInternal() { |
| 3399 | if (mShuttingDown) { |
| 3400 | // ignore notification during shutdown |
| 3401 | return; |
| 3402 | } |
| 3403 | |
| 3404 | if (!mContextEvictor) { |
| 3405 | return; |
| 3406 | } |
| 3407 | |
| 3408 | mContextEvictor->CacheIndexStateChanged(); |
| 3409 | } |
| 3410 | |
| 3411 | nsresult CacheFileIOManager::TrashDirectory(nsIFile* aFile) { |
| 3412 | LOG(("CacheFileIOManager::TrashDirectory() [file=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() [file=%s]" , aFile->HumanReadablePath().get()); } } while (0) |
| 3413 | aFile->HumanReadablePath().get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() [file=%s]" , aFile->HumanReadablePath().get()); } } while (0); |
| 3414 | |
| 3415 | nsresult rv; |
| 3416 | |
| 3417 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3417); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3417; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3418 | MOZ_ASSERT(mCacheDirectory)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mCacheDirectory)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mCacheDirectory))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mCacheDirectory" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3418); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mCacheDirectory" ")"); do { *((volatile int*)__null) = 3418; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3419 | |
| 3420 | // When the directory is empty, it is cheaper to remove it directly instead of |
| 3421 | // using the trash mechanism. |
| 3422 | bool isEmpty; |
| 3423 | rv = IsEmptyDirectory(aFile, &isEmpty); |
| 3424 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3424); return rv; } } while (false); |
| 3425 | |
| 3426 | if (isEmpty) { |
| 3427 | rv = aFile->Remove(false); |
| 3428 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Directory removed " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 3429 | ("CacheFileIOManager::TrashDirectory() - Directory removed "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Directory removed " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 3430 | "[rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Directory removed " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 3431 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Directory removed " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 3432 | return rv; |
| 3433 | } |
| 3434 | |
| 3435 | #ifdef DEBUG1 |
| 3436 | nsCOMPtr<nsIFile> dirCheck; |
| 3437 | rv = aFile->GetParent(getter_AddRefs(dirCheck)); |
| 3438 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3438); return rv; } } while (false); |
| 3439 | |
| 3440 | bool equals = false; |
| 3441 | rv = dirCheck->Equals(mCacheDirectory, &equals); |
| 3442 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3442); return rv; } } while (false); |
| 3443 | |
| 3444 | MOZ_ASSERT(equals)do { static_assert( mozilla::detail::AssertionConditionType< decltype(equals)>::isValid, "invalid assertion condition") ; if ((__builtin_expect(!!(!(!!(equals))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("equals", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3444); AnnotateMozCrashReason("MOZ_ASSERT" "(" "equals" ")" ); do { *((volatile int*)__null) = 3444; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3445 | #endif |
| 3446 | |
| 3447 | nsCOMPtr<nsIFile> dir, trash; |
| 3448 | nsAutoCString leaf; |
| 3449 | |
| 3450 | rv = aFile->Clone(getter_AddRefs(dir)); |
| 3451 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3451); return rv; } } while (false); |
| 3452 | |
| 3453 | rv = aFile->Clone(getter_AddRefs(trash)); |
| 3454 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3454); return rv; } } while (false); |
| 3455 | |
| 3456 | const int32_t kMaxTries = 16; |
| 3457 | srand(static_cast<unsigned>(PR_Now())); |
| 3458 | for (int32_t triesCount = 0;; ++triesCount) { |
| 3459 | leaf = TRASH_DIR"trash"; |
| 3460 | leaf.AppendInt(rand()); |
| 3461 | rv = trash->SetNativeLeafName(leaf); |
| 3462 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3462); return rv; } } while (false); |
| 3463 | |
| 3464 | bool exists; |
| 3465 | if (NS_SUCCEEDED(trash->Exists(&exists))((bool)(__builtin_expect(!!(!NS_FAILED_impl(trash->Exists( &exists))), 1))) && !exists) { |
| 3466 | break; |
| 3467 | } |
| 3468 | |
| 3469 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Trash directory already " "exists [leaf=%s]", leaf.get()); } } while (0) |
| 3470 | ("CacheFileIOManager::TrashDirectory() - Trash directory already "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Trash directory already " "exists [leaf=%s]", leaf.get()); } } while (0) |
| 3471 | "exists [leaf=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Trash directory already " "exists [leaf=%s]", leaf.get()); } } while (0) |
| 3472 | leaf.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Trash directory already " "exists [leaf=%s]", leaf.get()); } } while (0); |
| 3473 | |
| 3474 | if (triesCount == kMaxTries) { |
| 3475 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Could not find unused trash " "directory in %d tries.", kMaxTries); } } while (0) |
| 3476 | ("CacheFileIOManager::TrashDirectory() - Could not find unused trash "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Could not find unused trash " "directory in %d tries.", kMaxTries); } } while (0) |
| 3477 | "directory in %d tries.",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Could not find unused trash " "directory in %d tries.", kMaxTries); } } while (0) |
| 3478 | kMaxTries))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Could not find unused trash " "directory in %d tries.", kMaxTries); } } while (0); |
| 3479 | return NS_ERROR_FAILURE; |
| 3480 | } |
| 3481 | } |
| 3482 | |
| 3483 | LOG(("CacheFileIOManager::TrashDirectory() - Renaming directory [leaf=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Renaming directory [leaf=%s]" , leaf.get()); } } while (0) |
| 3484 | leaf.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::TrashDirectory() - Renaming directory [leaf=%s]" , leaf.get()); } } while (0); |
| 3485 | |
| 3486 | rv = dir->MoveToNative(nullptr, leaf); |
| 3487 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3487); return rv; } } while (false); |
| 3488 | |
| 3489 | StartRemovingTrash(); |
| 3490 | return NS_OK; |
| 3491 | } |
| 3492 | |
| 3493 | // static |
| 3494 | void CacheFileIOManager::OnTrashTimer(nsITimer* aTimer, void* aClosure) { |
| 3495 | LOG(("CacheFileIOManager::OnTrashTimer() [timer=%p, closure=%p]", aTimer,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OnTrashTimer() [timer=%p, closure=%p]" , aTimer, aClosure); } } while (0) |
| 3496 | aClosure))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OnTrashTimer() [timer=%p, closure=%p]" , aTimer, aClosure); } } while (0); |
| 3497 | |
| 3498 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 3499 | |
| 3500 | if (!ioMan) { |
| 3501 | return; |
| 3502 | } |
| 3503 | |
| 3504 | ioMan->mTrashTimer = nullptr; |
| 3505 | ioMan->StartRemovingTrash(); |
| 3506 | } |
| 3507 | |
| 3508 | nsresult CacheFileIOManager::StartRemovingTrash() { |
| 3509 | LOG(("CacheFileIOManager::StartRemovingTrash()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::StartRemovingTrash()" ); } } while (0); |
| 3510 | |
| 3511 | nsresult rv; |
| 3512 | |
| 3513 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3513); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3513; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3514 | |
| 3515 | if (mShuttingDown) { |
| 3516 | return NS_ERROR_NOT_INITIALIZED; |
| 3517 | } |
| 3518 | |
| 3519 | if (!mCacheDirectory) { |
| 3520 | return NS_ERROR_FILE_INVALID_PATH; |
| 3521 | } |
| 3522 | |
| 3523 | if (mTrashTimer) { |
| 3524 | LOG(("CacheFileIOManager::StartRemovingTrash() - Trash timer exists."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::StartRemovingTrash() - Trash timer exists." ); } } while (0); |
| 3525 | return NS_OK; |
| 3526 | } |
| 3527 | |
| 3528 | if (mRemovingTrashDirs) { |
| 3529 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::StartRemovingTrash() - Trash removing in " "progress."); } } while (0) |
| 3530 | ("CacheFileIOManager::StartRemovingTrash() - Trash removing in "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::StartRemovingTrash() - Trash removing in " "progress."); } } while (0) |
| 3531 | "progress."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::StartRemovingTrash() - Trash removing in " "progress."); } } while (0); |
| 3532 | return NS_OK; |
| 3533 | } |
| 3534 | |
| 3535 | uint32_t elapsed = (TimeStamp::NowLoRes() - mStartTime).ToMilliseconds(); |
| 3536 | if (elapsed < kRemoveTrashStartDelay60000) { |
| 3537 | nsCOMPtr<nsIEventTarget> ioTarget = IOTarget(); |
| 3538 | MOZ_ASSERT(ioTarget)do { static_assert( mozilla::detail::AssertionConditionType< decltype(ioTarget)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(ioTarget))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("ioTarget", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3538); AnnotateMozCrashReason("MOZ_ASSERT" "(" "ioTarget" ")" ); do { *((volatile int*)__null) = 3538; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3539 | |
| 3540 | return NS_NewTimerWithFuncCallback( |
| 3541 | getter_AddRefs(mTrashTimer), CacheFileIOManager::OnTrashTimer, nullptr, |
| 3542 | kRemoveTrashStartDelay60000 - elapsed, nsITimer::TYPE_ONE_SHOT, |
| 3543 | "net::CacheFileIOManager::StartRemovingTrash", ioTarget); |
| 3544 | } |
| 3545 | |
| 3546 | nsCOMPtr<nsIRunnable> ev; |
| 3547 | ev = NewRunnableMethod("net::CacheFileIOManager::RemoveTrashInternal", this, |
| 3548 | &CacheFileIOManager::RemoveTrashInternal); |
| 3549 | |
| 3550 | rv = mIOThread->Dispatch(ev, CacheIOThread::EVICT); |
| 3551 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3551); return rv; } } while (false); |
| 3552 | |
| 3553 | mRemovingTrashDirs = true; |
| 3554 | return NS_OK; |
| 3555 | } |
| 3556 | |
| 3557 | nsresult CacheFileIOManager::RemoveTrashInternal() { |
| 3558 | LOG(("CacheFileIOManager::RemoveTrashInternal()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal()" ); } } while (0); |
| 3559 | |
| 3560 | nsresult rv; |
| 3561 | |
| 3562 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3562); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3562; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3563 | |
| 3564 | if (mShuttingDown) { |
| 3565 | return NS_ERROR_NOT_INITIALIZED; |
| 3566 | } |
| 3567 | |
| 3568 | CacheIOThread::Cancelable cancelable(true); |
| 3569 | |
| 3570 | MOZ_ASSERT(!mTrashTimer)do { static_assert( mozilla::detail::AssertionConditionType< decltype(!mTrashTimer)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!mTrashTimer))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("!mTrashTimer", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3570); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!mTrashTimer" ")"); do { *((volatile int*)__null) = 3570; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3571 | MOZ_ASSERT(mRemovingTrashDirs)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mRemovingTrashDirs)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mRemovingTrashDirs))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mRemovingTrashDirs" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3571); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mRemovingTrashDirs" ")"); do { *((volatile int*)__null) = 3571; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3572 | |
| 3573 | if (!mTreeCreated) { |
| 3574 | rv = CreateCacheTree(); |
| 3575 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3576 | return rv; |
| 3577 | } |
| 3578 | } |
| 3579 | |
| 3580 | // mRemovingTrashDirs is accessed only on IO thread, so we can drop the flag |
| 3581 | // here and set it again once we dispatch a continuation event. By doing so, |
| 3582 | // we don't have to drop the flag on any possible early return. |
| 3583 | mRemovingTrashDirs = false; |
| 3584 | |
| 3585 | while (true) { |
| 3586 | if (CacheIOThread::YieldAndRerun()) { |
| 3587 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Breaking loop for " "higher level events."); } } while (0) |
| 3588 | ("CacheFileIOManager::RemoveTrashInternal() - Breaking loop for "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Breaking loop for " "higher level events."); } } while (0) |
| 3589 | "higher level events."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Breaking loop for " "higher level events."); } } while (0); |
| 3590 | mRemovingTrashDirs = true; |
| 3591 | return NS_OK; |
| 3592 | } |
| 3593 | |
| 3594 | // Find some trash directory |
| 3595 | if (!mTrashDir) { |
| 3596 | MOZ_ASSERT(!mTrashDirEnumerator)do { static_assert( mozilla::detail::AssertionConditionType< decltype(!mTrashDirEnumerator)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!mTrashDirEnumerator))), 0)) ) { do { } while (false); MOZ_ReportAssertionFailure("!mTrashDirEnumerator" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3596); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!mTrashDirEnumerator" ")"); do { *((volatile int*)__null) = 3596; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3597 | |
| 3598 | rv = FindTrashDirToRemove(); |
| 3599 | if (rv == NS_ERROR_NOT_AVAILABLE) { |
| 3600 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - No trash directory " "found."); } } while (0) |
| 3601 | ("CacheFileIOManager::RemoveTrashInternal() - No trash directory "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - No trash directory " "found."); } } while (0) |
| 3602 | "found."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - No trash directory " "found."); } } while (0); |
| 3603 | return NS_OK; |
| 3604 | } |
| 3605 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3605); return rv; } } while (false); |
| 3606 | |
| 3607 | rv = mTrashDir->GetDirectoryEntries(getter_AddRefs(mTrashDirEnumerator)); |
| 3608 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3608); return rv; } } while (false); |
| 3609 | |
| 3610 | continue; // check elapsed time |
| 3611 | } |
| 3612 | |
| 3613 | // We null out mTrashDirEnumerator once we remove all files in the |
| 3614 | // directory, so remove the trash directory if we don't have enumerator. |
| 3615 | if (!mTrashDirEnumerator) { |
| 3616 | rv = mTrashDir->Remove(false); |
| 3617 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3618 | // There is no reason why removing an empty directory should fail, but |
| 3619 | // if it does, we should continue and try to remove all other trash |
| 3620 | // directories. |
| 3621 | nsAutoCString leafName; |
| 3622 | mTrashDir->GetNativeLeafName(leafName); |
| 3623 | mFailedTrashDirs.AppendElement(leafName); |
| 3624 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Cannot remove " "trashdir. [name=%s]", leafName.get()); } } while (0) |
| 3625 | ("CacheFileIOManager::RemoveTrashInternal() - Cannot remove "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Cannot remove " "trashdir. [name=%s]", leafName.get()); } } while (0) |
| 3626 | "trashdir. [name=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Cannot remove " "trashdir. [name=%s]", leafName.get()); } } while (0) |
| 3627 | leafName.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Cannot remove " "trashdir. [name=%s]", leafName.get()); } } while (0); |
| 3628 | } |
| 3629 | |
| 3630 | mTrashDir = nullptr; |
| 3631 | continue; // check elapsed time |
| 3632 | } |
| 3633 | |
| 3634 | nsCOMPtr<nsIFile> file; |
| 3635 | rv = mTrashDirEnumerator->GetNextFile(getter_AddRefs(file)); |
Value stored to 'rv' is never read | |
| 3636 | if (!file) { |
| 3637 | mTrashDirEnumerator->Close(); |
| 3638 | mTrashDirEnumerator = nullptr; |
| 3639 | continue; // check elapsed time |
| 3640 | } |
| 3641 | bool isDir = false; |
| 3642 | file->IsDirectory(&isDir); |
| 3643 | if (isDir) { |
| 3644 | NS_WARNING(NS_DebugBreak(NS_DEBUG_WARNING, "Found a directory in a trash directory! It will be removed " "recursively, but this can block IO thread for a while!", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3646) |
| 3645 | "Found a directory in a trash directory! It will be removed "NS_DebugBreak(NS_DEBUG_WARNING, "Found a directory in a trash directory! It will be removed " "recursively, but this can block IO thread for a while!", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3646) |
| 3646 | "recursively, but this can block IO thread for a while!")NS_DebugBreak(NS_DEBUG_WARNING, "Found a directory in a trash directory! It will be removed " "recursively, but this can block IO thread for a while!", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3646); |
| 3647 | if (LOG_ENABLED()(__builtin_expect(!!(mozilla::detail::log_test(gCache2Log, mozilla ::LogLevel::Debug)), 0))) { |
| 3648 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0) |
| 3649 | ("CacheFileIOManager::RemoveTrashInternal() - Found a directory in "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0) |
| 3650 | "a trash "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0) |
| 3651 | "directory! It will be removed recursively, but this can block IO "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0) |
| 3652 | "thread for a while! [file=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0) |
| 3653 | file->HumanReadablePath().get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::RemoveTrashInternal() - Found a directory in " "a trash " "directory! It will be removed recursively, but this can block IO " "thread for a while! [file=%s]", file->HumanReadablePath( ).get()); } } while (0); |
| 3654 | } |
| 3655 | } |
| 3656 | file->Remove(isDir); |
| 3657 | } |
| 3658 | |
| 3659 | MOZ_ASSERT_UNREACHABLE("We should never get here")do { static_assert( mozilla::detail::AssertionConditionType< decltype(false)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(false))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("false" " (" "MOZ_ASSERT_UNREACHABLE: " "We should never get here" ")", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3659); AnnotateMozCrashReason("MOZ_ASSERT" "(" "false" ") (" "MOZ_ASSERT_UNREACHABLE: " "We should never get here" ")"); do { *((volatile int*)__null) = 3659; __attribute__((nomerge)) :: abort(); } while (false); } } while (false); |
| 3660 | return NS_OK; |
| 3661 | } |
| 3662 | |
| 3663 | nsresult CacheFileIOManager::FindTrashDirToRemove() { |
| 3664 | LOG(("CacheFileIOManager::FindTrashDirToRemove()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::FindTrashDirToRemove()" ); } } while (0); |
| 3665 | |
| 3666 | nsresult rv; |
| 3667 | |
| 3668 | if (!mCacheDirectory) { |
| 3669 | return NS_ERROR_UNEXPECTED; |
| 3670 | } |
| 3671 | |
| 3672 | // We call this method on the main thread during shutdown when user wants to |
| 3673 | // remove all cache files. |
| 3674 | MOZ_ASSERT(mIOThread->IsCurrentThread() || mShuttingDown)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread() || mShuttingDown)> ::isValid, "invalid assertion condition"); if ((__builtin_expect (!!(!(!!(mIOThread->IsCurrentThread() || mShuttingDown))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mIOThread->IsCurrentThread() || mShuttingDown" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3674); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread() || mShuttingDown" ")"); do { *((volatile int*)__null) = 3674; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3675 | |
| 3676 | nsCOMPtr<nsIDirectoryEnumerator> iter; |
| 3677 | rv = mCacheDirectory->GetDirectoryEntries(getter_AddRefs(iter)); |
| 3678 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3678); return rv; } } while (false); |
| 3679 | |
| 3680 | nsCOMPtr<nsIFile> file; |
| 3681 | while (NS_SUCCEEDED(iter->GetNextFile(getter_AddRefs(file)))((bool)(__builtin_expect(!!(!NS_FAILED_impl(iter->GetNextFile (getter_AddRefs(file)))), 1))) && file) { |
| 3682 | bool isDir = false; |
| 3683 | file->IsDirectory(&isDir); |
| 3684 | if (!isDir) { |
| 3685 | continue; |
| 3686 | } |
| 3687 | |
| 3688 | nsAutoCString leafName; |
| 3689 | rv = file->GetNativeLeafName(leafName); |
| 3690 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3691 | continue; |
| 3692 | } |
| 3693 | |
| 3694 | if (leafName.Length() < strlen(TRASH_DIR"trash")) { |
| 3695 | continue; |
| 3696 | } |
| 3697 | |
| 3698 | if (!StringBeginsWith(leafName, nsLiteralCString(TRASH_DIR"trash"))) { |
| 3699 | continue; |
| 3700 | } |
| 3701 | |
| 3702 | if (mFailedTrashDirs.Contains(leafName)) { |
| 3703 | continue; |
| 3704 | } |
| 3705 | |
| 3706 | LOG(("CacheFileIOManager::FindTrashDirToRemove() - Returning directory %s",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::FindTrashDirToRemove() - Returning directory %s" , leafName.get()); } } while (0) |
| 3707 | leafName.get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::FindTrashDirToRemove() - Returning directory %s" , leafName.get()); } } while (0); |
| 3708 | |
| 3709 | mTrashDir = file; |
| 3710 | return NS_OK; |
| 3711 | } |
| 3712 | |
| 3713 | // When we're here we've tried to delete all trash directories. Clear |
| 3714 | // mFailedTrashDirs so we will try to delete them again when we start removing |
| 3715 | // trash directories next time. |
| 3716 | mFailedTrashDirs.Clear(); |
| 3717 | return NS_ERROR_NOT_AVAILABLE; |
| 3718 | } |
| 3719 | |
| 3720 | // static |
| 3721 | nsresult CacheFileIOManager::InitIndexEntry(CacheFileHandle* aHandle, |
| 3722 | OriginAttrsHash aOriginAttrsHash, |
| 3723 | bool aAnonymous, bool aPinning) { |
| 3724 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::InitIndexEntry() [handle=%p, " "originAttrsHash=%" "l" "x" ", " "anonymous=%d, pinning=%d]" , aHandle, aOriginAttrsHash, aAnonymous, aPinning); } } while (0) |
| 3725 | ("CacheFileIOManager::InitIndexEntry() [handle=%p, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::InitIndexEntry() [handle=%p, " "originAttrsHash=%" "l" "x" ", " "anonymous=%d, pinning=%d]" , aHandle, aOriginAttrsHash, aAnonymous, aPinning); } } while (0) |
| 3726 | "originAttrsHash=%" PRIx64 ", "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::InitIndexEntry() [handle=%p, " "originAttrsHash=%" "l" "x" ", " "anonymous=%d, pinning=%d]" , aHandle, aOriginAttrsHash, aAnonymous, aPinning); } } while (0) |
| 3727 | "anonymous=%d, pinning=%d]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::InitIndexEntry() [handle=%p, " "originAttrsHash=%" "l" "x" ", " "anonymous=%d, pinning=%d]" , aHandle, aOriginAttrsHash, aAnonymous, aPinning); } } while (0) |
| 3728 | aHandle, aOriginAttrsHash, aAnonymous, aPinning))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::InitIndexEntry() [handle=%p, " "originAttrsHash=%" "l" "x" ", " "anonymous=%d, pinning=%d]" , aHandle, aOriginAttrsHash, aAnonymous, aPinning); } } while (0); |
| 3729 | |
| 3730 | nsresult rv; |
| 3731 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 3732 | |
| 3733 | if (aHandle->IsClosed() || !ioMan) { |
| 3734 | return NS_ERROR_NOT_INITIALIZED; |
| 3735 | } |
| 3736 | |
| 3737 | if (aHandle->IsSpecialFile()) { |
| 3738 | return NS_ERROR_UNEXPECTED; |
| 3739 | } |
| 3740 | |
| 3741 | RefPtr<InitIndexEntryEvent> ev = |
| 3742 | new InitIndexEntryEvent(aHandle, aOriginAttrsHash, aAnonymous, aPinning); |
| 3743 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 3744 | ? CacheIOThread::WRITE_PRIORITY |
| 3745 | : CacheIOThread::WRITE); |
| 3746 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3746); return rv; } } while (false); |
| 3747 | |
| 3748 | return NS_OK; |
| 3749 | } |
| 3750 | |
| 3751 | // static |
| 3752 | nsresult CacheFileIOManager::UpdateIndexEntry(CacheFileHandle* aHandle, |
| 3753 | const uint32_t* aFrecency, |
| 3754 | const bool* aHasAltData, |
| 3755 | const uint16_t* aOnStartTime, |
| 3756 | const uint16_t* aOnStopTime, |
| 3757 | const uint8_t* aContentType) { |
| 3758 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3759 | ("CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3760 | "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3761 | aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get() : "",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3762 | aHasAltData ? (*aHasAltData ? "true" : "false") : "",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3763 | aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3764 | aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0) |
| 3765 | aContentType ? nsPrintfCString("%u", *aContentType).get() : ""))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateIndexEntry() [handle=%p, frecency=%s, " "hasAltData=%s, onStartTime=%s, onStopTime=%s, contentType=%s]" , aHandle, aFrecency ? nsPrintfCString("%u", *aFrecency).get( ) : "", aHasAltData ? (*aHasAltData ? "true" : "false") : "", aOnStartTime ? nsPrintfCString("%u", *aOnStartTime).get() : "" , aOnStopTime ? nsPrintfCString("%u", *aOnStopTime).get() : "" , aContentType ? nsPrintfCString("%u", *aContentType).get() : ""); } } while (0); |
| 3766 | |
| 3767 | nsresult rv; |
| 3768 | RefPtr<CacheFileIOManager> ioMan = gInstance; |
| 3769 | |
| 3770 | if (aHandle->IsClosed() || !ioMan) { |
| 3771 | return NS_ERROR_NOT_INITIALIZED; |
| 3772 | } |
| 3773 | |
| 3774 | if (aHandle->IsSpecialFile()) { |
| 3775 | return NS_ERROR_UNEXPECTED; |
| 3776 | } |
| 3777 | |
| 3778 | RefPtr<UpdateIndexEntryEvent> ev = new UpdateIndexEntryEvent( |
| 3779 | aHandle, aFrecency, aHasAltData, aOnStartTime, aOnStopTime, aContentType); |
| 3780 | rv = ioMan->mIOThread->Dispatch(ev, aHandle->mPriority |
| 3781 | ? CacheIOThread::WRITE_PRIORITY |
| 3782 | : CacheIOThread::WRITE); |
| 3783 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3783); return rv; } } while (false); |
| 3784 | |
| 3785 | return NS_OK; |
| 3786 | } |
| 3787 | |
| 3788 | nsresult CacheFileIOManager::CreateFile(CacheFileHandle* aHandle) { |
| 3789 | MOZ_ASSERT(!aHandle->mFD)do { static_assert( mozilla::detail::AssertionConditionType< decltype(!aHandle->mFD)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!aHandle->mFD))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("!aHandle->mFD" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3789); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!aHandle->mFD" ")"); do { *((volatile int*)__null) = 3789; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3790 | MOZ_ASSERT(aHandle->mFile)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHandle->mFile)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aHandle->mFile))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("aHandle->mFile" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3790); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHandle->mFile" ")"); do { *((volatile int*)__null) = 3790; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3791 | |
| 3792 | nsresult rv; |
| 3793 | |
| 3794 | if (aHandle->IsDoomed()) { |
| 3795 | nsCOMPtr<nsIFile> file; |
| 3796 | |
| 3797 | rv = GetDoomedFile(getter_AddRefs(file)); |
| 3798 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3798); return rv; } } while (false); |
| 3799 | |
| 3800 | aHandle->mFile.swap(file); |
| 3801 | } else { |
| 3802 | bool exists; |
| 3803 | if (NS_SUCCEEDED(aHandle->mFile->Exists(&exists))((bool)(__builtin_expect(!!(!NS_FAILED_impl(aHandle->mFile ->Exists(&exists))), 1))) && exists) { |
| 3804 | NS_WARNING("Found a file that should not exist!")NS_DebugBreak(NS_DEBUG_WARNING, "Found a file that should not exist!" , nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3804); |
| 3805 | } |
| 3806 | } |
| 3807 | |
| 3808 | rv = OpenNSPRHandle(aHandle, true); |
| 3809 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3809); return rv; } } while (false); |
| 3810 | |
| 3811 | aHandle->mFileSize = 0; |
| 3812 | return NS_OK; |
| 3813 | } |
| 3814 | |
| 3815 | // static |
| 3816 | void CacheFileIOManager::HashToStr(const SHA1Sum::Hash* aHash, |
| 3817 | nsACString& _retval) { |
| 3818 | _retval.Truncate(); |
| 3819 | const char hexChars[] = {'0', '1', '2', '3', '4', '5', '6', '7', |
| 3820 | '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'}; |
| 3821 | for (uint32_t i = 0; i < sizeof(SHA1Sum::Hash); i++) { |
| 3822 | _retval.Append(hexChars[(*aHash)[i] >> 4]); |
| 3823 | _retval.Append(hexChars[(*aHash)[i] & 0xF]); |
| 3824 | } |
| 3825 | } |
| 3826 | |
| 3827 | // static |
| 3828 | nsresult CacheFileIOManager::StrToHash(const nsACString& aHash, |
| 3829 | SHA1Sum::Hash* _retval) { |
| 3830 | if (aHash.Length() != 2 * sizeof(SHA1Sum::Hash)) { |
| 3831 | return NS_ERROR_INVALID_ARG; |
| 3832 | } |
| 3833 | |
| 3834 | for (uint32_t i = 0; i < aHash.Length(); i++) { |
| 3835 | uint8_t value; |
| 3836 | |
| 3837 | if (aHash[i] >= '0' && aHash[i] <= '9') { |
| 3838 | value = aHash[i] - '0'; |
| 3839 | } else if (aHash[i] >= 'A' && aHash[i] <= 'F') { |
| 3840 | value = aHash[i] - 'A' + 10; |
| 3841 | } else if (aHash[i] >= 'a' && aHash[i] <= 'f') { |
| 3842 | value = aHash[i] - 'a' + 10; |
| 3843 | } else { |
| 3844 | return NS_ERROR_INVALID_ARG; |
| 3845 | } |
| 3846 | |
| 3847 | if (i % 2 == 0) { |
| 3848 | (reinterpret_cast<uint8_t*>(_retval))[i / 2] = value << 4; |
| 3849 | } else { |
| 3850 | (reinterpret_cast<uint8_t*>(_retval))[i / 2] += value; |
| 3851 | } |
| 3852 | } |
| 3853 | |
| 3854 | return NS_OK; |
| 3855 | } |
| 3856 | |
| 3857 | nsresult CacheFileIOManager::GetFile(const SHA1Sum::Hash* aHash, |
| 3858 | nsIFile** _retval) { |
| 3859 | nsresult rv; |
| 3860 | nsCOMPtr<nsIFile> file; |
| 3861 | rv = mCacheDirectory->Clone(getter_AddRefs(file)); |
| 3862 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3862); return rv; } } while (false); |
| 3863 | |
| 3864 | rv = file->AppendNative(nsLiteralCString(ENTRIES_DIR"entries")); |
| 3865 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3865); return rv; } } while (false); |
| 3866 | |
| 3867 | nsAutoCString leafName; |
| 3868 | HashToStr(aHash, leafName); |
| 3869 | |
| 3870 | rv = file->AppendNative(leafName); |
| 3871 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3871); return rv; } } while (false); |
| 3872 | |
| 3873 | file.swap(*_retval); |
| 3874 | return NS_OK; |
| 3875 | } |
| 3876 | |
| 3877 | nsresult CacheFileIOManager::GetSpecialFile(const nsACString& aKey, |
| 3878 | nsIFile** _retval) { |
| 3879 | nsresult rv; |
| 3880 | nsCOMPtr<nsIFile> file; |
| 3881 | rv = mCacheDirectory->Clone(getter_AddRefs(file)); |
| 3882 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3882); return rv; } } while (false); |
| 3883 | |
| 3884 | rv = file->AppendNative(aKey); |
| 3885 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3885); return rv; } } while (false); |
| 3886 | |
| 3887 | file.swap(*_retval); |
| 3888 | return NS_OK; |
| 3889 | } |
| 3890 | |
| 3891 | nsresult CacheFileIOManager::GetDoomedFile(nsIFile** _retval) { |
| 3892 | nsresult rv; |
| 3893 | nsCOMPtr<nsIFile> file; |
| 3894 | rv = mCacheDirectory->Clone(getter_AddRefs(file)); |
| 3895 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3895); return rv; } } while (false); |
| 3896 | |
| 3897 | rv = file->AppendNative(nsLiteralCString(DOOMED_DIR"doomed")); |
| 3898 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3898); return rv; } } while (false); |
| 3899 | |
| 3900 | rv = file->AppendNative("dummyleaf"_ns); |
| 3901 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3901); return rv; } } while (false); |
| 3902 | |
| 3903 | const int32_t kMaxTries = 64; |
| 3904 | srand(static_cast<unsigned>(PR_Now())); |
| 3905 | nsAutoCString leafName; |
| 3906 | for (int32_t triesCount = 0;; ++triesCount) { |
| 3907 | leafName.AppendInt(rand()); |
| 3908 | rv = file->SetNativeLeafName(leafName); |
| 3909 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3909); return rv; } } while (false); |
| 3910 | |
| 3911 | bool exists; |
| 3912 | if (NS_SUCCEEDED(file->Exists(&exists))((bool)(__builtin_expect(!!(!NS_FAILED_impl(file->Exists(& exists))), 1))) && !exists) { |
| 3913 | break; |
| 3914 | } |
| 3915 | |
| 3916 | if (triesCount == kMaxTries) { |
| 3917 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::GetDoomedFile() - Could not find unused file " "name in %d tries.", kMaxTries); } } while (0) |
| 3918 | ("CacheFileIOManager::GetDoomedFile() - Could not find unused file "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::GetDoomedFile() - Could not find unused file " "name in %d tries.", kMaxTries); } } while (0) |
| 3919 | "name in %d tries.",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::GetDoomedFile() - Could not find unused file " "name in %d tries.", kMaxTries); } } while (0) |
| 3920 | kMaxTries))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::GetDoomedFile() - Could not find unused file " "name in %d tries.", kMaxTries); } } while (0); |
| 3921 | return NS_ERROR_FAILURE; |
| 3922 | } |
| 3923 | |
| 3924 | leafName.Truncate(); |
| 3925 | } |
| 3926 | |
| 3927 | file.swap(*_retval); |
| 3928 | return NS_OK; |
| 3929 | } |
| 3930 | |
| 3931 | nsresult CacheFileIOManager::IsEmptyDirectory(nsIFile* aFile, bool* _retval) { |
| 3932 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3932); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 3932; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 3933 | |
| 3934 | nsresult rv; |
| 3935 | |
| 3936 | nsCOMPtr<nsIDirectoryEnumerator> enumerator; |
| 3937 | rv = aFile->GetDirectoryEntries(getter_AddRefs(enumerator)); |
| 3938 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3938); return rv; } } while (false); |
| 3939 | |
| 3940 | bool hasMoreElements = false; |
| 3941 | rv = enumerator->HasMoreElements(&hasMoreElements); |
| 3942 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3942); return rv; } } while (false); |
| 3943 | |
| 3944 | *_retval = !hasMoreElements; |
| 3945 | return NS_OK; |
| 3946 | } |
| 3947 | |
| 3948 | nsresult CacheFileIOManager::CheckAndCreateDir(nsIFile* aFile, const char* aDir, |
| 3949 | bool aEnsureEmptyDir) { |
| 3950 | nsresult rv; |
| 3951 | |
| 3952 | nsCOMPtr<nsIFile> file; |
| 3953 | if (!aDir) { |
| 3954 | file = aFile; |
| 3955 | } else { |
| 3956 | nsAutoCString dir(aDir); |
| 3957 | rv = aFile->Clone(getter_AddRefs(file)); |
| 3958 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3958); return rv; } } while (false); |
| 3959 | rv = file->AppendNative(dir); |
| 3960 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3960); return rv; } } while (false); |
| 3961 | } |
| 3962 | |
| 3963 | bool exists = false; |
| 3964 | rv = file->Exists(&exists); |
| 3965 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1))) && exists) { |
| 3966 | bool isDirectory = false; |
| 3967 | rv = file->IsDirectory(&isDirectory); |
| 3968 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0))) || !isDirectory) { |
| 3969 | // Try to remove the file |
| 3970 | rv = file->Remove(false); |
| 3971 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 3972 | exists = false; |
| 3973 | } |
| 3974 | } |
| 3975 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3975); return rv; } } while (false); |
| 3976 | } |
| 3977 | |
| 3978 | if (aEnsureEmptyDir && NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1))) && exists) { |
| 3979 | bool isEmpty; |
| 3980 | rv = IsEmptyDirectory(file, &isEmpty); |
| 3981 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3981); return rv; } } while (false); |
| 3982 | |
| 3983 | if (!isEmpty) { |
| 3984 | // Don't check the result, if this fails, it's OK. We do this |
| 3985 | // only for the doomed directory that doesn't need to be deleted |
| 3986 | // for the cost of completely disabling the whole browser. |
| 3987 | TrashDirectory(file); |
| 3988 | } |
| 3989 | } |
| 3990 | |
| 3991 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1))) && !exists) { |
| 3992 | rv = file->Create(nsIFile::DIRECTORY_TYPE, 0700); |
| 3993 | } |
| 3994 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 3995 | NS_WARNING("Cannot create directory")NS_DebugBreak(NS_DEBUG_WARNING, "Cannot create directory", nullptr , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 3995); |
| 3996 | return NS_ERROR_FAILURE; |
| 3997 | } |
| 3998 | |
| 3999 | return NS_OK; |
| 4000 | } |
| 4001 | |
| 4002 | nsresult CacheFileIOManager::CreateCacheTree() { |
| 4003 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4003); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 4003; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4004 | MOZ_ASSERT(!mTreeCreated)do { static_assert( mozilla::detail::AssertionConditionType< decltype(!mTreeCreated)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!mTreeCreated))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("!mTreeCreated", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4004); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!mTreeCreated" ")"); do { *((volatile int*)__null) = 4004; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4005 | |
| 4006 | if (!mCacheDirectory || mTreeCreationFailed) { |
| 4007 | return NS_ERROR_FILE_INVALID_PATH; |
| 4008 | } |
| 4009 | |
| 4010 | nsresult rv; |
| 4011 | |
| 4012 | // Set the flag here and clear it again below when the tree is created |
| 4013 | // successfully. |
| 4014 | mTreeCreationFailed = true; |
| 4015 | |
| 4016 | // ensure parent directory exists |
| 4017 | nsCOMPtr<nsIFile> parentDir; |
| 4018 | rv = mCacheDirectory->GetParent(getter_AddRefs(parentDir)); |
| 4019 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4019); return rv; } } while (false); |
| 4020 | rv = CheckAndCreateDir(parentDir, nullptr, false); |
| 4021 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4021); return rv; } } while (false); |
| 4022 | |
| 4023 | // ensure cache directory exists |
| 4024 | rv = CheckAndCreateDir(mCacheDirectory, nullptr, false); |
| 4025 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4025); return rv; } } while (false); |
| 4026 | |
| 4027 | // ensure entries directory exists |
| 4028 | rv = CheckAndCreateDir(mCacheDirectory, ENTRIES_DIR"entries", false); |
| 4029 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4029); return rv; } } while (false); |
| 4030 | |
| 4031 | // ensure doomed directory exists |
| 4032 | rv = CheckAndCreateDir(mCacheDirectory, DOOMED_DIR"doomed", true); |
| 4033 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4033); return rv; } } while (false); |
| 4034 | |
| 4035 | mTreeCreated = true; |
| 4036 | mTreeCreationFailed = false; |
| 4037 | |
| 4038 | if (!mContextEvictor) { |
| 4039 | RefPtr<CacheFileContextEvictor> contextEvictor; |
| 4040 | contextEvictor = new CacheFileContextEvictor(); |
| 4041 | |
| 4042 | // Init() method will try to load unfinished contexts from the disk. Store |
| 4043 | // the evictor as a member only when there is some unfinished job. |
| 4044 | contextEvictor->Init(mCacheDirectory); |
| 4045 | if (contextEvictor->ContextsCount()) { |
| 4046 | contextEvictor.swap(mContextEvictor); |
| 4047 | } |
| 4048 | } |
| 4049 | |
| 4050 | StartRemovingTrash(); |
| 4051 | |
| 4052 | return NS_OK; |
| 4053 | } |
| 4054 | |
| 4055 | nsresult CacheFileIOManager::OpenNSPRHandle(CacheFileHandle* aHandle, |
| 4056 | bool aCreate) { |
| 4057 | LOG(("CacheFileIOManager::OpenNSPRHandle BEGIN, handle=%p", aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle BEGIN, handle=%p" , aHandle); } } while (0); |
| 4058 | |
| 4059 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4059); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 4059; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4060 | MOZ_ASSERT(!aHandle->mFD)do { static_assert( mozilla::detail::AssertionConditionType< decltype(!aHandle->mFD)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(!aHandle->mFD))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("!aHandle->mFD" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4060); AnnotateMozCrashReason("MOZ_ASSERT" "(" "!aHandle->mFD" ")"); do { *((volatile int*)__null) = 4060; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4061 | MOZ_ASSERT(mHandlesByLastUsed.IndexOf(aHandle) == mHandlesByLastUsed.NoIndex)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mHandlesByLastUsed.IndexOf(aHandle) == mHandlesByLastUsed .NoIndex)>::isValid, "invalid assertion condition"); if (( __builtin_expect(!!(!(!!(mHandlesByLastUsed.IndexOf(aHandle) == mHandlesByLastUsed.NoIndex))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mHandlesByLastUsed.IndexOf(aHandle) == mHandlesByLastUsed.NoIndex" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4061); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mHandlesByLastUsed.IndexOf(aHandle) == mHandlesByLastUsed.NoIndex" ")"); do { *((volatile int*)__null) = 4061; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4062 | MOZ_ASSERT(mHandlesByLastUsed.Length() <= kOpenHandlesLimit)do { static_assert( mozilla::detail::AssertionConditionType< decltype(mHandlesByLastUsed.Length() <= 128)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(! !(mHandlesByLastUsed.Length() <= 128))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("mHandlesByLastUsed.Length() <= 128" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4062); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mHandlesByLastUsed.Length() <= 128" ")"); do { *((volatile int*)__null) = 4062; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4063 | MOZ_ASSERT((aCreate && !aHandle->mFileExists) ||do { static_assert( mozilla::detail::AssertionConditionType< decltype((aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists))>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!((aCreate && !aHandle ->mFileExists) || (!aCreate && aHandle->mFileExists )))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("(aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists)" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4064); AnnotateMozCrashReason("MOZ_ASSERT" "(" "(aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists)" ")"); do { *((volatile int*)__null) = 4064; __attribute__((nomerge )) ::abort(); } while (false); } } while (false) |
| 4064 | (!aCreate && aHandle->mFileExists))do { static_assert( mozilla::detail::AssertionConditionType< decltype((aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists))>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!((aCreate && !aHandle ->mFileExists) || (!aCreate && aHandle->mFileExists )))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("(aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists)" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4064); AnnotateMozCrashReason("MOZ_ASSERT" "(" "(aCreate && !aHandle->mFileExists) || (!aCreate && aHandle->mFileExists)" ")"); do { *((volatile int*)__null) = 4064; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4065 | |
| 4066 | nsresult rv; |
| 4067 | |
| 4068 | if (mHandlesByLastUsed.Length() == kOpenHandlesLimit128) { |
| 4069 | // close handle that hasn't been used for the longest time |
| 4070 | rv = MaybeReleaseNSPRHandleInternal(mHandlesByLastUsed[0], true); |
| 4071 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4071); return rv; } } while (false); |
| 4072 | } |
| 4073 | |
| 4074 | if (aCreate) { |
| 4075 | rv = aHandle->mFile->OpenNSPRFileDesc( |
| 4076 | PR_RDWR0x04 | PR_CREATE_FILE0x08 | PR_TRUNCATE0x20, 0600, &aHandle->mFD); |
| 4077 | if (rv == NS_ERROR_FILE_ALREADY_EXISTS || // error from nsLocalFileWin |
| 4078 | rv == NS_ERROR_FILE_NO_DEVICE_SPACE) { // error from nsLocalFileUnix |
| 4079 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we" " might reached a limit on FAT32. Will evict a single entry and try " "again. [hash=%08x%08x%08x%08x%08x]", PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 4080 | ("CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we" " might reached a limit on FAT32. Will evict a single entry and try " "again. [hash=%08x%08x%08x%08x%08x]", PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 4081 | " might reached a limit on FAT32. Will evict a single entry and try "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we" " might reached a limit on FAT32. Will evict a single entry and try " "again. [hash=%08x%08x%08x%08x%08x]", PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 4082 | "again. [hash=%08x%08x%08x%08x%08x]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we" " might reached a limit on FAT32. Will evict a single entry and try " "again. [hash=%08x%08x%08x%08x%08x]", PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0) |
| 4083 | LOGSHA1(aHandle->Hash())))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Cannot create a new file, we" " might reached a limit on FAT32. Will evict a single entry and try " "again. [hash=%08x%08x%08x%08x%08x]", PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[0]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[1]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[2]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[3]), PR_htonl((reinterpret_cast <const uint32_t*>(aHandle->Hash()))[4])); } } while ( 0); |
| 4084 | |
| 4085 | SHA1Sum::Hash hash; |
| 4086 | uint32_t cnt; |
| 4087 | |
| 4088 | rv = CacheIndex::GetEntryForEviction(true, &hash, &cnt); |
| 4089 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 4090 | rv = DoomFileByKeyInternal(&hash); |
| 4091 | } |
| 4092 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 4093 | rv = aHandle->mFile->OpenNSPRFileDesc( |
| 4094 | PR_RDWR0x04 | PR_CREATE_FILE0x08 | PR_TRUNCATE0x20, 0600, &aHandle->mFD); |
| 4095 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Successfully evicted entry" " with hash %08x%08x%08x%08x%08x. %s to create the new file." , PR_htonl((reinterpret_cast<const uint32_t*>(&hash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(& hash))[1]), PR_htonl((reinterpret_cast<const uint32_t*> (&hash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[4]), ((bool)(__builtin_expect(!!(!NS_FAILED_impl (rv)), 1))) ? "Succeeded" : "Failed"); } } while (0) |
| 4096 | ("CacheFileIOManager::OpenNSPRHandle() - Successfully evicted entry"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Successfully evicted entry" " with hash %08x%08x%08x%08x%08x. %s to create the new file." , PR_htonl((reinterpret_cast<const uint32_t*>(&hash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(& hash))[1]), PR_htonl((reinterpret_cast<const uint32_t*> (&hash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[4]), ((bool)(__builtin_expect(!!(!NS_FAILED_impl (rv)), 1))) ? "Succeeded" : "Failed"); } } while (0) |
| 4097 | " with hash %08x%08x%08x%08x%08x. %s to create the new file.",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Successfully evicted entry" " with hash %08x%08x%08x%08x%08x. %s to create the new file." , PR_htonl((reinterpret_cast<const uint32_t*>(&hash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(& hash))[1]), PR_htonl((reinterpret_cast<const uint32_t*> (&hash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[4]), ((bool)(__builtin_expect(!!(!NS_FAILED_impl (rv)), 1))) ? "Succeeded" : "Failed"); } } while (0) |
| 4098 | LOGSHA1(&hash), NS_SUCCEEDED(rv) ? "Succeeded" : "Failed"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Successfully evicted entry" " with hash %08x%08x%08x%08x%08x. %s to create the new file." , PR_htonl((reinterpret_cast<const uint32_t*>(&hash ))[0]), PR_htonl((reinterpret_cast<const uint32_t*>(& hash))[1]), PR_htonl((reinterpret_cast<const uint32_t*> (&hash))[2]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[3]), PR_htonl((reinterpret_cast<const uint32_t *>(&hash))[4]), ((bool)(__builtin_expect(!!(!NS_FAILED_impl (rv)), 1))) ? "Succeeded" : "Failed"); } } while (0); |
| 4099 | } else { |
| 4100 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Couldn't evict an existing" " entry."); } } while (0) |
| 4101 | ("CacheFileIOManager::OpenNSPRHandle() - Couldn't evict an existing"do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Couldn't evict an existing" " entry."); } } while (0) |
| 4102 | " entry."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() - Couldn't evict an existing" " entry."); } } while (0); |
| 4103 | rv = NS_ERROR_FILE_NO_DEVICE_SPACE; |
| 4104 | } |
| 4105 | } |
| 4106 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 4107 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Create failed with " "0x%08" "x", static_cast<uint32_t>(rv)); } } while (0) |
| 4108 | ("CacheFileIOManager::OpenNSPRHandle() Create failed with "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Create failed with " "0x%08" "x", static_cast<uint32_t>(rv)); } } while (0) |
| 4109 | "0x%08" PRIx32,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Create failed with " "0x%08" "x", static_cast<uint32_t>(rv)); } } while (0) |
| 4110 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Create failed with " "0x%08" "x", static_cast<uint32_t>(rv)); } } while (0); |
| 4111 | } |
| 4112 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4112); return rv; } } while (false); |
| 4113 | |
| 4114 | aHandle->mFileExists = true; |
| 4115 | } else { |
| 4116 | rv = aHandle->mFile->OpenNSPRFileDesc(PR_RDWR0x04, 0600, &aHandle->mFD); |
| 4117 | if (NS_ERROR_FILE_NOT_FOUND == rv) { |
| 4118 | LOG((" file doesn't exists"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, " file doesn't exists" ); } } while (0); |
| 4119 | aHandle->mFileExists = false; |
| 4120 | return DoomFileInternal(aHandle); |
| 4121 | } |
| 4122 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 4123 | LOG(("CacheFileIOManager::OpenNSPRHandle() Open failed with 0x%08" PRIx32,do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Open failed with 0x%08" "x", static_cast<uint32_t>(rv)); } } while (0) |
| 4124 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle() Open failed with 0x%08" "x", static_cast<uint32_t>(rv)); } } while (0); |
| 4125 | } |
| 4126 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4126); return rv; } } while (false); |
| 4127 | } |
| 4128 | |
| 4129 | mHandlesByLastUsed.AppendElement(aHandle); |
| 4130 | |
| 4131 | LOG(("CacheFileIOManager::OpenNSPRHandle END, handle=%p", aHandle))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::OpenNSPRHandle END, handle=%p" , aHandle); } } while (0); |
| 4132 | |
| 4133 | return NS_OK; |
| 4134 | } |
| 4135 | |
| 4136 | void CacheFileIOManager::NSPRHandleUsed(CacheFileHandle* aHandle) { |
| 4137 | MOZ_ASSERT(CacheFileIOManager::IsOnIOThreadOrCeased())do { static_assert( mozilla::detail::AssertionConditionType< decltype(CacheFileIOManager::IsOnIOThreadOrCeased())>::isValid , "invalid assertion condition"); if ((__builtin_expect(!!(!( !!(CacheFileIOManager::IsOnIOThreadOrCeased()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("CacheFileIOManager::IsOnIOThreadOrCeased()" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4137); AnnotateMozCrashReason("MOZ_ASSERT" "(" "CacheFileIOManager::IsOnIOThreadOrCeased()" ")"); do { *((volatile int*)__null) = 4137; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4138 | MOZ_ASSERT(aHandle->mFD)do { static_assert( mozilla::detail::AssertionConditionType< decltype(aHandle->mFD)>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(aHandle->mFD))), 0))) { do { } while (false); MOZ_ReportAssertionFailure("aHandle->mFD" , "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4138); AnnotateMozCrashReason("MOZ_ASSERT" "(" "aHandle->mFD" ")"); do { *((volatile int*)__null) = 4138; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4139 | |
| 4140 | DebugOnly<bool> found{}; |
| 4141 | found = mHandlesByLastUsed.RemoveElement(aHandle); |
| 4142 | MOZ_ASSERT(found)do { static_assert( mozilla::detail::AssertionConditionType< decltype(found)>::isValid, "invalid assertion condition"); if ((__builtin_expect(!!(!(!!(found))), 0))) { do { } while ( false); MOZ_ReportAssertionFailure("found", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4142); AnnotateMozCrashReason("MOZ_ASSERT" "(" "found" ")") ; do { *((volatile int*)__null) = 4142; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4143 | |
| 4144 | mHandlesByLastUsed.AppendElement(aHandle); |
| 4145 | } |
| 4146 | |
| 4147 | nsresult CacheFileIOManager::SyncRemoveDir(nsIFile* aFile, const char* aDir) { |
| 4148 | nsresult rv; |
| 4149 | nsCOMPtr<nsIFile> file; |
| 4150 | |
| 4151 | if (!aFile) { |
| 4152 | return NS_ERROR_INVALID_ARG; |
| 4153 | } |
| 4154 | |
| 4155 | if (!aDir) { |
| 4156 | file = aFile; |
| 4157 | } else { |
| 4158 | rv = aFile->Clone(getter_AddRefs(file)); |
| 4159 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4159)) { |
| 4160 | return rv; |
| 4161 | } |
| 4162 | |
| 4163 | rv = file->AppendNative(nsDependentCString(aDir)); |
| 4164 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4164)) { |
| 4165 | return rv; |
| 4166 | } |
| 4167 | } |
| 4168 | |
| 4169 | if (LOG_ENABLED()(__builtin_expect(!!(mozilla::detail::log_test(gCache2Log, mozilla ::LogLevel::Debug)), 0))) { |
| 4170 | LOG(("CacheFileIOManager::SyncRemoveDir() - Removing directory %s",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing directory %s" , file->HumanReadablePath().get()); } } while (0) |
| 4171 | file->HumanReadablePath().get()))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing directory %s" , file->HumanReadablePath().get()); } } while (0); |
| 4172 | } |
| 4173 | |
| 4174 | rv = file->Remove(true); |
| 4175 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4175)) { |
| 4176 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing failed! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4177 | ("CacheFileIOManager::SyncRemoveDir() - Removing failed! "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing failed! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4178 | "[rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing failed! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4179 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveDir() - Removing failed! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 4180 | } |
| 4181 | |
| 4182 | return rv; |
| 4183 | } |
| 4184 | |
| 4185 | nsresult CacheFileIOManager::DispatchPurgeTask( |
| 4186 | const nsCString& aCacheDirName, const nsCString& aSecondsToWait, |
| 4187 | const nsCString& aPurgeExtension) { |
| 4188 | #if !defined(MOZ_BACKGROUNDTASKS1) |
| 4189 | // If background tasks are disabled, then we should just bail out early. |
| 4190 | return NS_ERROR_NOT_IMPLEMENTED; |
| 4191 | #else |
| 4192 | nsCOMPtr<nsIFile> cacheDir; |
| 4193 | nsresult rv = mCacheDirectory->Clone(getter_AddRefs(cacheDir)); |
| 4194 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4194); return rv; } } while (false); |
| 4195 | |
| 4196 | nsCOMPtr<nsIFile> profileDir; |
| 4197 | rv = cacheDir->GetParent(getter_AddRefs(profileDir)); |
| 4198 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4198); return rv; } } while (false); |
| 4199 | |
| 4200 | nsCOMPtr<nsIFile> lf; |
| 4201 | rv = XRE_GetBinaryPath(getter_AddRefs(lf)); |
| 4202 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4202); return rv; } } while (false); |
| 4203 | |
| 4204 | nsAutoCString path; |
| 4205 | # if !defined(XP_WIN) |
| 4206 | rv = profileDir->GetNativePath(path); |
| 4207 | # else |
| 4208 | rv = profileDir->GetNativeTarget(path); |
| 4209 | # endif |
| 4210 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4210); return rv; } } while (false); |
| 4211 | |
| 4212 | nsCOMPtr<nsIBackgroundTasksRunner> runner = |
| 4213 | do_GetService("@mozilla.org/backgroundtasksrunner;1"); |
| 4214 | |
| 4215 | return runner->RemoveDirectoryInDetachedProcess( |
| 4216 | path, aCacheDirName, aSecondsToWait, aPurgeExtension, "HttpCache"_ns); |
| 4217 | #endif |
| 4218 | } |
| 4219 | |
| 4220 | void CacheFileIOManager::SyncRemoveAllCacheFiles() { |
| 4221 | LOG(("CacheFileIOManager::SyncRemoveAllCacheFiles()"))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles()" ); } } while (0); |
| 4222 | nsresult rv; |
| 4223 | |
| 4224 | // If we are already running in a background task, we |
| 4225 | // don't want to spawn yet another one at shutdown. |
| 4226 | if (inBackgroundTask()) { |
| 4227 | return; |
| 4228 | } |
| 4229 | |
| 4230 | if (StaticPrefs::network_cache_shutdown_purge_in_background_task()) { |
| 4231 | rv = [&]() -> nsresult { |
| 4232 | nsresult rv; |
| 4233 | |
| 4234 | // If there is no cache directory, there's nothing to remove. |
| 4235 | if (!mCacheDirectory) { |
| 4236 | return NS_OK; |
| 4237 | } |
| 4238 | |
| 4239 | nsAutoCString leafName; |
| 4240 | rv = mCacheDirectory->GetNativeLeafName(leafName); |
| 4241 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4241); return rv; } } while (false); |
| 4242 | |
| 4243 | leafName.Append('.'); |
| 4244 | |
| 4245 | PRExplodedTime now; |
| 4246 | PR_ExplodeTime(PR_Now(), PR_GMTParameters, &now); |
| 4247 | leafName.Append(nsPrintfCString( |
| 4248 | "%04d-%02d-%02d-%02d-%02d-%02d", now.tm_year, now.tm_month + 1, |
| 4249 | now.tm_mday, now.tm_hour, now.tm_min, now.tm_sec)); |
| 4250 | leafName.Append(kPurgeExtension); |
| 4251 | |
| 4252 | nsAutoCString secondsToWait; |
| 4253 | secondsToWait.AppendInt( |
| 4254 | StaticPrefs::network_cache_shutdown_purge_folder_wait_seconds()); |
| 4255 | |
| 4256 | rv = DispatchPurgeTask(leafName, secondsToWait, kPurgeExtension); |
| 4257 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4257); return rv; } } while (false); |
| 4258 | |
| 4259 | rv = mCacheDirectory->RenameToNative(nullptr, leafName); |
| 4260 | NS_ENSURE_SUCCESS(rv, rv)do { nsresult __rv = rv; if (((bool)(__builtin_expect(!!(NS_FAILED_impl (__rv)), 0)))) { const char* name = mozilla::GetStaticErrorName (__rv); mozilla::SmprintfPointer msg = mozilla::Smprintf( "NS_ENSURE_SUCCESS(%s, %s) failed with " "result 0x%" "X" "%s%s%s", "rv", "rv", static_cast<uint32_t >(__rv), name ? " (" : "", name ? name : "", name ? ")" : "" ); NS_DebugBreak(NS_DEBUG_WARNING, msg.get(), nullptr, "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4260); return rv; } } while (false); |
| 4261 | |
| 4262 | return NS_OK; |
| 4263 | }(); |
| 4264 | |
| 4265 | // Dispatching to the background task has succeeded. This is finished. |
| 4266 | if (NS_SUCCEEDED(rv)((bool)(__builtin_expect(!!(!NS_FAILED_impl(rv)), 1)))) { |
| 4267 | return; |
| 4268 | } |
| 4269 | } |
| 4270 | |
| 4271 | SyncRemoveDir(mCacheDirectory, ENTRIES_DIR"entries"); |
| 4272 | SyncRemoveDir(mCacheDirectory, DOOMED_DIR"doomed"); |
| 4273 | |
| 4274 | // Clear any intermediate state of trash dir enumeration. |
| 4275 | mFailedTrashDirs.Clear(); |
| 4276 | mTrashDir = nullptr; |
| 4277 | |
| 4278 | while (true) { |
| 4279 | // FindTrashDirToRemove() fills mTrashDir if there is any trash directory. |
| 4280 | rv = FindTrashDirToRemove(); |
| 4281 | if (rv == NS_ERROR_NOT_AVAILABLE) { |
| 4282 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - No trash directory " "found."); } } while (0) |
| 4283 | ("CacheFileIOManager::SyncRemoveAllCacheFiles() - No trash directory "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - No trash directory " "found."); } } while (0) |
| 4284 | "found."))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - No trash directory " "found."); } } while (0); |
| 4285 | break; |
| 4286 | } |
| 4287 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4287)) { |
| 4288 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - " "FindTrashDirToRemove() returned an unexpected error. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4289 | ("CacheFileIOManager::SyncRemoveAllCacheFiles() - "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - " "FindTrashDirToRemove() returned an unexpected error. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4290 | "FindTrashDirToRemove() returned an unexpected error. "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - " "FindTrashDirToRemove() returned an unexpected error. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4291 | "[rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - " "FindTrashDirToRemove() returned an unexpected error. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4292 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::SyncRemoveAllCacheFiles() - " "FindTrashDirToRemove() returned an unexpected error. " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 4293 | break; |
| 4294 | } |
| 4295 | |
| 4296 | rv = SyncRemoveDir(mTrashDir, nullptr); |
| 4297 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 4298 | nsAutoCString leafName; |
| 4299 | mTrashDir->GetNativeLeafName(leafName); |
| 4300 | mFailedTrashDirs.AppendElement(leafName); |
| 4301 | } |
| 4302 | } |
| 4303 | } |
| 4304 | |
| 4305 | // Returns default ("smart") size (in KB) of cache, given available disk space |
| 4306 | // (also in KB) |
| 4307 | static uint32_t SmartCacheSize(const int64_t availKB) { |
| 4308 | uint32_t maxSize; |
| 4309 | |
| 4310 | if (CacheObserver::ClearCacheOnShutdown()) { |
| 4311 | maxSize = kMaxClearOnShutdownCacheSizeKB; |
| 4312 | } else { |
| 4313 | maxSize = kMaxCacheSizeKB; |
| 4314 | } |
| 4315 | |
| 4316 | if (availKB > 25 * 1024 * 1024) { |
| 4317 | return maxSize; // skip computing if we're over 25 GB |
| 4318 | } |
| 4319 | |
| 4320 | // Grow/shrink in 10 MB units, deliberately, so that in the common case we |
| 4321 | // don't shrink cache and evict items every time we startup (it's important |
| 4322 | // that we don't slow down startup benchmarks). |
| 4323 | uint32_t sz10MBs = 0; |
| 4324 | uint32_t avail10MBs = availKB / (1024 * 10); |
| 4325 | |
| 4326 | // 2.5% of space above 7GB |
| 4327 | if (avail10MBs > 700) { |
| 4328 | sz10MBs += static_cast<uint32_t>((avail10MBs - 700) * .025); |
| 4329 | avail10MBs = 700; |
| 4330 | } |
| 4331 | // 7.5% of space between 500 MB -> 7 GB |
| 4332 | if (avail10MBs > 50) { |
| 4333 | sz10MBs += static_cast<uint32_t>((avail10MBs - 50) * .075); |
| 4334 | avail10MBs = 50; |
| 4335 | } |
| 4336 | |
| 4337 | #ifdef ANDROID |
| 4338 | // On Android, smaller/older devices may have very little storage and |
| 4339 | // device owners may be sensitive to storage footprint: Use a smaller |
| 4340 | // percentage of available space and a smaller minimum. |
| 4341 | |
| 4342 | // 16% of space up to 500 MB (10 MB min) |
| 4343 | sz10MBs += std::max<uint32_t>(1, static_cast<uint32_t>(avail10MBs * .16)); |
| 4344 | #else |
| 4345 | // 30% of space up to 500 MB (50 MB min) |
| 4346 | sz10MBs += std::max<uint32_t>(5, static_cast<uint32_t>(avail10MBs * .3)); |
| 4347 | #endif |
| 4348 | |
| 4349 | return std::min<uint32_t>(maxSize, sz10MBs * 10 * 1024); |
| 4350 | } |
| 4351 | |
| 4352 | nsresult CacheFileIOManager::UpdateSmartCacheSize(int64_t aFreeSpace) { |
| 4353 | MOZ_ASSERT(mIOThread->IsCurrentThread())do { static_assert( mozilla::detail::AssertionConditionType< decltype(mIOThread->IsCurrentThread())>::isValid, "invalid assertion condition" ); if ((__builtin_expect(!!(!(!!(mIOThread->IsCurrentThread ()))), 0))) { do { } while (false); MOZ_ReportAssertionFailure ("mIOThread->IsCurrentThread()", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4353); AnnotateMozCrashReason("MOZ_ASSERT" "(" "mIOThread->IsCurrentThread()" ")"); do { *((volatile int*)__null) = 4353; __attribute__((nomerge )) ::abort(); } while (false); } } while (false); |
| 4354 | |
| 4355 | nsresult rv; |
| 4356 | |
| 4357 | if (!CacheObserver::SmartCacheSizeEnabled()) { |
| 4358 | return NS_ERROR_NOT_AVAILABLE; |
| 4359 | } |
| 4360 | |
| 4361 | // Wait at least kSmartSizeUpdateInterval before recomputing smart size. |
| 4362 | static const TimeDuration kUpdateLimit = |
| 4363 | TimeDuration::FromMilliseconds(kSmartSizeUpdateInterval60000); |
| 4364 | if (!mLastSmartSizeTime.IsNull() && |
| 4365 | (TimeStamp::NowLoRes() - mLastSmartSizeTime) < kUpdateLimit) { |
| 4366 | return NS_OK; |
| 4367 | } |
| 4368 | |
| 4369 | // Do not compute smart size when cache size is not reliable. |
| 4370 | bool isUpToDate = false; |
| 4371 | CacheIndex::IsUpToDate(&isUpToDate); |
| 4372 | if (!isUpToDate) { |
| 4373 | return NS_ERROR_NOT_AVAILABLE; |
| 4374 | } |
| 4375 | |
| 4376 | uint32_t cacheUsage; |
| 4377 | rv = CacheIndex::GetCacheSize(&cacheUsage); |
| 4378 | if (NS_WARN_IF(NS_FAILED(rv))NS_warn_if_impl(((bool)(__builtin_expect(!!(NS_FAILED_impl(rv )), 0))), "NS_FAILED(rv)", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4378)) { |
| 4379 | LOG(do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateSmartCacheSize() - Cannot get cacheUsage! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4380 | ("CacheFileIOManager::UpdateSmartCacheSize() - Cannot get cacheUsage! "do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateSmartCacheSize() - Cannot get cacheUsage! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4381 | "[rv=0x%08" PRIx32 "]",do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateSmartCacheSize() - Cannot get cacheUsage! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0) |
| 4382 | static_cast<uint32_t>(rv)))do { const ::mozilla::LogModule* moz_real_module = gCache2Log ; if ((__builtin_expect(!!(mozilla::detail::log_test(moz_real_module , mozilla::LogLevel::Debug)), 0))) { mozilla::detail::log_print (moz_real_module, mozilla::LogLevel::Debug, "CacheFileIOManager::UpdateSmartCacheSize() - Cannot get cacheUsage! " "[rv=0x%08" "x" "]", static_cast<uint32_t>(rv)); } } while (0); |
| 4383 | return rv; |
| 4384 | } |
| 4385 | |
| 4386 | mLastSmartSizeTime = TimeStamp::NowLoRes(); |
| 4387 | |
| 4388 | uint32_t smartSize = SmartCacheSize(aFreeSpace + cacheUsage); |
| 4389 | |
| 4390 | if (smartSize == CacheObserver::DiskCacheCapacity()) { |
| 4391 | // Smart size has not changed. |
| 4392 | return NS_OK; |
| 4393 | } |
| 4394 | |
| 4395 | CacheObserver::SetSmartDiskCacheCapacity(smartSize); |
| 4396 | |
| 4397 | return NS_OK; |
| 4398 | } |
| 4399 | |
| 4400 | // Memory reporting |
| 4401 | |
| 4402 | namespace { |
| 4403 | |
| 4404 | // A helper class that dispatches and waits for an event that gets result of |
| 4405 | // CacheFileIOManager->mHandles.SizeOfExcludingThis() on the I/O thread |
| 4406 | // to safely get handles memory report. |
| 4407 | // We must do this, since the handle list is only accessed and managed w/o |
| 4408 | // locking on the I/O thread. That is by design. |
| 4409 | class SizeOfHandlesRunnable : public Runnable { |
| 4410 | public: |
| 4411 | SizeOfHandlesRunnable(mozilla::MallocSizeOf mallocSizeOf, |
| 4412 | CacheFileHandles const& handles, |
| 4413 | nsTArray<CacheFileHandle*> const& specialHandles, |
| 4414 | nsCOMPtr<nsITimer> const& metadataWritesTimer) |
| 4415 | : Runnable("net::SizeOfHandlesRunnable"), |
| 4416 | mMonitor("SizeOfHandlesRunnable.mMonitor"), |
| 4417 | mMonitorNotified(false), |
| 4418 | mMallocSizeOf(mallocSizeOf), |
| 4419 | mHandles(handles), |
| 4420 | mSpecialHandles(specialHandles), |
| 4421 | mMetadataWritesTimer(metadataWritesTimer), |
| 4422 | mSize(0) {} |
| 4423 | |
| 4424 | size_t Get(CacheIOThread* thread) { |
| 4425 | nsCOMPtr<nsIEventTarget> target = thread->Target(); |
| 4426 | if (!target) { |
| 4427 | NS_ERROR("If we have the I/O thread we also must have the I/O target")do { NS_DebugBreak(NS_DEBUG_ASSERTION, "If we have the I/O thread we also must have the I/O target" , "Error", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4427); MOZ_PretendNoReturn(); } while (0); |
| 4428 | return 0; |
| 4429 | } |
| 4430 | |
| 4431 | mozilla::MonitorAutoLock mon(mMonitor); |
| 4432 | mMonitorNotified = false; |
| 4433 | nsresult rv = target->Dispatch(this, nsIEventTarget::DISPATCH_NORMAL); |
| 4434 | if (NS_FAILED(rv)((bool)(__builtin_expect(!!(NS_FAILED_impl(rv)), 0)))) { |
| 4435 | NS_ERROR("Dispatch failed, cannot do memory report of CacheFileHandles")do { NS_DebugBreak(NS_DEBUG_ASSERTION, "Dispatch failed, cannot do memory report of CacheFileHandles" , "Error", "/var/lib/jenkins/workspace/firefox-scan-build/netwerk/cache2/CacheFileIOManager.cpp" , 4435); MOZ_PretendNoReturn(); } while (0); |
| 4436 | return 0; |
| 4437 | } |
| 4438 | |
| 4439 | while (!mMonitorNotified) { |
| 4440 | mon.Wait(); |
| 4441 | } |
| 4442 | return mSize; |
| 4443 | } |
| 4444 | |
| 4445 | NS_IMETHODvirtual nsresult Run() override { |
| 4446 | mozilla::MonitorAutoLock mon(mMonitor); |
| 4447 | // Excluding this since the object itself is a member of CacheFileIOManager |
| 4448 | // reported in CacheFileIOManager::SizeOfIncludingThis as part of |this|. |
| 4449 | mSize = mHandles.SizeOfExcludingThis(mMallocSizeOf); |
| 4450 | for (uint32_t i = 0; i < mSpecialHandles.Length(); ++i) { |
| 4451 | mSize += mSpecialHandles[i]->SizeOfIncludingThis(mMallocSizeOf); |
| 4452 | } |
| 4453 | nsCOMPtr<nsISizeOf> sizeOf = do_QueryInterface(mMetadataWritesTimer); |
| 4454 | if (sizeOf) { |
| 4455 | mSize += sizeOf->SizeOfIncludingThis(mMallocSizeOf); |
| 4456 | } |
| 4457 | |
| 4458 | mMonitorNotified = true; |
| 4459 | mon.Notify(); |
| 4460 | return NS_OK; |
| 4461 | } |
| 4462 | |
| 4463 | private: |
| 4464 | mozilla::Monitor mMonitor; |
| 4465 | bool mMonitorNotified; |
| 4466 | mozilla::MallocSizeOf mMallocSizeOf; |
| 4467 | CacheFileHandles const& mHandles; |
| 4468 | nsTArray<CacheFileHandle*> const& mSpecialHandles; |
| 4469 | nsCOMPtr<nsITimer> const& mMetadataWritesTimer; |
| 4470 | size_t mSize; |
| 4471 | }; |
| 4472 | |
| 4473 | } // namespace |
| 4474 | |
| 4475 | size_t CacheFileIOManager::SizeOfExcludingThisInternal( |
| 4476 | mozilla::MallocSizeOf mallocSizeOf) const { |
| 4477 | size_t n = 0; |
| 4478 | nsCOMPtr<nsISizeOf> sizeOf; |
| 4479 | |
| 4480 | if (mIOThread) { |
| 4481 | n += mIOThread->SizeOfIncludingThis(mallocSizeOf); |
| 4482 | |
| 4483 | // mHandles, mSpecialHandles and mMetadataWritesTimer must be accessed |
| 4484 | // only on the I/O thread, must sync dispatch. |
| 4485 | RefPtr<SizeOfHandlesRunnable> sizeOfHandlesRunnable = |
| 4486 | new SizeOfHandlesRunnable(mallocSizeOf, mHandles, mSpecialHandles, |
| 4487 | mMetadataWritesTimer); |
| 4488 | n += sizeOfHandlesRunnable->Get(mIOThread); |
| 4489 | } |
| 4490 | |
| 4491 | // mHandlesByLastUsed just refers handles reported by mHandles. |
| 4492 | |
| 4493 | sizeOf = do_QueryInterface(mCacheDirectory); |
| 4494 | if (sizeOf) n += sizeOf->SizeOfIncludingThis(mallocSizeOf); |
| 4495 | |
| 4496 | sizeOf = do_QueryInterface(mTrashTimer); |
| 4497 | if (sizeOf) n += sizeOf->SizeOfIncludingThis(mallocSizeOf); |
| 4498 | |
| 4499 | sizeOf = do_QueryInterface(mTrashDir); |
| 4500 | if (sizeOf) n += sizeOf->SizeOfIncludingThis(mallocSizeOf); |
| 4501 | |
| 4502 | for (uint32_t i = 0; i < mFailedTrashDirs.Length(); ++i) { |
| 4503 | n += mFailedTrashDirs[i].SizeOfExcludingThisIfUnshared(mallocSizeOf); |
| 4504 | } |
| 4505 | |
| 4506 | return n; |
| 4507 | } |
| 4508 | |
| 4509 | // static |
| 4510 | size_t CacheFileIOManager::SizeOfExcludingThis( |
| 4511 | mozilla::MallocSizeOf mallocSizeOf) { |
| 4512 | if (!gInstance) return 0; |
| 4513 | |
| 4514 | return gInstance->SizeOfExcludingThisInternal(mallocSizeOf); |
| 4515 | } |
| 4516 | |
| 4517 | // static |
| 4518 | size_t CacheFileIOManager::SizeOfIncludingThis( |
| 4519 | mozilla::MallocSizeOf mallocSizeOf) { |
| 4520 | return mallocSizeOf(gInstance) + SizeOfExcludingThis(mallocSizeOf); |
| 4521 | } |
| 4522 | |
| 4523 | } // namespace mozilla::net |