/* * Copyright (c) 2015-2017, 2019 The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * Process Domain Service Notifier API header */ #ifndef _SERVICE_NOTIFIER_H #define _SERVICE_NOTIFIER_H enum qmi_servreg_notif_service_state_enum_type_v01 { QMI_SERVREG_NOTIF_SERVICE_STATE_ENUM_TYPE_MIN_VAL_V01 = INT_MIN, QMI_SERVREG_NOTIF_SERVICE_STATE_ENUM_TYPE_MAX_VAL_V01 = INT_MAX, SERVREG_NOTIF_SERVICE_STATE_DOWN_V01 = 0x0FFFFFFF, SERVREG_NOTIF_SERVICE_STATE_UP_V01 = 0x1FFFFFFF, SERVREG_NOTIF_SERVICE_STATE_EARLY_DOWN_V01 = 0x2FFFFFFF, SERVREG_NOTIF_SERVICE_STATE_UNINIT_V01 = 0x7FFFFFFF, }; enum pd_subsys_state { ROOT_PD_DOWN, ROOT_PD_UP, ROOT_PD_ERR_FATAL, ROOT_PD_WDOG_BITE, ROOT_PD_SHUTDOWN, USER_PD_STATE_CHANGE, }; #if defined(CONFIG_MSM_SERVICE_NOTIFIER) /* service_notif_register_notifier() - Register a notifier for a service * On success, it returns back a handle. It takes the following arguments: * service_path: Individual service identifier path for which a client * registers for notifications. * instance_id: Instance id specific to a subsystem. * current_state: Current state of service returned by the registration * process. * notifier block: notifier callback for service events. */ void *service_notif_register_notifier(const char *service_path, int instance_id, struct notifier_block *nb, int *curr_state); /* service_notif_unregister_notifier() - Unregister a notifier for a service. * service_notif_handle - The notifier handler that was provided by the * service_notif_register_notifier function when the * client registered for notifications. * nb - The notifier block that was previously used during the registration. */ int service_notif_unregister_notifier(void *service_notif_handle, struct notifier_block *nb); int service_notif_pd_restart(const char *service_path, int instance_id); #else static inline void *service_notif_register_notifier(const char *service_path, int instance_id, struct notifier_block *nb, int *curr_state) { return ERR_PTR(-ENODEV); } static inline int service_notif_unregister_notifier(void *service_notif_handle, struct notifier_block *nb) { return -ENODEV; } static inline int service_notif_pd_restart(const char *service_path, int instance_id) { return -ENODEV; } #endif /* CONFIG_MSM_SERVICE_NOTIFIER */ #endif