mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-05 05:15:02 +08:00
9c5681011a
The earlier Allwinner SoCs (A10, A10s, A20, A31) have an embedded HDMI controller. That HDMI controller is able to do audio and CEC, but those have been left out for now. Reviewed-by: Chen-Yu Tsai <wens@csie.org> Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
158 lines
5.1 KiB
C
158 lines
5.1 KiB
C
/*
|
|
* Copyright (C) 2016 Maxime Ripard
|
|
*
|
|
* Maxime Ripard <maxime.ripard@free-electrons.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License as
|
|
* published by the Free Software Foundation; either version 2 of
|
|
* the License, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _SUN4I_HDMI_H_
|
|
#define _SUN4I_HDMI_H_
|
|
|
|
#include <drm/drm_connector.h>
|
|
#include <drm/drm_encoder.h>
|
|
|
|
#define SUN4I_HDMI_CTRL_REG 0x004
|
|
#define SUN4I_HDMI_CTRL_ENABLE BIT(31)
|
|
|
|
#define SUN4I_HDMI_IRQ_REG 0x008
|
|
#define SUN4I_HDMI_IRQ_STA_MASK 0x73
|
|
#define SUN4I_HDMI_IRQ_STA_FIFO_OF BIT(1)
|
|
#define SUN4I_HDMI_IRQ_STA_FIFO_UF BIT(0)
|
|
|
|
#define SUN4I_HDMI_HPD_REG 0x00c
|
|
#define SUN4I_HDMI_HPD_HIGH BIT(0)
|
|
|
|
#define SUN4I_HDMI_VID_CTRL_REG 0x010
|
|
#define SUN4I_HDMI_VID_CTRL_ENABLE BIT(31)
|
|
#define SUN4I_HDMI_VID_CTRL_HDMI_MODE BIT(30)
|
|
|
|
#define SUN4I_HDMI_VID_TIMING_ACT_REG 0x014
|
|
#define SUN4I_HDMI_VID_TIMING_BP_REG 0x018
|
|
#define SUN4I_HDMI_VID_TIMING_FP_REG 0x01c
|
|
#define SUN4I_HDMI_VID_TIMING_SPW_REG 0x020
|
|
|
|
#define SUN4I_HDMI_VID_TIMING_X(x) ((((x) - 1) & GENMASK(11, 0)))
|
|
#define SUN4I_HDMI_VID_TIMING_Y(y) ((((y) - 1) & GENMASK(11, 0)) << 16)
|
|
|
|
#define SUN4I_HDMI_VID_TIMING_POL_REG 0x024
|
|
#define SUN4I_HDMI_VID_TIMING_POL_TX_CLK (0x3e0 << 16)
|
|
#define SUN4I_HDMI_VID_TIMING_POL_VSYNC BIT(1)
|
|
#define SUN4I_HDMI_VID_TIMING_POL_HSYNC BIT(0)
|
|
|
|
#define SUN4I_HDMI_AVI_INFOFRAME_REG(n) (0x080 + (n))
|
|
|
|
#define SUN4I_HDMI_PAD_CTRL0_REG 0x200
|
|
#define SUN4I_HDMI_PAD_CTRL0_BIASEN BIT(31)
|
|
#define SUN4I_HDMI_PAD_CTRL0_LDOCEN BIT(30)
|
|
#define SUN4I_HDMI_PAD_CTRL0_LDODEN BIT(29)
|
|
#define SUN4I_HDMI_PAD_CTRL0_PWENC BIT(28)
|
|
#define SUN4I_HDMI_PAD_CTRL0_PWEND BIT(27)
|
|
#define SUN4I_HDMI_PAD_CTRL0_PWENG BIT(26)
|
|
#define SUN4I_HDMI_PAD_CTRL0_CKEN BIT(25)
|
|
#define SUN4I_HDMI_PAD_CTRL0_TXEN BIT(23)
|
|
|
|
#define SUN4I_HDMI_PAD_CTRL1_REG 0x204
|
|
#define SUN4I_HDMI_PAD_CTRL1_AMP_OPT BIT(23)
|
|
#define SUN4I_HDMI_PAD_CTRL1_AMPCK_OPT BIT(22)
|
|
#define SUN4I_HDMI_PAD_CTRL1_EMP_OPT BIT(20)
|
|
#define SUN4I_HDMI_PAD_CTRL1_EMPCK_OPT BIT(19)
|
|
#define SUN4I_HDMI_PAD_CTRL1_REG_DEN BIT(15)
|
|
#define SUN4I_HDMI_PAD_CTRL1_REG_DENCK BIT(14)
|
|
#define SUN4I_HDMI_PAD_CTRL1_REG_EMP(n) (((n) & 7) << 10)
|
|
#define SUN4I_HDMI_PAD_CTRL1_HALVE_CLK BIT(6)
|
|
#define SUN4I_HDMI_PAD_CTRL1_REG_AMP(n) (((n) & 7) << 3)
|
|
|
|
#define SUN4I_HDMI_PLL_CTRL_REG 0x208
|
|
#define SUN4I_HDMI_PLL_CTRL_PLL_EN BIT(31)
|
|
#define SUN4I_HDMI_PLL_CTRL_BWS BIT(30)
|
|
#define SUN4I_HDMI_PLL_CTRL_HV_IS_33 BIT(29)
|
|
#define SUN4I_HDMI_PLL_CTRL_LDO1_EN BIT(28)
|
|
#define SUN4I_HDMI_PLL_CTRL_LDO2_EN BIT(27)
|
|
#define SUN4I_HDMI_PLL_CTRL_SDIV2 BIT(25)
|
|
#define SUN4I_HDMI_PLL_CTRL_VCO_GAIN(n) (((n) & 7) << 20)
|
|
#define SUN4I_HDMI_PLL_CTRL_S(n) (((n) & 7) << 17)
|
|
#define SUN4I_HDMI_PLL_CTRL_CP_S(n) (((n) & 0x1f) << 12)
|
|
#define SUN4I_HDMI_PLL_CTRL_CS(n) (((n) & 0xf) << 8)
|
|
#define SUN4I_HDMI_PLL_CTRL_DIV(n) (((n) & 0xf) << 4)
|
|
#define SUN4I_HDMI_PLL_CTRL_DIV_MASK GENMASK(7, 4)
|
|
#define SUN4I_HDMI_PLL_CTRL_VCO_S(n) ((n) & 0xf)
|
|
|
|
#define SUN4I_HDMI_PLL_DBG0_REG 0x20c
|
|
#define SUN4I_HDMI_PLL_DBG0_TMDS_PARENT(n) (((n) & 1) << 21)
|
|
#define SUN4I_HDMI_PLL_DBG0_TMDS_PARENT_MASK BIT(21)
|
|
#define SUN4I_HDMI_PLL_DBG0_TMDS_PARENT_SHIFT 21
|
|
|
|
#define SUN4I_HDMI_PKT_CTRL_REG(n) (0x2f0 + (4 * (n)))
|
|
#define SUN4I_HDMI_PKT_CTRL_TYPE(n, t) ((t) << (((n) % 4) * 4))
|
|
|
|
#define SUN4I_HDMI_UNKNOWN_REG 0x300
|
|
#define SUN4I_HDMI_UNKNOWN_INPUT_SYNC BIT(27)
|
|
|
|
#define SUN4I_HDMI_DDC_CTRL_REG 0x500
|
|
#define SUN4I_HDMI_DDC_CTRL_ENABLE BIT(31)
|
|
#define SUN4I_HDMI_DDC_CTRL_START_CMD BIT(30)
|
|
#define SUN4I_HDMI_DDC_CTRL_FIFO_DIR_MASK BIT(8)
|
|
#define SUN4I_HDMI_DDC_CTRL_FIFO_DIR_READ (0 << 8)
|
|
#define SUN4I_HDMI_DDC_CTRL_RESET BIT(0)
|
|
|
|
#define SUN4I_HDMI_DDC_ADDR_REG 0x504
|
|
#define SUN4I_HDMI_DDC_ADDR_SEGMENT(seg) (((seg) & 0xff) << 24)
|
|
#define SUN4I_HDMI_DDC_ADDR_EDDC(addr) (((addr) & 0xff) << 16)
|
|
#define SUN4I_HDMI_DDC_ADDR_OFFSET(off) (((off) & 0xff) << 8)
|
|
#define SUN4I_HDMI_DDC_ADDR_SLAVE(addr) ((addr) & 0xff)
|
|
|
|
#define SUN4I_HDMI_DDC_FIFO_CTRL_REG 0x510
|
|
#define SUN4I_HDMI_DDC_FIFO_CTRL_CLEAR BIT(31)
|
|
|
|
#define SUN4I_HDMI_DDC_FIFO_DATA_REG 0x518
|
|
#define SUN4I_HDMI_DDC_BYTE_COUNT_REG 0x51c
|
|
|
|
#define SUN4I_HDMI_DDC_CMD_REG 0x520
|
|
#define SUN4I_HDMI_DDC_CMD_EXPLICIT_EDDC_READ 6
|
|
|
|
#define SUN4I_HDMI_DDC_CLK_REG 0x528
|
|
#define SUN4I_HDMI_DDC_CLK_M(m) (((m) & 0x7) << 3)
|
|
#define SUN4I_HDMI_DDC_CLK_N(n) ((n) & 0x7)
|
|
|
|
#define SUN4I_HDMI_DDC_LINE_CTRL_REG 0x540
|
|
#define SUN4I_HDMI_DDC_LINE_CTRL_SDA_ENABLE BIT(9)
|
|
#define SUN4I_HDMI_DDC_LINE_CTRL_SCL_ENABLE BIT(8)
|
|
|
|
#define SUN4I_HDMI_DDC_FIFO_SIZE 16
|
|
|
|
enum sun4i_hdmi_pkt_type {
|
|
SUN4I_HDMI_PKT_AVI = 2,
|
|
SUN4I_HDMI_PKT_END = 15,
|
|
};
|
|
|
|
struct sun4i_hdmi {
|
|
struct drm_connector connector;
|
|
struct drm_encoder encoder;
|
|
struct device *dev;
|
|
|
|
void __iomem *base;
|
|
|
|
/* Parent clocks */
|
|
struct clk *bus_clk;
|
|
struct clk *mod_clk;
|
|
struct clk *pll0_clk;
|
|
struct clk *pll1_clk;
|
|
|
|
/* And the clocks we create */
|
|
struct clk *ddc_clk;
|
|
struct clk *tmds_clk;
|
|
|
|
struct sun4i_drv *drv;
|
|
|
|
bool hdmi_monitor;
|
|
};
|
|
|
|
int sun4i_ddc_create(struct sun4i_hdmi *hdmi, struct clk *clk);
|
|
int sun4i_tmds_create(struct sun4i_hdmi *hdmi);
|
|
|
|
#endif /* _SUN4I_HDMI_H_ */
|