blob: 559ed10f2e6c6e4dcec39ea9e123d7bcf8ef54e2 [file] [log] [blame]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef _OSD_HW_DEF_H_
#define _OSD_HW_DEF_H_
#include "osd_hw.h"
static void osd1_update_color_mode(void);
static void osd1_update_enable(void);
static void osd1_update_color_key(void);
static void osd1_update_color_key_enable(void);
static void osd1_update_gbl_alpha(void);
static void osd1_update_order(void);
static void osd1_update_disp_geometry(void);
static void osd1_update_coef(void);
static void osd1_update_disp_freescale_enable(void);
static void osd1_update_disp_osd_reverse(void);
static void osd1_update_disp_osd_rotate(void);
static void osd1_update_disp_scale_enable(void);
static void osd1_update_disp_3d_mode(void);
static void osd2_update_color_mode(void);
static void osd2_update_enable(void);
static void osd2_update_color_key(void);
static void osd2_update_color_key_enable(void);
static void osd2_update_gbl_alpha(void);
static void osd2_update_order(void);
static void osd2_update_disp_geometry(void);
static void osd2_update_coef(void);
static void osd2_update_disp_freescale_enable(void);
static void osd2_update_disp_osd_reverse(void);
static void osd2_update_disp_osd_rotate(void);
static void osd2_update_disp_scale_enable(void);
static void osd2_update_disp_3d_mode(void);
static void viu2_osd1_update_color_mode(void);
static void viu2_osd1_update_enable(void);
static void viu2_osd1_update_color_key(void);
static void viu2_osd1_update_color_key_enable(void);
static void viu2_osd1_update_gbl_alpha(void);
static void viu2_osd1_update_order(void);
static void viu2_osd1_update_disp_geometry(void);
static void viu2_osd1_update_coef(void);
static void viu2_osd1_update_disp_freescale_enable(void);
static void viu2_osd1_update_disp_osd_reverse(void);
static void viu2_osd1_update_disp_osd_rotate(void);
static void viu2_osd1_update_disp_scale_enable(void);
static void viu2_osd1_update_disp_3d_mode(void);
extern struct hw_para_s osd_hw;
static update_func_t hw_func_array[HW_OSD_COUNT][HW_REG_INDEX_MAX] = {
{
osd1_update_color_mode,
osd1_update_enable,
osd1_update_color_key,
osd1_update_color_key_enable,
osd1_update_gbl_alpha,
osd1_update_order,
osd1_update_coef,
osd1_update_disp_geometry,
osd1_update_disp_scale_enable,
osd1_update_disp_freescale_enable,
osd1_update_disp_osd_reverse,
osd1_update_disp_osd_rotate,
},
{
osd2_update_color_mode,
osd2_update_enable,
osd2_update_color_key,
osd2_update_color_key_enable,
osd2_update_gbl_alpha,
osd2_update_order,
osd2_update_coef,
osd2_update_disp_geometry,
osd2_update_disp_scale_enable,
osd2_update_disp_freescale_enable,
osd2_update_disp_osd_reverse,
osd2_update_disp_osd_rotate,
},
{
viu2_osd1_update_color_mode,
viu2_osd1_update_enable,
viu2_osd1_update_color_key,
viu2_osd1_update_color_key_enable,
viu2_osd1_update_gbl_alpha,
viu2_osd1_update_order,
viu2_osd1_update_coef,
viu2_osd1_update_disp_geometry,
viu2_osd1_update_disp_scale_enable,
viu2_osd1_update_disp_freescale_enable,
viu2_osd1_update_disp_osd_reverse,
viu2_osd1_update_disp_osd_rotate,
},
};
#define add_to_update_list(osd_idx, cmd_idx) \
do { \
osd_hw.updated[osd_idx] |= (1<<cmd_idx); \
} while (0)
#define remove_from_update_list(osd_idx, cmd_idx) \
(osd_hw.updated[osd_idx] &= ~(1<<cmd_idx))
#endif