| /* SPDX-License-Identifier: MIT */ |
| /* |
| * Copyright (C) 2020 Red Hat, Inc. |
| * |
| * Authors: |
| * Hans de Goede <hdegoede@redhat.com> |
| */ |
| |
| #ifndef __DRM_PRIVACY_SCREEN_DRIVER_H__ |
| #define __DRM_PRIVACY_SCREEN_DRIVER_H__ |
| |
| #include <linux/device.h> |
| #include <linux/list.h> |
| #include <linux/mutex.h> |
| #include <drm/drm_connector.h> |
| |
| struct drm_privacy_screen; |
| |
| /** |
| * struct drm_privacy_screen_ops - drm_privacy_screen operations |
| * |
| * Defines the operations which the privacy-screen class code may call. |
| * These functions should be implemented by the privacy-screen driver. |
| */ |
| struct drm_privacy_screen_ops { |
| /** |
| * @set_sw_state: Called to request a change of the privacy-screen |
| * state. The privacy-screen class code contains a check to avoid this |
| * getting called when the hw_state reports the state is locked. |
| * It is the driver's responsibility to update sw_state and hw_state. |
| * This is always called with the drm_privacy_screen's lock held. |
| */ |
| int (*set_sw_state)(struct drm_privacy_screen *priv, |
| enum drm_privacy_screen_status sw_state); |
| /** |
| * @get_hw_state: Called to request that the driver gets the current |
| * privacy-screen state from the hardware and then updates sw_state and |
| * hw_state accordingly. This will be called by the core just before |
| * the privacy-screen is registered in sysfs. |
| */ |
| void (*get_hw_state)(struct drm_privacy_screen *priv); |
| }; |
| |
| /** |
| * struct drm_privacy_screen - central privacy-screen structure |
| * |
| * Central privacy-screen structure, this contains the struct device used |
| * to register the screen in sysfs, the screen's state, ops, etc. |
| */ |
| struct drm_privacy_screen { |
| /** @dev: device used to register the privacy-screen in sysfs. */ |
| struct device dev; |
| /** @lock: mutex protection all fields in this struct. */ |
| struct mutex lock; |
| /** @list: privacy-screen devices list list-entry. */ |
| struct list_head list; |
| /** @notifier_head: privacy-screen notifier head. */ |
| struct blocking_notifier_head notifier_head; |
| /** |
| * @ops: &struct drm_privacy_screen_ops for this privacy-screen. |
| * This is NULL if the driver has unregistered the privacy-screen. |
| */ |
| const struct drm_privacy_screen_ops *ops; |
| /** |
| * @sw_state: The privacy-screen's software state, see |
| * :ref:`Standard Connector Properties<standard_connector_properties>` |
| * for more info. |
| */ |
| enum drm_privacy_screen_status sw_state; |
| /** |
| * @hw_state: The privacy-screen's hardware state, see |
| * :ref:`Standard Connector Properties<standard_connector_properties>` |
| * for more info. |
| */ |
| enum drm_privacy_screen_status hw_state; |
| /** |
| * @drvdata: Private data owned by the privacy screen provider |
| */ |
| void *drvdata; |
| }; |
| |
| static inline |
| void *drm_privacy_screen_get_drvdata(struct drm_privacy_screen *priv) |
| { |
| return priv->drvdata; |
| } |
| |
| struct drm_privacy_screen *drm_privacy_screen_register( |
| struct device *parent, const struct drm_privacy_screen_ops *ops, |
| void *data); |
| void drm_privacy_screen_unregister(struct drm_privacy_screen *priv); |
| |
| void drm_privacy_screen_call_notifier_chain(struct drm_privacy_screen *priv); |
| |
| #endif |