These are internal otg params and should be handled as such.
Thich change passes the params as function arguments.
Signed-off-by: Dmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Reviewed-by: Eric Bernstein <Eric.Bernstein@amd.com>
Acked-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
                pipe_ctx->stream_res.tg->funcs->program_timing(
                                pipe_ctx->stream_res.tg,
                                &stream->timing,
+                               0,
+                               0,
+                               0,
+                               0,
+                               pipe_ctx->stream->signal,
                                true);
        }
 
 
 
                pipe_ctx->stream_res.tg->funcs->program_timing(pipe_ctx->stream_res.tg,
                                &stream->timing,
+                               0,
+                               0,
+                               0,
+                               0,
+                               pipe_ctx->stream->signal,
                                false);
 
                pipe_ctx->stream_res.tg->funcs->enable_advanced_request(
 
 
 void dce110_tg_program_timing(struct timing_generator *tg,
        const struct dc_crtc_timing *timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios)
 {
        if (use_vbios)
 
 
 void dce110_tg_program_timing(struct timing_generator *tg,
        const struct dc_crtc_timing *timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios);
 
 bool dce110_tg_is_blanked(struct timing_generator *tg);
 
 
 static void dce110_timing_generator_v_program_timing(struct timing_generator *tg,
        const struct dc_crtc_timing *timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios)
 {
        if (use_vbios)
 
                CRTC_OVERSCAN_COLOR_RED, overscan_color->color_r_cr);
 }
 
-void dce120_tg_program_timing(struct timing_generator *tg,
+static void dce120_tg_program_timing(struct timing_generator *tg,
        const struct dc_crtc_timing *timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios)
 {
        if (use_vbios)
 
 
 static void program_timing(struct timing_generator *tg,
        const struct dc_crtc_timing *timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios)
 {
        if (!use_vbios)
                program_pix_dur(tg, timing->pix_clk_100hz);
 
-       dce110_tg_program_timing(tg, timing, use_vbios);
+       dce110_tg_program_timing(tg, timing, 0, 0, 0, 0, 0, use_vbios);
 }
 
 static void dce80_timing_generator_enable_advanced_request(
 
                BREAK_TO_DEBUGGER();
                return DC_ERROR_UNEXPECTED;
        }
-       pipe_ctx->stream_res.tg->dlg_otg_param.vready_offset = pipe_ctx->pipe_dlg_param.vready_offset;
-       pipe_ctx->stream_res.tg->dlg_otg_param.vstartup_start = pipe_ctx->pipe_dlg_param.vstartup_start;
-       pipe_ctx->stream_res.tg->dlg_otg_param.vupdate_offset = pipe_ctx->pipe_dlg_param.vupdate_offset;
-       pipe_ctx->stream_res.tg->dlg_otg_param.vupdate_width = pipe_ctx->pipe_dlg_param.vupdate_width;
-
-       pipe_ctx->stream_res.tg->signal =  pipe_ctx->stream->signal;
 
        pipe_ctx->stream_res.tg->funcs->program_timing(
                        pipe_ctx->stream_res.tg,
                        &stream->timing,
+                       pipe_ctx->pipe_dlg_param.vready_offset,
+                       pipe_ctx->pipe_dlg_param.vstartup_start,
+                       pipe_ctx->pipe_dlg_param.vupdate_offset,
+                       pipe_ctx->pipe_dlg_param.vupdate_width,
+                       pipe_ctx->stream->signal,
                        true);
 
 #if 0 /* move to after enable_crtc */
        if (pipe_ctx->top_pipe == NULL) {
                bool blank = !is_pipe_tree_visible(pipe_ctx);
 
-               pipe_ctx->stream_res.tg->dlg_otg_param.vready_offset = pipe_ctx->pipe_dlg_param.vready_offset;
-               pipe_ctx->stream_res.tg->dlg_otg_param.vstartup_start = pipe_ctx->pipe_dlg_param.vstartup_start;
-               pipe_ctx->stream_res.tg->dlg_otg_param.vupdate_offset = pipe_ctx->pipe_dlg_param.vupdate_offset;
-               pipe_ctx->stream_res.tg->dlg_otg_param.vupdate_width = pipe_ctx->pipe_dlg_param.vupdate_width;
-
                pipe_ctx->stream_res.tg->funcs->program_global_sync(
-                               pipe_ctx->stream_res.tg);
+                               pipe_ctx->stream_res.tg,
+                               pipe_ctx->pipe_dlg_param.vready_offset,
+                               pipe_ctx->pipe_dlg_param.vstartup_start,
+                               pipe_ctx->pipe_dlg_param.vupdate_offset,
+                               pipe_ctx->pipe_dlg_param.vupdate_width);
 
                dc->hwss.blank_pixel_data(dc, pipe_ctx, blank);
 
 
 int get_vupdate_offset_from_vsync(struct pipe_ctx *pipe_ctx)
 {
-       struct timing_generator *optc = pipe_ctx->stream_res.tg;
        const struct dc_crtc_timing *dc_crtc_timing = &pipe_ctx->stream->timing;
        struct dc_crtc_timing patched_crtc_timing;
        int vesa_sync_start;
                        * interlace_factor;
 
        vertical_line_start = asic_blank_end -
-                       optc->dlg_otg_param.vstartup_start + 1;
+                       pipe_ctx->pipe_dlg_param.vstartup_start + 1;
 
        return vertical_line_start;
 }
 
 }
 
 void optc1_program_global_sync(
-               struct timing_generator *optc)
+               struct timing_generator *optc,
+               int vready_offset,
+               int vstartup_start,
+               int vupdate_offset,
+               int vupdate_width)
 {
        struct optc *optc1 = DCN10TG_FROM_TG(optc);
 
-       if (optc->dlg_otg_param.vstartup_start == 0) {
+       optc1->vready_offset = vready_offset;
+       optc1->vstartup_start = vstartup_start;
+       optc1->vupdate_offset = vupdate_offset;
+       optc1->vupdate_width = vupdate_width;
+
+       if (optc1->vstartup_start == 0) {
                BREAK_TO_DEBUGGER();
                return;
        }
 
        REG_SET(OTG_VSTARTUP_PARAM, 0,
-               VSTARTUP_START, optc->dlg_otg_param.vstartup_start);
+               VSTARTUP_START, optc1->vstartup_start);
 
        REG_SET_2(OTG_VUPDATE_PARAM, 0,
-                       VUPDATE_OFFSET, optc->dlg_otg_param.vupdate_offset,
-                       VUPDATE_WIDTH, optc->dlg_otg_param.vupdate_width);
+                       VUPDATE_OFFSET, optc1->vupdate_offset,
+                       VUPDATE_WIDTH, optc1->vupdate_width);
 
        REG_SET(OTG_VREADY_PARAM, 0,
-                       VREADY_OFFSET, optc->dlg_otg_param.vready_offset);
+                       VREADY_OFFSET, optc1->vready_offset);
 }
 
 static void optc1_disable_stereo(struct timing_generator *optc)
 void optc1_program_timing(
        struct timing_generator *optc,
        const struct dc_crtc_timing *dc_crtc_timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios)
 {
        struct dc_crtc_timing patched_crtc_timing;
 
        struct optc *optc1 = DCN10TG_FROM_TG(optc);
 
+       optc1->signal = signal;
+       optc1->vready_offset = vready_offset;
+       optc1->vstartup_start = vstartup_start;
+       optc1->vupdate_offset = vupdate_offset;
+       optc1->vupdate_width = vupdate_width;
        patched_crtc_timing = *dc_crtc_timing;
        optc1_apply_front_porch_workaround(optc, &patched_crtc_timing);
 
                        patched_crtc_timing.v_addressable +
                        patched_crtc_timing.v_border_bottom);
 
