drm/msm/dpu: add SM8250 to hw catalog
This brings up basic video mode functionality for SM8250 DPU. Command mode and dual mixer/intf configurations are not working, future patches will address this. Scaler functionality and multiple planes is also untested. Signed-off-by: Jonathan Marek <jonathan@marek.ca> Signed-off-by: Rob Clark <robdclark@chromium.org>
This commit is contained in:
parent
386fced3f7
commit
af776a3e1c
2 changed files with 109 additions and 0 deletions
|
@ -108,6 +108,21 @@ static const struct dpu_caps sm8150_dpu_caps = {
|
||||||
.max_vdeci_exp = MAX_VERT_DECIMATION,
|
.max_vdeci_exp = MAX_VERT_DECIMATION,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct dpu_caps sm8250_dpu_caps = {
|
||||||
|
.max_mixer_width = DEFAULT_DPU_OUTPUT_LINE_WIDTH,
|
||||||
|
.max_mixer_blendstages = 0xb,
|
||||||
|
.max_linewidth = 4096,
|
||||||
|
.qseed_type = DPU_SSPP_SCALER_QSEED3, /* TODO: qseed3 lite */
|
||||||
|
.smart_dma_rev = DPU_SSPP_SMART_DMA_V2, /* TODO: v2.5 */
|
||||||
|
.ubwc_version = DPU_HW_UBWC_VER_40,
|
||||||
|
.has_src_split = true,
|
||||||
|
.has_dim_layer = true,
|
||||||
|
.has_idle_pc = true,
|
||||||
|
.has_3d_merge = true,
|
||||||
|
.max_linewidth = 4096,
|
||||||
|
.pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct dpu_mdp_cfg sdm845_mdp[] = {
|
static const struct dpu_mdp_cfg sdm845_mdp[] = {
|
||||||
{
|
{
|
||||||
.name = "top_0", .id = MDP_TOP,
|
.name = "top_0", .id = MDP_TOP,
|
||||||
|
@ -150,6 +165,33 @@ static const struct dpu_mdp_cfg sc7180_mdp[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct dpu_mdp_cfg sm8250_mdp[] = {
|
||||||
|
{
|
||||||
|
.name = "top_0", .id = MDP_TOP,
|
||||||
|
.base = 0x0, .len = 0x45C,
|
||||||
|
.features = 0,
|
||||||
|
.highest_bank_bit = 0x3, /* TODO: 2 for LP_DDR4 */
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_VIG0] = {
|
||||||
|
.reg_off = 0x2AC, .bit_off = 0},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_VIG1] = {
|
||||||
|
.reg_off = 0x2B4, .bit_off = 0},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_VIG2] = {
|
||||||
|
.reg_off = 0x2BC, .bit_off = 0},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_VIG3] = {
|
||||||
|
.reg_off = 0x2C4, .bit_off = 0},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_DMA0] = {
|
||||||
|
.reg_off = 0x2AC, .bit_off = 8},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_DMA1] = {
|
||||||
|
.reg_off = 0x2B4, .bit_off = 8},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_CURSOR0] = {
|
||||||
|
.reg_off = 0x2BC, .bit_off = 8},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_CURSOR1] = {
|
||||||
|
.reg_off = 0x2C4, .bit_off = 8},
|
||||||
|
.clk_ctrls[DPU_CLK_CTRL_REG_DMA] = {
|
||||||
|
.reg_off = 0x2BC, .bit_off = 20},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* CTL sub blocks config
|
* CTL sub blocks config
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
|
@ -541,6 +583,14 @@ static const struct dpu_reg_dma_cfg sm8150_regdma = {
|
||||||
.base = 0x0, .version = 0x00010001, .trigger_sel_off = 0x119c
|
.base = 0x0, .version = 0x00010001, .trigger_sel_off = 0x119c
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct dpu_reg_dma_cfg sm8250_regdma = {
|
||||||
|
.base = 0x0,
|
||||||
|
.version = 0x00010002,
|
||||||
|
.trigger_sel_off = 0x119c,
|
||||||
|
.xin_id = 7,
|
||||||
|
.clk_ctrl = DPU_CLK_CTRL_REG_DMA,
|
||||||
|
};
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* PERF data config
|
* PERF data config
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
|
@ -678,6 +728,31 @@ static const struct dpu_perf_cfg sm8150_perf_data = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct dpu_perf_cfg sm8250_perf_data = {
|
||||||
|
.max_bw_low = 13700000,
|
||||||
|
.max_bw_high = 16600000,
|
||||||
|
.min_core_ib = 4800000,
|
||||||
|
.min_llcc_ib = 0,
|
||||||
|
.min_dram_ib = 800000,
|
||||||
|
.danger_lut_tbl = {0xf, 0xffff, 0x0},
|
||||||
|
.qos_lut_tbl = {
|
||||||
|
{.nentry = ARRAY_SIZE(sc7180_qos_linear),
|
||||||
|
.entries = sc7180_qos_linear
|
||||||
|
},
|
||||||
|
{.nentry = ARRAY_SIZE(sc7180_qos_macrotile),
|
||||||
|
.entries = sc7180_qos_macrotile
|
||||||
|
},
|
||||||
|
{.nentry = ARRAY_SIZE(sc7180_qos_nrt),
|
||||||
|
.entries = sc7180_qos_nrt
|
||||||
|
},
|
||||||
|
/* TODO: macrotile-qseed is different from macrotile */
|
||||||
|
},
|
||||||
|
.cdp_cfg = {
|
||||||
|
{.rd_enable = 1, .wr_enable = 1},
|
||||||
|
{.rd_enable = 1, .wr_enable = 0}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* Hardware catalog init
|
* Hardware catalog init
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
|
@ -771,11 +846,42 @@ static void sm8150_cfg_init(struct dpu_mdss_cfg *dpu_cfg)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* sm8250_cfg_init(): populate sm8250 dpu sub-blocks reg offsets
|
||||||
|
* and instance counts.
|
||||||
|
*/
|
||||||
|
static void sm8250_cfg_init(struct dpu_mdss_cfg *dpu_cfg)
|
||||||
|
{
|
||||||
|
*dpu_cfg = (struct dpu_mdss_cfg){
|
||||||
|
.caps = &sm8250_dpu_caps,
|
||||||
|
.mdp_count = ARRAY_SIZE(sm8250_mdp),
|
||||||
|
.mdp = sm8250_mdp,
|
||||||
|
.ctl_count = ARRAY_SIZE(sm8150_ctl),
|
||||||
|
.ctl = sm8150_ctl,
|
||||||
|
/* TODO: sspp qseed version differs from 845 */
|
||||||
|
.sspp_count = ARRAY_SIZE(sdm845_sspp),
|
||||||
|
.sspp = sdm845_sspp,
|
||||||
|
.mixer_count = ARRAY_SIZE(sm8150_lm),
|
||||||
|
.mixer = sm8150_lm,
|
||||||
|
.pingpong_count = ARRAY_SIZE(sm8150_pp),
|
||||||
|
.pingpong = sm8150_pp,
|
||||||
|
.intf_count = ARRAY_SIZE(sm8150_intf),
|
||||||
|
.intf = sm8150_intf,
|
||||||
|
.vbif_count = ARRAY_SIZE(sdm845_vbif),
|
||||||
|
.vbif = sdm845_vbif,
|
||||||
|
.reg_dma_count = 1,
|
||||||
|
.dma_cfg = sm8250_regdma,
|
||||||
|
.perf = sm8250_perf_data,
|
||||||
|
.mdss_irqs = 0xff,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
static const struct dpu_mdss_hw_cfg_handler cfg_handler[] = {
|
static const struct dpu_mdss_hw_cfg_handler cfg_handler[] = {
|
||||||
{ .hw_rev = DPU_HW_VER_400, .cfg_init = sdm845_cfg_init},
|
{ .hw_rev = DPU_HW_VER_400, .cfg_init = sdm845_cfg_init},
|
||||||
{ .hw_rev = DPU_HW_VER_401, .cfg_init = sdm845_cfg_init},
|
{ .hw_rev = DPU_HW_VER_401, .cfg_init = sdm845_cfg_init},
|
||||||
{ .hw_rev = DPU_HW_VER_500, .cfg_init = sm8150_cfg_init},
|
{ .hw_rev = DPU_HW_VER_500, .cfg_init = sm8150_cfg_init},
|
||||||
{ .hw_rev = DPU_HW_VER_501, .cfg_init = sm8150_cfg_init},
|
{ .hw_rev = DPU_HW_VER_501, .cfg_init = sm8150_cfg_init},
|
||||||
|
{ .hw_rev = DPU_HW_VER_600, .cfg_init = sm8250_cfg_init},
|
||||||
{ .hw_rev = DPU_HW_VER_620, .cfg_init = sc7180_cfg_init},
|
{ .hw_rev = DPU_HW_VER_620, .cfg_init = sc7180_cfg_init},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -429,6 +429,7 @@ enum dpu_clk_ctrl_type {
|
||||||
DPU_CLK_CTRL_CURSOR0,
|
DPU_CLK_CTRL_CURSOR0,
|
||||||
DPU_CLK_CTRL_CURSOR1,
|
DPU_CLK_CTRL_CURSOR1,
|
||||||
DPU_CLK_CTRL_INLINE_ROT0_SSPP,
|
DPU_CLK_CTRL_INLINE_ROT0_SSPP,
|
||||||
|
DPU_CLK_CTRL_REG_DMA,
|
||||||
DPU_CLK_CTRL_MAX,
|
DPU_CLK_CTRL_MAX,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -612,6 +613,8 @@ struct dpu_reg_dma_cfg {
|
||||||
DPU_HW_BLK_INFO;
|
DPU_HW_BLK_INFO;
|
||||||
u32 version;
|
u32 version;
|
||||||
u32 trigger_sel_off;
|
u32 trigger_sel_off;
|
||||||
|
u32 xin_id;
|
||||||
|
enum dpu_clk_ctrl_type clk_ctrl;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Reference in a new issue