drm/amd/display: Move view port registers and programming to memory input.
authorVitaly Prosyak <vitaly.prosyak@amd.com>
Thu, 13 Jul 2017 20:42:58 +0000 (15:42 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 26 Sep 2017 22:15:12 +0000 (18:15 -0400)
Signed-off-by: Vitaly Prosyak <vitaly.prosyak@amd.com>
Reviewed-by: Tony Cheng <Tony.Cheng@amd.com>
Acked-by: Harry Wentland <Harry.Wentland@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_dpp.c
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_dpp.h
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mem_input.c
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mem_input.h
drivers/gpu/drm/amd/display/dc/inc/hw/mem_input.h

index 85d3ca31daf5bba6051f8669ade5e989b0ca01be..fff81a14b21ce007a99a3909e6a347f0d579ed4a 100644 (file)
@@ -452,37 +452,6 @@ static void dpp_set_scl_filter(
        }
 }
 
-static void dpp_set_viewport(
-               struct dcn10_dpp *xfm,
-               const struct rect *viewport,
-               const struct rect *viewport_c)
-{
-       REG_SET_2(DCSURF_PRI_VIEWPORT_DIMENSION, 0,
-                       PRI_VIEWPORT_WIDTH, viewport->width,
-                       PRI_VIEWPORT_HEIGHT, viewport->height);
-
-       REG_SET_2(DCSURF_PRI_VIEWPORT_START, 0,
-                       PRI_VIEWPORT_X_START, viewport->x,
-                       PRI_VIEWPORT_Y_START, viewport->y);
-
-       /*for stereo*/
-       REG_SET_2(DCSURF_SEC_VIEWPORT_DIMENSION, 0,
-                               SEC_VIEWPORT_WIDTH, viewport->width,
-                               SEC_VIEWPORT_HEIGHT, viewport->height);
-
-       REG_SET_2(DCSURF_SEC_VIEWPORT_START, 0,
-                               SEC_VIEWPORT_X_START, viewport->x,
-                               SEC_VIEWPORT_Y_START, viewport->y);
-
-       /* DC supports NV12 only at the moment */
-       REG_SET_2(DCSURF_PRI_VIEWPORT_DIMENSION_C, 0,
-                       PRI_VIEWPORT_WIDTH_C, viewport_c->width,
-                       PRI_VIEWPORT_HEIGHT_C, viewport_c->height);
-
-       REG_SET_2(DCSURF_PRI_VIEWPORT_START_C, 0,
-                       PRI_VIEWPORT_X_START_C, viewport_c->x,
-                       PRI_VIEWPORT_Y_START_C, viewport_c->y);
-}
 
 static int get_lb_depth_bpc(enum lb_pixel_depth depth)
 {
@@ -616,8 +585,6 @@ void dpp_set_scaler_auto_scale(
 
        REG_UPDATE(SCL_MODE, DSCL_MODE, dscl_mode);
 
-       dpp_set_viewport(xfm, &scl_data->viewport, &scl_data->viewport_c);
-
        if (dscl_mode == DSCL_MODE_DSCL_BYPASS)
                return;
 
@@ -762,9 +729,6 @@ static void dpp_set_scaler_manual_scale(
        /* SCL mode */
        REG_UPDATE(SCL_MODE, DSCL_MODE, dscl_mode);
 
-       /* Viewport */
-       dpp_set_viewport(xfm, &scl_data->viewport, &scl_data->viewport_c);
-
        if (dscl_mode == DSCL_MODE_DSCL_BYPASS)
                return;
        /* LB */
index 993643552aff14c3f293f0454550e3ae1f9ba402..c1124e962d0e014b6a944fa10fde5314003e4ceb 100644 (file)
        SRI(SCL_COEF_RAM_TAP_SELECT, DSCL, id), \
        SRI(SCL_COEF_RAM_TAP_DATA, DSCL, id), \
        SRI(DSCL_2TAP_CONTROL, DSCL, id), \
-       SRI(DCSURF_PRI_VIEWPORT_DIMENSION, HUBP, id), \
-       SRI(DCSURF_PRI_VIEWPORT_START, HUBP, id), \
-       SRI(DCSURF_SEC_VIEWPORT_DIMENSION, HUBP, id), \
-       SRI(DCSURF_SEC_VIEWPORT_START, HUBP, id), \
-       SRI(DCSURF_PRI_VIEWPORT_DIMENSION_C, HUBP, id), \
-       SRI(DCSURF_PRI_VIEWPORT_START_C, HUBP, id), \
        SRI(MPC_SIZE, DSCL, id), \
        SRI(SCL_HORZ_FILTER_SCALE_RATIO, DSCL, id), \
        SRI(SCL_VERT_FILTER_SCALE_RATIO, DSCL, id), \
        TF_SF(DSCL0_DSCL_2TAP_CONTROL, SCL_V_2TAP_SHARP_EN, mask_sh),\
        TF_SF(DSCL0_DSCL_2TAP_CONTROL, SCL_V_2TAP_SHARP_FACTOR, mask_sh),\
        TF_SF(DSCL0_SCL_MODE, SCL_COEF_RAM_SELECT, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION, PRI_VIEWPORT_WIDTH, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION, PRI_VIEWPORT_HEIGHT, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_START, PRI_VIEWPORT_X_START, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_START, PRI_VIEWPORT_Y_START, mask_sh),\
-       TF_SF(HUBP0_DCSURF_SEC_VIEWPORT_DIMENSION, SEC_VIEWPORT_WIDTH, mask_sh),\
-       TF_SF(HUBP0_DCSURF_SEC_VIEWPORT_DIMENSION, SEC_VIEWPORT_HEIGHT, mask_sh),\
-       TF_SF(HUBP0_DCSURF_SEC_VIEWPORT_START, SEC_VIEWPORT_X_START, mask_sh),\
-       TF_SF(HUBP0_DCSURF_SEC_VIEWPORT_START, SEC_VIEWPORT_Y_START, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION_C, PRI_VIEWPORT_WIDTH_C, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION_C, PRI_VIEWPORT_HEIGHT_C, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_START_C, PRI_VIEWPORT_X_START_C, mask_sh),\
-       TF_SF(HUBP0_DCSURF_PRI_VIEWPORT_START_C, PRI_VIEWPORT_Y_START_C, mask_sh),\
        TF_SF(DSCL0_SCL_MODE, DSCL_MODE, mask_sh),\
        TF_SF(DSCL0_RECOUT_START, RECOUT_START_X, mask_sh),\
        TF_SF(DSCL0_RECOUT_START, RECOUT_START_Y, mask_sh),\
        type SCL_V_2TAP_SHARP_EN; \
        type SCL_V_2TAP_SHARP_FACTOR; \
        type SCL_COEF_RAM_SELECT; \
-       type PRI_VIEWPORT_WIDTH; \
-       type PRI_VIEWPORT_HEIGHT; \
-       type PRI_VIEWPORT_X_START; \
-       type PRI_VIEWPORT_Y_START; \
-       type SEC_VIEWPORT_WIDTH; \
-       type SEC_VIEWPORT_HEIGHT; \
-       type SEC_VIEWPORT_X_START; \
-       type SEC_VIEWPORT_Y_START; \
-       type PRI_VIEWPORT_WIDTH_C; \
-       type PRI_VIEWPORT_HEIGHT_C; \
-       type PRI_VIEWPORT_X_START_C; \
-       type PRI_VIEWPORT_Y_START_C; \
        type DSCL_MODE; \
        type RECOUT_START_X; \
        type RECOUT_START_Y; \
@@ -355,12 +325,6 @@ struct dcn_dpp_registers {
        uint32_t SCL_COEF_RAM_TAP_SELECT;
        uint32_t SCL_COEF_RAM_TAP_DATA;
        uint32_t DSCL_2TAP_CONTROL;
-       uint32_t DCSURF_PRI_VIEWPORT_DIMENSION;
-       uint32_t DCSURF_PRI_VIEWPORT_START;
-       uint32_t DCSURF_SEC_VIEWPORT_DIMENSION;
-       uint32_t DCSURF_SEC_VIEWPORT_START;
-       uint32_t DCSURF_PRI_VIEWPORT_DIMENSION_C;
-       uint32_t DCSURF_PRI_VIEWPORT_START_C;
        uint32_t MPC_SIZE;
        uint32_t SCL_HORZ_FILTER_SCALE_RATIO;
        uint32_t SCL_VERT_FILTER_SCALE_RATIO;
index eca0d53eedff4bcdd5245fb4cb7fea09bd5b5ce0..d714422ef979b8e76c06a1ea3c3c917e3ad3c856 100644 (file)
@@ -1470,6 +1470,8 @@ static void update_dchubp_dpp(
        /* scaler configuration */
        pipe_ctx->xfm->funcs->transform_set_scaler(
                        pipe_ctx->xfm, &pipe_ctx->scl_data);
+       mi->funcs->mem_program_viewport(mi,
+                       &pipe_ctx->scl_data.viewport, &pipe_ctx->scl_data.viewport_c);
 
        /*gamut remap*/
        program_gamut_remap(pipe_ctx);
index 4e723a017b9753f37340f22971a46cf472ba2494..efa02d160d1a122958932521f177f35b74704786 100644 (file)
@@ -1057,6 +1057,41 @@ static void min10_program_pte_vm(struct mem_input *mem_input,
                        SYSTEM_ACCESS_MODE, 3);
 }
 
+static void min_set_viewport(
+               struct mem_input *mem_input,
+               const struct rect *viewport,
+               const struct rect *viewport_c)
+{
+       struct dcn10_mem_input *mi = TO_DCN10_MEM_INPUT(mem_input);
+
+       REG_SET_2(DCSURF_PRI_VIEWPORT_DIMENSION, 0,
+                       PRI_VIEWPORT_WIDTH, viewport->width,
+                       PRI_VIEWPORT_HEIGHT, viewport->height);
+
+       REG_SET_2(DCSURF_PRI_VIEWPORT_START, 0,
+                       PRI_VIEWPORT_X_START, viewport->x,
+                       PRI_VIEWPORT_Y_START, viewport->y);
+
+       /*for stereo*/
+       REG_SET_2(DCSURF_SEC_VIEWPORT_DIMENSION, 0,
+                               SEC_VIEWPORT_WIDTH, viewport->width,
+                               SEC_VIEWPORT_HEIGHT, viewport->height);
+
+       REG_SET_2(DCSURF_SEC_VIEWPORT_START, 0,
+                               SEC_VIEWPORT_X_START, viewport->x,
+                               SEC_VIEWPORT_Y_START, viewport->y);
+
+       /* DC supports NV12 only at the moment */
+       REG_SET_2(DCSURF_PRI_VIEWPORT_DIMENSION_C, 0,
+                       PRI_VIEWPORT_WIDTH_C, viewport_c->width,
+                       PRI_VIEWPORT_HEIGHT_C, viewport_c->height);
+
+       REG_SET_2(DCSURF_PRI_VIEWPORT_START_C, 0,
+                       PRI_VIEWPORT_X_START_C, viewport_c->x,
+                       PRI_VIEWPORT_Y_START_C, viewport_c->y);
+}
+
+
 static struct mem_input_funcs dcn10_mem_input_funcs = {
        .mem_input_program_display_marks = min10_program_display_marks,
        .mem_input_program_surface_flip_and_addr =
@@ -1070,9 +1105,9 @@ static struct mem_input_funcs dcn10_mem_input_funcs = {
        .mem_input_program_pte_vm = min10_program_pte_vm,
        .set_blank = min10_set_blank,
        .dcc_control = min10_dcc_control,
+       .mem_program_viewport = min_set_viewport,
 };
 
-
 /*****************************************/
 /* Constructor, Destructor               */
 /*****************************************/
index c3f18bdc21579528183f5cd7db33c3c2f58be576..7efa857b8710607382925fd6d254f67f2ee050cc 100644 (file)
        SRI(DCSURF_SURFACE_PITCH_C, HUBPREQ, id),\
        SRI(DCSURF_SURFACE_CONFIG, HUBP, id),\
        SRI(DCSURF_FLIP_CONTROL, HUBPREQ, id),\
+       SRI(DCSURF_PRI_VIEWPORT_DIMENSION, HUBP, id), \
+       SRI(DCSURF_PRI_VIEWPORT_START, HUBP, id), \
+       SRI(DCSURF_SEC_VIEWPORT_DIMENSION, HUBP, id), \
+       SRI(DCSURF_SEC_VIEWPORT_START, HUBP, id), \
+       SRI(DCSURF_PRI_VIEWPORT_DIMENSION_C, HUBP, id), \
+       SRI(DCSURF_PRI_VIEWPORT_START_C, HUBP, id), \
        SRI(DCSURF_PRIMARY_SURFACE_ADDRESS_HIGH, HUBPREQ, id),\
        SRI(DCSURF_PRIMARY_SURFACE_ADDRESS, HUBPREQ, id),\
        SRI(DCSURF_SECONDARY_SURFACE_ADDRESS_HIGH, HUBPREQ, id),\
@@ -164,6 +170,12 @@ struct dcn_mi_registers {
        uint32_t DCSURF_SURFACE_PITCH_C;
        uint32_t DCSURF_SURFACE_CONFIG;
        uint32_t DCSURF_FLIP_CONTROL;
+       uint32_t DCSURF_PRI_VIEWPORT_DIMENSION;
+       uint32_t DCSURF_PRI_VIEWPORT_START;
+       uint32_t DCSURF_SEC_VIEWPORT_DIMENSION;
+       uint32_t DCSURF_SEC_VIEWPORT_START;
+       uint32_t DCSURF_PRI_VIEWPORT_DIMENSION_C;
+       uint32_t DCSURF_PRI_VIEWPORT_START_C;
        uint32_t DCSURF_PRIMARY_SURFACE_ADDRESS_HIGH;
        uint32_t DCSURF_PRIMARY_SURFACE_ADDRESS;
        uint32_t DCSURF_SECONDARY_SURFACE_ADDRESS_HIGH;
@@ -312,6 +324,18 @@ struct dcn_mi_registers {
        MI_SF(HUBPREQ0_DCSURF_FLIP_CONTROL, SURFACE_FLIP_TYPE, mask_sh),\
        MI_SF(HUBPREQ0_DCSURF_FLIP_CONTROL, SURFACE_FLIP_PENDING, mask_sh),\
        MI_SF(HUBPREQ0_DCSURF_FLIP_CONTROL, SURFACE_UPDATE_LOCK, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION, PRI_VIEWPORT_WIDTH, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION, PRI_VIEWPORT_HEIGHT, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_START, PRI_VIEWPORT_X_START, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_START, PRI_VIEWPORT_Y_START, mask_sh),\
+       MI_SF(HUBP0_DCSURF_SEC_VIEWPORT_DIMENSION, SEC_VIEWPORT_WIDTH, mask_sh),\
+       MI_SF(HUBP0_DCSURF_SEC_VIEWPORT_DIMENSION, SEC_VIEWPORT_HEIGHT, mask_sh),\
+       MI_SF(HUBP0_DCSURF_SEC_VIEWPORT_START, SEC_VIEWPORT_X_START, mask_sh),\
+       MI_SF(HUBP0_DCSURF_SEC_VIEWPORT_START, SEC_VIEWPORT_Y_START, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION_C, PRI_VIEWPORT_WIDTH_C, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_DIMENSION_C, PRI_VIEWPORT_HEIGHT_C, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_START_C, PRI_VIEWPORT_X_START_C, mask_sh),\
+       MI_SF(HUBP0_DCSURF_PRI_VIEWPORT_START_C, PRI_VIEWPORT_Y_START_C, mask_sh),\
        MI_SF(HUBPREQ0_DCSURF_PRIMARY_SURFACE_ADDRESS_HIGH, PRIMARY_SURFACE_ADDRESS_HIGH, mask_sh),\
        MI_SF(HUBPREQ0_DCSURF_PRIMARY_SURFACE_ADDRESS, PRIMARY_SURFACE_ADDRESS, mask_sh),\
        MI_SF(HUBPREQ0_DCSURF_SECONDARY_SURFACE_ADDRESS_HIGH, SECONDARY_SURFACE_ADDRESS_HIGH, mask_sh),\
@@ -459,6 +483,18 @@ struct dcn_mi_registers {
        type SURFACE_FLIP_TYPE;\
        type SURFACE_UPDATE_LOCK;\
        type SURFACE_FLIP_PENDING;\
+       type PRI_VIEWPORT_WIDTH; \
+       type PRI_VIEWPORT_HEIGHT; \
+       type PRI_VIEWPORT_X_START; \
+       type PRI_VIEWPORT_Y_START; \
+       type SEC_VIEWPORT_WIDTH; \
+       type SEC_VIEWPORT_HEIGHT; \
+       type SEC_VIEWPORT_X_START; \
+       type SEC_VIEWPORT_Y_START; \
+       type PRI_VIEWPORT_WIDTH_C; \
+       type PRI_VIEWPORT_HEIGHT_C; \
+       type PRI_VIEWPORT_X_START_C; \
+       type PRI_VIEWPORT_Y_START_C; \
        type PRIMARY_SURFACE_ADDRESS_HIGH;\
        type PRIMARY_SURFACE_ADDRESS;\
        type SECONDARY_SURFACE_ADDRESS_HIGH;\
index 64b810d48d07de767c4beb929fa6d1cd9ea9e1ff..1b7d151a66f805ab4cef97ec0dd5fcb2e636a79a 100644 (file)
@@ -89,6 +89,10 @@ struct mem_input_funcs {
 
        void (*dcc_control)(struct mem_input *mem_input, bool enable,
                        bool independent_64b_blks);
+       void (*mem_program_viewport)(
+                       struct mem_input *mem_input,
+                       const struct rect *viewport,
+                       const struct rect *viewport_c);
 #endif
 
        void (*mem_input_program_display_marks)(