-       vertical_line_start = asic_blank_end - optc->dlg_otg_param.vstartup_start + 1;
+       vertical_line_start = asic_blank_end - optc1->vstartup_start + 1;
        v_fp2 = 0;
        if (vertical_line_start < 0)
                v_fp2 = -vertical_line_start;
                OTG_V_SYNC_A_POL, v_sync_polarity);
 
        v_init = asic_blank_start;
-       if (optc->signal == SIGNAL_TYPE_DISPLAY_PORT ||
-               optc->signal == SIGNAL_TYPE_DISPLAY_PORT_MST ||
-               optc->signal == SIGNAL_TYPE_EDP) {
+       if (optc1->signal == SIGNAL_TYPE_DISPLAY_PORT ||
+               optc1->signal == SIGNAL_TYPE_DISPLAY_PORT_MST ||
+               optc1->signal == SIGNAL_TYPE_EDP) {
                start_point = 1;
                if (patched_crtc_timing.flags.INTERLACE == 1)
                        field_num = 1;
                        REG_UPDATE(OTG_INTERLACE_CONTROL,
                                        OTG_INTERLACE_ENABLE, 1);
                        v_init = v_init / 2;
-                       if ((optc->dlg_otg_param.vstartup_start/2)*2 > asic_blank_end)
+                       if ((optc1->vstartup_start/2)*2 > asic_blank_end)
                                v_fp2 = v_fp2 / 2;
                } else
                        REG_UPDATE(OTG_INTERLACE_CONTROL,
                        OTG_START_POINT_CNTL, start_point,
                        OTG_FIELD_NUMBER_CNTL, field_num);
 
-       optc1_program_global_sync(optc);
+       optc1_program_global_sync(optc,
+                       vready_offset,
+                       vstartup_start,
+                       vupdate_offset,
+                       vupdate_width);
 
        /* TODO
         * patched_crtc_timing.flags.HORZ_COUNT_BY_TWO == 1
 
        uint32_t min_v_sync_width;
        uint32_t min_v_blank;
        uint32_t min_v_blank_interlace;
+
+       int vstartup_start;
+       int vupdate_offset;
+       int vupdate_width;
+       int vready_offset;
+       enum signal_type signal;
 };
 
 void dcn10_timing_generator_init(struct optc *optc);
 void optc1_program_timing(
        struct timing_generator *optc,
        const struct dc_crtc_timing *dc_crtc_timing,
+       int vready_offset,
+       int vstartup_start,
+       int vupdate_offset,
+       int vupdate_width,
+       const enum signal_type signal,
        bool use_vbios);
 
 void optc1_setup_vertical_interrupt0(
                uint32_t start_line);
 
 void optc1_program_global_sync(
-               struct timing_generator *optc);
+               struct timing_generator *optc,
+               int vready_offset,
+               int vstartup_start,
+               int vupdate_offset,
+               int vupdate_width);
 
 bool optc1_disable_crtc(struct timing_generator *optc);
 
 
        CRTC_STATE_VACTIVE
 };
 
-struct _dlg_otg_param {
-       int vstartup_start;
-       int vupdate_offset;
-       int vupdate_width;
-       int vready_offset;
-};
-
 struct vupdate_keepout_params {
        int start_offset;
        int end_offset;
        const struct timing_generator_funcs *funcs;
        struct dc_bios *bp;
        struct dc_context *ctx;
-       struct _dlg_otg_param dlg_otg_param;
-       enum signal_type signal;
        int inst;
 };
 
                                                        const struct dc_crtc_timing *timing);
        void (*program_timing)(struct timing_generator *tg,
                                                        const struct dc_crtc_timing *timing,
-                                                       bool use_vbios);
+                                                       int vready_offset,
+                                                       int vstartup_start,
+                                                       int vupdate_offset,
+                                                       int vupdate_width,
+                                                       const enum signal_type signal,
+                                                       bool use_vbios
+       );
        void (*setup_vertical_interrupt0)(
                        struct timing_generator *optc,
                        uint32_t start_line,
 
        bool (*arm_vert_intr)(struct timing_generator *tg, uint8_t width);
 
-       void (*program_global_sync)(struct timing_generator *tg);
+       void (*program_global_sync)(struct timing_generator *tg,
+                       int vready_offset,
+                       int vstartup_start,
+                       int vupdate_offset,
+                       int vupdate_width);
        void (*enable_optc_clock)(struct timing_generator *tg, bool enable);
        void (*program_stereo)(struct timing_generator *tg,
                const struct dc_crtc_timing *timing, struct crtc_stereo_flags *flags);