drm: mali-dp: Add support for writeback on DP550/DP650
Mali-DP display processors are able to write the composition result to a memory buffer via the SE. Add entry points in the HAL for enabling/disabling this feature, and implement support for it on DP650 and DP550. DP500 acts differently and so is omitted from this change. Changes since v3: - Fix missing vsync interrupt for DP550 Signed-off-by: Liviu Dudau <Liviu.Dudau@arm.com> Signed-off-by: Brian Starkey <brian.starkey@arm.com> [rebased and fixed conflicts] Signed-off-by: Mihail Atanassov <mihail.atanassov@arm.com>
This commit is contained in:
@@ -588,6 +588,49 @@ static long malidp550_se_calc_mclk(struct malidp_hw_device *hwdev,
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int malidp550_enable_memwrite(struct malidp_hw_device *hwdev,
|
||||
dma_addr_t *addrs, s32 *pitches,
|
||||
int num_planes, u16 w, u16 h, u32 fmt_id)
|
||||
{
|
||||
u32 base = MALIDP550_SE_MEMWRITE_BASE;
|
||||
u32 de_base = malidp_get_block_base(hwdev, MALIDP_DE_BLOCK);
|
||||
|
||||
/* enable the scaling engine block */
|
||||
malidp_hw_setbits(hwdev, MALIDP_SCALE_ENGINE_EN, de_base + MALIDP_DE_DISPLAY_FUNC);
|
||||
|
||||
malidp_hw_write(hwdev, fmt_id, base + MALIDP_MW_FORMAT);
|
||||
switch (num_planes) {
|
||||
case 2:
|
||||
malidp_hw_write(hwdev, lower_32_bits(addrs[1]), base + MALIDP_MW_P2_PTR_LOW);
|
||||
malidp_hw_write(hwdev, upper_32_bits(addrs[1]), base + MALIDP_MW_P2_PTR_HIGH);
|
||||
malidp_hw_write(hwdev, pitches[1], base + MALIDP_MW_P2_STRIDE);
|
||||
/* fall through */
|
||||
case 1:
|
||||
malidp_hw_write(hwdev, lower_32_bits(addrs[0]), base + MALIDP_MW_P1_PTR_LOW);
|
||||
malidp_hw_write(hwdev, upper_32_bits(addrs[0]), base + MALIDP_MW_P1_PTR_HIGH);
|
||||
malidp_hw_write(hwdev, pitches[0], base + MALIDP_MW_P1_STRIDE);
|
||||
break;
|
||||
default:
|
||||
WARN(1, "Invalid number of planes");
|
||||
}
|
||||
|
||||
malidp_hw_write(hwdev, MALIDP_DE_H_ACTIVE(w) | MALIDP_DE_V_ACTIVE(h),
|
||||
MALIDP550_SE_MEMWRITE_OUT_SIZE);
|
||||
malidp_hw_setbits(hwdev, MALIDP550_SE_MEMWRITE_ONESHOT | MALIDP_SE_MEMWRITE_EN,
|
||||
MALIDP550_SE_CONTROL);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void malidp550_disable_memwrite(struct malidp_hw_device *hwdev)
|
||||
{
|
||||
u32 base = malidp_get_block_base(hwdev, MALIDP_DE_BLOCK);
|
||||
|
||||
malidp_hw_clearbits(hwdev, MALIDP550_SE_MEMWRITE_ONESHOT | MALIDP_SE_MEMWRITE_EN,
|
||||
MALIDP550_SE_CONTROL);
|
||||
malidp_hw_clearbits(hwdev, MALIDP_SCALE_ENGINE_EN, base + MALIDP_DE_DISPLAY_FUNC);
|
||||
}
|
||||
|
||||
static int malidp650_query_hw(struct malidp_hw_device *hwdev)
|
||||
{
|
||||
u32 conf = malidp_hw_read(hwdev, MALIDP550_CONFIG_ID);
|
||||
@@ -674,9 +717,11 @@ const struct malidp_hw malidp_device[MALIDP_MAX_DEVICES] = {
|
||||
.se_irq_map = {
|
||||
.irq_mask = MALIDP550_SE_IRQ_EOW |
|
||||
MALIDP550_SE_IRQ_AXI_ERR,
|
||||
.vsync_irq = MALIDP550_SE_IRQ_EOW,
|
||||
},
|
||||
.dc_irq_map = {
|
||||
.irq_mask = MALIDP550_DC_IRQ_CONF_VALID,
|
||||
.irq_mask = MALIDP550_DC_IRQ_CONF_VALID |
|
||||
MALIDP550_DC_IRQ_SE,
|
||||
.vsync_irq = MALIDP550_DC_IRQ_CONF_VALID,
|
||||
},
|
||||
.pixel_formats = malidp550_de_formats,
|
||||
@@ -692,6 +737,8 @@ const struct malidp_hw malidp_device[MALIDP_MAX_DEVICES] = {
|
||||
.rotmem_required = malidp550_rotmem_required,
|
||||
.se_set_scaling_coeffs = malidp550_se_set_scaling_coeffs,
|
||||
.se_calc_mclk = malidp550_se_calc_mclk,
|
||||
.enable_memwrite = malidp550_enable_memwrite,
|
||||
.disable_memwrite = malidp550_disable_memwrite,
|
||||
.features = 0,
|
||||
},
|
||||
[MALIDP_650] = {
|
||||
@@ -712,9 +759,11 @@ const struct malidp_hw malidp_device[MALIDP_MAX_DEVICES] = {
|
||||
.se_irq_map = {
|
||||
.irq_mask = MALIDP550_SE_IRQ_EOW |
|
||||
MALIDP550_SE_IRQ_AXI_ERR,
|
||||
.vsync_irq = MALIDP550_SE_IRQ_EOW,
|
||||
},
|
||||
.dc_irq_map = {
|
||||
.irq_mask = MALIDP550_DC_IRQ_CONF_VALID,
|
||||
.irq_mask = MALIDP550_DC_IRQ_CONF_VALID |
|
||||
MALIDP550_DC_IRQ_SE,
|
||||
.vsync_irq = MALIDP550_DC_IRQ_CONF_VALID,
|
||||
},
|
||||
.pixel_formats = malidp550_de_formats,
|
||||
@@ -730,6 +779,8 @@ const struct malidp_hw malidp_device[MALIDP_MAX_DEVICES] = {
|
||||
.rotmem_required = malidp550_rotmem_required,
|
||||
.se_set_scaling_coeffs = malidp550_se_set_scaling_coeffs,
|
||||
.se_calc_mclk = malidp550_se_calc_mclk,
|
||||
.enable_memwrite = malidp550_enable_memwrite,
|
||||
.disable_memwrite = malidp550_disable_memwrite,
|
||||
.features = 0,
|
||||
},
|
||||
};
|
||||
|
Reference in New Issue
Block a user