blob: 6f1fb2cfcca50f76f0ff0b3666c52f5356af250f [file]
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
* Copyright (c) 2021 Amlogic, Inc. All rights reserved.
*/
#include "vicp_reg.h"
#include "vicp_log.h"
#include "vicp_hardware.h"
#include "vicp_rdma.h"
static u32 rdma_enable_flag;
static int pps_lut_tap8[33][8] = {{0, 0, 0, 128, 0, 0, 0, 0},
{-1, 1, 0, 127, 2, -1, 1, -1},
{-1, 2, -2, 127, 4, -2, 1, -1},
{-2, 3, -4, 127, 6, -3, 2, -1},
{-3, 4, -7, 127, 10, -4, 3, -2},
{-3, 5, -9, 127, 12, -5, 3, -2},
{-4, 6, -11, 127, 15, -6, 4, -3},
{-4, 7, -13, 127, 16, -7, 5, -3},
{-5, 7, -14, 127, 20, -8, 5, -4},
{-5, 8, -16, 127, 21, -9, 6, -4},
{-6, 9, -17, 127, 24, -11, 7, -5},
{-6, 10, -18, 126, 26, -12, 7, -5},
{-7, 10, -20, 127, 29, -13, 8, -6},
{-7, 11, -21, 124, 32, -14, 9, -6},
{-8, 12, -22, 124, 35, -15, 9, -7},
{-8, 12, -23, 123, 37, -16, 10, -7},
{-9, 13, -24, 121, 40, -17, 11, -7},
{-9, 14, -25, 120, 43, -18, 11, -8},
{-10, 14, -26, 119, 46, -19, 12, -8},
{-10, 15, -27, 118, 49, -20, 12, -9},
{-10, 15, -27, 115, 52, -21, 13, -9},
{-10, 15, -28, 114, 55, -22, 13, -9},
{-11, 16, -28, 112, 58, -23, 14, -10},
{-11, 16, -29, 111, 61, -24, 14, -10},
{-11, 16, -29, 107, 64, -24, 15, -10},
{-11, 17, -29, 104, 67, -25, 15, -10},
{-11, 17, -29, 103, 70, -26, 15, -11},
{-12, 17, -29, 100, 73, -26, 16, -11},
{-12, 17, -29, 98, 76, -27, 16, -11},
{-12, 17, -29, 96, 79, -28, 16, -11},
{-12, 17, -29, 92, 82, -28, 17, -11},
{-12, 17, -29, 90, 85, -29, 17, -11},
{-12, 17, -29, 88, 88, -29, 17, -12}};
static int pps_lut_tap8_s11[33][8] = {{0, 0, 0, 512, 0, 0, 0, 0},
{-1, 3, -7, 512, 7, -3, 1, 0},
{-2, 5, -14, 511, 15, -5, 2, 0},
{-2, 7, -20, 510, 23, -8, 3, -1},
{-3, 10, -27, 509, 31, -11, 3, 0},
{-4, 12, -32, 507, 39, -14, 4, 0},
{-4, 14, -38, 504, 48, -17, 5, 0},
{-5, 16, -43, 501, 57, -19, 6, -1},
{-5, 18, -49, 498, 66, -22, 7, -1},
{-6, 19, -53, 495, 75, -26, 8, 0},
{-6, 21, -58, 490, 85, -29, 10, -1},
{-6, 22, -62, 486, 94, -32, 11, -1},
{-7, 24, -66, 481, 104, -35, 12, -1},
{-7, 25, -69, 476, 114, -38, 13, -2},
{-7, 26, -72, 470, 124, -41, 14, -2},
{-8, 27, -75, 464, 134, -44, 15, -1},
{-8, 28, -78, 458, 145, -47, 16, -2},
{-8, 29, -80, 451, 155, -50, 17, -2},
{-8, 30, -83, 444, 166, -53, 18, -2},
{-8, 31, -84, 437, 177, -56, 19, -4},
{-8, 31, -86, 429, 188, -59, 20, -3},
{-9, 32, -87, 421, 199, -62, 22, -4},
{-8, 32, -88, 413, 209, -64, 23, -5},
{-8, 32, -89, 405, 220, -67, 24, -5},
{-9, 33, -89, 396, 231, -69, 25, -6},
{-8, 33, -90, 387, 242, -72, 25, -5},
{-8, 33, -90, 377, 253, -74, 26, -5},
{-8, 32, -89, 368, 264, -76, 27, -6},
{-8, 32, -89, 358, 275, -78, 28, -6},
{-8, 32, -88, 348, 286, -80, 29, -7},
{-7, 32, -88, 338, 297, -82, 29, -7},
{-7, 31, -86, 328, 307, -84, 30, -7},
{-8, 31, -85, 318, 318, -85, 31, -8}};
static int pps_lut_tap4_s11[33][4] = {{0, 512, 0, 0},
{-5, 512, 5, 0},
{-10, 511, 11, 0},
{-14, 510, 17, -1},
{-18, 508, 23, -1},
{-22, 506, 29, -1},
{-25, 503, 36, -2},
{-28, 500, 43, -3},
{-32, 496, 51, -3},
{-34, 491, 59, -4},
{-37, 487, 67, -5},
{-39, 482, 75, -6},
{-41, 476, 84, -7},
{-42, 470, 92, -8},
{-44, 463, 102, -9},
{-45, 456, 111, -10},
{-45, 449, 120, -12},
{-47, 442, 130, -13},
{-47, 434, 140, -15},
{-47, 425, 151, -17},
{-47, 416, 161, -18},
{-47, 407, 172, -20},
{-47, 398, 182, -21},
{-47, 389, 193, -23},
{-46, 379, 204, -25},
{-45, 369, 215, -27},
{-44, 358, 226, -28},
{-43, 348, 237, -30},
{-43, 337, 249, -31},
{-41, 326, 260, -33},
{-40, 316, 271, -35},
{-39, 305, 282, -36},
{-37, 293, 293, -37}};
static struct vicp_afbce_reg_s afbce_reg;
static struct vicp_lossy_compress_reg_s lossy_compress_reg;
void init_vicp_module_reg(enum meson_cpuid_type_e cpuid)
{
if (cpuid == MESON_CPU_MAJOR_ID_S5) {
vicp_reg_array_init(VICP_SUPPORT_CHIP_S5, VICP_MODULE_AFBCE, &afbce_reg);
} else if (cpuid == MESON_CPU_MAJOR_ID_T3X) {
vicp_reg_array_init(VICP_SUPPORT_CHIP_t3X, VICP_MODULE_AFBCE, &afbce_reg);
vicp_reg_array_init(VICP_SUPPORT_CHIP_t3X, VICP_MODULE_LOSSY_COMPRESS,
&lossy_compress_reg);
} else {
vicp_print(VICP_ERROR, "%s: this chip don't support vicp.\n", __func__);
}
}
void set_module_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_CTRL, is_enable, 0, 1);
}
void set_module_start(u32 is_start)
{
return write_vicp_reg_bits(VID_CMPR_START, is_start, 0, 1);
}
void set_module_reset(void)
{
return write_vicp_reg_bits(VID_CMPR_SW_RESETS, 1, 15, 1);
}
void set_rdma_start(u32 input_count)
{
return vicp_reg_set_bits(VID_CMPR_INT_CTRL, input_count, 0, 8);
}
void set_rdma_flag(u32 is_enable)
{
rdma_enable_flag = is_enable;
}
void set_rdmif_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_RDMIFXN_GEN_REG, is_enable, 0, 1);
}
void set_afbcd_enable(u32 is_enable)
{
//0:disable; 1:enable
return write_vicp_reg_bits(VID_CMPR_AFBCDM_ENABLE, is_enable, 8, 1);
}
void set_input_path(enum vicp_input_path_e path)
{
return write_vicp_reg_bits(VID_CMPR_AFBCDM_VDTOP_CTRL0, path, 13, 1);
}
void set_input_size(u32 size_v, u32 size_h)
{
return write_vicp_reg(VID_CMPR_IN_SIZE, (size_v << 16) | size_h);
}
void set_output_size(u32 size_v, u32 size_h)
{
return write_vicp_reg(VID_CMPR_OUT_SIZE, (size_v << 16) | size_h);
}
void set_afbcd_4k_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_AFBCDM_VDTOP_CTRL0, is_enable, 14, 1);
}
void set_afbcd_input_size(u32 size_h, u32 size_v)
{
u32 value = 0;
value = ((size_h & 0x1fff) << 16) | (size_v & 0x1fff);
return write_vicp_reg(VID_CMPR_AFBCDM_SIZE_IN, value);
}
void set_afbcd_default_color(u32 def_color_y, u32 def_color_u, u32 def_color_v)
{
u32 value = 0;
value = ((def_color_y & 0x3ff) << 20) |
((def_color_u & 0x3ff) << 10) |
((def_color_v & 0x3ff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_DEC_DEF_COLOR, value);
}
void set_afbcd_mode(struct vicp_afbcd_mode_reg_s afbcd_mode)
{
u32 value = 0;
value = ((afbcd_mode.ddr_sz_mode & 0x1) << 29) |
((afbcd_mode.blk_mem_mode & 0x1) << 28) |
((afbcd_mode.rev_mode & 0x3) << 26) |
((afbcd_mode.mif_urgent & 0x3) << 24) |
((afbcd_mode.hold_line_num & 0x7f) << 16) |
((afbcd_mode.burst_len & 0x3) << 14) |
((afbcd_mode.compbits_yuv & 0x3f) << 8) |
((afbcd_mode.vert_skip_y & 0x3) << 6) |
((afbcd_mode.horz_skip_y & 0x3) << 4) |
((afbcd_mode.vert_skip_uv & 0x3) << 2) |
((afbcd_mode.horz_skip_uv & 0x3) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_MODE, value);
}
void set_afbcd_conv_control(enum vicp_color_format_e fmt_mode, u32 lbuf_len)
{
u32 value = 0;
value = ((fmt_mode & 0x3) << 12) | ((lbuf_len & 0xfff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_CONV_CTRL, value);
}
void set_afbcd_lbuf_depth(u32 dec_lbuf_depth, u32 mif_lbuf_depth)
{
u32 value = 0;
value = ((dec_lbuf_depth & 0xfff) << 16) | ((mif_lbuf_depth & 0xfff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_LBUF_DEPTH, value);
}
void set_afbcd_headaddr(u64 addr)
{
return write_vicp_reg(VID_CMPR_AFBCDM_HEAD_BADDR, addr >> 4);
}
void set_afbcd_bodyaddr(u64 addr)
{
return write_vicp_reg(VID_CMPR_AFBCDM_BODY_BADDR, addr >> 4);
}
void set_afbcd_mif_scope(u32 v_h_flag, u32 scope_begin, u32 scope_end)
{
u32 scope_value = 0, reg = 0;
//0 h_scope, 1 v_scope
if (v_h_flag == 0) {
reg = VID_CMPR_AFBCDM_MIF_HOR_SCOPE;
scope_value = ((scope_begin & 0x3ff) << 16) | ((scope_end & 0x3ff) << 0);
} else {
reg = VID_CMPR_AFBCDM_MIF_VER_SCOPE;
scope_value = ((scope_begin & 0xfff) << 16) | ((scope_end & 0xfff) << 0);
}
return write_vicp_reg(reg, scope_value);
}
void set_afbcd_pixel_scope(u32 v_h_flag, u32 scope_begin, u32 scope_end)
{
u32 scope_value = 0, reg = 0;
//0 h_scope, 1 v_scope
if (v_h_flag == 0)
reg = VID_CMPR_AFBCDM_PIXEL_HOR_SCOPE;
else
reg = VID_CMPR_AFBCDM_PIXEL_VER_SCOPE;
scope_value = ((scope_begin & 0x1fff) << 16) | ((scope_end & 0x1fff) << 0);
return write_vicp_reg(reg, scope_value);
}
void set_afbcd_general(struct vicp_afbcd_general_reg_s reg)
{
u32 value = 0;
value = ((reg.gclk_ctrl_core & 0x3f) << 23) |
((reg.fmt_size_sw_mode & 0x1) << 22) |
((reg.addr_link_en & 0x1) << 21) |
((reg.fmt444_comb & 0x1) << 20) |
((reg.dos_uncomp_mode & 0x1) << 19) |
((reg.soft_rst & 0x7) << 16) |
((reg.ddr_blk_size & 0x3) << 12) |
((reg.cmd_blk_size & 0x7) << 9) |
((reg.dec_enable & 0x1) << 8) |
((reg.head_len_sel & 0x1) << 1) |
((reg.reserved & 0x1) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_ENABLE, value);
}
void set_afbcd_colorformat_control(struct vicp_afbcd_cfmt_control_reg_s cfmt_control)
{
u32 value;
value = ((cfmt_control.gclk_bit_dis & 0x1) << 31) |
((cfmt_control.soft_rst_bit & 0x1) << 30) |
((cfmt_control.cfmt_h_rpt_pix & 0x1) << 28) |
((cfmt_control.cfmt_h_ini_phase & 0xf) << 24) |
((cfmt_control.cfmt_h_rpt_p0_en & 0x1) << 23) |
((cfmt_control.cfmt_h_yc_ratio & 0x3) << 21) |
((cfmt_control.cfmt_h_en & 0x1) << 20) |
((cfmt_control.cfmt_v_phase0_en & 0x1) << 19) |
((cfmt_control.cfmt_v_rpt_last_dis & 0x1) << 18) |
((cfmt_control.cfmt_v_phase0_nrpt_en & 0x1) << 17) |
((cfmt_control.cfmt_v_rpt_line0_en & 0x1) << 16) |
((cfmt_control.cfmt_v_skip_line_num & 0xf) << 12) |
((cfmt_control.cfmt_v_ini_phase & 0xf) << 8) |
((cfmt_control.cfmt_v_phase_step & 0x7f) << 1) |
((cfmt_control.cfmt_v_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_VD_CFMT_CTRL, value);
}
void set_afbcd_colorformat_w(u32 hz_fmt_w, u32 vt_fmt_w)
{
u32 value = 0;
value = (hz_fmt_w << 16) | (vt_fmt_w << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_VD_CFMT_W, value);
}
void set_afbcd_colorformat_h(u32 fmt_size_h)
{
return write_vicp_reg(VID_CMPR_AFBCDM_VD_CFMT_H, fmt_size_h);
}
void set_afbcd_quant_control(struct vicp_afbcd_quant_control_reg_s quant_control)
{
u32 value = 0;
value = ((quant_control.quant_expand_en_1 & 0x1) << 11) |
((quant_control.quant_expand_en_0 & 0x1) << 10) |
((quant_control.bcleav_offsst & 0x3) << 8) |
((quant_control.lossy_chrm_en & 0x1) << 4) |
((quant_control.lossy_luma_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_IQUANT_ENABLE, value);
}
void set_afbcd_rotate_control(struct vicp_afbcd_rotate_control_reg_s rotate_control)
{
u32 value = 0;
value = ((rotate_control.out_ds_mode_h & 0x3) << 30) |
((rotate_control.out_ds_mode_v & 0x3) << 28) |
((rotate_control.pip_mode & 0x1) << 27) |
((rotate_control.uv_shrk_drop_mode_v & 0x7) << 24) |
((rotate_control.uv_shrk_drop_mode_h & 0x7) << 20) |
((rotate_control.uv_shrk_ratio_v & 0x3) << 18) |
((rotate_control.uv_shrk_ratio_h & 0x3) << 16) |
((rotate_control.y_shrk_drop_mode_v & 0x7) << 12) |
((rotate_control.y_shrk_drop_mode_h & 0x7) << 8) |
((rotate_control.y_shrk_ratio_v & 0x3) << 6) |
((rotate_control.y_shrk_ratio_h & 0x3) << 4) |
((rotate_control.uv422_drop_mode & 0x3) << 2) |
((rotate_control.out_fmt_for_uv422 & 0x3) << 1) |
((rotate_control.enable & 0x1) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_ROT_CTRL, value);
}
void set_afbcd_rotate_scope(struct vicp_afbcd_rotate_scope_reg_s rotate_scope)
{
u32 value = 0;
value = ((rotate_scope.debug_probe & 0x1f) << 20) |
((rotate_scope.out_ds_mode & 0x1) << 19) |
((rotate_scope.out_fmt_down_mode & 0x3) << 17) |
((rotate_scope.in_fmt_force444 & 0x1) << 16) |
((rotate_scope.out_fmt_mode & 0x3) << 14) |
((rotate_scope.out_compbits_y & 0x3) << 12) |
((rotate_scope.out_compbits_uv & 0x3) << 10) |
((rotate_scope.win_bgn_v & 0x3) << 8) |
((rotate_scope.win_bgn_h & 0x1f) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_ROT_SCOPE, value);
}
void set_afbcd_loss_control(struct vicp_afbcd_lossy_ctrl_reg_s lossy_ctrl_reg)
{
u32 value = 0;
value = ((lossy_ctrl_reg.fix_cr_en & 0x1) << 4) |
((lossy_ctrl_reg.quant_diff_root_leave & 0xf) << 0);
return write_vicp_reg(VID_CMPR_AFBCD_LOSS_CTRL, value);
}
void set_afbce_path_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_WR_PATH_CTRL, is_enable, 1, 1);
}
void set_afbcd_burst_control(struct vicp_afbcd_burst_ctrl_reg_s burst_ctrl_reg)
{
u32 value = 0;
value = ((burst_ctrl_reg.ofset_burst4_en & 0x1) << 4) |
((burst_ctrl_reg.burst_length_add_en & 0x1) << 3) |
((burst_ctrl_reg.burst_length_add_value & 0x7) << 0);
return write_vicp_reg(VID_CMPR_AFBCD_BURST_CTRL, value);
}
void set_afbce_lossy_luma_enable(u32 enable)
{
return write_vicp_reg_bits(afbce_reg.afbce_quant_enable, (enable & 0x1), 0, 1);
}
void set_afbce_lossy_chrm_enable(u32 enable)
{
return write_vicp_reg_bits(afbce_reg.afbce_quant_enable, (enable & 0x1), 4, 1);
}
void set_afbce_lossy_control(struct vicp_afbce_loss_ctrl_reg_s loss_ctrl_reg)
{
u32 value = 0;
value = ((loss_ctrl_reg.fix_cr_en & 0x1) << 31) |
((loss_ctrl_reg.rc_en & 0x1) << 30) |
((loss_ctrl_reg.write_qlevel_mode & 0x1) << 29) |
((loss_ctrl_reg.debug_qlevel_en & 0x1) << 28) |
((loss_ctrl_reg.cal_bit_early_mode & 0x3) << 16) |
((loss_ctrl_reg.quant_diff_root_leave & 0xf) << 12) |
((loss_ctrl_reg.debug_qlevel_value & 0xf) << 8) |
((loss_ctrl_reg.debug_qlevel_max_0 & 0xf) << 4) |
((loss_ctrl_reg.debug_qlevel_max_1 & 0xf) << 0);
return write_vicp_reg(lossy_compress_reg.loss_ctrl, value);
}
void set_afbce_lossy_brust_num(u32 num0, u32 num1, u32 num2, u32 num3)
{
u32 value = 0;
value = ((num3 & 0x1f) << 24) |
((num2 & 0x1f) << 16) |
((num1 & 0x1f) << 8) |
((num0 & 0x1f) << 0);
return write_vicp_reg(lossy_compress_reg.loss_burst_num, value);
}
void set_afbce_format(struct vicp_afbce_format_reg_s format_reg)
{
u32 value = 0;
value = ((format_reg.burst_length_add_value & 0x7) << 12) |
((format_reg.ofset_burst4_en & 0x1) << 11) |
((format_reg.burst_length_add_en & 0x1) << 10) |
((format_reg.format_mode & 0x3) << 8) |
((format_reg.compbits_c & 0xf) << 4) |
((format_reg.compbits_y & 0xf) << 0);
return write_vicp_reg(afbce_reg.afbce_format, value);
}
void set_afbce_ofset_burst4_en(u32 enable)
{
return vicp_reg_set_bits(afbce_reg.afbce_format, enable, 11, 1);
}
void set_afbce_input_size(u32 size_h, u32 size_v)
{
u32 value = 0;
value = (((size_h & 0x1fff) << 16) | (size_v & 0x1fff) << 0);
return write_vicp_reg(afbce_reg.afbce_size_in, value);
}
void set_afbce_blk_size(u32 size_h, u32 size_v)
{
u32 value = 0;
value = ((size_h & 0x1fff) << 16) | ((size_v & 0x1fff) << 0);
return write_vicp_reg(afbce_reg.afbce_block_size_in, value);
}
void set_afbce_head_addr(u64 head_addr)
{
return write_vicp_reg(afbce_reg.afbce_head_baddr, head_addr >> 4);
}
void set_rdmif_luma_fifo_size(u32 size)
{
return write_vicp_reg(VID_CMPR_RDMIFXN_LUMA_FIFO_SIZE, size);
}
void set_rdmif_general_reg(struct vicp_rdmif_general_reg_s reg)
{
u32 value = 0;
value = ((reg.enable_free_clk & 0x1) << 31) |
((reg.reset_on_go_field & 0x1) << 29) |
((reg.urgent_chroma & 0x1) << 28) |
((reg.urgent_luma & 0x1) << 27) |
((reg.chroma_end_at_last_line & 0x1) << 26) |
((reg.luma_end_at_last_line & 0x1) << 25) |
((reg.hold_lines & 0x3f) << 19) |
((reg.last_line_mode & 0x1) << 18) |
((reg.ro_busy & 0x1) << 17) |
(((reg.demux_mode & 0x1) << 16) |
((reg.bytes_per_pixel & 0x3) << 14) |
((reg.ddr_burst_size_cr & 0x3) << 12) |
((reg.ddr_burst_size_cb & 0x3) << 10) |
((reg.ddr_burst_size_y & 0x3) << 8) |
((reg.chroma_rpt_lastl & 0x1) << 6) |
((reg.little_endian & 0x1) << 4) |
((reg.chroma_hz_avg & 0x1) << 3) |
((reg.luma_hz_avg & 0x1) << 2) |
((reg.set_separate_en & 0x1) << 1) |
((reg.enable & 0x1) << 0));
return write_vicp_reg(VID_CMPR_RDMIFXN_GEN_REG, value);
}
void set_rdmif_general_reg2(struct vicp_rdmif_general_reg2_s reg)
{
u32 value = 0;
value = ((reg.chroma_line_read_sel & 0x1) << 29) |
((reg.luma_line_read_sel & 0x1) << 28) |
((reg.shift_pat_cr & 0xf) << 24) |
((reg.shift_pat_cb & 0xf) << 16) |
((reg.shift_pat_y & 0xf) << 8) |
((reg.hold_lines & 0x1) << 6) |
((reg.y_rev1 & 0x1) << 5) |
((reg.x_rev1 & 0x1) << 4) |
((reg.y_rev0 & 0x1) << 3) |
((reg.x_rev0 & 0x1) << 2) |
((reg.color_map & 0x3) << 0);
return write_vicp_reg(VID_CMPR_RDMIFXN_GEN_REG2, value);
}
void set_rdmif_general_reg3(struct vicp_rdmif_general_reg3_s reg)
{
u32 value = 0;
value = ((reg.f0_stride32aligned2 & 0x1) << 26) |
((reg.f0_stride32aligned1 & 0x1) << 25) |
((reg.f0_stride32aligned0 & 0x1) << 24) |
((reg.f0_cav_blk_mode2 & 0x3) << 22) |
((reg.f0_cav_blk_mode1 & 0x3) << 20) |
((reg.f0_cav_blk_mode0 & 0x3) << 18) |
((reg.abort_mode & 0x3) << 16) |
((reg.dbg_mode & 0x3) << 10) |
((reg.bits_mode & 0x3) << 8) |
((reg.block_len & 0x3) << 4) |
((reg.burst_len & 0x3) << 1) |
((reg.bit_swap & 0x1) << 0);
return write_vicp_reg(VID_CMPR_RDMIFXN_GEN_REG3, value);
}
void set_rdmif_base_addr(enum rdmif_baseaddr_type_e addr_type, u64 base_addr)
{
u32 value = 0, reg = 0;
value = base_addr >> 4;
switch (addr_type) {
case RDMIF_BASEADDR_TYPE_Y:
reg = VID_CMPR_RDMIFXN_BADDR_Y;
break;
case RDMIF_BASEADDR_TYPE_CB:
reg = VID_CMPR_RDMIFXN_BADDR_CB;
break;
case RDMIF_BASEADDR_TYPE_CR:
reg = VID_CMPR_RDMIFXN_BADDR_CR;
break;
case RDMIF_BASEADDR_TYPE_MAX:
default:
vicp_print(VICP_ERROR, "%s: invalid case.", __func__);
break;
}
if (reg != 0)
write_vicp_reg_bits(reg, value, 0, 32);
}
void set_rdmif_stride(enum rdmif_stride_type_e stride_type, u32 stride_value)
{
switch (stride_type) {
case RDMIF_STRIDE_TYPE_Y:
write_vicp_reg_bits(VID_CMPR_RDMIFXN_STRIDE_0, stride_value, 0, 13);
break;
case RDMIF_STRIDE_TYPE_CB:
write_vicp_reg_bits(VID_CMPR_RDMIFXN_STRIDE_0, stride_value, 16, 13);
break;
case RDMIF_STRIDE_TYPE_CR:
write_vicp_reg_bits(VID_CMPR_RDMIFXN_STRIDE_1, (1 << 16) | stride_value, 0, 32);
break;
case RDMIF_STRIDE_TYPE_MAX:
default:
vicp_print(VICP_ERROR, "%s: invalid case.", __func__);
break;
}
}
void set_rdmif_luma_position(u32 index, u32 is_x, u32 start, u32 end)
{
u32 value = 0, reg = 0;
value = (end << 16) | (start << 0);
if (index == 0) {
if (is_x)
reg = VID_CMPR_RDMIFXN_LUMA_X0;
else
reg = VID_CMPR_RDMIFXN_LUMA_Y0;
} else {
if (is_x)
reg = VID_CMPR_RDMIFXN_LUMA_X1;
else
reg = VID_CMPR_RDMIFXN_LUMA_Y1;
}
return write_vicp_reg(reg, value);
}
void set_rdmif_chroma_position(u32 index, u32 is_x, u32 start, u32 end)
{
u32 value = 0, reg = 0;
value = (end << 16) | (start << 0);
if (index == 0) {
if (is_x)
reg = VID_CMPR_RDMIFXN_CHROMA_X0;
else
reg = VID_CMPR_RDMIFXN_CHROMA_Y0;
} else {
if (is_x)
reg = VID_CMPR_RDMIFXN_CHROMA_X1;
else
reg = VID_CMPR_RDMIFXN_CHROMA_Y1;
}
return write_vicp_reg(reg, value);
}
void set_rdmif_rpt_loop(struct vicp_rdmif_rpt_loop_s rpt_loop)
{
u32 value = 0;
value = ((rpt_loop.rpt_loop1_chroma_start & 0xf) << 28) |
((rpt_loop.rpt_loop1_chroma_end & 0xf) << 24) |
((rpt_loop.rpt_loop1_luma_start & 0xf) << 20) |
((rpt_loop.rpt_loop1_luma_end & 0xf) << 16) |
((rpt_loop.rpt_loop0_chroma_start & 0xf) << 12) |
((rpt_loop.rpt_loop0_chroma_end & 0xf) << 8) |
((rpt_loop.rpt_loop0_luma_start & 0xf) << 4) |
((rpt_loop.rpt_loop0_luma_end & 0xf) << 0);
return write_vicp_reg(VID_CMPR_RDMIFXN_RPT_LOOP, value);
}
void set_rdmif_luma_rpt_pat(u32 luma_index, u32 value)
{
if (luma_index == 0)
return write_vicp_reg(VID_CMPR_RDMIFXN_LUMA0_RPT_PAT, value);
else
return write_vicp_reg(VID_CMPR_RDMIFXN_LUMA1_RPT_PAT, value);
}
void set_rdmif_chroma_rpt_pat(u32 chroma_index, u32 value)
{
if (chroma_index == 0)
return write_vicp_reg(VID_CMPR_RDMIFXN_CHROMA0_RPT_PAT, value);
else
return write_vicp_reg(VID_CMPR_RDMIFXN_CHROMA1_RPT_PAT, value);
}
void set_rdmif_dummy_pixel(u32 value)
{
return write_vicp_reg(VID_CMPR_RDMIFXN_DUMMY_PIXEL, value);
}
void set_rdmif_color_format_control(struct vicp_rdmif_color_format_s color_format)
{
u32 value = 0;
value = ((color_format.cfmt_gclk_bit_dis & 0x1) << 31) |
((color_format.cfmt_soft_rst_bit & 0x1) << 30) |
((color_format.cfmt_h_rpt_pix & 0x1) << 28) |
((color_format.cfmt_h_ini_phase & 0xf) << 24) |
((color_format.cfmt_h_rpt_p0_en & 0x1) << 23) |
((color_format.cfmt_h_yc_ratio & 0x3) << 21) |
((color_format.cfmt_h_en & 0x1) << 20) |
((color_format.cfmt_h_rpt_pix & 0x1) << 19) |
((color_format.cfmt_h_rpt_pix & 0x1) << 18) |
((color_format.cfmt_v_phase0_nrpt_en & 0x1) << 17) |
((color_format.cfmt_v_rpt_line0_en & 0x1) << 16) |
((color_format.cfmt_v_skip_line_num & 0xf) << 12) |
((color_format.cfmt_v_ini_phase & 0xf) << 8) |
((color_format.cfmt_v_phase_step & 0x7f) << 1) |
((color_format.cfmt_v_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_RDMIFXN_CFMT_CTRL, value);
}
void set_rdmif_color_format_width(u32 cfmt_width_h, u32 cfmt_width_v)
{
u32 value = 0;
value = (cfmt_width_h << 16) | (cfmt_width_v << 0);
return write_vicp_reg(VID_CMPR_RDMIFXN_CFMT_W, value);
}
void set_afbce_mif_size(struct vicp_afbce_mif_size_reg_s mif_size_reg)
{
u32 value = 0;
value = ((mif_size_reg.ddr_blk_size & 0x3) << 28) |
((mif_size_reg.cmd_blk_size & 0x7) << 24) |
((mif_size_reg.uncmp_size & 0xff) << 16) |
((mif_size_reg.mmu_page_size & 0xffff) << 0);
return write_vicp_reg(afbce_reg.afbce_mif_size, value);
}
void set_afbce_mix_scope(u32 h_or_v, u32 begin, u32 end)
{
u32 value = 0, reg = 0;
if (h_or_v == 1) {
reg = afbce_reg.afbce_mif_hor_scope;
value = ((end & 0x3ff) << 16) | ((begin & 0x3ff) << 0);
} else {
reg = afbce_reg.afbce_mif_ver_scope;
value = ((end & 0xfff) << 16) | ((begin & 0xfff) << 0);
}
return write_vicp_reg(reg, value);
}
void set_afbce_pixel_in_scope(u32 h_or_v, u32 begin, u32 end)
{
u32 value = 0, reg = 0;
if (h_or_v == 1)
reg = afbce_reg.afbce_pixel_hor_scope;
else
reg = afbce_reg.afbce_pixel_ver_scope;
value = ((end & 0x1fff) << 16) | ((begin & 0x1fff) << 0);
return write_vicp_reg(reg, value);
}
void set_afbce_conv_control(u32 fmt_ybuf_depth, u32 lbuf_depth)
{
u32 value = 0;
value = (fmt_ybuf_depth & 0x1fff) << 16 | ((lbuf_depth & 0xfff) << 0);
return write_vicp_reg(afbce_reg.afbce_conv_ctrl, value);
}
void set_afbce_mode(struct vicp_afbce_mode_reg_s afbce_mode_reg)
{
u32 value = 0;
value = ((afbce_mode_reg.soft_rst & 0x3) << 29) |
((afbce_mode_reg.rev_mode & 0x3) << 26) |
((afbce_mode_reg.mif_urgent & 0x3) << 24) |
((afbce_mode_reg.hold_line_num & 0x7f) << 16) |
((afbce_mode_reg.burst_mode & 0x3) << 14) |
((afbce_mode_reg.fmt444_comb & 0x1) << 0);
return write_vicp_reg(afbce_reg.afbce_mode, value);
}
void set_afbce_default_color1(u32 def_color_a, u32 def_color_y)
{
u32 value = 0;
value = ((def_color_a & 0xfff) << 12) | ((def_color_y & 0xfff) << 0);
return write_vicp_reg(afbce_reg.afbce_def_color1, value);
}
void set_afbce_default_color2(u32 def_color_u, u32 def_color_v)
{
u32 value = 0;
value = ((def_color_v & 0xfff) << 12) | ((def_color_u & 0xfff) << 0);
return write_vicp_reg(afbce_reg.afbce_def_color2, value);
}
void set_afbce_mmu_rmif_scope(u32 x_or_y, u32 start, u32 end)
{
u32 value = 0, reg = 0;
if (x_or_y == 1)
reg = afbce_reg.afbce_mmu_rmif_scope_x;
else
reg = afbce_reg.afbce_mmu_rmif_scope_y;
value = ((end & 0x1fff) << 16) | ((start & 0x1fff) << 0);
return write_vicp_reg(reg, value);
}
void set_afbce_mmu_rmif_control1(struct vicp_afbce_mmu_rmif_control1_reg_s rmif_control1)
{
u32 value = 0;
value = ((rmif_control1.sync_sel & 0x3) << 24) |
((rmif_control1.canvas_id & 0xff) << 16) |
((rmif_control1.cmd_intr_len & 0x7) << 12) |
((rmif_control1.cmd_req_size & 0x3) << 10) |
((rmif_control1.burst_len & 0x3) << 8) |
((rmif_control1.swap_64bit & 0x1) << 7) |
((rmif_control1.little_endian & 0x1) << 6) |
((rmif_control1.y_rev & 0x1) << 5) |
((rmif_control1.x_rev & 0x1) << 4) |
((rmif_control1.pack_mode & 0x3) << 0);
return write_vicp_reg(afbce_reg.afbce_mmu_rmif_ctrl1, value);
}
void set_afbce_mmu_rmif_control2(struct vicp_afbce_mmu_rmif_control2_reg_s rmif_control2)
{
u32 value = 0;
value = ((rmif_control2.sw_rst & 0x3) << 30) |
((rmif_control2.int_clr & 0x3) << 20) |
((rmif_control2.gclk_ctrl & 0x3) << 18) |
((rmif_control2.urgent_ctrl & 0x1ffff) << 0);
return write_vicp_reg(afbce_reg.afbce_mmu_rmif_ctrl2, value);
}
void set_afbce_mmu_rmif_control3(struct vicp_afbce_mmu_rmif_control3_reg_s rmif_control3)
{
u32 value = 0;
value = ((rmif_control3.vstep & 0xf) << 20) |
((rmif_control3.acc_mode & 0x1) << 16) |
((rmif_control3.stride & 0x1fff) << 0);
return write_vicp_reg(afbce_reg.afbce_mmu_rmif_ctrl3, value);
}
void set_afbce_mmu_rmif_control4(u64 baddr)
{
return write_vicp_reg(afbce_reg.afbce_mmu_rmif_ctrl4, (baddr >> 4));
}
void set_afbce_pip_control(struct vicp_afbce_pip_control_reg_s pip_control)
{
u32 value = 0;
value = ((pip_control.enc_align_en & 0x1) << 2) |
((pip_control.pip_ini_ctrl & 0x1) << 1) |
((pip_control.pip_mode & 0x1) << 0);
return write_vicp_reg(afbce_reg.afbce_pip_ctrl, value);
}
void set_afbce_rotation_control(u32 rotation_en, u32 step_v)
{
u32 value = 0;
value = ((rotation_en & 0x1) << 4) | ((step_v & 0xf) << 0);
return write_vicp_reg(afbce_reg.afbce_rot_ctrl, value);
}
void set_afbce_enable(struct vicp_afbce_enable_reg_s enable_reg)
{
u32 value = 0;
value = ((enable_reg.gclk_ctrl & 0xfff) << 20) |
((enable_reg.afbce_sync_sel & 0xf) << 16) |
((enable_reg.enc_rst_mode & 0x1) << 13) |
((enable_reg.enc_en_mode & 0x1) << 12) |
((enable_reg.enc_enable & 0x1) << 8) |
((enable_reg.pls_enc_frm_start & 0x1) << 0);
return write_vicp_reg(afbce_reg.afbce_enable, value);
}
void set_afbce_start(u32 is_start)
{
return write_vicp_reg_bits(afbce_reg.afbce_enable, is_start, 0, 1);
}
void set_wrmif_path_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_WR_PATH_CTRL, is_enable, 0, 1);
}
void set_wrmif_shrk_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_WRMIF_SHRK_CTRL, is_enable, 0, 1);
}
void set_wrmif_shrk_size(u32 size)
{
return write_vicp_reg_bits(VID_CMPR_WRMIF_SHRK_SIZE, size, 0, 26);
}
void set_wrmif_shrk_mode_h(u32 mode)
{
return write_vicp_reg_bits(VID_CMPR_WRMIF_SHRK_CTRL, mode, 6, 2);
}
void set_wrmif_shrk_mode_v(u32 mode)
{
return write_vicp_reg_bits(VID_CMPR_WRMIF_SHRK_CTRL, mode, 8, 2);
}
void set_wrmif_base_addr(u32 index, u64 addr)
{
if (index == 0)
return write_vicp_reg(VID_CMPR_WRMIF_BADDR0, (addr >> 4));
else
return write_vicp_reg(VID_CMPR_WRMIF_BADDR1, (addr >> 4));
}
void set_wrmif_stride(u32 is_y, u32 value)
{
if (is_y == 1)
return write_vicp_reg(VID_CMPR_WRMIF_STRIDE0, value);
else
return write_vicp_reg(VID_CMPR_WRMIF_STRIDE1, value);
}
void set_wrmif_range(u32 is_x, u32 rev, u32 start, u32 end)
{
u32 value = 0, reg = 0;
value = (rev << 30) | (start << 16) | (end << 0);
if (is_x == 1)
reg = VID_CMPR_WRMIF_X;
else
reg = VID_CMPR_WRMIF_Y;
return write_vicp_reg(reg, value);
}
void set_wrmif_control(struct vicp_wrmif_control_s wrmif_control)
{
u32 value = 0;
value = ((wrmif_control.swap_64bits_en & 0x1) << 30) |
((wrmif_control.burst_limit & 0xf) << 26) |
((wrmif_control.canvas_sync_en & 0x1) << 25) |
((wrmif_control.gate_clock_en & 0x1) << 24) |
((wrmif_control.rgb_mode & 0x3) << 22) |
((wrmif_control.h_conv & 0x3) << 20) |
((wrmif_control.v_conv & 0x3) << 18) |
((wrmif_control.swap_cbcr & 0x1) << 17) |
((wrmif_control.urgent & 0x1) << 16) |
((wrmif_control.word_limit & 0xf) << 4) |
((wrmif_control.data_ext_ena & 0x1) << 3) |
((wrmif_control.little_endian & 0x1) << 2) |
((wrmif_control.bit10_mode & 0x1) << 1) |
((wrmif_control.wrmif_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_WRMIF_CTRL, value);
}
void set_crop_enable(u32 is_enable)
{
return write_vicp_reg_bits(VID_CMPR_CROP_CTRL, is_enable, 31, 1);
}
void set_crop_holdline(u32 hold_line)
{
return write_vicp_reg_bits(VID_CMPR_CROP_CTRL, hold_line, 0, 4);
}
void set_crop_dimm(u32 dimm_layer_en, u32 dimm_data)
{
u32 value = 0;
value = ((dimm_layer_en & 0x1) << 31) | ((dimm_data & 0x3fffffff) << 0);
return write_vicp_reg(VID_CMPR_CROP_DIMM_CTRL, value);
}
void set_crop_size_in(u32 size_h, u32 size_v)
{
u32 value = 0;
value = ((size_h & 0x1fff) << 16) | ((size_v & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_CROP_SIZE_IN, value);
}
void set_crop_scope_h(u32 begain, u32 end)
{
u32 value = 0;
value = ((end & 0x1fff) << 16) | ((begain & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_CROP_HSCOPE, value);
}
void set_crop_scope_v(u32 begain, u32 end)
{
u32 value = 0;
value = ((end & 0x1fff) << 16) | ((begain & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_CROP_VSCOPE, value);
}
void set_top_holdline(void)
{
write_vicp_reg_bits(afbce_reg.afbce_mode, 0x5, 16, 7);
write_vicp_reg_bits(VID_CMPR_HOLD_LINE, 0x5, 0, 16);
}
void set_pre_scaler_control(struct vicp_pre_scaler_ctrl_reg_s pre_scaler_ctrl_reg)
{
u32 value = 0;
value = ((pre_scaler_ctrl_reg.preh_hb_num & 0xf) << 25) |
((pre_scaler_ctrl_reg.preh_vb_num & 0xf) << 21) |
((pre_scaler_ctrl_reg.sc_coef_s11_mode & 0x1) << 20) |
((pre_scaler_ctrl_reg.vsc_nor_rs_bits & 0xf) << 16) |
((pre_scaler_ctrl_reg.hsc_nor_rs_bits & 0xf) << 12) |
((pre_scaler_ctrl_reg.prehsc_flt_num & 0xf) << 8) |
((pre_scaler_ctrl_reg.prevsc_flt_num & 0xf) << 4) |
((pre_scaler_ctrl_reg.prehsc_rate & 0x3) << 2) |
((pre_scaler_ctrl_reg.prevsc_rate & 0x3) << 0);
return write_vicp_reg(VID_CMPR_PRE_SCALE_CTRL, value);
}
void set_scaler_coef_param(u32 coef_index)
{
u32 i = 0;
if (coef_index == 0) {
write_vicp_reg(VID_CMPR_SCALE_COEF_IDX, 0x0100);
for (i = 0; i < 33; i++)
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8[i][0] & 0xff) << 24) |
((pps_lut_tap8[i][1] & 0xff) << 16) |
((pps_lut_tap8[i][2] & 0xff) << 8) |
((pps_lut_tap8[i][3] & 0xff) << 0)
);
write_vicp_reg(VID_CMPR_SCALE_COEF_IDX, 0x0180);
for (i = 0; i < 33; i++)
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8[i][4] & 0xff) << 24) |
((pps_lut_tap8[i][5] & 0xff) << 16) |
((pps_lut_tap8[i][6] & 0xff) << 8) |
((pps_lut_tap8[i][7] & 0xff) << 0)
);
} else {
write_vicp_reg(VID_CMPR_SCALE_COEF_IDX, 0x0000);
for (i = 0; i < 33; i++) {
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap4_s11[i][0] & 0x7ff) << 16) |
((pps_lut_tap4_s11[i][1] & 0x7ff) << 0)
);
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap4_s11[i][2] & 0x7ff) << 16) |
((pps_lut_tap4_s11[i][3] & 0x7ff) << 0)
);
}
write_vicp_reg(VID_CMPR_SCALE_COEF_IDX, 0x0100);
for (i = 0; i < 33; i++) {
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8_s11[i][0] & 0x7ff) << 16) |
((pps_lut_tap8_s11[i][1] & 0x7ff) << 0)
);
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8_s11[i][2] & 0x7ff) << 16) |
((pps_lut_tap8_s11[i][3] & 0x7ff) << 0)
);
}
write_vicp_reg(VID_CMPR_SCALE_COEF_IDX, 0x0180);
for (i = 0; i < 33; i++) {
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8_s11[i][4] & 0x7ff) << 16) |
((pps_lut_tap8_s11[i][5] & 0x7ff) << 0)
);
write_vicp_reg(VID_CMPR_SCALE_COEF,
((pps_lut_tap8_s11[i][6] & 0x7ff) << 16) |
((pps_lut_tap8_s11[i][7] & 0x7ff) << 0)
);
}
}
}
void set_vsc_region12_start(u32 region1_start, u32 region2_start)
{
u32 value = 0;
value = ((region1_start & 0x1fff) << 16) | ((region2_start & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_VSC_REGION12_STARTP, value);
}
void set_vsc_region34_start(u32 region3_start, u32 region4_start)
{
u32 value = 0;
value = ((region3_start & 0x1fff) << 16) | ((region4_start & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_VSC_REGION34_STARTP, value);
}
void set_vsc_region4_end(u32 region4_end)
{
return write_vicp_reg(VID_CMPR_VSC_REGION4_ENDP, ((region4_end & 0x1fff) << 0));
}
void set_vsc_start_phase_step(u32 step)
{
return write_vicp_reg(VID_CMPR_VSC_START_PHASE_STEP, step);
}
void set_vsc_region_phase_slope(u32 region_num, u32 slop_val)
{
if (region_num == 0)
return write_vicp_reg(VID_CMPR_VSC_REGION0_PHASE_SLOPE, slop_val);
else if (region_num == 1)
return write_vicp_reg(VID_CMPR_VSC_REGION1_PHASE_SLOPE, slop_val);
else if (region_num == 3)
return write_vicp_reg(VID_CMPR_VSC_REGION3_PHASE_SLOPE, slop_val);
else if (region_num == 4)
return write_vicp_reg(VID_CMPR_VSC_REGION4_PHASE_SLOPE, slop_val);
}
void set_vsc_phase_control(struct vicp_vsc_phase_ctrl_reg_s vsc_phase_ctrl_reg)
{
u32 value = 0;
value = ((vsc_phase_ctrl_reg.double_line_mode & 0x3) << 17) |
((vsc_phase_ctrl_reg.prog_interlace & 0x1) << 16) |
((vsc_phase_ctrl_reg.bot_l0_out_en & 0x1) << 15) |
((vsc_phase_ctrl_reg.bot_rpt_l0_num & 0x3) << 13) |
((vsc_phase_ctrl_reg.bot_ini_rcv_num & 0xf) << 8) |
((vsc_phase_ctrl_reg.top_l0_out_en & 0x1) << 7) |
((vsc_phase_ctrl_reg.top_rpt_l0_num & 0x3) << 5) |
((vsc_phase_ctrl_reg.top_ini_rcv_num & 0xf) << 0);
return write_vicp_reg(VID_CMPR_VSC_PHASE_CTRL, value);
}
void set_vsc_ini_phase(u32 bot_ini_phase, u32 top_ini_phase)
{
u32 value = 0;
value = ((bot_ini_phase & 0xffff) << 16) | ((top_ini_phase & 0xffff) << 0);
return write_vicp_reg(VID_CMPR_VSC_INI_PHASE, value);
}
void set_hsc_region12_start(u32 region1_start, u32 region2_start)
{
u32 value = 0;
value = ((region1_start & 0x1fff) << 16) | ((region2_start & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_HSC_REGION12_STARTP, value);
}
void set_hsc_region34_start(u32 region3_start, u32 region4_start)
{
u32 value = 0;
value = ((region3_start & 0x1fff) << 16) | ((region4_start & 0x1fff) << 0);
return write_vicp_reg(VID_CMPR_HSC_REGION34_STARTP, value);
}
void set_hsc_region4_end(u32 region4_end)
{
return write_vicp_reg(VID_CMPR_HSC_REGION4_ENDP, ((region4_end & 0x1fff) << 0));
}
void set_hsc_start_phase_step(u32 step)
{
return write_vicp_reg(VID_CMPR_HSC_START_PHASE_STEP, step);
}
void set_hsc_region_phase_slope(u32 region_num, u32 slop_val)
{
if (region_num == 0)
return write_vicp_reg(VID_CMPR_HSC_REGION0_PHASE_SLOPE, slop_val);
else if (region_num == 1)
return write_vicp_reg(VID_CMPR_HSC_REGION1_PHASE_SLOPE, slop_val);
else if (region_num == 3)
return write_vicp_reg(VID_CMPR_HSC_REGION3_PHASE_SLOPE, slop_val);
else if (region_num == 4)
return write_vicp_reg(VID_CMPR_HSC_REGION4_PHASE_SLOPE, slop_val);
}
void set_hsc_phase_control(struct vicp_hsc_phase_ctrl_reg_s hsc_phase_ctrl_reg)
{
u32 value = 0;
value = ((hsc_phase_ctrl_reg.ini_rcv_num0_exp & 0x7) << 24) |
((hsc_phase_ctrl_reg.rpt_p0_num0 & 0xf) << 20) |
((hsc_phase_ctrl_reg.ini_rcv_num0 & 0xf) << 16) |
((hsc_phase_ctrl_reg.ini_phase0 & 0xffff) << 0);
return write_vicp_reg(VID_CMPR_HSC_PHASE_CTRL, value);
}
void set_scaler_misc(struct vicp_scaler_misc_reg_s scaler_misc_reg)
{
u32 value = 0;
value = ((scaler_misc_reg.sc_din_mode & 0x1) << 27) |
((scaler_misc_reg.reg_l0_out_fix & 0x1) << 26) |
((scaler_misc_reg.hf_sep_coef_4srnet_en & 0x1) << 25) |
((scaler_misc_reg.repeat_last_line_en & 0x1) << 24) |
((scaler_misc_reg.old_prehsc_en & 0x1) << 23) |
((scaler_misc_reg.hsc_len_div2_en & 0x1) << 22) |
((scaler_misc_reg.prevsc_lbuf_mode & 0x1) << 21) |
((scaler_misc_reg.prehsc_en & 0x1) << 20) |
((scaler_misc_reg.prevsc_en & 0x1) << 19) |
((scaler_misc_reg.vsc_en & 0x1) << 18) |
((scaler_misc_reg.hsc_en & 0x1) << 17) |
((scaler_misc_reg.sc_top_en & 0x1) << 16) |
((scaler_misc_reg.sc_vd_en & 0x1) << 15) |
((scaler_misc_reg.hsc_nonlinear_4region_en & 0x1) << 12) |
((scaler_misc_reg.hsc_bank_length & 0xf) << 8) |
((scaler_misc_reg.vsc_phase_field_mode & 0x1) << 5) |
((scaler_misc_reg.vsc_nonlinear_4region_en & 0x1) << 4) |
((scaler_misc_reg.vsc_bank_length & 0x7) << 0);
return write_vicp_reg(VID_CMPR_SC_MISC, value);
}
void set_security_enable(u32 dma_en, u32 mmu_en, u32 input_en)
{
u32 value = 0;
value = ((dma_en & 0x1) << 2) |
((mmu_en & 0x1) << 1) |
((input_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_SEC_CTRL, value);
}
void set_fgrain_control(struct vicp_fgrain_ctrl_reg_s fgrain_ctrl_reg)
{
u32 value = 0;
value = ((fgrain_ctrl_reg.sync_ctrl & 0x3) << 24) |
((fgrain_ctrl_reg.dma_st_clr & 0x1) << 22) |
((fgrain_ctrl_reg.hold4dma_scale & 0x1) << 21) |
((fgrain_ctrl_reg.hold4dma_tbl & 0x1) << 20) |
((fgrain_ctrl_reg.cin_uv_swap & 0x1) << 19) |
((fgrain_ctrl_reg.cin_rev & 0x1) << 18) |
((fgrain_ctrl_reg.yin_rev & 0x1) << 17) |
((fgrain_ctrl_reg.fgrain_ext_imode & 0x1) << 16) |
((fgrain_ctrl_reg.use_par_apply_fgrain & 0x1) << 15) |
((fgrain_ctrl_reg.fgrain_last_ln_mode & 0x1) << 14) |
((fgrain_ctrl_reg.fgrain_use_sat4bp & 0x1) << 13) |
((fgrain_ctrl_reg.apply_c_mode & 0x1) << 12) |
((fgrain_ctrl_reg.fgrain_tbl_sign_mode & 0x1) << 11) |
((fgrain_ctrl_reg.fgrain_tbl_ext_mode & 0x1) << 10) |
((fgrain_ctrl_reg.fmt_mode & 0x3) << 8) |
((fgrain_ctrl_reg.comp_bits & 0x3) << 6) |
((fgrain_ctrl_reg.rev_mode & 0x3) << 4) |
((fgrain_ctrl_reg.block_mode & 0x1) << 2) |
((fgrain_ctrl_reg.fgrain_loc_en & 0x1) << 1) |
((fgrain_ctrl_reg.fgrain_glb_en & 0x1) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_FGRAIN_CTRL, value);
}
void set_fgrain_window_h(u32 begain, u32 end)
{
u32 value = 0;
value = ((end & 0xffff) << 16) | ((begain & 0xffff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_FGRAIN_WIN_H, value);
}
void set_fgrain_window_v(u32 begain, u32 end)
{
u32 value = 0;
value = ((end & 0xffff) << 16) | ((begain & 0xffff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_FGRAIN_WIN_V, value);
}
void set_fgrain_slice_window_h(u32 begain, u32 end)
{
u32 value = 0;
value = ((end & 0xffff) << 16) | ((begain & 0xffff) << 0);
return write_vicp_reg(VID_CMPR_AFBCDM_FGRAIN_SLICE_WIN_H, value);
}
void set_fgrain_lut_data(u32 val)
{
return write_vicp_reg(VID_CMPR_FGRAIN_LUT_DATA, val);
}
int read_vicp_reg(u32 reg)
{
return vicp_reg_read(reg);
}
void write_vicp_reg(u32 reg, u32 val)
{
struct rdma_buf_type_s *buf = NULL;
vicp_print(VICP_DUMP_REG, "%s: set reg 0x%04x with 0x%08x\n", __func__, reg, val);
if (rdma_enable_flag) {
buf = get_current_vicp_rdma_buf();
vicp_rdma_wr(buf, (u64)reg, (u64)val, 0, 32);
return;
} else {
return vicp_reg_write(reg, val);
}
}
void write_vicp_reg_bits(u32 reg, const u32 value, const u32 start, const u32 len)
{
struct rdma_buf_type_s *buf = NULL;
vicp_print(VICP_DUMP_REG, "%s: set reg 0x%04x from %d to %d bit with 0x%08x\n",
__func__, reg, start, (start + len - 1), value);
if (rdma_enable_flag) {
buf = get_current_vicp_rdma_buf();
vicp_rdma_wr(buf, (u64)reg, value, (u64)start, (u64)len);
return;
} else {
return vicp_reg_set_bits(reg, value, start, len);
}
}