Skip to content

Commit 1930c11

Browse files
jamwandliviu
authored andcommitted
drm/komeda: Computing layer_split internally
For layer_split no need user to enable/disable it, but compute it in komeda internally, komeda will enable it if the scaling exceed the acceptable range of scaler. Signed-off-by: james qian wang (Arm Technology China) <[email protected]> Signed-off-by: Liviu Dudau <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
1 parent 75c5bf9 commit 1930c11

File tree

4 files changed

+14
-13
lines changed

4 files changed

+14
-13
lines changed

drivers/gpu/drm/arm/display/komeda/komeda_pipeline.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -537,7 +537,8 @@ void komeda_pipeline_disable(struct komeda_pipeline *pipe,
537537
void komeda_pipeline_update(struct komeda_pipeline *pipe,
538538
struct drm_atomic_state *old_state);
539539

540-
void komeda_complete_data_flow_cfg(struct komeda_data_flow_cfg *dflow,
540+
void komeda_complete_data_flow_cfg(struct komeda_layer *layer,
541+
struct komeda_data_flow_cfg *dflow,
541542
struct drm_framebuffer *fb);
542543

543544
#endif /* _KOMEDA_PIPELINE_H_*/

drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -784,9 +784,11 @@ komeda_timing_ctrlr_validate(struct komeda_timing_ctrlr *ctrlr,
784784
return 0;
785785
}
786786

787-
void komeda_complete_data_flow_cfg(struct komeda_data_flow_cfg *dflow,
787+
void komeda_complete_data_flow_cfg(struct komeda_layer *layer,
788+
struct komeda_data_flow_cfg *dflow,
788789
struct drm_framebuffer *fb)
789790
{
791+
struct komeda_scaler *scaler = layer->base.pipeline->scalers[0];
790792
u32 w = dflow->in_w;
791793
u32 h = dflow->in_h;
792794

@@ -803,6 +805,13 @@ void komeda_complete_data_flow_cfg(struct komeda_data_flow_cfg *dflow,
803805

804806
dflow->en_scaling = (w != dflow->out_w) || (h != dflow->out_h);
805807
dflow->is_yuv = fb->format->is_yuv;
808+
809+
/* try to enable split if scaling exceed the scaler's acceptable
810+
* input/output range.
811+
*/
812+
if (dflow->en_scaling && scaler)
813+
dflow->en_split = !in_range(&scaler->hsize, dflow->in_w) ||
814+
!in_range(&scaler->hsize, dflow->out_w);
806815
}
807816

808817
static bool merger_is_available(struct komeda_pipeline *pipe,

drivers/gpu/drm/arm/display/komeda/komeda_plane.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -58,9 +58,8 @@ komeda_plane_init_data_flow(struct drm_plane_state *st,
5858
}
5959

6060
dflow->en_img_enhancement = !!kplane_st->img_enhancement;
61-
dflow->en_split = !!kplane_st->layer_split;
6261

63-
komeda_complete_data_flow_cfg(dflow, fb);
62+
komeda_complete_data_flow_cfg(kplane->layer, dflow, fb);
6463

6564
return 0;
6665
}

drivers/gpu/drm/arm/display/komeda/komeda_wb_connector.c

Lines changed: 1 addition & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,6 @@ komeda_wb_init_data_flow(struct komeda_layer *wb_layer,
1313
struct komeda_crtc_state *kcrtc_st,
1414
struct komeda_data_flow_cfg *dflow)
1515
{
16-
struct komeda_scaler *scaler = wb_layer->base.pipeline->scalers[0];
1716
struct drm_framebuffer *fb = conn_st->writeback_job->fb;
1817

1918
memset(dflow, 0, sizeof(*dflow));
@@ -28,14 +27,7 @@ komeda_wb_init_data_flow(struct komeda_layer *wb_layer,
2827
dflow->pixel_blend_mode = DRM_MODE_BLEND_PIXEL_NONE;
2928
dflow->rot = DRM_MODE_ROTATE_0;
3029

31-
komeda_complete_data_flow_cfg(dflow, fb);
32-
33-
/* if scaling exceed the acceptable scaler input/output range, try to
34-
* enable split.
35-
*/
36-
if (dflow->en_scaling && scaler)
37-
dflow->en_split = !in_range(&scaler->hsize, dflow->in_w) ||
38-
!in_range(&scaler->hsize, dflow->out_w);
30+
komeda_complete_data_flow_cfg(wb_layer, dflow, fb);
3931

4032
return 0;
4133
}

0 commit comments

Comments
 (0)