2024-09-09 08:57:42 +00:00
|
|
|
/* Copyright (c) 2011, 2013 - 2014, The Linux Foundation. All rights reserved.
|
2024-09-09 08:52:07 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Subsystem restart notifier API header
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SUBSYS_NOTIFIER_H
|
|
|
|
#define _SUBSYS_NOTIFIER_H
|
|
|
|
|
|
|
|
#include <linux/notifier.h>
|
|
|
|
|
|
|
|
enum subsys_notif_type {
|
|
|
|
SUBSYS_BEFORE_SHUTDOWN,
|
|
|
|
SUBSYS_AFTER_SHUTDOWN,
|
|
|
|
SUBSYS_BEFORE_POWERUP,
|
|
|
|
SUBSYS_AFTER_POWERUP,
|
|
|
|
SUBSYS_RAMDUMP_NOTIFICATION,
|
2024-09-09 08:57:42 +00:00
|
|
|
SUBSYS_POWERUP_FAILURE,
|
|
|
|
SUBSYS_PROXY_VOTE,
|
|
|
|
SUBSYS_PROXY_UNVOTE,
|
|
|
|
SUBSYS_SOC_RESET,
|
2024-09-09 08:52:07 +00:00
|
|
|
SUBSYS_NOTIF_TYPE_COUNT
|
|
|
|
};
|
|
|
|
|
|
|
|
#if defined(CONFIG_MSM_SUBSYSTEM_RESTART)
|
|
|
|
/* Use the subsys_notif_register_notifier API to register for notifications for
|
|
|
|
* a particular subsystem. This API will return a handle that can be used to
|
|
|
|
* un-reg for notifications using the subsys_notif_unregister_notifier API by
|
|
|
|
* passing in that handle as an argument.
|
|
|
|
*
|
|
|
|
* On receiving a notification, the second (unsigned long) argument of the
|
|
|
|
* notifier callback will contain the notification type, and the third (void *)
|
|
|
|
* argument will contain the handle that was returned by
|
|
|
|
* subsys_notif_register_notifier.
|
|
|
|
*/
|
|
|
|
void *subsys_notif_register_notifier(
|
|
|
|
const char *subsys_name, struct notifier_block *nb);
|
|
|
|
int subsys_notif_unregister_notifier(void *subsys_handle,
|
|
|
|
struct notifier_block *nb);
|
|
|
|
|
|
|
|
/* Use the subsys_notif_init_subsys API to initialize the notifier chains form
|
|
|
|
* a particular subsystem. This API will return a handle that can be used to
|
|
|
|
* queue notifications using the subsys_notif_queue_notification API by passing
|
|
|
|
* in that handle as an argument.
|
|
|
|
*/
|
|
|
|
void *subsys_notif_add_subsys(const char *);
|
|
|
|
int subsys_notif_queue_notification(void *subsys_handle,
|
|
|
|
enum subsys_notif_type notif_type,
|
|
|
|
void *data);
|
|
|
|
#else
|
|
|
|
|
|
|
|
static inline void *subsys_notif_register_notifier(
|
|
|
|
const char *subsys_name, struct notifier_block *nb)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int subsys_notif_unregister_notifier(void *subsys_handle,
|
|
|
|
struct notifier_block *nb)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *subsys_notif_add_subsys(const char *subsys_name)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int subsys_notif_queue_notification(void *subsys_handle,
|
|
|
|
enum subsys_notif_type notif_type,
|
|
|
|
void *data)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_MSM_SUBSYSTEM_RESTART */
|
|
|
|
|
|
|
|
#endif
|