Lines Matching refs:win
47 #define VIDOSD_A(win) (VIDOSD_BASE + 0x00 + (win) * 16) argument
48 #define VIDOSD_B(win) (VIDOSD_BASE + 0x04 + (win) * 16) argument
53 #define VIDOSD_C(win) (VIDOSD_BASE + 0x08 + (win) * 16) argument
55 #define VIDOSD_D(win) (VIDOSD_BASE + 0x0C + (win) * 16) argument
57 #define VIDWnALPHA0(win) (VIDW_ALPHA + 0x00 + (win) * 8) argument
58 #define VIDWnALPHA1(win) (VIDW_ALPHA + 0x04 + (win) * 8) argument
60 #define VIDWx_BUF_START(win, buf) (VIDW_BUF_START(buf) + (win) * 8) argument
61 #define VIDWx_BUF_START_S(win, buf) (VIDW_BUF_START_S(buf) + (win) * 8) argument
62 #define VIDWx_BUF_END(win, buf) (VIDW_BUF_END(buf) + (win) * 8) argument
63 #define VIDWx_BUF_SIZE(win, buf) (VIDW_BUF_SIZE(buf) + (win) * 4) argument
282 static void fimd_enable_video_output(struct fimd_context *ctx, unsigned int win, in fimd_enable_video_output() argument
285 u32 val = readl(ctx->regs + WINCON(win)); in fimd_enable_video_output()
292 writel(val, ctx->regs + WINCON(win)); in fimd_enable_video_output()
296 unsigned int win, in fimd_enable_shadow_channel_path() argument
302 val |= SHADOWCON_CHx_ENABLE(win); in fimd_enable_shadow_channel_path()
304 val &= ~SHADOWCON_CHx_ENABLE(win); in fimd_enable_shadow_channel_path()
312 unsigned int win, ch_enabled = 0; in fimd_clear_channels() local
323 for (win = 0; win < WINDOWS_NR; win++) { in fimd_clear_channels()
324 u32 val = readl(ctx->regs + WINCON(win)); in fimd_clear_channels()
327 fimd_enable_video_output(ctx, win, false); in fimd_clear_channels()
330 fimd_enable_shadow_channel_path(ctx, win, in fimd_clear_channels()
480 static void fimd_win_set_pixfmt(struct fimd_context *ctx, unsigned int win, in fimd_win_set_pixfmt() argument
491 if (ctx->driver_data->has_limited_fmt && !win) { in fimd_win_set_pixfmt()
547 writel(val, ctx->regs + WINCON(win)); in fimd_win_set_pixfmt()
550 if (win != 0) { in fimd_win_set_pixfmt()
559 writel(val, ctx->regs + VIDOSD_C(win)); in fimd_win_set_pixfmt()
563 writel(val, ctx->regs + VIDWnALPHA0(win)); in fimd_win_set_pixfmt()
564 writel(val, ctx->regs + VIDWnALPHA1(win)); in fimd_win_set_pixfmt()
568 static void fimd_win_set_colkey(struct fimd_context *ctx, unsigned int win) in fimd_win_set_colkey() argument
577 writel(keycon0, ctx->regs + WKEYCON0_BASE(win)); in fimd_win_set_colkey()
578 writel(keycon1, ctx->regs + WKEYCON1_BASE(win)); in fimd_win_set_colkey()
588 unsigned int win, bool protect) in fimd_shadow_protect_win() argument
604 bits = SHADOWCON_WINx_PROTECT(win); in fimd_shadow_protect_win()
648 unsigned int win = plane->zpos; in fimd_update_plane() local
661 writel(val, ctx->regs + VIDWx_BUF_START(win, 0)); in fimd_update_plane()
666 writel(val, ctx->regs + VIDWx_BUF_END(win, 0)); in fimd_update_plane()
680 writel(val, ctx->regs + VIDWx_BUF_SIZE(win, 0)); in fimd_update_plane()
687 writel(val, ctx->regs + VIDOSD_A(win)); in fimd_update_plane()
699 writel(val, ctx->regs + VIDOSD_B(win)); in fimd_update_plane()
705 if (win != 3 && win != 4) { in fimd_update_plane()
706 u32 offset = VIDOSD_D(win); in fimd_update_plane()
707 if (win == 0) in fimd_update_plane()
708 offset = VIDOSD_C(win); in fimd_update_plane()
715 fimd_win_set_pixfmt(ctx, win, state->fb); in fimd_update_plane()
718 if (win != 0) in fimd_update_plane()
719 fimd_win_set_colkey(ctx, win); in fimd_update_plane()
721 fimd_enable_video_output(ctx, win, true); in fimd_update_plane()
724 fimd_enable_shadow_channel_path(ctx, win, true); in fimd_update_plane()
734 unsigned int win = plane->zpos; in fimd_disable_plane() local
739 fimd_enable_video_output(ctx, win, false); in fimd_disable_plane()
742 fimd_enable_shadow_channel_path(ctx, win, false); in fimd_disable_plane()
896 int win; in fimd_irq_handler() local
911 for (win = 0 ; win < WINDOWS_NR ; win++) { in fimd_irq_handler()
912 struct exynos_drm_plane *plane = &ctx->planes[win]; in fimd_irq_handler()
917 start = readl(ctx->regs + VIDWx_BUF_START(win, 0)); in fimd_irq_handler()
918 start_s = readl(ctx->regs + VIDWx_BUF_START_S(win, 0)); in fimd_irq_handler()