linux/drivers/gpu/drm/sprd/sprd_dsi.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0 */
   2/*
   3 * Copyright (C) 2020 Unisoc Inc.
   4 */
   5
   6#ifndef __SPRD_DSI_H__
   7#define __SPRD_DSI_H__
   8
   9#include <linux/of.h>
  10#include <linux/device.h>
  11#include <linux/regmap.h>
  12#include <video/videomode.h>
  13
  14#include <drm/drm_bridge.h>
  15#include <drm/drm_connector.h>
  16#include <drm/drm_encoder.h>
  17#include <drm/drm_mipi_dsi.h>
  18#include <drm/drm_print.h>
  19#include <drm/drm_panel.h>
  20
  21#define encoder_to_dsi(encoder) \
  22        container_of(encoder, struct sprd_dsi, encoder)
  23
  24enum dsi_work_mode {
  25        DSI_MODE_CMD = 0,
  26        DSI_MODE_VIDEO
  27};
  28
  29enum video_burst_mode {
  30        VIDEO_NON_BURST_WITH_SYNC_PULSES = 0,
  31        VIDEO_NON_BURST_WITH_SYNC_EVENTS,
  32        VIDEO_BURST_WITH_SYNC_PULSES
  33};
  34
  35enum dsi_color_coding {
  36        COLOR_CODE_16BIT_CONFIG1 = 0,
  37        COLOR_CODE_16BIT_CONFIG2,
  38        COLOR_CODE_16BIT_CONFIG3,
  39        COLOR_CODE_18BIT_CONFIG1,
  40        COLOR_CODE_18BIT_CONFIG2,
  41        COLOR_CODE_24BIT,
  42        COLOR_CODE_20BIT_YCC422_LOOSELY,
  43        COLOR_CODE_24BIT_YCC422,
  44        COLOR_CODE_16BIT_YCC422,
  45        COLOR_CODE_30BIT,
  46        COLOR_CODE_36BIT,
  47        COLOR_CODE_12BIT_YCC420,
  48        COLOR_CODE_COMPRESSTION,
  49        COLOR_CODE_MAX
  50};
  51
  52enum pll_timing {
  53        NONE,
  54        REQUEST_TIME,
  55        PREPARE_TIME,
  56        SETTLE_TIME,
  57        ZERO_TIME,
  58        TRAIL_TIME,
  59        EXIT_TIME,
  60        CLKPOST_TIME,
  61        TA_GET,
  62        TA_GO,
  63        TA_SURE,
  64        TA_WAIT,
  65};
  66
  67struct dphy_pll {
  68        u8 refin; /* Pre-divider control signal */
  69        u8 cp_s; /* 00: SDM_EN=1, 10: SDM_EN=0 */
  70        u8 fdk_s; /* PLL mode control: integer or fraction */
  71        u8 sdm_en;
  72        u8 div;
  73        u8 int_n; /* integer N PLL */
  74        u32 ref_clk; /* dphy reference clock, unit: MHz */
  75        u32 freq; /* panel config, unit: KHz */
  76        u32 fvco;
  77        u32 potential_fvco;
  78        u32 nint; /* sigma delta modulator NINT control */
  79        u32 kint; /* sigma delta modulator KINT control */
  80        u8 lpf_sel; /* low pass filter control */
  81        u8 out_sel; /* post divider control */
  82        u8 vco_band; /* vco range */
  83        u8 det_delay;
  84};
  85
  86struct dsi_context {
  87        void __iomem *base;
  88        struct regmap *regmap;
  89        struct dphy_pll pll;
  90        struct videomode vm;
  91        bool enabled;
  92
  93        u8 work_mode;
  94        u8 burst_mode;
  95        u32 int0_mask;
  96        u32 int1_mask;
  97
  98        /* maximum time (ns) for data lanes from HS to LP */
  99        u16 data_hs2lp;
 100        /* maximum time (ns) for data lanes from LP to HS */
 101        u16 data_lp2hs;
 102        /* maximum time (ns) for clk lanes from HS to LP */
 103        u16 clk_hs2lp;
 104        /* maximum time (ns) for clk lanes from LP to HS */
 105        u16 clk_lp2hs;
 106        /* maximum time (ns) for BTA operation - REQUIRED */
 107        u16 max_rd_time;
 108        /* enable receiving frame ack packets - for video mode */
 109        bool frame_ack_en;
 110        /* enable receiving tear effect ack packets - for cmd mode */
 111        bool te_ack_en;
 112};
 113
 114struct sprd_dsi {
 115        struct drm_device *drm;
 116        struct mipi_dsi_host host;
 117        struct mipi_dsi_device *slave;
 118        struct drm_encoder encoder;
 119        struct drm_bridge *panel_bridge;
 120        struct dsi_context ctx;
 121};
 122
 123int dphy_pll_config(struct dsi_context *ctx);
 124void dphy_timing_config(struct dsi_context *ctx);
 125
 126#endif /* __SPRD_DSI_H__ */
 127