Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2016 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 17 | #include "EventReporter.h" |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 18 | |
| 19 | using android::interface_cast; |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 20 | using android::net::INetdUnsolicitedEventListener; |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 21 | using android::net::metrics::INetdEventListener; |
| 22 | |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 23 | android::sp<INetdEventListener> EventReporter::getNetdEventListener() { |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 24 | std::lock_guard lock(mEventMutex); |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 25 | if (mNetdEventListener == nullptr) { |
| 26 | // Use checkService instead of getService because getService waits for 5 seconds for the |
| 27 | // service to become available. The DNS resolver inside netd is started much earlier in the |
| 28 | // boot sequence than the framework DNS listener, and we don't want to delay all DNS lookups |
| 29 | // for 5 seconds until the DNS listener starts up. |
| 30 | android::sp<android::IBinder> b = android::defaultServiceManager()->checkService( |
| 31 | android::String16("netd_listener")); |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 32 | mNetdEventListener = interface_cast<INetdEventListener>(b); |
Michal Karpinski | be581e2 | 2016-10-06 16:56:04 +0100 | [diff] [blame] | 33 | } |
| 34 | // If the netd listener service is dead, the binder call will just return an error, which should |
| 35 | // be fine because the only impact is that we can't log netd events. In any case, this should |
| 36 | // only happen if the system server is going down, which means it will shortly be taking us down |
| 37 | // with it. |
| 38 | return mNetdEventListener; |
| 39 | } |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 40 | |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 41 | EventReporter::UnsolListenerMap EventReporter::getNetdUnsolicitedEventListenerMap() const { |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 42 | std::lock_guard lock(mUnsolicitedMutex); |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 43 | return mUnsolListenerMap; |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 44 | } |
| 45 | |
| 46 | void EventReporter::registerUnsolEventListener( |
Bernie Innocenti | 9ee088d | 2019-02-01 17:14:32 +0900 | [diff] [blame] | 47 | const android::sp<INetdUnsolicitedEventListener>& listener) { |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 48 | std::lock_guard lock(mUnsolicitedMutex); |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 49 | |
| 50 | // Create the death listener. |
| 51 | class DeathRecipient : public android::IBinder::DeathRecipient { |
| 52 | public: |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 53 | DeathRecipient(EventReporter* eventReporter, |
| 54 | android::sp<INetdUnsolicitedEventListener> listener) |
| 55 | : mEventReporter(eventReporter), mListener(std::move(listener)) {} |
Bernie Innocenti | 9ee088d | 2019-02-01 17:14:32 +0900 | [diff] [blame] | 56 | ~DeathRecipient() override = default; |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 57 | void binderDied(const android::wp<android::IBinder>& /* who */) override { |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 58 | mEventReporter->unregisterUnsolEventListener(mListener); |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 59 | } |
Bernie Innocenti | 9ee088d | 2019-02-01 17:14:32 +0900 | [diff] [blame] | 60 | |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 61 | private: |
| 62 | EventReporter* mEventReporter; |
Bernie Innocenti | 9ee088d | 2019-02-01 17:14:32 +0900 | [diff] [blame] | 63 | android::sp<INetdUnsolicitedEventListener> mListener; |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 64 | }; |
| 65 | android::sp<android::IBinder::DeathRecipient> deathRecipient = |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 66 | new DeathRecipient(this, listener); |
| 67 | |
Luke Huang | 528af60 | 2018-08-29 19:06:05 +0800 | [diff] [blame] | 68 | android::IInterface::asBinder(listener)->linkToDeath(deathRecipient); |
Luke Huang | 900f18e | 2019-01-31 16:50:17 +0800 | [diff] [blame^] | 69 | |
| 70 | // TODO: Consider to use remote binder address as registering key |
| 71 | mUnsolListenerMap.insert({listener, deathRecipient}); |
| 72 | } |
| 73 | |
| 74 | void EventReporter::unregisterUnsolEventListener( |
| 75 | const android::sp<INetdUnsolicitedEventListener>& listener) { |
| 76 | std::lock_guard lock(mUnsolicitedMutex); |
| 77 | mUnsolListenerMap.erase(listener); |
Bernie Innocenti | 9ee088d | 2019-02-01 17:14:32 +0900 | [diff] [blame] | 78 | } |