2018-04-04 17:57:11 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2016 Allwinnertech Co., Ltd.
|
|
|
|
* Copyright (C) 2017-2018 Bootlin
|
|
|
|
*
|
|
|
|
* Maxime Ripard <maxime.ripard@bootlin.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SUN6I_MIPI_DSI_H_
|
|
|
|
#define _SUN6I_MIPI_DSI_H_
|
|
|
|
|
|
|
|
#include <drm/drm_connector.h>
|
|
|
|
#include <drm/drm_encoder.h>
|
|
|
|
#include <drm/drm_mipi_dsi.h>
|
|
|
|
|
2019-02-11 22:41:22 +08:00
|
|
|
#define SUN6I_DSI_TCON_DIV 4
|
|
|
|
|
2018-04-04 17:57:11 +08:00
|
|
|
struct sun6i_dsi {
|
|
|
|
struct drm_connector connector;
|
|
|
|
struct drm_encoder encoder;
|
|
|
|
struct mipi_dsi_host host;
|
|
|
|
|
|
|
|
struct clk *bus_clk;
|
|
|
|
struct clk *mod_clk;
|
|
|
|
struct regmap *regs;
|
2019-10-03 14:45:25 +08:00
|
|
|
struct regulator *regulator;
|
2018-04-04 17:57:11 +08:00
|
|
|
struct reset_control *reset;
|
2019-01-21 23:45:49 +08:00
|
|
|
struct phy *dphy;
|
2018-04-04 17:57:11 +08:00
|
|
|
|
|
|
|
struct device *dev;
|
|
|
|
struct sun4i_drv *drv;
|
|
|
|
struct mipi_dsi_device *device;
|
|
|
|
struct drm_panel *panel;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct sun6i_dsi *host_to_sun6i_dsi(struct mipi_dsi_host *host)
|
|
|
|
{
|
|
|
|
return container_of(host, struct sun6i_dsi, host);
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct sun6i_dsi *connector_to_sun6i_dsi(struct drm_connector *connector)
|
|
|
|
{
|
|
|
|
return container_of(connector, struct sun6i_dsi, connector);
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct sun6i_dsi *encoder_to_sun6i_dsi(const struct drm_encoder *encoder)
|
|
|
|
{
|
|
|
|
return container_of(encoder, struct sun6i_dsi, encoder);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _SUN6I_MIPI_DSI_H_ */
|