mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
0ef1905ecf
Our current global state handling is pretty ad-hoc. Let's try to make it better by imitating the standard drm core private object approach. The reason why we don't want to directly use the private objects is locking; Each private object has its own lock so if we introduce any global private objects we get serialized by that single lock across all pipes. The global state apporoach instead uses a read/write lock type of approach where each individual crtc lock counts as a read lock, and grabbing all the crtc locks allows one write access. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20200120174728.21095-15-ville.syrjala@linux.intel.com Reviewed-by: Imre Deak <imre.deak@intel.com>
64 lines
2.2 KiB
C
64 lines
2.2 KiB
C
/* SPDX-License-Identifier: MIT */
|
|
/*
|
|
* Copyright © 2019 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __INTEL_ATOMIC_H__
|
|
#define __INTEL_ATOMIC_H__
|
|
|
|
#include <linux/types.h>
|
|
|
|
struct drm_atomic_state;
|
|
struct drm_connector;
|
|
struct drm_connector_state;
|
|
struct drm_crtc;
|
|
struct drm_crtc_state;
|
|
struct drm_device;
|
|
struct drm_i915_private;
|
|
struct drm_property;
|
|
struct intel_atomic_state;
|
|
struct intel_connector;
|
|
struct intel_crtc;
|
|
struct intel_crtc_state;
|
|
|
|
int intel_digital_connector_atomic_get_property(struct drm_connector *connector,
|
|
const struct drm_connector_state *state,
|
|
struct drm_property *property,
|
|
u64 *val);
|
|
int intel_digital_connector_atomic_set_property(struct drm_connector *connector,
|
|
struct drm_connector_state *state,
|
|
struct drm_property *property,
|
|
u64 val);
|
|
int intel_digital_connector_atomic_check(struct drm_connector *conn,
|
|
struct drm_atomic_state *state);
|
|
struct drm_connector_state *
|
|
intel_digital_connector_duplicate_state(struct drm_connector *connector);
|
|
bool intel_connector_needs_modeset(struct intel_atomic_state *state,
|
|
struct drm_connector *connector);
|
|
struct intel_digital_connector_state *
|
|
intel_atomic_get_digital_connector_state(struct intel_atomic_state *state,
|
|
struct intel_connector *connector);
|
|
|
|
struct drm_crtc_state *intel_crtc_duplicate_state(struct drm_crtc *crtc);
|
|
void intel_crtc_destroy_state(struct drm_crtc *crtc,
|
|
struct drm_crtc_state *state);
|
|
void intel_crtc_free_hw_state(struct intel_crtc_state *crtc_state);
|
|
void intel_crtc_copy_color_blobs(struct intel_crtc_state *crtc_state);
|
|
struct drm_atomic_state *intel_atomic_state_alloc(struct drm_device *dev);
|
|
void intel_atomic_state_free(struct drm_atomic_state *state);
|
|
void intel_atomic_state_clear(struct drm_atomic_state *state);
|
|
|
|
struct intel_crtc_state *
|
|
intel_atomic_get_crtc_state(struct drm_atomic_state *state,
|
|
struct intel_crtc *crtc);
|
|
|
|
int intel_atomic_setup_scalers(struct drm_i915_private *dev_priv,
|
|
struct intel_crtc *intel_crtc,
|
|
struct intel_crtc_state *crtc_state);
|
|
|
|
int _intel_atomic_lock_global_state(struct intel_atomic_state *state);
|
|
|
|
int _intel_atomic_serialize_global_state(struct intel_atomic_state *state);
|
|
|
|
#endif /* __INTEL_ATOMIC_H__ */
|