Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(306)

Unified Diff: components/webdata/common/web_data_request_manager.h

Issue 2845753002: Remove data race in WebDataRequest::CancelRequest. (Closed)
Patch Set: rebase Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | components/webdata/common/web_data_request_manager.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/webdata/common/web_data_request_manager.h
diff --git a/components/webdata/common/web_data_request_manager.h b/components/webdata/common/web_data_request_manager.h
index 87b5509158375c61b8abe819be392828c1127d89..eb621a2cff1d9be23ace41bf44def05fa79d35e7 100644
--- a/components/webdata/common/web_data_request_manager.h
+++ b/components/webdata/common/web_data_request_manager.h
@@ -12,6 +12,7 @@
#include <map>
#include <memory>
+#include "base/atomicops.h"
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "base/single_thread_task_runner.h"
@@ -40,7 +41,7 @@ class WebDataRequest {
// Returns |true| if the request is active and |false| if the request has been
// cancelled or has already completed.
- bool IsActive() const;
+ bool IsActive();
private:
// For access to the web request mutable state under the manager's lock.
@@ -48,17 +49,19 @@ class WebDataRequest {
// Private constructor called for WebDataRequestManager::NewRequest.
WebDataRequest(WebDataRequestManager* manager,
- WebDataServiceConsumer* consumer);
+ WebDataServiceConsumer* consumer,
+ WebDataServiceBase::Handle handle);
- // Internal debugging helper to assert that the request is active and that the
- // manager's lock is held by the current thread.
- void AssertThreadSafe() const;
+ // Retrieves the manager set in the constructor, if the request is still
+ // active, or nullptr if the request is inactive. The returned value may
+ // change between calls.
+ WebDataRequestManager* GetManager();
// Retrieves the |consumer_| set in the constructor.
- WebDataServiceConsumer* GetConsumer() const;
+ WebDataServiceConsumer* GetConsumer();
// Retrieves the original task runner of the request.
- scoped_refptr<base::SingleThreadTaskRunner> GetTaskRunner() const;
+ scoped_refptr<base::SingleThreadTaskRunner> GetTaskRunner();
// Marks the current request as inactive, either due to cancellation or
// completion.
@@ -67,16 +70,16 @@ class WebDataRequest {
// Tracks task runner that the request originated on.
const scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
- // Used to notify manager if request is cancelled. Uses a raw ptr instead of
- // a ref_ptr so that it can be set to null when a request is cancelled or
- // completed.
- WebDataRequestManager* manager_;
+ // The manager associated with this request. This is stored as a raw (untyped)
+ // pointer value because it does double duty as the flag indicating whether or
+ // not this request is active (non-nullptr => active).
+ base::subtle::AtomicWord atomic_manager_;
// The originator of the service request.
- WebDataServiceConsumer* consumer_;
+ WebDataServiceConsumer* const consumer_;
// Identifier for this request.
- WebDataServiceBase::Handle handle_;
+ const WebDataServiceBase::Handle handle_;
DISALLOW_COPY_AND_ASSIGN(WebDataRequest);
};
@@ -104,10 +107,6 @@ class WebDataRequestManager
void RequestCompleted(std::unique_ptr<WebDataRequest> request,
std::unique_ptr<WDTypedResult> result);
- // A debugging aid to assert that the pending_lock_ is held by the current
- // thread.
- void AssertLockedByCurrentThread() const;
-
private:
friend class base::RefCountedThreadSafe<WebDataRequestManager>;
« no previous file with comments | « no previous file | components/webdata/common/web_data_request_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698