| #ifndef ANDROID_HARDWARE_MANAGER_V1_0_SERVICEMANAGER_H |
| #define ANDROID_HARDWARE_MANAGER_V1_0_SERVICEMANAGER_H |
| |
| #include <android/hidl/manager/1.0/IServiceManager.h> |
| #include <hidl/Status.h> |
| #include <hidl/MQDescriptor.h> |
| #include <map> |
| |
| #include "HidlService.h" |
| |
| namespace android { |
| namespace hidl { |
| namespace manager { |
| namespace V1_0 { |
| namespace implementation { |
| |
| using ::android::hardware::hidl_death_recipient; |
| using ::android::hardware::hidl_vec; |
| using ::android::hardware::hidl_string; |
| using ::android::hardware::Return; |
| using ::android::hardware::Void; |
| using ::android::hidl::base::V1_0::IBase; |
| using ::android::hidl::manager::V1_0::IServiceManager; |
| using ::android::hidl::manager::V1_0::IServiceNotification; |
| using ::android::sp; |
| using ::android::wp; |
| |
| struct ServiceManager : public IServiceManager, hidl_death_recipient { |
| // Methods from ::android::hidl::manager::V1_0::IServiceManager follow. |
| Return<sp<IBase>> get(const hidl_string& fqName, |
| const hidl_string& name) override; |
| Return<bool> add(const hidl_string& name, |
| const sp<IBase>& service) override; |
| |
| Return<Transport> getTransport(const hidl_string& fqName, |
| const hidl_string& name); |
| |
| Return<void> list(list_cb _hidl_cb) override; |
| Return<void> listByInterface(const hidl_string& fqInstanceName, |
| listByInterface_cb _hidl_cb) override; |
| |
| Return<bool> registerForNotifications(const hidl_string& fqName, |
| const hidl_string& name, |
| const sp<IServiceNotification>& callback) override; |
| |
| Return<void> debugDump(debugDump_cb _cb) override; |
| Return<void> registerPassthroughClient(const hidl_string &fqName, |
| const hidl_string &name, int32_t pid) override; |
| |
| virtual void serviceDied(uint64_t cookie, const wp<IBase>& who); |
| private: |
| bool remove(const wp<IBase>& who); |
| bool removePackageListener(const wp<IBase>& who); |
| bool removeServiceListener(const wp<IBase>& who); |
| size_t countExistingService() const; |
| void forEachExistingService(std::function<void(const HidlService *)> f) const; |
| void forEachServiceEntry(std::function<void(const HidlService *)> f) const; |
| |
| using InstanceMap = std::map< |
| std::string, // instance name e.x. "manager" |
| std::unique_ptr<HidlService> |
| >; |
| |
| struct PackageInterfaceMap { |
| InstanceMap &getInstanceMap(); |
| const InstanceMap &getInstanceMap() const; |
| |
| /** |
| * Finds a HidlService with the desired name. If none, |
| * returns nullptr. HidlService::getService() might also be nullptr |
| * if there are registered IServiceNotification objects for it. Return |
| * value should be treated as a temporary reference. |
| */ |
| HidlService *lookup( |
| const std::string &name); |
| const HidlService *lookup( |
| const std::string &name) const; |
| |
| void insertService(std::unique_ptr<HidlService> &&service); |
| |
| void addPackageListener(sp<IServiceNotification> listener); |
| bool removePackageListener(const wp<IBase>& who); |
| |
| void sendPackageRegistrationNotification( |
| const hidl_string &fqName, |
| const hidl_string &instanceName); |
| |
| private: |
| InstanceMap mInstanceMap{}; |
| |
| std::vector<sp<IServiceNotification>> mPackageListeners{}; |
| }; |
| |
| /** |
| * Access to this map doesn't need to be locked, since hwservicemanager |
| * is single-threaded. |
| * |
| * e.x. |
| * mServiceMap["[email protected]::IServiceManager"]["manager"] |
| * -> HidlService object |
| */ |
| std::map< |
| std::string, // package::interface e.x. "[email protected]::IServiceManager" |
| PackageInterfaceMap |
| > mServiceMap; |
| }; |
| |
| } // namespace implementation |
| } // namespace V1_0 |
| } // namespace manager |
| } // namespace hidl |
| } // namespace android |
| |
| #endif // ANDROID_HARDWARE_MANAGER_V1_0_SERVICEMANAGER_H |