| /* SPDX-License-Identifier: GPL-2.0-only */ | 
 | /* | 
 |  * External Connector (extcon) framework | 
 |  * - linux/include/linux/extcon-provider.h for extcon provider device driver. | 
 |  * | 
 |  * Copyright (C) 2017 Samsung Electronics | 
 |  * Author: Chanwoo Choi <cw00.choi@samsung.com> | 
 |  */ | 
 |  | 
 | #ifndef __LINUX_EXTCON_PROVIDER_H__ | 
 | #define __LINUX_EXTCON_PROVIDER_H__ | 
 |  | 
 | #include <linux/extcon.h> | 
 |  | 
 | struct extcon_dev; | 
 |  | 
 | #if IS_ENABLED(CONFIG_EXTCON) | 
 |  | 
 | /* Following APIs register/unregister the extcon device. */ | 
 | int extcon_dev_register(struct extcon_dev *edev); | 
 | void extcon_dev_unregister(struct extcon_dev *edev); | 
 | int devm_extcon_dev_register(struct device *dev, | 
 | 				struct extcon_dev *edev); | 
 | void devm_extcon_dev_unregister(struct device *dev, | 
 | 				struct extcon_dev *edev); | 
 |  | 
 | /* Following APIs allocate/free the memory of the extcon device. */ | 
 | struct extcon_dev *extcon_dev_allocate(const unsigned int *cable); | 
 | void extcon_dev_free(struct extcon_dev *edev); | 
 | struct extcon_dev *devm_extcon_dev_allocate(struct device *dev, | 
 | 				const unsigned int *cable); | 
 | void devm_extcon_dev_free(struct device *dev, struct extcon_dev *edev); | 
 |  | 
 | /* Synchronize the state and property value for each external connector. */ | 
 | int extcon_sync(struct extcon_dev *edev, unsigned int id); | 
 |  | 
 | /* | 
 |  * Following APIs set the connected state of each external connector. | 
 |  * The 'id' argument indicates the defined external connector. | 
 |  */ | 
 | int extcon_set_state(struct extcon_dev *edev, unsigned int id, | 
 | 				bool state); | 
 | int extcon_set_state_sync(struct extcon_dev *edev, unsigned int id, | 
 | 				bool state); | 
 |  | 
 | /* | 
 |  * Following APIs set the property of each external connector. | 
 |  * The 'id' argument indicates the defined external connector | 
 |  * and the 'prop' indicates the extcon property. | 
 |  * | 
 |  * And extcon_set_property_capability() set the capability of the property | 
 |  * for each external connector. They are used to set the capability of the | 
 |  * property of each external connector based on the id and property. | 
 |  */ | 
 | int extcon_set_property(struct extcon_dev *edev, unsigned int id, | 
 | 				unsigned int prop, | 
 | 				union extcon_property_value prop_val); | 
 | int extcon_set_property_sync(struct extcon_dev *edev, unsigned int id, | 
 | 				unsigned int prop, | 
 | 				union extcon_property_value prop_val); | 
 | int extcon_set_property_capability(struct extcon_dev *edev, | 
 | 				unsigned int id, unsigned int prop); | 
 |  | 
 | #else /* CONFIG_EXTCON */ | 
 | static inline int extcon_dev_register(struct extcon_dev *edev) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline void extcon_dev_unregister(struct extcon_dev *edev) { } | 
 |  | 
 | static inline int devm_extcon_dev_register(struct device *dev, | 
 | 				struct extcon_dev *edev) | 
 | { | 
 | 	return -EINVAL; | 
 | } | 
 |  | 
 | static inline void devm_extcon_dev_unregister(struct device *dev, | 
 | 				struct extcon_dev *edev) { } | 
 |  | 
 | static inline struct extcon_dev *extcon_dev_allocate(const unsigned int *cable) | 
 | { | 
 | 	return ERR_PTR(-ENOSYS); | 
 | } | 
 |  | 
 | static inline void extcon_dev_free(struct extcon_dev *edev) { } | 
 |  | 
 | static inline struct extcon_dev *devm_extcon_dev_allocate(struct device *dev, | 
 | 				const unsigned int *cable) | 
 | { | 
 | 	return ERR_PTR(-ENOSYS); | 
 | } | 
 |  | 
 | static inline void devm_extcon_dev_free(struct extcon_dev *edev) { } | 
 |  | 
 |  | 
 | static inline int extcon_set_state(struct extcon_dev *edev, unsigned int id, | 
 | 				bool state) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline int extcon_set_state_sync(struct extcon_dev *edev, unsigned int id, | 
 | 				bool state) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline int extcon_sync(struct extcon_dev *edev, unsigned int id) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline int extcon_set_property(struct extcon_dev *edev, unsigned int id, | 
 | 				unsigned int prop, | 
 | 				union extcon_property_value prop_val) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline int extcon_set_property_sync(struct extcon_dev *edev, | 
 | 				unsigned int id, unsigned int prop, | 
 | 				union extcon_property_value prop_val) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static inline int extcon_set_property_capability(struct extcon_dev *edev, | 
 | 				unsigned int id, unsigned int prop) | 
 | { | 
 | 	return 0; | 
 | } | 
 | #endif /* CONFIG_EXTCON */ | 
 | #endif /* __LINUX_EXTCON_PROVIDER_H__ */ |