1133add5bSMaxime Ripard // SPDX-License-Identifier: GPL-2.0+ 2133add5bSMaxime Ripard /* 3133add5bSMaxime Ripard * Copyright (c) 2016 Allwinnertech Co., Ltd. 4133add5bSMaxime Ripard * Copyright (C) 2017-2018 Bootlin 5133add5bSMaxime Ripard * 6133add5bSMaxime Ripard * Maxime Ripard <maxime.ripard@bootlin.com> 7133add5bSMaxime Ripard */ 8133add5bSMaxime Ripard 9133add5bSMaxime Ripard #ifndef _SUN6I_MIPI_DSI_H_ 10133add5bSMaxime Ripard #define _SUN6I_MIPI_DSI_H_ 11133add5bSMaxime Ripard 12133add5bSMaxime Ripard #include <drm/drm_connector.h> 13133add5bSMaxime Ripard #include <drm/drm_encoder.h> 14133add5bSMaxime Ripard #include <drm/drm_mipi_dsi.h> 15133add5bSMaxime Ripard 16*85fb3526SMaxime Ripard #define SUN6I_DSI_TCON_DIV 4 17*85fb3526SMaxime Ripard 18133add5bSMaxime Ripard struct sun6i_dsi { 19133add5bSMaxime Ripard struct drm_connector connector; 20133add5bSMaxime Ripard struct drm_encoder encoder; 21133add5bSMaxime Ripard struct mipi_dsi_host host; 22133add5bSMaxime Ripard 23133add5bSMaxime Ripard struct clk *bus_clk; 24133add5bSMaxime Ripard struct clk *mod_clk; 25133add5bSMaxime Ripard struct regmap *regs; 26133add5bSMaxime Ripard struct reset_control *reset; 27bb3b6fcbSMaxime Ripard struct phy *dphy; 28133add5bSMaxime Ripard 29133add5bSMaxime Ripard struct device *dev; 30133add5bSMaxime Ripard struct sun4i_drv *drv; 31133add5bSMaxime Ripard struct mipi_dsi_device *device; 32133add5bSMaxime Ripard struct drm_panel *panel; 33133add5bSMaxime Ripard }; 34133add5bSMaxime Ripard 35133add5bSMaxime Ripard static inline struct sun6i_dsi *host_to_sun6i_dsi(struct mipi_dsi_host *host) 36133add5bSMaxime Ripard { 37133add5bSMaxime Ripard return container_of(host, struct sun6i_dsi, host); 38133add5bSMaxime Ripard }; 39133add5bSMaxime Ripard 40133add5bSMaxime Ripard static inline struct sun6i_dsi *connector_to_sun6i_dsi(struct drm_connector *connector) 41133add5bSMaxime Ripard { 42133add5bSMaxime Ripard return container_of(connector, struct sun6i_dsi, connector); 43133add5bSMaxime Ripard }; 44133add5bSMaxime Ripard 45133add5bSMaxime Ripard static inline struct sun6i_dsi *encoder_to_sun6i_dsi(const struct drm_encoder *encoder) 46133add5bSMaxime Ripard { 47133add5bSMaxime Ripard return container_of(encoder, struct sun6i_dsi, encoder); 48133add5bSMaxime Ripard }; 49133add5bSMaxime Ripard 50133add5bSMaxime Ripard #endif /* _SUN6I_MIPI_DSI_H_ */ 51