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

Unified Diff: net/base/address_tracker_linux.h

Issue 571743002: Adding non-tracking mode support to AddressTracker. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add one more comment on the usage of ThreadChecker. Created 6 years, 3 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 | net/base/address_tracker_linux.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/base/address_tracker_linux.h
diff --git a/net/base/address_tracker_linux.h b/net/base/address_tracker_linux.h
index 415e8c89e9d8dc354d48c8a48dc24064068f71fd..e065949ef4c09d74e542c341fd43831df6b5398a 100644
--- a/net/base/address_tracker_linux.h
+++ b/net/base/address_tracker_linux.h
@@ -20,6 +20,8 @@
#include "base/message_loop/message_loop.h"
#include "base/synchronization/condition_variable.h"
#include "base/synchronization/lock.h"
+#include "base/threading/thread_checker.h"
+#include "base/threading/thread_restrictions.h"
#include "net/base/net_util.h"
#include "net/base/network_change_notifier.h"
@@ -33,19 +35,33 @@ class NET_EXPORT_PRIVATE AddressTrackerLinux :
public:
typedef std::map<IPAddressNumber, struct ifaddrmsg> AddressMap;
- // Will run |address_callback| when the AddressMap changes, |link_callback|
- // when the list of online links changes, and |tunnel_callback| when the list
- // of online tunnels changes.
+ // Non-tracking version constructor: When AddressTrackerLinux is
+ // constructed without callbacks, it takes a snapshot of current
+ // system configuration once Init() returns. The configuration is
+ // available through GetOnlineLinks() and GetAddressMap (). Note
+ // that the thread creating |AddressTrackerLinux| must be the one
+ // calling Init(). Otherwise, the |thread_checker_| will fail the
+ // assert on CalledOnValidThread().
+ AddressTrackerLinux();
+
+ // Tracking version constructor: it will run |address_callback| when
+ // the AddressMap changes, |link_callback| when the list of online
+ // links changes, and |tunnel_callback| when the list of online
+ // tunnels changes.
AddressTrackerLinux(const base::Closure& address_callback,
const base::Closure& link_callback,
const base::Closure& tunnel_callback);
virtual ~AddressTrackerLinux();
- // Starts watching system configuration for changes. The current thread must
- // have a MessageLoopForIO.
+ // In tracking mode, it starts watching system configuration for
+ // changes. The current thread must have a MessageLoopForIO. For
+ // non-tracking mode, the |AddressMap| and |online_links_| will be a
+ // one time snapshot of current system configuration after Init()
+ // returns.
void Init();
AddressMap GetAddressMap() const;
+ base::hash_set<int> GetOnlineLinks() const;
// Implementation of NetworkChangeNotifierLinux::GetCurrentConnectionType().
// Safe to call from any thread, but will block until Init() has completed.
@@ -54,6 +70,32 @@ class NET_EXPORT_PRIVATE AddressTrackerLinux :
private:
friend class AddressTrackerLinuxTest;
+ // A private nested class to facilitate different locking behaviors
+ // depending on whether the |AddressTrackerLinux| is in tracking
+ // mode or not. Lock will only be taken in the tracking mode.
+ class AddressTrackerAutoLock {
pauljensen 2014/09/19 18:39:42 Please move all this code into address_tracker_lin
guoweis2 2014/09/19 18:48:30 Done.
+ public:
+ AddressTrackerAutoLock(const AddressTrackerLinux& tracker, base::Lock& lock)
+ : tracker_(tracker), lock_(lock) {
+ if (tracker_.tracking_)
+ lock_.Acquire();
+ }
+
+ ~AddressTrackerAutoLock() {
+ if (tracker_.tracking_) {
+ lock_.AssertAcquired();
+ lock_.Release();
+ } else {
+ DCHECK(tracker_.thread_checker_.CalledOnValidThread());
pauljensen 2014/09/19 18:39:42 let's move this to the constructor so it's a littl
guoweis2 2014/09/19 18:48:30 Done.
+ }
+ }
+
+ private:
+ const AddressTrackerLinux& tracker_;
+ base::Lock& lock_;
+ DISALLOW_COPY_AND_ASSIGN(AddressTrackerAutoLock);
+ };
+
// A function that returns the name of an interface given the interface index
// in |interface_index|.
typedef const char* (*GetInterfaceNameFunction)(int interface_index);
@@ -105,12 +147,20 @@ class NET_EXPORT_PRIVATE AddressTrackerLinux :
AddressMap address_map_;
// Set of interface indices for links that are currently online.
+ mutable base::Lock online_links_lock_;
base::hash_set<int> online_links_;
base::Lock is_offline_lock_;
bool is_offline_;
bool is_offline_initialized_;
base::ConditionVariable is_offline_initialized_cv_;
+ bool tracking_;
+
+ // A |ThreadChecker| to validate that in the non-tracking mode, the
pauljensen 2014/09/19 18:39:42 Eh how about something like "Used to verify single
guoweis2 2014/09/19 18:48:30 Done.
+ // thread destructing a |AddressTrackerAutoLock| is the same as the
+ // one which created it. This is to catch any unexpected callback
+ // happening in the non-tracking mode.
+ base::ThreadChecker thread_checker_;
};
} // namespace internal
« no previous file with comments | « no previous file | net/base/address_tracker_linux.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698