2018-07-08 02:05:34 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
|
|
* ZynqMP DPSUB Subsystem Driver
|
|
|
|
*
|
|
|
|
* Copyright (C) 2017 - 2020 Xilinx, Inc.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* - Hyun Woo Kwon <hyun.kwon@xilinx.com>
|
|
|
|
* - Laurent Pinchart <laurent.pinchart@ideasonboard.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ZYNQMP_DPSUB_H_
|
|
|
|
#define _ZYNQMP_DPSUB_H_
|
|
|
|
|
2021-08-04 16:21:41 +00:00
|
|
|
#include <drm/drm_encoder.h>
|
|
|
|
|
2018-07-08 02:05:34 +00:00
|
|
|
struct clk;
|
|
|
|
struct device;
|
2021-08-04 16:21:41 +00:00
|
|
|
struct drm_bridge;
|
2018-07-08 02:05:34 +00:00
|
|
|
struct drm_device;
|
|
|
|
struct zynqmp_disp;
|
|
|
|
struct zynqmp_dp;
|
|
|
|
|
|
|
|
enum zynqmp_dpsub_format {
|
|
|
|
ZYNQMP_DPSUB_FORMAT_RGB,
|
|
|
|
ZYNQMP_DPSUB_FORMAT_YCRCB444,
|
|
|
|
ZYNQMP_DPSUB_FORMAT_YCRCB422,
|
|
|
|
ZYNQMP_DPSUB_FORMAT_YONLY,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct zynqmp_dpsub - ZynqMP DisplayPort Subsystem
|
|
|
|
* @drm: The DRM/KMS device
|
|
|
|
* @dev: The physical device
|
|
|
|
* @apb_clk: The APB clock
|
2021-08-06 11:29:52 +00:00
|
|
|
* @vid_clk: Video clock
|
|
|
|
* @vid_clk_from_ps: True of the video clock comes from PS, false from PL
|
2021-08-04 16:21:41 +00:00
|
|
|
* @encoder: The dummy DRM encoder
|
|
|
|
* @bridge: The DP encoder bridge
|
2018-07-08 02:05:34 +00:00
|
|
|
* @disp: The display controller
|
|
|
|
* @dp: The DisplayPort controller
|
|
|
|
* @dma_align: DMA alignment constraint (must be a power of 2)
|
|
|
|
*/
|
|
|
|
struct zynqmp_dpsub {
|
|
|
|
struct drm_device drm;
|
|
|
|
struct device *dev;
|
|
|
|
|
|
|
|
struct clk *apb_clk;
|
2021-08-06 11:29:52 +00:00
|
|
|
struct clk *vid_clk;
|
|
|
|
bool vid_clk_from_ps;
|
2018-07-08 02:05:34 +00:00
|
|
|
|
2021-08-04 16:21:41 +00:00
|
|
|
struct drm_encoder encoder;
|
|
|
|
struct drm_bridge *bridge;
|
|
|
|
|
2018-07-08 02:05:34 +00:00
|
|
|
struct zynqmp_disp *disp;
|
|
|
|
struct zynqmp_dp *dp;
|
|
|
|
|
|
|
|
unsigned int dma_align;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct zynqmp_dpsub *to_zynqmp_dpsub(struct drm_device *drm)
|
|
|
|
{
|
|
|
|
return container_of(drm, struct zynqmp_dpsub, drm);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _ZYNQMP_DPSUB_H_ */
|