-
Notifications
You must be signed in to change notification settings - Fork 116
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix a data race that could manifest as null pointer dereference in FutureBase::Release() #747
Conversation
❌ Integration test FAILEDRequested by @dconeybe on commit a219a97
Add flaky tests to go/fpl-cpp-flake-tracker |
… api_ was always assigned to null
…plicated in the call to the copy/move operators
…e private headers
@@ -20,6 +20,7 @@ | |||
#include <stddef.h> | |||
#include <stdint.h> | |||
|
|||
#include <mutex> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you use firebase::Mutex and firebase::MutexLock instead?
release_build_files/readme.md
Outdated
@@ -569,6 +569,9 @@ code. | |||
## Release Notes | |||
### Next Release | |||
- Changes | |||
- All Products (Android): Fixed a data race that could manifest as null |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you change this to "General (Android):"?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done.
🍞 Dismissed stale approval on external PR.
@@ -20,6 +20,7 @@ | |||
#include <stddef.h> | |||
#include <stdint.h> | |||
|
|||
#include <mutex> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
<mutex> is an unapproved C++11 header.
} | ||
detail::RegisterForCleanup(api_, this); | ||
} | ||
|
||
return *this; | ||
} | ||
|
||
#if defined(FIREBASE_USE_MOVE_OPERATORS) | ||
inline FutureBase::FutureBase(FutureBase&& rhs) noexcept | ||
: api_(NULL) // NOLINT | ||
{ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
{ should almost always be at the end of the previous line
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, could you fix the lint warning actually?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh wait just noticed it's not in your code - never mind.
@@ -569,6 +569,9 @@ code. | |||
## Release Notes | |||
### Next Release | |||
- Changes | |||
- General (Android): Fixed a data race that could manifest as null pointer |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One last note (it can wait for the followup) - this isn't Android only, right? We can remove the "(Android)" tag.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ahh right. I've opened #749 to fix the release notes entry.
I had originally thought that the issue was specific to Android, because the bug only surfaced on Android; however, it indeed affects all platforms.
* Fix test on emulator workflow failures (#734) * If simulator install ios app failed, reset simulator and try again (#733) * Trigger workflow move github api cod to github.py (#746) * Fix a data race that could manifest as null pointer dereference in FutureBase::Release() (#747) * Cancel callbacks for messaging (#745) * Cancel callbacks for messaging util::Terminate is referenced counted som when there ar more APIs than messaging active the callbacks will not be canceled until later and still cause a NULL ref due to the FutureData being destroyed now. * Cancel callback earlier * Update readme * Remove "Android" tag from the release notes entry for #747 (#749) * Remove calls to LogInfo, LogError, LogDebug during obj-c +load. (#706) * Remove calls to LogInfo, LogError, LogDebug during obj-c +load. This could be causing an issue in C++ as global class constructors have not yet been run. * Add Objective-C/C++ and Java to code formatter script; format those files. (#755) * Allow format_code to format .m/.mm files; clang-format already knows how. * Run format_code.py on all objective-c/objective-c++ files. * Add Java file extensions to format_code.py * Format all Java source files. * Remove check for objc header, as they are now supported. * Format objective-c .h files. * Don't let lint comment on line length any more; code formatting will report that. * Messaging crash during initialization (#760) * Messaging crash during initialization * Update readme * Don't redeclare inherited state in CredentialsProviderDesktop (#731) * Reduce disk space usage when packaging the built SDK (#763) Remove intermediate build files during desktop packaging step. This should reduce the disk space usage, as those files (*.o and *.obj) are not required when merging libraries. * Workaround for Linux x86 build: downgrade libraries on GitHub runners (#764) When installing 32-bit Linux dependencies on GitHub runners, downgrade libpcre2-8-0 to an earlier version to ensure compatibility with the i386 version of the package. This is something that should be fixed in a subsequent Ubuntu release and so is a temporary workaround. This also adds checks to the various prerequisite commands run by build_desktop.py, which was previously just silently ignoring errors (making this much harder to track down). Now it will error out as soon as a command fails. Co-authored-by: Mou Sun <69009538+sunmou99@users.noreply.github.com> Co-authored-by: Denver Coneybeare <dconeybe@google.com> Co-authored-by: Tobias Barendt <tobias@robotsquid.com> Co-authored-by: Jon Simantov <jsimantov@google.com> Co-authored-by: Sebastian Schmidt <mrschmidt@google.com>
The
FutureBase
class has two data members that can be accessed concurrently from multiple threads without any synchronization:api_
andhandle_
. This data race was detected by the thread sanitizer.Although there are no known customer reports of crashes resulting from this data race, a recent continuous integration run crashed in Firestore with a null pointer dereference in the following stack trace:
The test in question is
FirestoreCanBeDeletedFromTransaction
:firebase-cpp-sdk/firestore/integration_test_internal/src/firestore_test.cc
Lines 1528 to 1544 in 9efb188
This test deletes the
Firestore
instance from an auxiliary thread, which would cause all of theFuture
objects it owns to be "released" from that alternate thread. Therefore, in rare conditions, this would race with the deletion of theFuture
object from the test thread, and yield the null pointer dereference.This PR fixes the data race by protecting those two members with a mutex.
Googlers can see b/183225305 and b/205966141 for more details.