Files
vi-kernel/vvcam/isp/isp_ioctl.c
2022-09-13 10:34:22 +08:00

3689 lines
116 KiB
C
Executable File

/****************************************************************************
*
* The MIT License (MIT)
*
* Copyright (c) 2020 VeriSilicon Holdings Co., Ltd.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*
*****************************************************************************
*
* The GPL License (GPL)
*
* Copyright (c) 2020 VeriSilicon Holdings Co., Ltd.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program;
*
*****************************************************************************
*
* Note: This software is released under dual MIT and GPL licenses. A
* recipient may use this file under the terms of either the MIT license or
* GPL License. If you wish to use only one license not the other, you can
* indicate your decision by deleting one of the above license notices in your
* version of this file.
*
*****************************************************************************/
/* process public and sample isp command. for complex modules, need new files.*/
#include "mrv_all_bits.h"
#include "isp_ioctl.h"
#include "isp_types.h"
#include "isp_wdr.h"
#include <linux/dma-mapping.h>
#include <linux/dma-buf.h>
#ifdef __KERNEL__
#include <linux/regmap.h>
#include <linux/of_reserved_mem.h>
#endif
#ifdef CONFIG_VSI_ISP_DEBUG
#define isp_info(fmt, ...) pr_info(fmt, ##__VA_ARGS__)
#define isp_debug(fmt, ...) pr_debug(fmt, ##__VA_ARGS__)
#define isp_err(fmt, ...) pr_err(fmt, ##__VA_ARGS__)
#else
#define isp_info(fmt, ...)
#define isp_debug(fmt, ...)
#define isp_err(fmt, ...) pr_err(fmt, ##__VA_ARGS__)
#endif
volatile MrvAllRegister_t *all_regs = NULL;
#ifndef __KERNEL__
#define ISP_REG_SIZE 0x10000
static HalHandle_t hal_handle;
void isp_ic_set_hal(HalHandle_t hal)
{
hal_handle = hal;
}
void isp_write_reg(struct isp_ic_dev *dev, u32 offset, u32 val)
{
//pr_info("%s addr 0x%08x val 0x%08x\n", __func__, offset, val);
if (offset >= ISP_REG_SIZE)
return;
HalWriteReg(hal_handle, offset, val);
}
u32 isp_read_reg(struct isp_ic_dev *dev, u32 offset)
{
if (offset >= ISP_REG_SIZE)
return 0;
return HalReadReg(hal_handle, offset);
}
long isp_copy_data(void *dst, void *src, int size)
{
if (dst != src)
memcpy(dst, src, size);
return 0;
}
#else
void isp_write_reg(struct isp_ic_dev *dev, u32 offset, u32 val)
{
// isp_info("%s addr 0x%08x val 0x%08x\n", __func__, offset, val);
if (offset >= ISP_REG_SIZE)
return;
__raw_writel(val, dev->base + offset);
/*isp_info("%s addr 0x%08x val 0x%08x\n", __func__, offset, val);*/
}
u32 isp_read_reg(struct isp_ic_dev *dev, u32 offset)
{
u32 val = 0;
if (offset >= ISP_REG_SIZE)
return 0;
val = __raw_readl(dev->base + offset);
/*isp_info("%s addr 0x%08x val 0x%08x\n", __func__, offset, val);*/
return val;
}
#endif
int isp_reset(struct isp_ic_dev *dev)
{
isp_info("enter %s\n", __func__);
isp_write_reg(dev, REG_ADDR(vi_ircl), 0xFFFFFFBF);
#ifdef __KERNEL__
mdelay(2);
#endif
isp_write_reg(dev, REG_ADDR(vi_ircl), 0x0);
/*clear mis array*/
isp_write_reg(dev, REG_ADDR(isp_ctrl), 0x0); //clear isp_ctrl disable_isp_clk
isp_info("exit %s\n", __func__);
return 0;
}
int isp_enable_tpg(struct isp_ic_dev *dev)
{
u32 addr, isp_tpg_ctrl;
isp_info("enter %s\n", __func__);
addr = REG_ADDR(isp_tpg_ctrl);
isp_tpg_ctrl = isp_read_reg(dev, addr);
//REG_SET_SLICE(isp_tpg_ctrl, TPG_FRAME_NUM, 1);//set tpg frame num
REG_SET_SLICE(isp_tpg_ctrl, TPG_ENABLE, 1);
isp_write_reg(dev, addr, isp_tpg_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_disable_tpg(struct isp_ic_dev *dev)
{
u32 addr, isp_tpg_ctrl;
isp_info("enter %s\n", __func__);
addr = REG_ADDR(isp_tpg_ctrl);
isp_tpg_ctrl = isp_read_reg(dev, addr);
REG_SET_SLICE(isp_tpg_ctrl, TPG_ENABLE, 0);
isp_write_reg(dev, addr, isp_tpg_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_enable_bls(struct isp_ic_dev *dev)
{
#ifndef ISP_BLS
//isp_err("unsupported function %s", __func__);
return -1;
#else
u32 isp_bls_ctrl = isp_read_reg(dev, REG_ADDR(isp_bls_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_bls_ctrl, MRV_BLS_BLS_ENABLE,
MRV_BLS_BLS_ENABLE_PROCESS);
isp_write_reg(dev, REG_ADDR(isp_bls_ctrl), isp_bls_ctrl);
isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_disable_bls(struct isp_ic_dev *dev)
{
#ifndef ISP_BLS
//isp_err("unsupported function %s", __func__);
return -1;
#else
u32 isp_bls_ctrl = isp_read_reg(dev, REG_ADDR(isp_bls_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_bls_ctrl, MRV_BLS_BLS_ENABLE,
MRV_BLS_BLS_ENABLE_BYPASS);
isp_write_reg(dev, REG_ADDR(isp_bls_ctrl), isp_bls_ctrl);
isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_enable(struct isp_ic_dev *dev)
{
u32 isp_ctrl, isp_imsc;
isp_info("enter %s\n", __func__);
isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_imsc |= (MRV_ISP_IMSC_ISP_OFF_MASK | MRV_ISP_IMSC_FRAME_MASK);
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_INFORM_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
/*Set lsc tbl after isp enable*/
if (dev->update_lsc_tbl) {
isp_s_lsc_tbl(dev);
dev->update_lsc_tbl = false;
}
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_disable(struct isp_ic_dev *dev)
{
u32 isp_ctrl;
/* #ifndef ENABLE_IRQ
u32 isp_imsc;
#endif*/
isp_info("enter %s\n", __func__);
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
/* #ifndef ENABLE_IRQ
isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_imsc |= (MRV_ISP_IMSC_ISP_OFF_MASK | MRV_ISP_IMSC_FRAME_MASK);
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
#endif*/
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_INFORM_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GEN_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_write_reg(dev, REG_ADDR(isp_isr), MRV_ISP_ISR_ISP_OFF_MASK);
isp_info("exit %s\n", __func__);
return 0;
}
bool is_isp_enable(struct isp_ic_dev *dev)
{
// isp_info("enter %s\n", __func__);
return isp_read_reg(dev, REG_ADDR(isp_ctrl)) & 0x01;
}
int isp_enable_lsc(struct isp_ic_dev *dev)
{
u32 isp_lsc_ctrl = isp_read_reg(dev, REG_ADDR(isp_lsc_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_lsc_ctrl, MRV_LSC_LSC_EN, 1U);
isp_write_reg(dev, REG_ADDR(isp_lsc_ctrl), isp_lsc_ctrl);
{
uint32_t isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GEN_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
}
isp_info("exit %s\n", __func__);
return 0;
}
int isp_disable_lsc(struct isp_ic_dev *dev)
{
u32 isp_lsc_ctrl = isp_read_reg(dev, REG_ADDR(isp_lsc_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_lsc_ctrl, MRV_LSC_LSC_EN, 0U);
isp_write_reg(dev, REG_ADDR(isp_lsc_ctrl), isp_lsc_ctrl);
{
uint32_t isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GEN_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
}
isp_info("exit %s\n", __func__);
return 0;
}
#if defined(__KERNEL__) && defined(ISP8000NANO_V1802)
static int isp_gpr_input_control(struct isp_ic_dev *dev)
{
struct isp_context isp_ctx = *(&dev->ctx);
unsigned int fmt_offset = 3;
unsigned int isp_dewarp_control_val;
if (dev->mix_gpr == NULL)
return -ENOMEM;
if (dev->id == 0)
fmt_offset = 3;
else
fmt_offset = 13;
regmap_read(dev->mix_gpr, 0x138, &isp_dewarp_control_val);
if (isp_dewarp_control_val == 0)
isp_dewarp_control_val = 0x8d8360;
switch (isp_ctx.input_selection) {
case MRV_ISP_INPUT_SELECTION_12EXT:
isp_dewarp_control_val &= ~(0x3f << fmt_offset);
isp_dewarp_control_val |= (0x2c << fmt_offset);
break;
case MRV_ISP_INPUT_SELECTION_10ZERO:
case MRV_ISP_INPUT_SELECTION_10MSB:
isp_dewarp_control_val &= ~(0x3f << fmt_offset);
isp_dewarp_control_val |= (0x2b << fmt_offset);
break;
case MRV_ISP_INPUT_SELECTION_8ZERO:
case MRV_ISP_INPUT_SELECTION_8MSB:
isp_dewarp_control_val &= ~(0x3f << fmt_offset);
isp_dewarp_control_val |= (0x2a << fmt_offset);
break;
default:
return 0;
}
regmap_write(dev->mix_gpr, 0x138, isp_dewarp_control_val);
return 0;
}
#endif
int isp_s_input(struct isp_ic_dev *dev)
{
struct isp_context isp_ctx = *(&dev->ctx);
u32 isp_ctrl, isp_acq_prop, isp_demosaic;
#ifdef ISP_HDR_STITCH
u32 isp_stitching_ctrl;
#endif //ISP_HDR_STITCH
isp_info("enter %s\n", __func__);
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_MODE, isp_ctx.mode);
isp_acq_prop = isp_read_reg(dev, REG_ADDR(isp_acq_prop));
REG_SET_SLICE(isp_acq_prop, MRV_ISP_SAMPLE_EDGE, isp_ctx.sample_edge);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_HSYNC_POL,
isp_ctx.hSyncLowPolarity);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_VSYNC_POL,
isp_ctx.vSyncLowPolarity);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_BAYER_PAT, isp_ctx.bayer_pattern);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_CONV_422, isp_ctx.sub_sampling);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_CCIR_SEQ, isp_ctx.seq_ccir);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_FIELD_SELECTION,
isp_ctx.field_selection);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_INPUT_SELECTION,
isp_ctx.input_selection);
REG_SET_SLICE(isp_acq_prop, MRV_ISP_LATENCY_FIFO_SELECTION,
isp_ctx.latency_fifo);
isp_write_reg(dev, REG_ADDR(isp_acq_prop), isp_acq_prop);
isp_write_reg(dev, REG_ADDR(isp_acq_h_offs), isp_ctx.acqWindow.x);
isp_write_reg(dev, REG_ADDR(isp_acq_v_offs), isp_ctx.acqWindow.y);
isp_write_reg(dev, REG_ADDR(isp_acq_h_size), isp_ctx.acqWindow.width);
isp_write_reg(dev, REG_ADDR(isp_acq_v_size), isp_ctx.acqWindow.height);
#ifdef ISP_MI_HDR
isp_write_reg(dev, REG_ADDR(isp_hdr_interval), 0x113);
isp_write_reg(dev, REG_ADDR(isp_hdr_ret_h_blank), 0x200);
isp_write_reg(dev, REG_ADDR(isp_hdr_ret_v_blank), 0x30);
isp_write_reg(dev, REG_ADDR(isp_hdr_ret_h_size), isp_ctx.acqWindow.width);
isp_write_reg(dev, REG_ADDR(isp_hdr_ret_v_size), isp_ctx.acqWindow.height);
#endif
isp_write_reg(dev, REG_ADDR(isp_out_h_offs),
(isp_ctx.ofWindow.x & MRV_ISP_ISP_OUT_H_OFFS_MASK));
isp_write_reg(dev, REG_ADDR(isp_out_v_offs),
(isp_ctx.ofWindow.y & MRV_ISP_ISP_OUT_V_OFFS_MASK));
isp_write_reg(dev, REG_ADDR(isp_out_h_size),
(isp_ctx.ofWindow.width & MRV_ISP_ISP_OUT_H_SIZE_MASK));
isp_write_reg(dev, REG_ADDR(isp_out_v_size),
(isp_ctx.ofWindow.height & MRV_ISP_ISP_OUT_V_SIZE_MASK));
isp_write_reg(dev, REG_ADDR(isp_is_h_offs),
(isp_ctx.isWindow.x & MRV_IS_IS_H_OFFS_MASK));
isp_write_reg(dev, REG_ADDR(isp_is_v_offs),
(isp_ctx.isWindow.y & MRV_IS_IS_V_OFFS_MASK));
isp_write_reg(dev, REG_ADDR(isp_is_h_size),
(isp_ctx.isWindow.width & MRV_IS_IS_H_SIZE_MASK));
isp_write_reg(dev, REG_ADDR(isp_is_v_size),
(isp_ctx.isWindow.height & MRV_IS_IS_V_SIZE_MASK));
isp_demosaic = isp_read_reg(dev, REG_ADDR(isp_demosaic));
REG_SET_SLICE(isp_demosaic, MRV_ISP_DEMOSAIC_BYPASS,
isp_ctx.bypass_mode);
REG_SET_SLICE(isp_demosaic, MRV_ISP_DEMOSAIC_TH,
isp_ctx.demosaic_threshold);
isp_write_reg(dev, REG_ADDR(isp_demosaic), isp_demosaic);
#ifdef ISP_HDR_STITCH
isp_write_reg(dev, REG_ADDR(isp_stitching_frame_width), isp_ctx.acqWindow.width);
isp_write_reg(dev, REG_ADDR(isp_stitching_frame_height), isp_ctx.acqWindow.height);
isp_write_reg(dev, REG_ADDR(isp_stitching_hdr_mode), isp_ctx.stitching_mode);
isp_stitching_ctrl = isp_read_reg(dev, REG_ADDR(isp_stitching_ctrl));
REG_SET_SLICE(isp_stitching_ctrl, STITCHING_BAYER_PATTERN, isp_ctx.bayer_pattern);
isp_write_reg(dev, REG_ADDR(isp_stitching_ctrl), isp_stitching_ctrl);
#endif
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
#if defined(__KERNEL__) && defined(ISP8000NANO_V1802)
isp_gpr_input_control(dev);
#endif
return 0;
}
int isp_s_digital_gain(struct isp_ic_dev *dev)
{
struct isp_digital_gain_cxt dgain = *(&dev->dgain);
u32 isp_dgain_rb = isp_read_reg(dev, REG_ADDR(isp_dgain_rb));
u32 isp_dgain_g = isp_read_reg(dev, REG_ADDR(isp_dgain_g));
u32 isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
if (!dgain.enable) {
isp_err("%s, Disable isp digital gain", __func__);
REG_SET_SLICE(isp_ctrl, MRV_ISP_DIGITAL_GAIN_EN, 0U);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
return 0;
}
//isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_dgain_rb, ISP_DIGITAL_GAIN_R, dgain.gain_r);
REG_SET_SLICE(isp_dgain_rb, ISP_DIGITAL_GAIN_B, dgain.gain_b);
REG_SET_SLICE(isp_dgain_g, ISP_DIGITAL_GAIN_GR, dgain.gain_gr);
REG_SET_SLICE(isp_dgain_g, ISP_DIGITAL_GAIN_GB, dgain.gain_gb);
REG_SET_SLICE(isp_ctrl, MRV_ISP_DIGITAL_GAIN_EN, 1U);
isp_write_reg(dev, REG_ADDR(isp_dgain_rb), isp_dgain_rb);
isp_write_reg(dev, REG_ADDR(isp_dgain_g), isp_dgain_g);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
//isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_demosaic(struct isp_ic_dev *dev)
{
struct isp_context isp_ctx = *(&dev->ctx);
u32 isp_demosaic;
isp_info("enter %s\n", __func__);
isp_demosaic = isp_read_reg(dev, REG_ADDR(isp_demosaic));
REG_SET_SLICE(isp_demosaic, MRV_ISP_DEMOSAIC_BYPASS,
isp_ctx.bypass_mode);
REG_SET_SLICE(isp_demosaic, MRV_ISP_DEMOSAIC_TH,
isp_ctx.demosaic_threshold);
isp_write_reg(dev, REG_ADDR(isp_demosaic), isp_demosaic);
isp_info("exit %s\n", __func__);
return 0;;
}
int isp_s_tpg(struct isp_ic_dev *dev)
{
struct isp_tpg_context tpg = *(&dev->tpg);
u32 addr, regVal;
isp_info("enter %s\n", __func__);
addr = REG_ADDR(isp_tpg_ctrl);
regVal = isp_read_reg(dev, addr);
REG_SET_SLICE(regVal, TPG_IMG_NUM, tpg.image_type);
REG_SET_SLICE(regVal, TPG_CFA_PAT, tpg.bayer_pattern);
REG_SET_SLICE(regVal, TPG_COLOR_DEPTH, tpg.color_depth);
REG_SET_SLICE(regVal, TPG_RESOLUTION, tpg.resolution);
REG_SET_SLICE(regVal, TPG_FRAME_NUM, tpg.frame_num);
isp_write_reg(dev, addr, regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_PIX_GAP_IN, tpg.pixleGap);
REG_SET_SLICE(regVal, TPG_LINE_GAP_IN, tpg.lineGap);
isp_write_reg(dev, REG_ADDR(isp_tpg_gap_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_PIX_GAP_STD_IN, tpg.gapStandard);
isp_write_reg(dev, REG_ADDR(isp_tpg_gap_std_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_RANDOM_SEED, tpg.randomSeed);
isp_write_reg(dev, REG_ADDR(isp_tpg_random_seed), regVal);
REG_SET_SLICE(regVal, TPG_HTOTAL_IN, tpg.user_mode_h.total);
REG_SET_SLICE(regVal, TPG_VTOTAL_IN, tpg.user_mode_v.total);
isp_write_reg(dev, REG_ADDR(isp_tpg_total_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_HACT_IN, tpg.user_mode_h.act);
REG_SET_SLICE(regVal, TPG_VACT_IN, tpg.user_mode_v.act);
isp_write_reg(dev, REG_ADDR(isp_tpg_act_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_FP_H_IN, tpg.user_mode_h.fp);
REG_SET_SLICE(regVal, TPG_FP_V_IN, tpg.user_mode_v.fp);
isp_write_reg(dev, REG_ADDR(isp_tpg_fp_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_BP_H_IN, tpg.user_mode_h.bp);
REG_SET_SLICE(regVal, TPG_BP_V_IN, tpg.user_mode_v.bp);
isp_write_reg(dev, REG_ADDR(isp_tpg_bp_in), regVal);
regVal = 0;
REG_SET_SLICE(regVal, TPG_HS_W_IN, tpg.user_mode_h.sync);
REG_SET_SLICE(regVal, TPG_VS_W_IN, tpg.user_mode_v.sync);
isp_write_reg(dev, REG_ADDR(isp_tpg_w_in), regVal);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_mcm_wr(struct isp_ic_dev *dev)
{
struct isp_mcm_context *mcm = &dev->mcm;
u32 mcm_ctrl;
u32 mcm_hsync_preample_ext;
u32 mcm_size, mcm_rd_fmt;
int i;
isp_info("enter %s\n", __func__);
mcm_ctrl = isp_read_reg(dev, REG_ADDR(mcm_ctrl));
mcm_rd_fmt = isp_read_reg(dev, REG_ADDR(mcm_rd_cfg));
mcm_hsync_preample_ext = isp_read_reg(dev, REG_ADDR(mcm_hsync_preample_ext));
REG_SET_SLICE(mcm_ctrl, MCM_BYPASS_SWITCH, mcm->bypass_switch);
REG_SET_SLICE(mcm_ctrl, MCM_WR0_FMT, mcm->wr_fmt[MCM_INDEX_WR0]);
REG_SET_SLICE(mcm_ctrl, MCM_WR1_FMT, mcm->wr_fmt[MCM_INDEX_WR1]);
REG_SET_SLICE(mcm_ctrl, MCM_G2_WR0_FMT, mcm->wr_fmt[MCM_INDEX_G2_WR0]);
REG_SET_SLICE(mcm_ctrl, MCM_G2_WR1_FMT, mcm->wr_fmt[MCM_INDEX_G2_WR1]);
REG_SET_SLICE(mcm_ctrl, MCM_SENSOR_MEM_BYPASS, mcm->sensor_mem_bypass);
REG_SET_SLICE(mcm_rd_fmt, MCM_RD_FMT, mcm->rd_fmt);
REG_SET_SLICE(mcm_hsync_preample_ext, MCM_HSYNC_PREAMPLE_EXT, mcm->hsync_rpeample_ext);
for (i = MCM_INDEX_WR0 ; i < MCM_INDEX_WR_MAX; i++){
REG_SET_SLICE(mcm_size, MCM_HEIGHT0, mcm->height[i]);
REG_SET_SLICE(mcm_size, MCM_WIDTH0, mcm->width[i]);
isp_write_reg(dev, REG_ADDR(mcm_size0) + i *4, mcm_size);
}
isp_write_reg(dev, REG_ADDR(mcm_hsync_preample_ext), mcm_hsync_preample_ext);
isp_write_reg(dev, REG_ADDR(mcm_rd_cfg), mcm_rd_fmt);
isp_write_reg(dev, REG_ADDR(mcm_ctrl), mcm_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_bypass_mcm(struct isp_ic_dev *dev)
{
struct isp_mcm_context *mcm = &dev->mcm;
u32 mcm_ctrl;
u32 mcm_retiming0;
u32 mcm_retiming1;
u32 mcm_wr_retiming0;
u32 mcm_wr_retiming1;
isp_info("enter %s\n", __func__);
mcm_ctrl = isp_read_reg(dev, REG_ADDR(mcm_ctrl));
mcm_retiming0 = isp_read_reg(dev, REG_ADDR(mcm_retiming0));
mcm_retiming1 = isp_read_reg(dev, REG_ADDR(mcm_retiming1));
mcm_wr_retiming0 = isp_read_reg(dev, REG_ADDR(mcm_wr_retiming0));
mcm_wr_retiming1 = isp_read_reg(dev, REG_ADDR(mcm_wr_retiming1));
if (mcm->bypass_enable) {
REG_SET_SLICE(mcm_ctrl, MCM_BYPASS_EN, 1);
} else {
REG_SET_SLICE(mcm_ctrl, MCM_BYPASS_EN, 0);
}
REG_SET_SLICE(mcm_retiming0, MCM_VSYNC_DURATION, mcm->vsync_duration);
REG_SET_SLICE(mcm_retiming0, MCM_VSYNC_BLANK, mcm->vsync_blank);
REG_SET_SLICE(mcm_retiming1, MCM_HSYNC_PREAMPLE, mcm->hsync_preample);
REG_SET_SLICE(mcm_retiming1, MCM_HSYNC_BLANK, mcm->hsync_blank);
REG_SET_SLICE(mcm_wr_retiming0, MCM_VSYNC_DURATION, mcm->vsync_duration);
REG_SET_SLICE(mcm_wr_retiming0, MCM_VSYNC_BLANK, mcm->vsync_blank);
REG_SET_SLICE(mcm_wr_retiming1, MCM_HSYNC_PREAMPLE, mcm->hsync_preample);
REG_SET_SLICE(mcm_wr_retiming1, MCM_HSYNC_BLANK, mcm->hsync_blank);
isp_write_reg(dev, REG_ADDR(mcm_ctrl), mcm_ctrl);
isp_write_reg(dev, REG_ADDR(mcm_retiming0), mcm_retiming0); // 0x01042801);//
isp_write_reg(dev, REG_ADDR(mcm_retiming1), mcm_retiming1); //0x00008478); //
isp_write_reg(dev, REG_ADDR(mcm_wr_retiming0), mcm_wr_retiming0); //0x01042801); //
isp_write_reg(dev, REG_ADDR(mcm_wr_retiming1), mcm_wr_retiming1); //0x000084ec);//
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_mux(struct isp_ic_dev *dev)
{
struct isp_mux_context mux = *(&dev->mux);
u32 vi_dpcl;
isp_info("enter %s\n", __func__);
vi_dpcl = isp_read_reg(dev, REG_ADDR(vi_dpcl));
REG_SET_SLICE(vi_dpcl, MRV_VI_MP_MUX, mux.mp_mux);
REG_SET_SLICE(vi_dpcl, MRV_VI_DMA_SPMUX, mux.sp_mux);
REG_SET_SLICE(vi_dpcl, MRV_VI_CHAN_MODE, mux.chan_mode);
REG_SET_SLICE(vi_dpcl, MRV_VI_DMA_IEMUX, mux.ie_mux);
REG_SET_SLICE(vi_dpcl, MRV_VI_DMA_SWITCH, mux.dma_read_switch);
REG_SET_SLICE(vi_dpcl, MRV_IF_SELECT, mux.if_select);
isp_write_reg(dev, REG_ADDR(vi_dpcl), vi_dpcl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_bls(struct isp_ic_dev *dev)
{
#ifndef ISP_BLS
//isp_err("unsupported function %s", __func__);
return -1;
#else
struct isp_bls_context bls = *(&dev->bls);
u32 isp_bls_ctrl = isp_read_reg(dev, REG_ADDR(isp_bls_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_bls_ctrl, MRV_BLS_BLS_MODE, bls.mode);
isp_write_reg(dev, REG_ADDR(isp_bls_ctrl), isp_bls_ctrl);
isp_write_reg(dev, REG_ADDR(isp_bls_a_fixed), bls.a);
isp_write_reg(dev, REG_ADDR(isp_bls_b_fixed), bls.b);
isp_write_reg(dev, REG_ADDR(isp_bls_c_fixed), bls.c);
isp_write_reg(dev, REG_ADDR(isp_bls_d_fixed), bls.d);
return 0;
#endif
}
int isp_enable_awb(struct isp_ic_dev *dev)
{
u32 isp_awb_prop = isp_read_reg(dev, REG_ADDR(isp_awb_prop));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MODE, MRV_ISP_AWB_MODE_MEAS);
isp_write_reg(dev, REG_ADDR(isp_awb_prop), isp_awb_prop);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_AWB_DONE_MASK);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_disable_awb(struct isp_ic_dev *dev)
{
u32 isp_awb_prop = isp_read_reg(dev, REG_ADDR(isp_awb_prop));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MODE, MRV_ISP_AWB_MODE_NOMEAS);
isp_write_reg(dev, REG_ADDR(isp_awb_prop), isp_awb_prop);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc & ~MRV_ISP_IMSC_AWB_DONE_MASK);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_awb(struct isp_ic_dev *dev)
{
struct isp_awb_context awb = *(&dev->awb);
u32 gain_data = 0;
u32 isp_awb_thresh = 0;
u32 isp_awb_ref = 0;
u32 isp_awb_prop = 0;
/* isp_info("enter %s\n", __func__); */
isp_awb_prop = isp_read_reg(dev, REG_ADDR(isp_awb_prop));
if (awb.mode == MRV_ISP_AWB_MEAS_MODE_YCBCR) {
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MEAS_MODE,
MRV_ISP_AWB_MEAS_MODE_YCBCR);
if (awb.max_y == 0) {
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MAX_EN,
MRV_ISP_AWB_MAX_EN_DISABLE);
} else {
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MAX_EN,
MRV_ISP_AWB_MAX_EN_ENABLE);
}
} else if (awb.mode == MRV_ISP_AWB_MEAS_MODE_RGB) {
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MAX_EN,
MRV_ISP_AWB_MAX_EN_DISABLE);
REG_SET_SLICE(isp_awb_prop, MRV_ISP_AWB_MEAS_MODE,
MRV_ISP_AWB_MEAS_MODE_RGB);
}
isp_write_reg(dev, REG_ADDR(isp_awb_prop), isp_awb_prop);
REG_SET_SLICE(isp_awb_thresh, MRV_ISP_AWB_MAX_Y, awb.max_y);
REG_SET_SLICE(isp_awb_thresh, MRV_ISP_AWB_MIN_Y__MAX_G,
awb.min_y_max_g);
REG_SET_SLICE(isp_awb_thresh, MRV_ISP_AWB_MAX_CSUM, awb.max_c_sum);
REG_SET_SLICE(isp_awb_thresh, MRV_ISP_AWB_MIN_C, awb.min_c);
isp_write_reg(dev, REG_ADDR(isp_awb_thresh), isp_awb_thresh);
REG_SET_SLICE(isp_awb_ref, MRV_ISP_AWB_REF_CR__MAX_R, awb.refcr_max_r);
REG_SET_SLICE(isp_awb_ref, MRV_ISP_AWB_REF_CB__MAX_B, awb.refcb_max_b);
isp_write_reg(dev, REG_ADDR(isp_awb_ref), isp_awb_ref);
isp_write_reg(dev, REG_ADDR(isp_awb_frames), 0);
isp_write_reg(dev, REG_ADDR(isp_awb_h_offs),
(MRV_ISP_AWB_H_OFFS_MASK & awb.window.x));
isp_write_reg(dev, REG_ADDR(isp_awb_v_offs),
(MRV_ISP_AWB_V_OFFS_MASK & awb.window.y));
isp_write_reg(dev, REG_ADDR(isp_awb_h_size),
(MRV_ISP_AWB_H_SIZE_MASK & awb.window.width));
isp_write_reg(dev, REG_ADDR(isp_awb_v_size),
(MRV_ISP_AWB_V_SIZE_MASK & awb.window.height));
gain_data = 0UL;
#ifdef ISP_AWB_0410 //This is Gain value component 4 bit int part and 10 bit fractional part
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_R, awb.gain_r << 2);
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_B, awb.gain_b << 2) ;
#else //This is Gain value component 2 bit int part and 8 bit fractional part
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_R, awb.gain_r);
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_B, awb.gain_b);
#endif
isp_write_reg(dev, REG_ADDR(isp_awb_gain_rb), gain_data);
gain_data = 0UL;
#ifdef ISP_AWB_0410 //This is Gain value component 4 bit int part and 10 bit fractional part
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_GR, awb.gain_gr << 2);
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_GB, awb.gain_gb << 2);
#else //This is Gain value component 2 bit int part and 8 bit fractional part
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_GR, awb.gain_gr);
REG_SET_SLICE(gain_data, MRV_ISP_AWB_GAIN_GB, awb.gain_gb);
#endif
isp_write_reg(dev, REG_ADDR(isp_awb_gain_g), gain_data);
return 0;
}
int isp_s_is(struct isp_ic_dev *dev)
{
struct isp_is_context is = *(&dev->is);
u32 isp_is_ctrl;
u32 isp_is_displace;
u32 isp_ctrl;
isp_info("enter %s\n", __func__);
isp_is_ctrl = isp_read_reg(dev, REG_ADDR(isp_is_ctrl));
if (!is.enable) {
REG_SET_SLICE(isp_is_ctrl, MRV_IS_IS_EN, 0);
isp_write_reg(dev, REG_ADDR(isp_is_ctrl), isp_is_ctrl);
return 0;
}
REG_SET_SLICE(isp_is_ctrl, MRV_IS_IS_EN, 1);
isp_write_reg(dev, REG_ADDR(isp_is_h_offs), is.window.x);
isp_write_reg(dev, REG_ADDR(isp_is_v_offs), is.window.y);
isp_write_reg(dev, REG_ADDR(isp_is_h_size), is.window.width);
isp_write_reg(dev, REG_ADDR(isp_is_v_size), is.window.height);
isp_write_reg(dev, REG_ADDR(isp_is_recenter),
is.recenter & MRV_IS_IS_RECENTER_MASK);
isp_write_reg(dev, REG_ADDR(isp_is_max_dx), is.max_dx);
isp_write_reg(dev, REG_ADDR(isp_is_max_dy), is.max_dy);
isp_is_displace = isp_read_reg(dev, REG_ADDR(isp_is_displace));
REG_SET_SLICE(isp_is_displace, MRV_IS_DX, is.displace_x);
REG_SET_SLICE(isp_is_displace, MRV_IS_DY, is.displace_y);
isp_write_reg(dev, REG_ADDR(isp_is_displace), isp_is_displace);
isp_write_reg(dev, REG_ADDR(isp_is_ctrl), isp_is_ctrl);
if (is.update) {
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GEN_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
is.update = false;
}
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_raw_is(struct isp_ic_dev *dev)
{
#ifndef ISP_RAWIS
//isp_err("unsupported funciton: %s\n", __func__);
return -EINVAL;
#else
struct isp_is_context rawis = *(&dev->rawis);
u32 isp_raw_is_ctrl;
u32 isp_raw_is_displace;
// u32 isp_ctrl;
isp_info("enter %s\n", __func__);
isp_raw_is_ctrl = isp_read_reg(dev, REG_ADDR(isp_raw_is_ctrl));
if (!rawis.enable) {
isp_write_reg(dev, REG_ADDR(isp_raw_is_h_size),
rawis.window.width);
isp_write_reg(dev, REG_ADDR(isp_raw_is_v_size),
rawis.window.height);
REG_SET_SLICE(isp_raw_is_ctrl, MRV_ISP_RAW_IS_EN, 0);
isp_write_reg(dev, REG_ADDR(isp_raw_is_ctrl), isp_raw_is_ctrl);
return 0;
}
REG_SET_SLICE(isp_raw_is_ctrl, MRV_ISP_RAW_IS_EN, 1);
isp_write_reg(dev, REG_ADDR(isp_raw_is_h_offs), rawis.window.x);
isp_write_reg(dev, REG_ADDR(isp_raw_is_v_offs), rawis.window.y);
isp_write_reg(dev, REG_ADDR(isp_raw_is_h_size), rawis.window.width);
isp_write_reg(dev, REG_ADDR(isp_raw_is_v_size), rawis.window.height);
isp_write_reg(dev, REG_ADDR(isp_raw_is_recenter),
rawis.recenter & MRV_IS_IS_RECENTER_MASK);
isp_write_reg(dev, REG_ADDR(isp_raw_is_max_dx), rawis.max_dx);
isp_write_reg(dev, REG_ADDR(isp_raw_is_max_dy), rawis.max_dy);
isp_raw_is_displace = isp_read_reg(dev, REG_ADDR(isp_raw_is_displace));
REG_SET_SLICE(isp_raw_is_displace, MRV_ISP_RAW_IS_DX, rawis.displace_x);
REG_SET_SLICE(isp_raw_is_displace, MRV_ISP_RAW_IS_DY, rawis.displace_y);
isp_write_reg(dev, REG_ADDR(isp_raw_is_displace), isp_raw_is_displace);
isp_write_reg(dev, REG_ADDR(isp_raw_is_ctrl), isp_raw_is_ctrl);
/*dont update the configuration at the sub module function*/
#if 0
if (rawis.update) {
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
rawis.update = false;
}
#endif
return 0;
#endif
}
int isp_s_cnr(struct isp_ic_dev *dev)
{
struct isp_cnr_context *cnr = &dev->cnr;
u32 isp_ctrl;
isp_info("enter %s\n", __func__);
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
if (!cnr->enable) {
REG_SET_SLICE(isp_ctrl, MRV_ISP_CNR_EN, 0);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
return 0;
}
REG_SET_SLICE(isp_ctrl, MRV_ISP_CNR_EN, 1);
isp_write_reg(dev, REG_ADDR(isp_cnr_linesize), cnr->line_width);
isp_write_reg(dev, REG_ADDR(isp_cnr_threshold_c1), cnr->threshold_1);
isp_write_reg(dev, REG_ADDR(isp_cnr_threshold_c2), cnr->threshold_2);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
void isp_test_bt(struct isp_ic_dev *dev)
{
isp_write_reg(dev, 0x00000010, 0x00019f7b);
isp_write_reg(dev, 0x00000014, 0x00020000);
isp_write_reg(dev, 0x00001200, 0x00000000);
isp_write_reg(dev, 0x00001204, 0x01e00280);
isp_write_reg(dev, 0x00001208, 0x01e00280);
isp_write_reg(dev, 0x00001308, 0x6ce60608);
isp_write_reg(dev, 0x00001314, 0x000008c4);
isp_write_reg(dev, 0x00001318, 0x00000001);
isp_write_reg(dev, 0x0000131c, 0x03a2013b);
isp_write_reg(dev, 0x00001320, 0x00000000);
isp_write_reg(dev, 0x00001324, 0xc0000000);
isp_write_reg(dev, 0x00001328, 0x0004B000);
isp_write_reg(dev, 0x0000132c, 0x00000000);
isp_write_reg(dev, 0x00001330, 0x00000280);
isp_write_reg(dev, 0x00001334, 0x00000280);
isp_write_reg(dev, 0x00001338, 0x000001e0);
isp_write_reg(dev, 0x0000133c, 0x0004B000);
isp_write_reg(dev, 0x00001340, 0xc0040000);
isp_write_reg(dev, 0x00001344, 0x0004B000);
isp_write_reg(dev, 0x000016c0, 0x07ffffff);
isp_write_reg(dev, 0x000005bc, 0x00000003);
isp_write_reg(dev, 0x000016c4, 0x052c4e39);
isp_write_reg(dev, 0x00000404, 0x00d00018);
isp_write_reg(dev, 0x00000410, 0x00000280);
isp_write_reg(dev, 0x00000414, 0x000001e0);
isp_write_reg(dev, 0x00000538, 0x01000100);
isp_write_reg(dev, 0x0000053c, 0x02270220);
isp_write_reg(dev, 0x0000059c, 0x00000280);
isp_write_reg(dev, 0x000005a0, 0x000001e0);
isp_write_reg(dev, 0x00002310, 0x00000280);
isp_write_reg(dev, 0x00002314, 0x000001e0);
isp_write_reg(dev, 0x0000295c, 0x00000070);
isp_write_reg(dev, 0x00003e00, 0x040128be);
isp_write_reg(dev, 0x00003e04, 0x00000000);
isp_write_reg(dev, 0x00003e08, 0x00001f08);
isp_write_reg(dev, 0x00003e0c, 0x200003ff);
isp_write_reg(dev, 0x00003e10, 0x0c968628);
isp_write_reg(dev, 0x00003e14, 0x00008008);
isp_write_reg(dev, 0x00003e18, 0x007d07d0);
isp_write_reg(dev, 0x00003e1c, 0x301a3012);
isp_write_reg(dev, 0x00003e20, 0x04010000);
isp_write_reg(dev, 0x00003e24, 0x22018000);
isp_write_reg(dev, 0x00003e28, 0x00020000);
isp_write_reg(dev, 0x00003e2c, 0x0210210a);
isp_write_reg(dev, 0x00003e30, 0x00102102);
isp_write_reg(dev, 0x00003e34, 0x0000388c);
isp_write_reg(dev, 0x00003e38, 0x00000000);
isp_write_reg(dev, 0x00003e3c, 0x00000000);
isp_write_reg(dev, 0x00003e40, 0x00000000);
isp_write_reg(dev, 0x00003e44, 0x00000001);
isp_write_reg(dev, 0x00003e48, 0x10001000);
isp_write_reg(dev, 0x00003e4c, 0x00000000);
isp_write_reg(dev, 0x00003e50, 0x00000000);
isp_write_reg(dev, 0x00003e54, 0x00000000);
isp_write_reg(dev, 0x00003e58, 0x00080010);
isp_write_reg(dev, 0x00003e5c, 0x00080010);
isp_write_reg(dev, 0x00003e60, 0x01300280);
isp_write_reg(dev, 0x00000018, 0x00001000);
isp_write_reg(dev, 0x00001200, 0x00000001); //why
isp_write_reg(dev, 0x00000418, 0x00000001);
isp_write_reg(dev, 0x00000400, 0x80100686);
isp_write_reg(dev, 0x00000400, 0x80100097);
isp_write_reg(dev, 0x00001300, 0x00000001);
isp_write_reg(dev, 0x00001310, 0x00000038);
isp_write_reg(dev, 0x000014e4, 0x00000238);
isp_write_reg(dev, 0x00001600, 0x0000005c);
isp_write_reg(dev, 0x00000704, 0x00c00222);
isp_write_reg(dev, 0x00000708, 0x00a001e0);
isp_write_reg(dev, 0x0000070c, 0x000a4023);
isp_write_reg(dev, 0x00000710, 0x000a401e);
isp_write_reg(dev, 0x00000714, 0x000b8001);
isp_write_reg(dev, 0x00000718, 0x003540a0);
isp_write_reg(dev, 0x0000071c, 0x00000050);
isp_write_reg(dev, 0x00000720, 0x3aca095b);
isp_write_reg(dev, 0x00000700, 0x00000c42);
isp_info("end %s\n", __func__);
}
int isp_start_stream(struct isp_ic_dev *dev, u32 numFrames)
{
u32 isp_imsc, isp_ctrl;
isp_info("enter %s\n", __func__);
#ifdef ISP_PDAF
isp_write_reg(dev, 0x5d00, 0x1);
#endif
isp_write_reg(dev, REG_ADDR(isp_sh_ctrl), 0x10);
isp_write_reg(dev, REG_ADDR(isp_acq_nr_frames),
(MRV_ISP_ACQ_NR_FRAMES_MASK & numFrames));
isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_imsc |=
(MRV_ISP_IMSC_ISP_OFF_MASK | MRV_ISP_IMSC_FRAME_MASK |
MRV_ISP_IMSC_FRAME_IN_MASK | MRV_ISP_IMSC_PIC_SIZE_ERR_MASK | MRV_ISP_IMSC_FLASH_ON_MASK);
/* isp_imsc |= (MRV_ISP_IMSC_FRAME_MASK | MRV_ISP_IMSC_DATA_LOSS_MASK | MRV_ISP_IMSC_FRAME_IN_MASK); */
isp_write_reg(dev, REG_ADDR(isp_icr), 0xFFFFFFFF);
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
isp_write_reg(dev, 0x00001320, 1);
isp_write_reg(dev, 0x00001610, 1);
#if 0/*add by shenwuyi for live sensor*/
isp_write_reg(dev, 0x00000c68, 10);/*fream_rete_ctrl*/
isp_write_reg(dev, 0x00002200, 0x00000000); //disable lsc
isp_write_reg(dev, 0x000005bc, 0x00000001); //irq_enable
isp_write_reg(dev, 0x00000538, 0x01000100); //awb_gain_gr
isp_write_reg(dev, 0x0000053c, 0x02270220); //awb_gain_gc
#endif
/*isp_test_bt(dev);*/
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_INFORM_ENABLE, 1);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
/*Set lsc tbl after isp enable*/
if (dev->update_lsc_tbl) {
isp_s_lsc_tbl(dev);
dev->update_lsc_tbl = false;
}
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GEN_CFG_UPD, 1);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_CFG_UPD, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_stop_stream(struct isp_ic_dev *dev)
{
isp_info("enter %s\n", __func__);
isp_write_reg(dev, REG_ADDR(isp_imsc), 0);
isp_disable(dev);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_cc(struct isp_ic_dev *dev)
{
struct isp_cc_context *cc = &dev->cc;
u32 isp_ctrl, addr;
int i;
isp_info("enter %s\n", __func__);
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_CSM_Y_RANGE, cc->conv_range_y_full);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_CSM_C_RANGE, cc->conv_range_c_full);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
if (cc->update_curve) {
addr = REG_ADDR(isp_cc_coeff_0);
for (i = 0; i < 9; i++) {
isp_write_reg(dev, addr + i * 4,
MRV_ISP_CC_COEFF_0_MASK & cc->lCoeff[i]);
}
}
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_xtalk(struct isp_ic_dev *dev)
{
struct isp_xtalk_context xtalk = *(&dev->xtalk);
int i;
/* isp_info("enter %s\n", __func__); */
for (i = 0; i < 9; i++) {
#ifdef ISP_CTM_0507 // Coefficient for cross talk matrix.Use bit 11,Values are 12-bit signed fixed-point numbers with 5 bit integer and 7 bit fractional part, ranging from -16 (0x800) to +15.992 (0x7FF).
isp_write_reg(dev, REG_ADDR(cross_talk_coef_block_arr[i]),
MRV_ISP_CT_COEFF_MASK & (xtalk.lCoeff[i] << 1));
#else // Coefficient for cross talk matrix.Values are 11-bit signed fixed-point numbers with 4 bit integer and 7 bit fractional part, ranging from -8 (0x400) to +7.992 (0x3FF).
isp_write_reg(dev, REG_ADDR(cross_talk_coef_block_arr[i]),
MRV_ISP_CT_COEFF_MASK & xtalk.lCoeff[i]);
#endif
}
isp_write_reg(dev, REG_ADDR(isp_ct_offset_r),
(MRV_ISP_CT_OFFSET_R_MASK & xtalk.r));
isp_write_reg(dev, REG_ADDR(isp_ct_offset_g),
(MRV_ISP_CT_OFFSET_G_MASK & xtalk.g));
isp_write_reg(dev, REG_ADDR(isp_ct_offset_b),
(MRV_ISP_CT_OFFSET_B_MASK & xtalk.b));
return 0;
}
int isp_enable_wb(struct isp_ic_dev *dev, bool bEnable)
{
u32 isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_AWB_ENABLE, bEnable);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_enable_gamma_out(struct isp_ic_dev *dev, bool bEnable)
{
u32 isp_ctrl;
struct isp_gamma_out_context *gamma = &dev->gamma_out;
isp_info("enter %s\n", __func__);
gamma->enableGamma = bEnable;
if(gamma->changed || !is_isp_enable(dev))
{
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GAMMA_OUT_ENABLE, bEnable);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
gamma->changed = false;
} else {
gamma->changed = true;
}
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_gamma_out(struct isp_ic_dev *dev)
{
u32 isp_gamma_out_mode;
int i;
u32 isp_ctrl;
struct isp_gamma_out_context *gamma = &dev->gamma_out;
if(gamma->changed || !is_isp_enable(dev)) {
isp_gamma_out_mode = isp_read_reg(dev, REG_ADDR(isp_gamma_out_mode));
REG_SET_SLICE(isp_gamma_out_mode, MRV_ISP_EQU_SEGM, gamma->mode);
isp_write_reg(dev, REG_ADDR(isp_gamma_out_mode), isp_gamma_out_mode);
for (i = 0; i < 17; i++) {
isp_write_reg(dev, REG_ADDR(gamma_out_y_block_arr[i]),
MRV_ISP_ISP_GAMMA_OUT_Y_MASK & gamma->curve[i]);
}
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GAMMA_OUT_ENABLE, gamma->enableGamma);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
gamma->changed = false;
} else {
gamma->changed = true;
}
return 0;
}
int isp_s_lsc_tbl(struct isp_ic_dev *dev)
{
int i, n;
u32 isp_ctrl;
u32 sram_addr;
u32 isp_lsc_status;
struct isp_lsc_context *lsc = (&dev->lsc);
//isp_debug("enter %s\n", __func__);
/*need to set tbl after isp_ctrl enable In ISP8000NANO_V1802*/
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
/* Enable isp to enable ram clock for write correct table to ram. */
if (!(isp_ctrl & 0x01)) {
dev->update_lsc_tbl = true;
return 0;
}
isp_lsc_status = isp_read_reg(dev, REG_ADDR(isp_lsc_status));
sram_addr = (isp_lsc_status & 0x2U) ? 0U : 153U;
isp_write_reg(dev, REG_ADDR(isp_lsc_r_table_addr), sram_addr);
isp_write_reg(dev, REG_ADDR(isp_lsc_gr_table_addr), sram_addr);
isp_write_reg(dev, REG_ADDR(isp_lsc_gb_table_addr), sram_addr);
isp_write_reg(dev, REG_ADDR(isp_lsc_b_table_addr), sram_addr);
#ifdef ISP_LSC_V2
for (n = 0; n < ((CAMERIC_MAX_LSC_SECTORS + 1) * (CAMERIC_MAX_LSC_SECTORS + 1)); n += CAMERIC_MAX_LSC_SECTORS + 1) {
for (i = 0; i < (CAMERIC_MAX_LSC_SECTORS); i += 2) {
isp_write_reg(dev, REG_ADDR(isp_lsc_r_table_data), (lsc->r[n + i] & 0xFFF) | ((lsc->r[n + i + 1] & 0xFFF) << 12) | ((lsc->r[n + i] >> 12) << 24) | ((lsc->r[n + i + 1] >> 12) << 28));
isp_write_reg(dev, REG_ADDR(isp_lsc_gr_table_data), (lsc->gr[n + i] & 0xFFF) | ((lsc->gr[n + i + 1] & 0xFFF) << 12) | ((lsc->gr[n + i] >> 12) << 24) | ((lsc->gr[n + i + 1] >> 12) << 28));
isp_write_reg(dev, REG_ADDR(isp_lsc_gb_table_data), (lsc->gb[n + i] & 0xFFF) | ((lsc->gb[n + i + 1] & 0xFFF) << 12) | ((lsc->gb[n + i] >> 12) << 24) | ((lsc->gb[n + i + 1] >> 12) << 28));
isp_write_reg(dev, REG_ADDR(isp_lsc_b_table_data), (lsc->b[n + i] & 0xFFF) | ((lsc->b[n + i + 1] & 0xFFF) << 12) | ((lsc->b[n + i] >> 12) << 24) | ((lsc->b[n + i + 1] >> 12) << 28));
}
isp_write_reg(dev, REG_ADDR(isp_lsc_r_table_data), (lsc->r[n + CAMERIC_MAX_LSC_SECTORS] & 0xFFF) | ((lsc->r[n + CAMERIC_MAX_LSC_SECTORS] >> 12) << 24));
isp_write_reg(dev, REG_ADDR(isp_lsc_gr_table_data), (lsc->gr[n + CAMERIC_MAX_LSC_SECTORS] & 0xFFF) | ((lsc->gr[n + CAMERIC_MAX_LSC_SECTORS] >> 12) << 24));
isp_write_reg(dev, REG_ADDR(isp_lsc_gb_table_data), (lsc->gb[n + CAMERIC_MAX_LSC_SECTORS] & 0xFFF) | ((lsc->gb[n + CAMERIC_MAX_LSC_SECTORS] >> 12) << 24));
isp_write_reg(dev, REG_ADDR(isp_lsc_b_table_data), (lsc->b[n + CAMERIC_MAX_LSC_SECTORS] & 0xFFF) | ((lsc->b[n + CAMERIC_MAX_LSC_SECTORS] >> 12) << 24));
}
#else
for (n = 0;
n <
((CAMERIC_MAX_LSC_SECTORS + 1) * (CAMERIC_MAX_LSC_SECTORS + 1));
n += CAMERIC_MAX_LSC_SECTORS + 1) {
/* 17 sectors with 2 values in one DWORD = 9 DWORDs (8 steps + 1 outside loop) */
for (i = 0; i < (CAMERIC_MAX_LSC_SECTORS); i += 2) {
isp_write_reg(dev, REG_ADDR(isp_lsc_r_table_data),
lsc->r[n +
i] | (lsc->r[n + i + 1] << 12));
isp_write_reg(dev, REG_ADDR(isp_lsc_gr_table_data),
lsc->gr[n +
i] | (lsc->gr[n + i + 1] << 12));
isp_write_reg(dev, REG_ADDR(isp_lsc_gb_table_data),
lsc->gb[n +
i] | (lsc->gb[n + i + 1] << 12));
isp_write_reg(dev, REG_ADDR(isp_lsc_b_table_data),
lsc->b[n +
i] | (lsc->b[n + i + 1] << 12));
}
isp_write_reg(dev, REG_ADDR(isp_lsc_r_table_data),
lsc->r[n + CAMERIC_MAX_LSC_SECTORS]);
isp_write_reg(dev, REG_ADDR(isp_lsc_gr_table_data),
lsc->gr[n + CAMERIC_MAX_LSC_SECTORS]);
isp_write_reg(dev, REG_ADDR(isp_lsc_gb_table_data),
lsc->gb[n + CAMERIC_MAX_LSC_SECTORS]);
isp_write_reg(dev, REG_ADDR(isp_lsc_b_table_data),
lsc->b[n + CAMERIC_MAX_LSC_SECTORS]);
}
#endif
isp_write_reg(dev, REG_ADDR(isp_lsc_table_sel),
(isp_lsc_status & 0x2U) ? 0U : 1U);
//isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_lsc_sec(struct isp_ic_dev *dev)
{
int i;
struct isp_lsc_context *lsc = (&dev->lsc);
/* isp_info("enter %s\n", __func__); */
for (i = 0; i < CAEMRIC_GRAD_TBL_SIZE; i += 2) {
isp_write_reg(dev, REG_ADDR(isp_lsc_xsize_01) + i * 2,
(lsc->x_size[i] & MRV_LSC_Y_SECT_SIZE_0_MASK) |
((lsc->x_size[i + 1]
<< MRV_LSC_X_SECT_SIZE_1_SHIFT)
& MRV_LSC_X_SECT_SIZE_1_MASK));
isp_write_reg(dev, REG_ADDR(isp_lsc_ysize_01) + i * 2,
(lsc->y_size[i] & MRV_LSC_Y_SECT_SIZE_0_MASK) |
((lsc->y_size[i + 1]
<< MRV_LSC_Y_SECT_SIZE_1_SHIFT)
& MRV_LSC_Y_SECT_SIZE_1_MASK));
isp_write_reg(dev, REG_ADDR(isp_lsc_xgrad_01) + i * 2,
(lsc->x_grad[i] & MRV_LSC_XGRAD_0_MASK) |
((lsc->x_grad[i + 1]
<< MRV_LSC_XGRAD_1_SHIFT)
& MRV_LSC_XGRAD_1_MASK));
isp_write_reg(dev, REG_ADDR(isp_lsc_ygrad_01) + i * 2,
(lsc->y_grad[i] & MRV_LSC_YGRAD_0_MASK) |
((lsc->y_grad[i + 1]
<< MRV_LSC_YGRAD_1_SHIFT)
& MRV_LSC_YGRAD_1_MASK));
}
return 0;
}
int isp_ioc_read_mis(struct isp_ic_dev *dev, void __user *args)
{
isp_mis_list_t* pCList = &dev->circle_list;
isp_mis_t mis_data;
u32 ary[2];
int ret = -1;
ret = isp_irq_read_circle_queue(&mis_data, pCList);
if (ret < 0) {
/*isp_info("%s can not dequeue mis data\n", __func__);*/
return ret;
}
/*isp_info("%s irq src %d val 0x%08x\n", __func__, mis_data.irq_src, mis_data.val);*/
ary[0] = mis_data.irq_src;
ary[1] = mis_data.val;
viv_check_retval(copy_to_user(args, ary, sizeof( ary)));
return 0;
}
static int isp_ioc_read_reg(struct isp_ic_dev *dev, void __user * args)
{
struct isp_reg_t reg;
viv_check_retval(copy_from_user(&reg, args, sizeof(reg)));
reg.val = isp_read_reg(dev, reg.offset);
viv_check_retval(copy_to_user(args, &reg, sizeof(reg)));
return 0;
}
static int isp_ioc_write_reg(struct isp_ic_dev *dev, void __user *args)
{
struct isp_reg_t reg;
viv_check_retval((copy_from_user(&reg, args, sizeof(reg))));
isp_write_reg(dev, reg.offset, reg.val);
return 0;
}
int isp_ioc_disable_isp_off(struct isp_ic_dev *dev, void __user *args)
{
u32 isp_imsc;
isp_info("enter %s\n", __func__);
isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_imsc &= ~MRV_ISP_IMSC_ISP_OFF_MASK;
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_g_awbmean(struct isp_ic_dev *dev, struct isp_awb_mean *mean)
{
u32 reg = isp_read_reg(dev, REG_ADDR(isp_awb_mean));
/* isp_info("enter %s\n", __func__); */
mean->g = REG_GET_SLICE(reg, MRV_ISP_AWB_MEAN_Y__G);
mean->b = REG_GET_SLICE(reg, MRV_ISP_AWB_MEAN_CB__B);
mean->r = REG_GET_SLICE(reg, MRV_ISP_AWB_MEAN_CR__R);
mean->no_white_count = isp_read_reg(dev, REG_ADDR(isp_awb_white_cnt));
return 0;
}
int isp_s_ee(struct isp_ic_dev *dev)
{
#ifndef ISP_EE
//isp_err("unsupported function: %s\n", __func__);
return -EINVAL;
#else
struct isp_ee_context *ee = &dev->ee;
u32 isp_ee_ctrl = isp_read_reg(dev, REG_ADDR(isp_ee_ctrl));
u32 gain = 0;
//isp_info("enter %s\n", __func__);
if (!ee->enable) {
isp_write_reg(dev, REG_ADDR(isp_ee_ctrl),
isp_ee_ctrl & ~EE_CTRL_ENABLE_MASK);
return 0;
}
REG_SET_SLICE(isp_ee_ctrl, EE_CTRL_INPUT_SEL, ee->input_sel);
REG_SET_SLICE(isp_ee_ctrl, EE_CTRL_SOURCE_STRENGTH, ee->src_strength);
REG_SET_SLICE(isp_ee_ctrl, EE_CTRL_STRENGTH, ee->strength);
REG_SET_SLICE(gain, EE_UV_GAIN, ee->uv_gain);
REG_SET_SLICE(gain, EE_EDGE_GAIN, ee->edge_gain);
isp_write_reg(dev, REG_ADDR(isp_ee_y_gain), ee->y_gain);
isp_write_reg(dev, REG_ADDR(isp_ee_uv_gain), gain);
isp_write_reg(dev, REG_ADDR(isp_ee_ctrl),
isp_ee_ctrl | EE_CTRL_ENABLE_MASK);
//isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_s_exp(struct isp_ic_dev *dev)
{
struct isp_exp_context *exp = &dev->exp;
u32 isp_exp_ctrl = isp_read_reg(dev, REG_ADDR(isp_exp_ctrl));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_info("enter %s\n", __func__);
if (!exp->enable) {
REG_SET_SLICE(isp_exp_ctrl, MRV_AE_EXP_START, 0);
isp_write_reg(dev, REG_ADDR(isp_exp_ctrl), isp_exp_ctrl);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc & ~MRV_ISP_IMSC_EXP_END_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_exp_h_offset),
(MRV_AE_ISP_EXP_H_OFFSET_MASK & exp->window.x));
isp_write_reg(dev, REG_ADDR(isp_exp_v_offset),
(MRV_AE_ISP_EXP_V_OFFSET_MASK & exp->window.y));
isp_write_reg(dev, REG_ADDR(isp_exp_h_size),
(MRV_AE_ISP_EXP_H_SIZE_MASK & exp->window.width));
isp_write_reg(dev, REG_ADDR(isp_exp_v_size),
(MRV_AE_ISP_EXP_V_SIZE_MASK & exp->window.height));
#ifdef ISP_AE_SHADOW
isp_write_reg(dev, REG_ADDR(isp_exp_h_offset_shd),
(MRV_AE_ISP_EXP_H_OFFSET_MASK & exp->window.x));
isp_write_reg(dev, REG_ADDR(isp_exp_v_offset_shd),
(MRV_AE_ISP_EXP_V_OFFSET_MASK & exp->window.y));
isp_write_reg(dev, REG_ADDR(isp_exp_h_size_shd),
(MRV_AE_ISP_EXP_H_SIZE_MASK & exp->window.width));
isp_write_reg(dev, REG_ADDR(isp_exp_v_size_shd),
(MRV_AE_ISP_EXP_V_SIZE_MASK & exp->window.height));
#endif
REG_SET_SLICE(isp_exp_ctrl, MRV_AE_EXP_MEAS_MODE, exp->mode);
REG_SET_SLICE(isp_exp_ctrl, MRV_AE_EXP_START, 1);
isp_write_reg(dev, REG_ADDR(isp_exp_ctrl), isp_exp_ctrl);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_EXP_END_MASK);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_hdrexp(struct isp_ic_dev *dev)
{
struct isp_exp_context *hdrexp = &dev->hdrexp;
u32 isp_hdr_exp_conf = isp_read_reg(dev, REG_ADDR(isp_hdr_exp_conf));
u32 isp_stitching_imsc = isp_read_reg(dev, REG_ADDR(isp_stitching_imsc));
pr_info("enter %s\n", __func__);
if (!dev->hdrexp.enable) {
pr_info("%s, hdr disabled\n",__func__);
REG_SET_SLICE(isp_hdr_exp_conf, MRV_HDR_EXP_START, 0);
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_conf), isp_hdr_exp_conf);
isp_write_reg(dev, REG_ADDR(isp_stitching_imsc), isp_stitching_imsc & ~0x38);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_h_offset),
(MRV_ISP_HDR_EXP_H_OFFSET_MASK & hdrexp->window.x));
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_v_offset),
(MRV_ISP_HDR_EXP_V_OFFSET_MASK & hdrexp->window.y));
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_h_size),
(MRV_ISP_HDR_EXP_H_SIZE_MASK & hdrexp->window.width));
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_v_size),
(MRV_ISP_HDR_EXP_V_SIZE_MASK & hdrexp->window.height));
REG_SET_SLICE(isp_hdr_exp_conf, MRV_HDR_EXP_MEAS_MODE, hdrexp->mode);
REG_SET_SLICE(isp_hdr_exp_conf, MRV_HDR_EXP_SRC_SEL, 1); //hardware only support 1
REG_SET_SLICE(isp_hdr_exp_conf, MRV_HDR_EXP_START, 1);
isp_write_reg(dev, REG_ADDR(isp_hdr_exp_conf), isp_hdr_exp_conf);
isp_write_reg(dev, REG_ADDR(isp_stitching_imsc), isp_stitching_imsc | 0x38);
return 0;
}
int isp_g_expmean(struct isp_ic_dev *dev, u8 *mean)
{
int i = 0;
/* isp_info("enter %s\n", __func__); */
if (!dev || !mean)
return -EINVAL;
for (; i < 25; i++) {
mean[i] = isp_read_reg(dev, REG_ADDR(isp_exp_mean_00) + i * 4);
}
return 0;
}
int isp_g_hdrexpmean(struct isp_ic_dev *dev, u8 * mean)
{
int i = 0;
pr_info("enter %s\n", __func__);
if (!dev || !mean)
return -EINVAL;
for (; i < 75; i++) {
mean[i] = isp_read_reg(dev, REG_ADDR(isp_hdr_exp_statistics[i]));
}
return 0;
}
#ifdef ISP_HIST256
#define HIST_BIN_TOTAL 256
#else
#define HIST_BIN_TOTAL 16
#endif
int isp_s_hist(struct isp_ic_dev *dev)
{
struct isp_hist_context *hist = &dev->hist;
#ifdef ISP_HIST256
u32 isp_hist256_prop = isp_read_reg(dev, REG_ADDR(isp_hist256_prop));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
int i;
if (!hist->enable) {
REG_SET_SLICE(isp_hist256_prop, MRV_HIST_MODE,
MRV_HIST_MODE_NONE);
isp_write_reg(dev, REG_ADDR(isp_hist256_prop),
isp_hist256_prop);
//isp_write_reg(dev, REG_ADDR(isp_imsc),
// isp_imsc & ~MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_hist256_h_offs),
(MRV_HIST_H_OFFSET_MASK & hist->window.x));
isp_write_reg(dev, REG_ADDR(isp_hist256_v_offs),
(MRV_HIST_V_OFFSET_MASK & hist->window.y));
isp_write_reg(dev, REG_ADDR(isp_hist256_h_size),
(MRV_HIST_H_SIZE_MASK & hist->window.width));
isp_write_reg(dev, REG_ADDR(isp_hist256_v_size),
(MRV_HIST_V_SIZE_MASK & hist->window.height));
for (i = 0; i < 24; i += 4) {
isp_write_reg(dev, REG_ADDR(isp_hist256_weight_00to30) + i,
hist->weight[i +
0] | (hist->weight[i +
1] << 8) |
(hist->weight[i + 2] << 16) | (hist->weight[i +
3] <<
24));
}
isp_write_reg(dev, REG_ADDR(isp_hist256_weight_44), hist->weight[24]);
REG_SET_SLICE(isp_hist256_prop, MRV_HIST_STEPSIZE, hist->step_size);
REG_SET_SLICE(isp_hist256_prop, MRV_HIST_MODE, hist->mode);
isp_write_reg(dev, REG_ADDR(isp_hist256_prop), isp_hist256_prop);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
#else
u32 isp_hist_prop = isp_read_reg(dev, REG_ADDR(isp_hist_prop));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
int i;
isp_info("enter %s\n", __func__);
if (!hist->enable) {
REG_SET_SLICE(isp_hist_prop, MRV_HIST_MODE, MRV_HIST_MODE_NONE);
isp_write_reg(dev, REG_ADDR(isp_hist_prop), isp_hist_prop);
//isp_write_reg(dev, REG_ADDR(isp_imsc),
// isp_imsc & ~MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_hist_h_offs),
(MRV_HIST_H_OFFSET_MASK & hist->window.x));
isp_write_reg(dev, REG_ADDR(isp_hist_v_offs),
(MRV_HIST_V_OFFSET_MASK & hist->window.y));
isp_write_reg(dev, REG_ADDR(isp_hist_h_size),
(MRV_HIST_H_SIZE_MASK & hist->window.width));
isp_write_reg(dev, REG_ADDR(isp_hist_v_size),
(MRV_HIST_V_SIZE_MASK & hist->window.height));
for (i = 0; i < 24; i += 4) {
isp_write_reg(dev, REG_ADDR(isp_hist_weight_00to30) + i,
hist->weight[i + 0] |
(hist->weight[i + 1] << 8) |
(hist->weight[i + 2] << 16) |
(hist->weight[i + 3] << 24));
}
isp_write_reg(dev, REG_ADDR(isp_hist_weight_44), hist->weight[24]);
REG_SET_SLICE(isp_hist_prop, MRV_HIST_STEPSIZE, hist->step_size);
REG_SET_SLICE(isp_hist_prop, MRV_HIST_MODE, hist->mode);
isp_write_reg(dev, REG_ADDR(isp_hist_prop), isp_hist_prop);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
isp_info("exit %s\n", __func__);
#endif
return 0;
}
int isp_s_hdrhist(struct isp_ic_dev *dev)
{
struct isp_hist_context *hdrhist = &dev->hdrhist;
u32 isp_hdr_hist_prop = isp_read_reg(dev, REG_ADDR(isp_hdr_hist_prop));
u32 isp_stitching_imsc = isp_read_reg(dev, REG_ADDR(isp_stitching_imsc));
pr_info("enter %s\n", __func__);
if (!dev->hdrhist.enable) {
pr_info("%s, hdr disable\n", __func__);
REG_SET_SLICE(isp_hdr_hist_prop, MRV_HIST_MODE, MRV_HIST_MODE_NONE);
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_prop), isp_hdr_hist_prop);
isp_write_reg(dev, REG_ADDR(isp_stitching_imsc),
isp_stitching_imsc & ~0x1c0);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_h_offs),
(MRV_HIST_H_OFFSET_MASK & hdrhist->window.x));
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_v_offs),
(MRV_HIST_V_OFFSET_MASK & hdrhist->window.y));
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_h_size),
(MRV_HIST_H_SIZE_MASK & hdrhist->window.width));
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_v_size),
(MRV_HIST_V_SIZE_MASK & hdrhist->window.height));
REG_SET_SLICE(isp_hdr_hist_prop, MRV_HIST_STEPSIZE, hdrhist->step_size);
REG_SET_SLICE(isp_hdr_hist_prop, MRV_HIST_MODE, hdrhist->mode);
isp_write_reg(dev, REG_ADDR(isp_hdr_hist_prop), isp_hdr_hist_prop);
isp_write_reg(dev, REG_ADDR(isp_stitching_imsc), isp_stitching_imsc | 0x1c0);
return 0;
}
int isp_g_histmean(struct isp_ic_dev *dev, u32 *mean)
{
int i = 0;
/* isp_info("enter %s\n", __func__); */
if (!dev || !mean)
return -EINVAL;
#ifdef ISP_HIST256
for (; i < HIST_BIN_TOTAL; i++) {
mean[i] = isp_read_reg(dev, REG_ADDR(isp_hist256_bin_n));
}
#else
for (; i < HIST_BIN_TOTAL; i++) {
mean[i] = isp_read_reg(dev,
REG_ADDR(histogram_measurement_result_arr[i]));
}
#endif
return 0;
}
int isp_g_hdrhistmean(struct isp_ic_dev *dev, u32 * mean)
{
int i = 0;
pr_info("enter %s\n", __func__);
if (!dev || !mean)
return -EINVAL;
// size is fixed 48 now, contain 3 channels
for (; i < 48; i++) {
mean[i] = isp_read_reg(dev, REG_ADDR(isp_hdr_hist_statistics[i]));
}
return 0;
}
int isp_s_hist64(struct isp_ic_dev *dev)
{
#ifndef ISP_HIST64
//pr_err("Not supported hist64 module\n");
return -1;
#else
struct isp_hist64_context *hist64 = &dev->hist64;
u32 isp64_hist_prop = isp_read_reg(dev, REG_ADDR(isp64_hist_prop));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
u32 isp64_hist_subsampling = isp_read_reg(dev, REG_ADDR(isp64_hist_subsampling));
u32 isp64_hist_sample_range = isp_read_reg(dev, REG_ADDR(isp64_hist_sample_range));
u32 isp64_hist_coeff_r = 0, isp64_hist_coeff_g = 0, isp64_hist_coeff_b = 0;
int i;
if (!hist64->enable) {
REG_SET_SLICE(isp64_hist_prop, MRV_HIST_MODE,
MRV_HIST_MODE_NONE);
isp_write_reg(dev, REG_ADDR(isp64_hist_prop),
isp64_hist_prop);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc & ~MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
//isp_write_reg(dev, REG_ADDR(isp64_hist_ctrl),
/// hist64->enable & ~MRV_HIST_UPDATE_ENABLE_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp64_hist_h_offs),
(MRV_HIST_H_OFFSET_MASK & hist64->window.x));
isp_write_reg(dev, REG_ADDR(isp64_hist_v_offs),
(MRV_HIST_V_OFFSET_MASK & hist64->window.y));
isp_write_reg(dev, REG_ADDR(isp64_hist_h_size),
(MRV_HIST_H_SIZE_MASK & hist64->window.width));
isp_write_reg(dev, REG_ADDR(isp64_hist_v_size),
(MRV_HIST_V_SIZE_MASK & hist64->window.height));
for (i = 0; i < 24; i += 4) {
isp_write_reg(dev, REG_ADDR(isp64_hist_weight_00to30) + i,
hist64->weight[i +
0] | (hist64->weight[i +
1] << 8) |
(hist64->weight[i + 2] << 16) | (hist64->weight[i +
3] <<
24));
}
isp_write_reg(dev, REG_ADDR(isp64_hist_weight_44), hist64->weight[24]);
REG_SET_SLICE(isp64_hist_prop, MRV_HIST_CHANNEL_SELECT, hist64->channel);
REG_SET_SLICE(isp64_hist_prop, MRV_HIST_MODE, hist64->mode);
REG_SET_SLICE(isp64_hist_subsampling, MRV_HIST_V_STEPSIZE, hist64->vStepSize);
REG_SET_SLICE(isp64_hist_subsampling, MRV_HIST_H_STEP_INC, hist64->hStepInc);
REG_SET_SLICE(isp64_hist_sample_range, MRV_HIST_SAMPLE_OFFSET, hist64->sample_offset);
REG_SET_SLICE(isp64_hist_sample_range, MRV_HIST_SAMPLE_SHIFT, hist64->sample_shift);
REG_SET_SLICE(isp64_hist_coeff_r, MRV_HIST_COEFF_R, hist64->r_coeff);
REG_SET_SLICE(isp64_hist_coeff_g, MRV_HIST_COEFF_G, hist64->g_coeff);
REG_SET_SLICE(isp64_hist_coeff_b, MRV_HIST_COEFF_B, hist64->b_coeff);
isp_write_reg(dev, REG_ADDR(isp64_hist_subsampling), isp64_hist_subsampling);
isp_write_reg(dev, REG_ADDR(isp64_hist_sample_range), isp64_hist_sample_range);
isp_write_reg(dev, REG_ADDR(isp64_hist_prop), isp64_hist_prop);
isp_write_reg(dev, REG_ADDR(isp64_hist_coeff_r), isp64_hist_coeff_r);
isp_write_reg(dev, REG_ADDR(isp64_hist_coeff_g), isp64_hist_coeff_g);
isp_write_reg(dev, REG_ADDR(isp64_hist_coeff_b), isp64_hist_coeff_b);
isp_write_reg(dev, REG_ADDR(isp64_hist_ctrl),
hist64->enable);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_HIST_MEASURE_RDY_MASK);
return 0;
#endif
}
#define HIST64_BIN_TOTAL 32
int isp_g_hist64mean(struct isp_ic_dev *dev, u32 *mean)
{
#ifndef ISP_HIST64
//pr_err("Not supported hist64 module\n");
return -1;
#else
int i = 0;
isp_info("enter %s\n", __func__);
if (!dev || !mean)
return -EINVAL;
for (; i < HIST64_BIN_TOTAL; i++) {
mean[i] = isp_read_reg(dev,
REG_ADDR(isp64_histogram_measurement_result_arr[i]));
}
isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_g_hist64_vstart_status(struct isp_ic_dev *dev, u32 *status)
{
#ifndef ISP_HIST64
//pr_err("Not supported hist64 module\n");
return -1;
#else
/* isp_info("enter %s\n", __func__); */
if (!dev || !status)
return -EINVAL;
*status = isp_read_reg(dev, REG_ADDR(isp64_hist_vstart_status));
return 0;
#endif
}
int isp_update_hist64(struct isp_ic_dev *dev)
{
#ifndef ISP_HIST64
//pr_err("Not supported hist64\n");
return -1;
#else
struct isp_hist64_context* hist64 =&dev->hist64;
isp_write_reg(dev, REG_ADDR(isp64_hist_forced_upd_start_line),hist64->forced_upd_start_line);
isp_write_reg(dev, REG_ADDR(isp64_hist_forced_update), hist64->forced_upd);
return 0;
#endif
}
int isp_s_ge(struct isp_ic_dev *dev)
{
#ifndef ISP_GREENEQUILIBRATE
//isp_err("unsupported function %s\n", __func__);
return -1;
#else
struct isp_ge_context *ge = &dev->ge;
u32 green_equilibrate_ctrl =
isp_read_reg(dev, REG_ADDR(green_equilibrate_ctrl));
u32 green_equilibrate_hcnt_dummy = 0;
isp_info("enter %s\n", __func__);
if (!ge->enable) {
REG_SET_SLICE(green_equilibrate_ctrl,
ISP_GREEN_EQUILIBTATE_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(green_equilibrate_ctrl),
green_equilibrate_ctrl);
return 0;
}
REG_SET_SLICE(green_equilibrate_ctrl, ISP_GREEN_EQUILIBTATE_TH,
ge->threshold);
REG_SET_SLICE(green_equilibrate_ctrl, ISP_GREEN_EQUILIBTATE_ENABLE, 1);
REG_SET_SLICE(green_equilibrate_hcnt_dummy,
ISP_GREEN_EQUILIBTATE_HCNT_DUMMY, ge->h_dummy);
isp_write_reg(dev, REG_ADDR(green_equilibrate_ctrl),
green_equilibrate_ctrl);
isp_write_reg(dev, REG_ADDR(green_equilibrate_hcnt_dummy),
green_equilibrate_hcnt_dummy);
isp_write_reg(dev, REG_ADDR(green_equilibrate_ctrl_shd),
green_equilibrate_ctrl);
isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_s_ca(struct isp_ic_dev *dev)
{
#ifndef ISP_CA
//isp_err("unsupported function %s\n", __func__);
return -1;
#else
struct isp_ca_context *ca = &dev->ca;
u32 isp_curve_ctrl = isp_read_reg(dev, REG_ADDR(isp_curve_ctrl));
// u32 isp_curve_lut_x_addr = isp_read_reg(dev, REG_ADDR(isp_curve_lut_x_addr));
// u32 isp_curve_lut_luma_addr = isp_read_reg(dev, REG_ADDR(isp_curve_lut_luma_addr));
// u32 isp_curve_lut_chroma_addr = isp_read_reg(dev, REG_ADDR(isp_curve_lut_chroma_addr));
// u32 isp_curve_lut_shift_addr = isp_read_reg(dev, REG_ADDR(isp_curve_lut_shift_addr));
int i = 0;
/*isp_info("enter %s\n", __func__);*/
if (!ca->enable) {
REG_SET_SLICE(isp_curve_ctrl, ISP_CURVE_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_curve_ctrl), isp_curve_ctrl);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_curve_lut_x_addr), 0);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_luma_addr), 0);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_chroma_addr), 0);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_shift_addr), 0);
for (i = 0; i < CA_CURVE_DATA_TABLE_LEN; i++) {
isp_write_reg(dev, REG_ADDR(isp_curve_lut_x_write_data),
dev->ca.lut_x[i]);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_luma_write_data),
dev->ca.lut_luma[i]);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_chroma_write_data),
dev->ca.lut_chroma[i]);
isp_write_reg(dev, REG_ADDR(isp_curve_lut_shift_write_data),
dev->ca.lut_shift[i]);
}
REG_SET_SLICE(isp_curve_ctrl, ISP_CURVE_MODE, dev->ca.mode);
REG_SET_SLICE(isp_curve_ctrl, ISP_CURVE_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_curve_ctrl), isp_curve_ctrl);
/*isp_info("exit %s\n", __func__);*/
return 0;
#endif
}
int isp_s_dpcc(struct isp_ic_dev *dev)
{
struct isp_dpcc_context *dpcc = &dev->dpcc;
const u32 reg_gap = 20;
int i;
u32 isp_dpcc_mode = isp_read_reg(dev, REG_ADDR(isp_dpcc_mode));
isp_info("enter %s\n", __func__);
if (!dpcc->enable) {
REG_SET_SLICE(isp_dpcc_mode, MRV_DPCC_ISP_DPCC_ENABLE, 0);
} else {
REG_SET_SLICE(isp_dpcc_mode, MRV_DPCC_ISP_DPCC_ENABLE, 1);
}
isp_write_reg(dev, REG_ADDR(isp_dpcc_mode), dpcc->mode);
isp_write_reg(dev, REG_ADDR(isp_dpcc_output_mode), dpcc->outmode);
isp_write_reg(dev, REG_ADDR(isp_dpcc_set_use), dpcc->set_use);
for (i = 0; i < 3; i++) {
isp_write_reg(dev, REG_ADDR(isp_dpcc_methods_set_1) + i * 4,
0x1FFF & dpcc->methods_set[i]);
isp_write_reg(dev,
REG_ADDR(isp_dpcc_line_thresh_1) + i * reg_gap,
0xFFFF & dpcc->params[i].line_thresh);
isp_write_reg(dev,
REG_ADDR(isp_dpcc_line_mad_fac_1) + i * reg_gap,
0x3F3F & dpcc->params[i].line_mad_fac);
isp_write_reg(dev, REG_ADDR(isp_dpcc_pg_fac_1) + i * reg_gap,
0x3F3F & dpcc->params[i].pg_fac);
isp_write_reg(dev,
REG_ADDR(isp_dpcc_rnd_thresh_1) + i * reg_gap,
0xFFFF & dpcc->params[i].rnd_thresh);
isp_write_reg(dev, REG_ADDR(isp_dpcc_rg_fac_1) + i * reg_gap,
0x3F3F & dpcc->params[i].rg_fac);
}
isp_write_reg(dev, REG_ADDR(isp_dpcc_ro_limits), dpcc->ro_limits);
isp_write_reg(dev, REG_ADDR(isp_dpcc_rnd_offs), dpcc->rnd_offs);
isp_write_reg(dev, REG_ADDR(isp_dpcc_mode), isp_dpcc_mode);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_flt(struct isp_ic_dev *dev)
{
struct flt_denoise_type {
u32 thresh_sh0;
u32 thresh_sh1;
u32 thresh_bl0;
u32 thresh_bl1;
u32 stage_select;
u32 vmode;
u32 hmode;
};
struct flt_sharpen_type {
u32 fac_sh0;
u32 fac_sh1;
u32 fac_mid;
u32 fac_bl0;
u32 fac_bl1;
};
static struct flt_denoise_type denoise_tbl[] = {
{0, 0, 0, 0, 6, MRV_FILT_FILT_CHR_V_MODE_STATIC8,
MRV_FILT_FILT_CHR_H_MODE_BYPASS},
{18, 33, 8, 2, 6, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{26, 44, 13, 5, 4, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{36, 51, 23, 10, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{41, 67, 26, 15, 3, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{75, 10, 50, 20, 3, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{90, 120, 60, 26, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{120, 150, 80, 51, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{170, 200, 140, 100, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{250, 300, 180, 150, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{1023, 1023, 1023, 1023, 2, MRV_FILT_FILT_CHR_V_MODE_STATIC12,
MRV_FILT_FILT_CHR_H_MODE_DYN_2},
{1023, 1023, 1023, 1023, 0, MRV_FILT_FILT_CHR_V_MODE_BYPASS,
MRV_FILT_FILT_CHR_H_MODE_BYPASS},
};
static struct flt_sharpen_type sharpen_tbl[] = {
{0x4, 0x4, 0x4, 0x2, 0x0},
{0x7, 0x8, 0x6, 0x2, 0x0},
{0xA, 0xC, 0x8, 0x4, 0x0},
{0xC, 0x10, 0xA, 0x6, 0x2},
{0x16, 0x16, 0xC, 0x8, 0x4},
{0x14, 0x1B, 0x10, 0xA, 0x4},
{0x1A, 0x20, 0x13, 0xC, 0x6},
{0x1E, 0x26, 0x17, 0x10, 0x8},
{0x24, 0x2C, 0x1D, 0x15, 0x0D},
{0x2A, 0x30, 0x22, 0x1A, 0x14},
{0x30, 0x3F, 0x28, 0x24, 0x20},
};
// isp_info("enter %s\n", __func__);
if(dev->flt.changed || !is_isp_enable(dev))
{
struct isp_flt_context *flt = &dev->flt;
u32 isp_flt_mode = isp_read_reg(dev, REG_ADDR(isp_filt_mode));
if (!flt->enable) {
REG_SET_SLICE(isp_flt_mode, MRV_FILT_FILT_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_filt_mode), isp_flt_mode);
return 0;
}
if (flt->denoise >= 0) {
isp_write_reg(dev, REG_ADDR(isp_filt_thresh_sh0),
denoise_tbl[flt->denoise].thresh_sh0);
isp_write_reg(dev, REG_ADDR(isp_filt_thresh_sh1),
denoise_tbl[flt->denoise].thresh_sh1);
isp_write_reg(dev, REG_ADDR(isp_filt_thresh_bl0),
denoise_tbl[flt->denoise].thresh_bl0);
isp_write_reg(dev, REG_ADDR(isp_filt_thresh_bl1),
denoise_tbl[flt->denoise].thresh_bl1);
REG_SET_SLICE(isp_flt_mode, MRV_FILT_STAGE1_SELECT,
denoise_tbl[flt->denoise].stage_select);
REG_SET_SLICE(isp_flt_mode, MRV_FILT_FILT_CHR_V_MODE,
denoise_tbl[flt->denoise].vmode);
REG_SET_SLICE(isp_flt_mode, MRV_FILT_FILT_CHR_H_MODE,
denoise_tbl[flt->denoise].hmode);
}
if (flt->sharpen >= 0) {
isp_write_reg(dev, REG_ADDR(isp_filt_fac_sh0),
sharpen_tbl[flt->sharpen].fac_sh0);
isp_write_reg(dev, REG_ADDR(isp_filt_fac_sh1),
sharpen_tbl[flt->sharpen].fac_sh1);
isp_write_reg(dev, REG_ADDR(isp_filt_fac_mid),
sharpen_tbl[flt->sharpen].fac_mid);
isp_write_reg(dev, REG_ADDR(isp_filt_fac_bl0),
sharpen_tbl[flt->sharpen].fac_bl0);
isp_write_reg(dev, REG_ADDR(isp_filt_fac_bl1),
sharpen_tbl[flt->sharpen].fac_bl1);
}
REG_SET_SLICE(isp_flt_mode, MRV_FILT_FILT_MODE,
MRV_FILT_FILT_MODE_DYNAMIC);
isp_write_reg(dev, REG_ADDR(isp_filt_mode), isp_flt_mode);
REG_SET_SLICE(isp_flt_mode, MRV_FILT_FILT_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_filt_mode), isp_flt_mode);
isp_write_reg(dev, REG_ADDR(isp_filt_lum_weight), 0x00032040);
dev->flt.changed = false;
} else {
dev->flt.changed = true;
}
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_cac(struct isp_ic_dev *dev)
{
struct isp_cac_context *cac = &dev->cac;
u32 val = 0;
u32 isp_cac_ctrl = isp_read_reg(dev, REG_ADDR(isp_cac_ctrl));
isp_info("enter %s\n", __func__);
if (!cac->enable) {
REG_SET_SLICE(isp_cac_ctrl, MRV_CAC_CAC_EN, 0);
isp_write_reg(dev, REG_ADDR(isp_cac_ctrl), isp_cac_ctrl);
return 0;
}
REG_SET_SLICE(isp_cac_ctrl, MRV_CAC_H_CLIP_MODE, cac->hmode);
REG_SET_SLICE(isp_cac_ctrl, MRV_CAC_V_CLIP_MODE, cac->vmode);
isp_write_reg(dev, REG_ADDR(isp_cac_count_start),
cac->hstart | (cac->vstart << 16));
isp_write_reg(dev, REG_ADDR(isp_cac_a), cac->ar | (cac->ab << 16));
isp_write_reg(dev, REG_ADDR(isp_cac_b), cac->br | (cac->bb << 16));
isp_write_reg(dev, REG_ADDR(isp_cac_c), cac->cr | (cac->cb << 16));
REG_SET_SLICE(val, MRV_CAC_X_NS, cac->xns);
REG_SET_SLICE(val, MRV_CAC_X_NF, cac->xnf);
isp_write_reg(dev, REG_ADDR(isp_cac_x_norm), val);
val = 0;
REG_SET_SLICE(val, MRV_CAC_Y_NS, cac->yns);
REG_SET_SLICE(val, MRV_CAC_Y_NF, cac->ynf);
isp_write_reg(dev, REG_ADDR(isp_cac_y_norm), val);
REG_SET_SLICE(isp_cac_ctrl, MRV_CAC_CAC_EN, 1);
isp_write_reg(dev, REG_ADDR(isp_cac_ctrl), isp_cac_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_deg(struct isp_ic_dev *dev)
{
struct isp_deg_context *deg = &dev->deg;
int i;
u32 isp_gamma_dx_lo = 0;
u32 isp_gamma_dx_hi = 0;
u32 isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
isp_info("enter %s\n", __func__);
if (!deg->enable) {
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GAMMA_IN_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
return 0;
}
for (i = 0; i < 8; i++) {
isp_gamma_dx_lo |= deg->segment[i] << (i * 4);
isp_gamma_dx_hi |= deg->segment[i + 8] << (i * 4);
}
isp_write_reg(dev, REG_ADDR(isp_gamma_dx_lo), isp_gamma_dx_lo);
isp_write_reg(dev, REG_ADDR(isp_gamma_dx_hi), isp_gamma_dx_hi);
for (i = 0; i < 17; i++) {
isp_write_reg(dev, REG_ADDR(degamma_r_y_block_arr[i]),
deg->r[i]);
isp_write_reg(dev, REG_ADDR(degamma_g_y_block_arr[i]),
deg->g[i]);
isp_write_reg(dev, REG_ADDR(degamma_b_y_block_arr[i]),
deg->b[i]);
}
REG_SET_SLICE(isp_ctrl, MRV_ISP_ISP_GAMMA_IN_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
static u32 get_eff_coeff(int decimal)
{
u32 value = 0;
if (decimal <= -6)
value = 15;
else if (decimal <= -3)
value = 14;
else if (decimal == -2)
value = 13;
else if (decimal == -1)
value = 12;
else if (decimal == 0)
value = 0;
else if (decimal == 1)
value = 8;
else if (decimal == 2)
value = 9;
else if (decimal < 6)
value = 10;
else
value = 11;
return value;
}
int isp_s_ie(struct isp_ic_dev *dev)
{
struct isp_ie_context *ie = &dev->ie;
u32 img_eff_ctrl = isp_read_reg(dev, REG_ADDR(img_eff_ctrl));
u32 vi_iccl = isp_read_reg(dev, REG_ADDR(vi_iccl));
u32 vi_ircl = isp_read_reg(dev, REG_ADDR(vi_ircl));
u32 img_eff_tint = isp_read_reg(dev, REG_ADDR(img_eff_tint));
u32 img_eff_color_sel = isp_read_reg(dev, REG_ADDR(img_eff_color_sel));
u32 mat[9];
u32 sharpen = 0;
int i;
isp_info("enter %s\n", __func__);
REG_SET_SLICE(vi_ircl, MRV_VI_IE_SOFT_RST, 1);
isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
if (!ie->enable) {
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_CFG_UPD,
MRV_IMGEFF_CFG_UPD_UPDATE);
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_BYPASS_MODE,
MRV_IMGEFF_BYPASS_MODE_BYPASS);
REG_SET_SLICE(vi_iccl, MRV_VI_IE_CLK_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl);
isp_write_reg(dev, REG_ADDR(img_eff_ctrl), img_eff_ctrl);
return 0;
}
REG_SET_SLICE(vi_ircl, MRV_VI_IE_SOFT_RST, 0);
isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
REG_SET_SLICE(vi_iccl, MRV_VI_IE_CLK_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl);
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_EFFECT_MODE, ie->mode);
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_FULL_RANGE, ie->full_range);
for (i = 0; i < 9; i++)
mat[i] = get_eff_coeff(ie->m[i]);
if (ie->mode == MRV_IMGEFF_EFFECT_MODE_SEPIA) {
img_eff_tint = isp_read_reg(dev, REG_ADDR(img_eff_tint));
REG_SET_SLICE(img_eff_tint, MRV_IMGEFF_INCR_CR, ie->tint_cr);
REG_SET_SLICE(img_eff_tint, MRV_IMGEFF_INCR_CB, ie->tint_cb);
isp_write_reg(dev, REG_ADDR(img_eff_tint), img_eff_tint);
} else if (ie->mode == MRV_IMGEFF_EFFECT_MODE_COLOR_SEL) {
REG_SET_SLICE(img_eff_color_sel, MRV_IMGEFF_COLOR_SELECTION,
ie->color_sel);
REG_SET_SLICE(img_eff_color_sel, MRV_IMGEFF_COLOR_THRESHOLD,
ie->color_thresh);
isp_write_reg(dev, REG_ADDR(img_eff_color_sel),
img_eff_color_sel);
} else if (ie->mode == MRV_IMGEFF_EFFECT_MODE_EMBOSS) {
isp_write_reg(dev, REG_ADDR(img_eff_mat_1),
mat[0] | (mat[1] << 4) | (mat[2] << 8) | (mat[3]
<< 12));
isp_write_reg(dev, REG_ADDR(img_eff_mat_2),
mat[4] | (mat[5] << 4) | (mat[6] << 8) | (mat[7]
<< 12));
isp_write_reg(dev, REG_ADDR(img_eff_mat_3), mat[8]);
} else if (ie->mode == MRV_IMGEFF_EFFECT_MODE_SKETCH ||
ie->mode == MRV_IMGEFF_EFFECT_MODE_SHARPEN) {
isp_write_reg(dev, REG_ADDR(img_eff_mat_3),
(mat[0] << 4) | (mat[1] << 8) | (mat[2] << 12));
isp_write_reg(dev, REG_ADDR(img_eff_mat_4),
mat[3] | (mat[4] << 4) | (mat[5] << 8) | (mat[6]
<< 12));
isp_write_reg(dev, REG_ADDR(img_eff_mat_5),
mat[7] | (mat[8] << 4));
REG_SET_SLICE(sharpen, MRV_IMGEFF_SHARP_FACTOR,
ie->sharpen_factor);
REG_SET_SLICE(sharpen, MRV_IMGEFF_CORING_THR,
ie->sharpen_thresh);
isp_write_reg(dev, REG_ADDR(img_eff_sharpen), sharpen);
}
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_CFG_UPD,
MRV_IMGEFF_CFG_UPD_UPDATE);
REG_SET_SLICE(img_eff_ctrl, MRV_IMGEFF_BYPASS_MODE,
MRV_IMGEFF_BYPASS_MODE_PROCESS);
isp_write_reg(dev, REG_ADDR(img_eff_ctrl), img_eff_ctrl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_vsm(struct isp_ic_dev *dev)
{
struct isp_vsm_context *vsm = &dev->vsm;
u32 isp_vsm_mode = isp_read_reg(dev, REG_ADDR(isp_vsm_mode));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_info("enter %s\n", __func__);
if (!vsm->enable) {
REG_SET_SLICE(isp_vsm_mode, ISP_VSM_MEAS_EN, 0);
REG_SET_SLICE(isp_vsm_mode, ISP_VSM_MEAS_IRQ_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_vsm_mode), isp_vsm_mode);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc & ~MRV_ISP_IMSC_VSM_END_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(isp_vsm_h_offs), vsm->window.x);
isp_write_reg(dev, REG_ADDR(isp_vsm_v_offs), vsm->window.y);
isp_write_reg(dev, REG_ADDR(isp_vsm_h_size),
vsm->window.width & 0xFFFFE);
isp_write_reg(dev, REG_ADDR(isp_vsm_v_size),
vsm->window.height & 0xFFFFE);
isp_write_reg(dev, REG_ADDR(isp_vsm_h_segments), vsm->h_seg);
isp_write_reg(dev, REG_ADDR(isp_vsm_v_segments), vsm->v_seg);
REG_SET_SLICE(isp_vsm_mode, ISP_VSM_MEAS_EN, 1);
REG_SET_SLICE(isp_vsm_mode, ISP_VSM_MEAS_IRQ_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_vsm_mode), isp_vsm_mode);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_VSM_END_MASK);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_g_vsm(struct isp_ic_dev *dev, struct isp_vsm_result *vsm)
{
isp_info("enter %s\n", __func__);
vsm->x = isp_read_reg(dev, REG_ADDR(isp_vsm_delta_h));
vsm->y = isp_read_reg(dev, REG_ADDR(isp_vsm_delta_v));
isp_info("exit %s\n", __func__);
return 0;
}
#if 0
u32 get_afm_shift(u32 count, u32 thresh)
{
u32 grad = count;
u32 shift = 0;
while (grad > (thresh)) {
++shift;
grad >>= 1;
}
return shift;
}
#endif
int isp_s_afm(struct isp_ic_dev *dev)
{
struct isp_afm_context *afm = &dev->afm;
u32 mask =
(MRV_ISP_IMSC_AFM_FIN_MASK | MRV_ISP_IMSC_AFM_LUM_OF_MASK |
MRV_ISP_IMSC_AFM_SUM_OF_MASK);
u32 shift = 0;
int i;
u32 isp_afm_ctrl = isp_read_reg(dev, REG_ADDR(isp_afm_ctrl));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
isp_info("enter %s\n", __func__);
if (!afm->enable) {
REG_SET_SLICE(isp_afm_ctrl, MRV_AFM_AFM_EN, 0);
isp_imsc &= ~mask;
isp_write_reg(dev, REG_ADDR(isp_afm_ctrl), isp_afm_ctrl);
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
return 0;
}
for (i = 0; i < 3; i++) {
isp_write_reg(dev, REG_ADDR(isp_afm_lt_a) + i * 8,
(afm->window[i].x << 16) | afm->window[i].y);
isp_write_reg(dev, REG_ADDR(isp_afm_rb_a) + i * 8,
((afm->window[i].x + afm->window[i].width -
1) << 16) | ((afm->window[i].y +
afm->window[i].height - 1)));
}
REG_SET_SLICE(shift, MRV_AFM_LUM_VAR_SHIFT, afm->lum_shift);
REG_SET_SLICE(shift, MRV_AFM_AFM_VAR_SHIFT, afm->afm_shift);
isp_write_reg(dev, REG_ADDR(isp_afm_var_shift), shift);
isp_write_reg(dev, REG_ADDR(isp_afm_thres), afm->thresh);
REG_SET_SLICE(isp_afm_ctrl, MRV_AFM_AFM_EN, 1);
isp_imsc |= mask;
isp_write_reg(dev, REG_ADDR(isp_afm_ctrl), isp_afm_ctrl);
isp_write_reg(dev, REG_ADDR(isp_imsc), isp_imsc);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_g_afm(struct isp_ic_dev *dev, struct isp_afm_result *afm)
{
isp_debug("enter %s\n", __func__);
afm->sum_a = isp_read_reg(dev, REG_ADDR(isp_afm_sum_a));
afm->sum_b = isp_read_reg(dev, REG_ADDR(isp_afm_sum_b));
afm->sum_c = isp_read_reg(dev, REG_ADDR(isp_afm_sum_c));
afm->lum_a = isp_read_reg(dev, REG_ADDR(isp_afm_lum_a));
afm->lum_b = isp_read_reg(dev, REG_ADDR(isp_afm_lum_b));
afm->lum_c = isp_read_reg(dev, REG_ADDR(isp_afm_lum_c));
isp_debug("exit %s\n", __func__);
return 0;
}
int isp_s_exp2_inputsel(struct isp_ic_dev *dev)
{
#ifndef ISP_AEV2
pr_err("unsupported function: %s\n", __func__);
return -EINVAL;
#else
struct isp_exp2_context *exp2 = &dev->exp2;
u32 isp_expv2_ctrl = isp_read_reg(dev, REG_ADDR(isp_expv2_ctrl));
REG_SET_SLICE(isp_expv2_ctrl, MRV_AE_ISP_EXPV2_INPUT_SELECT, exp2->input_select);
isp_write_reg(dev, REG_ADDR(isp_expv2_ctrl), isp_expv2_ctrl);
return 0;
#endif
}
int isp_s_exp2_sizeratio(struct isp_ic_dev *dev, u32 h_size)
{
#ifndef ISP_AEV2
pr_err("unsupported function: %s\n", __func__);
return -EINVAL;
#else
u32 size_inv;
size_inv = isp_read_reg(dev, REG_ADDR(isp_expv2_size_invert));
REG_SET_SLICE(size_inv, MRV_AE_ISP_EXPV2_SIZE_INVERT_H, h_size);
isp_write_reg(dev, REG_ADDR(isp_expv2_size_invert), size_inv);
return 0;
#endif
}
int isp_s_exp2(struct isp_ic_dev *dev)
{
#ifndef ISP_AEV2
//isp_err("unsupported function: %s\n", __func__);
return -EINVAL;
#else
u32 miv2_ctrl, miv2_mp_fmt, miv2_mp_bus_id, miv2_mp_ctrl, miv2_ctrl_shd;
struct isp_exp2_context *exp2 = &dev->exp2;
u32 isp_expv2_ctrl = isp_read_reg(dev, REG_ADDR(isp_expv2_ctrl));
u32 grid_w, grid_h;
u32 size, offset, size_inv, weight;
isp_info("enter %s\n", __func__);
grid_w = ((exp2->window.width - 1) >> 6) << 1;
grid_h = ((exp2->window.height - 1) >> 6) << 1;
if (!exp2->enable) {
REG_SET_SLICE(isp_expv2_ctrl, MRV_AE_ISP_EXPV2_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_expv2_ctrl), isp_expv2_ctrl);
return 0;
}
size = 0;
REG_SET_SLICE(size, MRV_AE_ISP_EXPV2_SIZE_H, grid_w);
REG_SET_SLICE(size, MRV_AE_ISP_EXPV2_SIZE_V, grid_h);
offset = 0;
REG_SET_SLICE(offset, MRV_AE_ISP_EXPV2_OFFSET_H, exp2->window.x);
REG_SET_SLICE(offset, MRV_AE_ISP_EXPV2_OFFSET_V, exp2->window.y);
size_inv = 0;
REG_SET_SLICE(size_inv, MRV_AE_ISP_EXPV2_SIZE_INVERT_H, (65536 + grid_w/2) / grid_w);
REG_SET_SLICE(size_inv, MRV_AE_ISP_EXPV2_SIZE_INVERT_V, (65536 + grid_h/2) / grid_h);
weight = 0;
REG_SET_SLICE(weight, MRV_AE_ISP_EXPV2_PIX_WEIGHT_R, exp2->r)
REG_SET_SLICE(weight, MRV_AE_ISP_EXPV2_PIX_WEIGHT_GR, exp2->gr)
REG_SET_SLICE(weight, MRV_AE_ISP_EXPV2_PIX_WEIGHT_GB, exp2->gb)
REG_SET_SLICE(weight, MRV_AE_ISP_EXPV2_PIX_WEIGHT_B, exp2->b)
isp_write_reg(dev, REG_ADDR(isp_expv2_offset), offset);
isp_write_reg(dev, REG_ADDR(isp_expv2_size_invert), size_inv);
isp_write_reg(dev, REG_ADDR(isp_expv2_size), size);
#ifdef ISP_AE_SHADOW
isp_write_reg(dev, REG_ADDR(isp_expv2_offset_shd), offset);
isp_write_reg(dev, REG_ADDR(isp_expv2_size_invert_shd), size_inv);
isp_write_reg(dev, REG_ADDR(isp_expv2_size_shd), size);
#endif
isp_write_reg(dev, REG_ADDR(isp_expv2_pixel_weight), weight);
miv2_ctrl = isp_read_reg(dev, REG_ADDR(miv2_ctrl));
REG_SET_SLICE(miv2_ctrl, MP_JDP_PATH_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(miv2_ctrl), miv2_ctrl);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_base_ad_init), dev->exp2.pa);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_size_init), AEV2_DMA_SIZE);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_offs_cnt_init), 0);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_llength), AEV2_DMA_SIZE);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_pic_width), 1024);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_pic_height), 1);
isp_write_reg(dev, REG_ADDR(miv2_mp_jdp_pic_size), AEV2_DMA_SIZE);
REG_SET_SLICE(isp_expv2_ctrl, MRV_AE_ISP_EXPV2_ENABLE, 1);
REG_SET_SLICE(isp_expv2_ctrl, MRV_AE_ISP_EXPV2_INPUT_SELECT, exp2->input_select);
isp_write_reg(dev, REG_ADDR(isp_expv2_ctrl), isp_expv2_ctrl);
miv2_ctrl_shd = isp_read_reg(dev, REG_ADDR(miv2_ctrl_shd));
if (!(miv2_ctrl_shd && MP_YCBCR_PATH_ENABLE_MASK) && !(miv2_ctrl_shd && MP_RAW_PATH_ENABLE_MASK)) {
miv2_mp_fmt = isp_read_reg(dev, REG_ADDR(miv2_mp_fmt));
#ifdef ISP_AEV2_V2
REG_SET_SLICE(miv2_mp_fmt, MP_WR_JDP_DP_BIT, 1);
#endif
REG_SET_SLICE(miv2_mp_fmt, MP_WR_JDP_FMT, 0);
isp_write_reg(dev, REG_ADDR(miv2_mp_fmt), miv2_mp_fmt);
miv2_mp_bus_id = isp_read_reg(dev, REG_ADDR(miv2_mp_bus_id));
REG_SET_SLICE(miv2_mp_bus_id, MP_BUS_SW_EN, 1);
REG_SET_SLICE(miv2_mp_bus_id, MP_WR_ID_EN, 1);
isp_write_reg(dev, REG_ADDR(miv2_mp_bus_id), miv2_mp_bus_id);
miv2_mp_ctrl = isp_read_reg(dev, REG_ADDR(miv2_mp_ctrl));
REG_SET_SLICE(miv2_mp_ctrl, MP_AUTO_UPDATE, 1);
REG_SET_SLICE(miv2_mp_ctrl, MP_INIT_BASE_EN, 1);
REG_SET_SLICE(miv2_mp_ctrl, MP_INIT_OFFSET_EN, 1);
isp_write_reg(dev, REG_ADDR(miv2_mp_ctrl), miv2_mp_ctrl);
}
isp_info("exit %s\n", __func__);
return 0;
#endif
}
int isp_s_2dnr(struct isp_ic_dev *dev)
{
#ifndef ISP_2DNR
//isp_err("unsupported function: %s\n", __func__);
return -EINVAL;
#else
struct isp_2dnr_context *dnr2 = &dev->dnr2;
u32 isp_denoise2d_control =
isp_read_reg(dev, REG_ADDR(isp_denoise2d_control));
u32 value, addr, strength;
u32 isp_ctrl;
int i;
/*isp_info("enter %s\n", __func__);*/
if (!dnr2->enable) {
#ifndef ISP_2DNR_V4
REG_SET_SLICE(isp_denoise2d_control, ISP_2DNR_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_control),
isp_denoise2d_control);
#else
value = isp_read_reg(dev, REG_ADDR(isp_denoise3d2_ctrl));
REG_SET_SLICE(value, DENOISE3D_V20_NLM_ENABLE, 0);
if((value & DENOISE3D_V20_TNR_ENABLE_MASK) == 0)
REG_SET_SLICE(value, DENOISE3D_V20_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(isp_denoise3d2_ctrl),
value);
#endif
return 0;
}
strength = isp_read_reg(dev, REG_ADDR(isp_denoise2d_strength));
REG_SET_SLICE(strength, ISP_2DNR_PRGAMMA_STRENGTH, dnr2->pre_gamma);
REG_SET_SLICE(strength, ISP_2DNR_STRENGTH, dnr2->strength);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_strength), strength);
addr = REG_ADDR(isp_denoise2d_sigma_y[0]);
for (i = 0; i < 60; i += 5) {
value = 0;
REG_SET_SLICE(value, ISP_2DNR_SIGMAY0, dnr2->sigma[i]);
REG_SET_SLICE(value, ISP_2DNR_SIGMAY1, dnr2->sigma[i + 1]);
REG_SET_SLICE(value, ISP_2DNR_SIGMAY2A,
dnr2->sigma[i + 2] >> 6);
isp_write_reg(dev, addr, value);
value = 0;
addr += 4;
REG_SET_SLICE(value, ISP_2DNR_SIGMAY2B,
dnr2->sigma[i + 2] & 0x3f);
REG_SET_SLICE(value, ISP_2DNR_SIGMAY0, dnr2->sigma[i + 3]);
REG_SET_SLICE(value, ISP_2DNR_SIGMAY1, dnr2->sigma[i + 4]);
isp_write_reg(dev, addr, value);
addr += 4;
}
isp_ctrl = isp_read_reg(dev, REG_ADDR(isp_ctrl));
isp_write_reg(dev, REG_ADDR(isp_ctrl), isp_ctrl);
REG_SET_SLICE(isp_denoise2d_control, ISP_2DNR_ENABLE, 1);
#if defined(ISP_2DNR_V2) || defined(ISP_2DNR_V4)
isp_write_reg(dev, REG_ADDR(isp_denoise2d_sigma_sqr), dnr2->sigma_sqr);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_sigma_sqr_shd),
dnr2->sigma_sqr);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_weight_mul_factor),
dnr2->weight);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_weight_mul_factor_shd),
dnr2->weight);
/* refer to HW spec for HBLANK */
//isp_write_reg(dev, REG_ADDR(isp_denoise2d_dummy_hblank), 0);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_strength_shd), strength);
isp_write_reg(dev, REG_ADDR(isp_denoise2d_control_shd),
isp_denoise2d_control);
#endif
#ifndef ISP_2DNR_V4
isp_write_reg(dev, REG_ADDR(isp_denoise2d_control),
isp_denoise2d_control);
#else
value = isp_read_reg(dev, REG_ADDR(isp_denoise3d2_blending));
REG_SET_SLICE(value, DENOISE3D_V20_NLM_STRENGTH_OFFSET, dnr2->str_off);
REG_SET_SLICE(value, DENOISE3D_V20_NLM_STRENGTH_MAX, dnr2->str_max);
REG_SET_SLICE(value, DENOISE3D_V20_NLM_STRENGTH_SLOPE, dnr2->str_slope);
isp_write_reg(dev, REG_ADDR(isp_denoise3d2_blending), value);
value = isp_read_reg(dev, REG_ADDR(isp_denoise3d2_ctrl));
REG_SET_SLICE(value, DENOISE3D_V20_NLM_ENABLE, 1);
REG_SET_SLICE(value, DENOISE3D_V20_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(isp_denoise3d2_ctrl),
value);
#endif
/*isp_info("exit %s\n", __func__);*/
return 0;
#endif
}
int isp_s_simp(struct isp_ic_dev *dev)
{
struct isp_simp_context *simp = &dev->simp;
u32 vi_ircl = isp_read_reg(dev, REG_ADDR(vi_ircl));
u32 vi_iccl = isp_read_reg(dev, REG_ADDR(vi_iccl));
u32 super_imp_ctrl = isp_read_reg(dev, REG_ADDR(super_imp_ctrl));
isp_info("enter %s\n", __func__);
REG_SET_SLICE(vi_ircl, MRV_VI_SIMP_SOFT_RST, 1);
isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
if (!simp->enable) {
REG_SET_SLICE(vi_iccl, MRV_VI_SIMP_CLK_ENABLE, 0);
isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl);
return 0;
}
REG_SET_SLICE(vi_ircl, MRV_VI_SIMP_SOFT_RST, 0);
isp_write_reg(dev, REG_ADDR(super_imp_offset_x), simp->x);
isp_write_reg(dev, REG_ADDR(super_imp_offset_y), simp->y);
isp_write_reg(dev, REG_ADDR(super_imp_color_y), simp->r);
isp_write_reg(dev, REG_ADDR(super_imp_color_cb), simp->g);
isp_write_reg(dev, REG_ADDR(super_imp_color_cr), simp->b);
REG_SET_SLICE(super_imp_ctrl, MRV_SI_TRANSPARENCY_MODE,
simp->transparency_mode);
REG_SET_SLICE(super_imp_ctrl, MRV_SI_REF_IMAGE, simp->ref_image);
isp_write_reg(dev, REG_ADDR(super_imp_ctrl), super_imp_ctrl);
isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
REG_SET_SLICE(vi_iccl, MRV_VI_SIMP_CLK_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl);
isp_info("exit %s\n", __func__);
return 0;
}
int isp_s_cproc(struct isp_ic_dev *dev)
{
struct isp_cproc_context *cproc = &dev->cproc;
u32 vi_iccl = isp_read_reg(dev, REG_ADDR(vi_iccl));
u32 cproc_ctrl = isp_read_reg(dev, REG_ADDR(cproc_ctrl));
//REG_SET_SLICE(vi_ircl, MRV_VI_CP_SOFT_RST, 1);
//isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
//if there is no shd register. should update cporc register in isp frame end irq.
#ifndef ISP_CPROC_SHD
if(dev->cproc.changed || !is_isp_enable(dev))
{
#endif
/*isp_info("enter %s %d\n", __func__, cproc->enable);*/
if (!cproc->enable) {
REG_SET_SLICE(cproc_ctrl, MRV_CPROC_CPROC_ENABLE, 0);
/* REG_SET_SLICE(vi_iccl, MRV_VI_CP_CLK_ENABLE, 0); */
/* isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl); */
isp_write_reg(dev, REG_ADDR(cproc_ctrl), cproc_ctrl);
return 0;
}
//REG_SET_SLICE(vi_ircl, MRV_VI_CP_SOFT_RST, 0);
//isp_write_reg(dev, REG_ADDR(vi_ircl), vi_ircl);
isp_write_reg(dev, REG_ADDR(cproc_contrast), cproc->contrast);
isp_write_reg(dev, REG_ADDR(cproc_brightness), cproc->brightness);
isp_write_reg(dev, REG_ADDR(cproc_saturation), cproc->saturation);
isp_write_reg(dev, REG_ADDR(cproc_hue), cproc->hue);
REG_SET_SLICE(cproc_ctrl, MRV_CPROC_CPROC_ENABLE, 1);
REG_SET_SLICE(cproc_ctrl, MRV_CPROC_CPROC_C_OUT_RANGE,
cproc->c_out_full);
REG_SET_SLICE(cproc_ctrl, MRV_CPROC_CPROC_Y_OUT_RANGE,
cproc->y_out_full);
REG_SET_SLICE(cproc_ctrl, MRV_CPROC_CPROC_Y_IN_RANGE, cproc->y_in_full);
REG_SET_SLICE(vi_iccl, MRV_VI_CP_CLK_ENABLE, 1);
isp_write_reg(dev, REG_ADDR(vi_iccl), vi_iccl);
isp_write_reg(dev, REG_ADDR(cproc_ctrl), cproc_ctrl);
#ifndef ISP_CPROC_SHD
dev->cproc.changed = false;
} else {
dev->cproc.changed = true;
}
#endif
/*isp_info("exit %s\n", __func__);*/
return 0;
}
int isp_s_elawb(struct isp_ic_dev *dev)
{
struct isp_elawb_context *elawb = &dev->elawb;
u32 awb_meas_mode = isp_read_reg(dev, REG_ADDR(awb_meas_mode));
u32 isp_imsc = isp_read_reg(dev, REG_ADDR(isp_imsc));
u32 id = elawb->id;
u32 data;
if (!elawb->enable) {
REG_SET_SLICE(awb_meas_mode, ISP_AWB_MEAS_IRQ_ENABLE, 0);
REG_SET_SLICE(awb_meas_mode, ISP_AWB_MEAS_EN, 0);
isp_write_reg(dev, REG_ADDR(awb_meas_mode), awb_meas_mode);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc & ~MRV_ISP_IMSC_AWB_DONE_MASK);
return 0;
}
isp_write_reg(dev, REG_ADDR(awb_meas_h_offs), elawb->window.x);
isp_write_reg(dev, REG_ADDR(awb_meas_v_offs), elawb->window.y);
isp_write_reg(dev, REG_ADDR(awb_meas_h_size), elawb->window.width);
isp_write_reg(dev, REG_ADDR(awb_meas_v_size), elawb->window.height);
if (id > 0 && id < 9) {
isp_write_reg(dev, REG_ADDR(awb_meas_center[id - 1].x),
elawb->info[id - 1].x);
isp_write_reg(dev, REG_ADDR(awb_meas_center[id - 1].y),
elawb->info[id - 1].y);
isp_write_reg(dev, REG_ADDR(awb_meas_axis[id - 1].a1),
elawb->info[id - 1].a1);
isp_write_reg(dev, REG_ADDR(awb_meas_axis[id - 1].a2),
elawb->info[id - 1].a2);
isp_write_reg(dev, REG_ADDR(awb_meas_axis[id - 1].a3),
elawb->info[id - 1].a3);
isp_write_reg(dev, REG_ADDR(awb_meas_axis[id - 1].a4),
elawb->info[id - 1].a4);
isp_write_reg(dev, REG_ADDR(awb_meas_rmax[id - 1]),
elawb->info[id - 1].r_max_sqr);
}
data = 0;
REG_SET_SLICE(data, MRV_ISP_AWB_GAIN_R, elawb->r);
REG_SET_SLICE(data, MRV_ISP_AWB_GAIN_B, elawb->b);
isp_write_reg(dev, REG_ADDR(isp_awb_gain_rb), data);
data = 0;
REG_SET_SLICE(data, MRV_ISP_AWB_GAIN_GR, elawb->gr);
REG_SET_SLICE(data, MRV_ISP_AWB_GAIN_GB, elawb->gb);
isp_write_reg(dev, REG_ADDR(isp_awb_gain_g), data);
REG_SET_SLICE(awb_meas_mode, ISP_AWB_MEAS_IRQ_ENABLE, 1);
REG_SET_SLICE(awb_meas_mode, ISP_AWB_MEAS_EN, 1);
isp_write_reg(dev, REG_ADDR(awb_meas_mode), awb_meas_mode);
isp_write_reg(dev, REG_ADDR(isp_imsc),
isp_imsc | MRV_ISP_IMSC_AWB_DONE_MASK);
return 0;
}
int isp_ioc_qcap(struct isp_ic_dev *dev, void __user *args)
{
/* use public VIDIOC_QUERYCAP to query the type of v4l-subdevs. */
#ifdef __KERNEL__
#ifndef USE_FPGA
struct v4l2_capability *cap = (struct v4l2_capability *)args;
strcpy((char *)cap->driver, "viv_isp_subdev");
cap->bus_info[0] = (__u8)dev->id;//isp channel id
#else
struct v4l2_capability cap;
strcpy((char *)cap.driver, "viv_isp_subdev");
cap.bus_info[0] = (__u8)dev->id;//isp channel id
isp_info("enter %s viv_isp_subdev\n", __func__);
viv_check_retval(copy_to_user
((struct v4l2_capability *)args, &cap, sizeof(cap)));
#endif
#endif
return 0;
}
int isp_ioc_g_status(struct isp_ic_dev *dev, void __user *args)
{
u32 val = 0;
/* val = isp_read_reg(REG_ADDR(isp_feature_version)); */
viv_check_retval(copy_to_user(args, &val, sizeof(val)));
return 0;
}
static u32 getScaleFactor(u32 src, u32 dst)
{
if (dst > src) {
return ((65536 * (src - 1)) / (dst - 1));
} else if (dst < src) {
return ((65536 * (dst - 1)) / (src - 1)) + 1;
}
return 65536;
}
int isp_set_scaling(int id, struct isp_ic_dev *dev, bool stabilization, bool crop)
{
u32 addr, ctrl;
u32 iw, ih, ow, oh;
u32 inputWidth, inputHeight, outputWidth, outputHeight;
u32 scale_hy, scale_hcb, scale_hcr, scale_vy, scale_vc;
struct isp_mi_data_path_context *path = &dev->mi.path[id];
if (crop) { //enabled crop.Do not need to scaler.
isp_info("%s:The crop enabled ,So does not need to do scaler.\n", __func__);
return 0;
}
if (id == IC_MI_PATH_MAIN) { /* mp */
addr = REG_ADDR(mrsz_ctrl);
} else if (id == IC_MI_PATH_SELF) { /* sp */
addr = REG_ADDR(srsz_ctrl);
} else if (id == IC_MI_PATH_SELF2) { /* sp2 */
addr = REG_ADDR(srsz2_ctrl);
} else {
return -EFAULT;
}
inputWidth = path->in_width;
inputHeight = path->in_height;
outputWidth = path->out_width;
outputHeight = path->out_height;
if (stabilization) { /* enabled image stabilization. */
inputWidth = isp_read_reg(dev, REG_ADDR(isp_is_h_size));
inputHeight = isp_read_reg(dev, REG_ADDR(isp_is_v_size));
}
ctrl = isp_read_reg(dev, addr);
iw = inputWidth / 2;
ih = inputHeight;
ow = outputWidth / 2;
oh = outputHeight;
switch (path->in_mode) {
case IC_MI_DATAMODE_YUV422:
oh = outputHeight;
break;
case IC_MI_DATAMODE_YUV420:
oh = outputHeight / 2; /* scale cbcr */
break;
case IC_MI_DATAMODE_YUV444:
oh = outputHeight;
break;
case IC_MI_DATAMODE_RGB888:
oh = outputHeight;
break;
default:
return -EFAULT;
}
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_HY_ENABLE,
inputWidth != outputWidth);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_VY_ENABLE,
inputHeight != outputHeight);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_HY_UP, inputWidth < outputWidth);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_VY_UP, inputHeight < outputHeight);
scale_hy = getScaleFactor(inputWidth, outputWidth);
scale_vy = getScaleFactor(inputHeight, outputHeight);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_HC_ENABLE, iw != ow);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_VC_ENABLE, ih != oh);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_HC_UP, iw < ow);
REG_SET_SLICE(ctrl, MRV_MRSZ_SCALE_VC_UP, ih < oh);
scale_hcr = getScaleFactor(iw, ow);
scale_hcb = getScaleFactor(iw, ow);
scale_vc = getScaleFactor(ih, oh);
/*Need to update immediately*/
REG_SET_SLICE(ctrl, MRV_MRSZ_CFG_UPD, 1);
if (id == IC_MI_PATH_MAIN) {
isp_write_reg(dev, REG_ADDR(mrsz_scale_vc), scale_vc);
isp_write_reg(dev, REG_ADDR(mrsz_scale_vy), scale_vy);
isp_write_reg(dev, REG_ADDR(mrsz_scale_hcr), scale_hcr);
isp_write_reg(dev, REG_ADDR(mrsz_scale_hcb), scale_hcb);
isp_write_reg(dev, REG_ADDR(mrsz_scale_hy), scale_hy);
isp_write_reg(dev, REG_ADDR(mrsz_ctrl), ctrl);
} else if (id == IC_MI_PATH_SELF) {
isp_write_reg(dev, REG_ADDR(srsz_scale_vc), scale_vc);
isp_write_reg(dev, REG_ADDR(srsz_scale_vy), scale_vy);
isp_write_reg(dev, REG_ADDR(srsz_scale_hcr), scale_hcr);
isp_write_reg(dev, REG_ADDR(srsz_scale_hcb), scale_hcb);
isp_write_reg(dev, REG_ADDR(srsz_scale_hy), scale_hy);
isp_write_reg(dev, REG_ADDR(srsz_ctrl), ctrl);
} else if (id == IC_MI_PATH_SELF2) {
isp_write_reg(dev, REG_ADDR(srsz2_scale_vc), scale_vc);
isp_write_reg(dev, REG_ADDR(srsz2_scale_vy), scale_vy);
isp_write_reg(dev, REG_ADDR(srsz2_scale_hcr), scale_hcr);
isp_write_reg(dev, REG_ADDR(srsz2_scale_hcb), scale_hcb);
isp_write_reg(dev, REG_ADDR(srsz2_scale_hy), scale_hy);
isp_write_reg(dev, REG_ADDR(srsz2_ctrl), ctrl);
}
return 0;
}
typedef struct isp_crop_reg_s {
u32 crop_ctrl_addr;
u32 crop_x_dir_addr;
u32 crop_y_dir_addr;
} isp_crop_reg_t;
int isp_set_crop(struct isp_ic_dev *dev)
{
long ret = 0;
u32 crop_ctrl, crop_x_dir, crop_y_dir;
u8 i;
isp_crop_reg_t crop_reg[ISP_MI_PATH_SP2_BP + 1] = {
{
REG_ADDR(mrsz_ctrl),
REG_ADDR(mrsz_phase_crop_x),
REG_ADDR(mrsz_phase_crop_y)
},
{
REG_ADDR(srsz_ctrl),
REG_ADDR(srsz_phase_crop_x),
REG_ADDR(srsz_phase_crop_y)
},
{
REG_ADDR(srsz2_ctrl),
REG_ADDR(srsz2_phase_crop_x),
REG_ADDR(srsz2_phase_crop_y)
}
};
struct isp_crop_context *crop = dev->crop;
for ( i = 0; i <= ISP_MI_PATH_SP2_BP; i++) {
crop_ctrl = isp_read_reg(dev, crop_reg[i].crop_ctrl_addr);
crop_x_dir = isp_read_reg(dev, crop_reg[i].crop_x_dir_addr);
crop_y_dir = isp_read_reg(dev, crop_reg[i].crop_y_dir_addr);
if (!crop[i].enabled) {
#ifndef ISP8000NANO_BASE
REG_SET_SLICE(crop_ctrl, MRV_MRSZ_CROP_ENABLE, 0);
#endif
isp_write_reg(dev, crop_reg[i].crop_ctrl_addr, crop_ctrl);
continue;
}
REG_SET_SLICE(crop_x_dir, MRV_MRSZ_PHASE_H_START, crop[i].window.x);
REG_SET_SLICE(crop_y_dir, MRV_MRSZ_PHASE_V_START, crop[i].window.y);
REG_SET_SLICE(crop_x_dir, MRV_MRSZ_PHASE_H_END, crop[i].window.width + crop[i].window.x - 1); //x_end = x + width -1
REG_SET_SLICE(crop_y_dir, MRV_MRSZ_PHASE_V_END, crop[i].window.height + crop[i].window.y - 1); //y_end = y + height -1
#ifndef ISP8000NANO_BASE
REG_SET_SLICE(crop_ctrl, MRV_MRSZ_CROP_ENABLE, 1);
/*Need to update immediately*/
REG_SET_SLICE(crop_ctrl, MRV_MRSZ_CFG_UPD, 1);
#endif
isp_write_reg(dev, crop_reg[i].crop_x_dir_addr, crop_x_dir);
isp_write_reg(dev, crop_reg[i].crop_y_dir_addr, crop_y_dir);
isp_write_reg(dev, crop_reg[i].crop_ctrl_addr, crop_ctrl);
}
return ret;
}
int isp_ioc_g_feature(struct isp_ic_dev *dev, void __user *args)
{
u32 val = 0;
#ifdef ISP_EE
val |= ISP_EE_SUPPORT;
#endif
#ifdef ISP_WDR3
val |= ISP_WDR3_SUPPORT;
#endif
#ifdef ISP_2DNR
val |= ISP_2DNR_SUPPORT;
#endif
#ifdef ISP_3DNR
val |= ISP_3DNR_SUPPORT;
#endif
#ifdef ISP_WDR_V3
val |= ISP_WDR3_SUPPORT;
#endif
#ifdef ISP_MIV2
val |= ISP_MIV2_SUPPORT;
#endif
#ifdef ISP_AEV2
val |= ISP_AEV2_SUPPORT;
#endif
#ifdef ISP_HDR_STITCH
val |= ISP_HDR_STITCH_SUPPORT;
#endif
viv_check_retval(copy_to_user(args, &val, sizeof(val)));
return 0;
}
int isp_ioc_g_feature_veresion(struct isp_ic_dev *dev, void __user *args)
{
u32 val = 0;
/* val = isp_read_reg(REG_ADDR(isp_feature_version)); */
viv_check_retval(copy_to_user(args, &val, sizeof(val)));
return 0;
}
static long isp_get_extmem(struct isp_ic_dev *dev, void __user *args)
{
#define UT_USED_SIZE 0x01000000
long ret = 0;
struct isp_extmem_info ext_mem;
dev->ut_addr = dma_alloc_coherent(dev->device, UT_USED_SIZE, &dev->ut_phy_addr, GFP_KERNEL);
if (dev->ut_addr != NULL) {
ext_mem.addr = dev->ut_phy_addr;
ext_mem.size = UT_USED_SIZE;
} else {
return -1;
}
ret = copy_to_user(args, &ext_mem, sizeof(struct isp_extmem_info));
return ret;
}
long isp_priv_ioctl(struct isp_ic_dev *dev, unsigned int cmd, void __user *args)
{
int ret = -1;
if (!dev) {
return ret;
}
/*pr_info("[%s:%d]cmd 0x%08x\n", __func__, __LINE__, cmd);*/
switch (cmd) {
case ISPIOC_RESET:
if((ret = isp_mi_stop(dev)) != 0 )
{
pr_err("[%s:%d]stop mi error before resetting!\n", __func__, __LINE__);
break;
}
if((ret = isp_stop_stream(dev)) != 0)
{
pr_err("[%s:%d]stop isp stream before resetting!\n", __func__, __LINE__);
break;
}
ret = isp_reset(dev);
break;
case ISPIOC_WRITE_REG:
ret = isp_ioc_write_reg(dev, args);
break;
case ISPIOC_READ_REG:
ret = isp_ioc_read_reg(dev, args);
break;
case ISPIOC_GET_MIS:
ret = isp_ioc_read_mis(dev, args);
break;
case ISPIOC_ENABLE_TPG:
ret = isp_enable_tpg(dev);
break;
case ISPIOC_DISABLE_TPG:
ret = isp_disable_tpg(dev);
break;
case ISPIOC_ENABLE_BLS:
ret = isp_enable_bls(dev);
break;
case ISPIOC_DISABLE_BLS:
ret = isp_disable_bls(dev);
break;
case ISPIOC_START_DMA_READ:
ret = isp_ioc_start_dma_read(dev, args);
break;
case ISPIOC_CFG_DMA:
ret = isp_ioc_cfg_dma(dev, args);
break;
case ISPIOC_MI_STOP:
ret = isp_mi_stop(dev);
break;
case ISPIOC_DISABLE_ISP_OFF:
ret = isp_ioc_disable_isp_off(dev, args);
break;
case ISPIOC_ISP_STOP:
ret = isp_stop_stream(dev);
if(!ret) {
dev->streaming = false;
}
break;
case ISPIOC_ENABLE:
ret = isp_enable(dev);
break;
case ISPIOC_DISABLE:
ret = isp_disable(dev);
break;
case ISPIOC_ISP_STATUS:{
bool enable = is_isp_enable(dev);
viv_check_retval(copy_to_user
(args, &enable, sizeof(bool)));
ret = 0;
break;
}
case ISPIOC_ENABLE_LSC:
ret = isp_enable_lsc(dev);
break;
case ISPIOC_DISABLE_LSC:
ret = isp_disable_lsc(dev);
break;
case ISPIOC_S_DIGITAL_GAIN:
viv_check_retval(copy_from_user
(&dev->dgain, args, sizeof(dev->dgain)));
ret = isp_s_digital_gain(dev);
break;
#ifdef ISP_DEMOSAIC2
case ISPIOC_S_DMSC_INTP:
viv_check_retval(copy_from_user
(&dev->demosaic.intp, args,
sizeof(dev->demosaic.intp)));
ret = isp_set_dmsc_intp(dev);
break;
case ISPIOC_S_DMSC_DMOI:
viv_check_retval(copy_from_user
(&dev->demosaic.demoire, args,
sizeof(dev->demosaic.demoire)));
ret = isp_set_dmsc_dmoi(dev);
break;
case ISPIOC_S_DMSC_SKIN:
viv_check_retval(copy_from_user
(&dev->demosaic.skin, args,
sizeof(dev->demosaic.skin)));
ret = isp_set_dmsc_skin(dev);
break;
case ISPIOC_S_DMSC_SHAP:
viv_check_retval(copy_from_user
(&dev->demosaic.sharpen, args,
sizeof(dev->demosaic.sharpen)));
ret = isp_set_dmsc_sharpen(dev);
break;
case ISPIOC_S_DMSC_SHAP_LINE:
viv_check_retval(copy_from_user
(&dev->demosaic.sharpenLine, args,
sizeof(dev->demosaic.sharpenLine)));
ret = isp_set_dmsc_sharpen_line(dev);
break;
case ISPIOC_S_DMSC_CAC:
viv_check_retval(copy_from_user
(&dev->cac, args, sizeof(dev->cac)));
ret = isp_set_dmsc_cac(dev);
break;
case ISPIOC_S_DMSC_DEPURPLE:
viv_check_retval(copy_from_user
(&dev->demosaic.depurple, args,
sizeof(dev->demosaic.depurple)));
ret = isp_set_dmsc_depurple(dev);
break;
case ISPIOC_S_DMSC_GFILTER:
viv_check_retval(copy_from_user
(&dev->demosaic.gFilter, args,
sizeof(dev->demosaic.gFilter)));
ret = isp_set_dmsc_gfilter(dev);
break;
case ISPIOC_S_DMSC:
viv_check_retval(copy_from_user
(&dev->demosaic, args, sizeof(dev->demosaic)));
ret = isp_s_dmsc(dev);
break;
#endif
case ISPIOC_ENABLE_AWB:
ret = isp_enable_awb(dev);
break;
case ISPIOC_DISABLE_AWB:
ret = isp_disable_awb(dev);
break;
case ISPIOC_ENABLE_WB:
ret = isp_enable_wb(dev, 1);
break;
case ISPIOC_DISABLE_WB:
ret = isp_enable_wb(dev, 0);
break;
case ISPIOC_ENABLE_GAMMA_OUT:
ret = isp_enable_gamma_out(dev, 1);
break;
case ISPIOC_DISABLE_GAMMA_OUT:
ret = isp_enable_gamma_out(dev, 0);
break;
#if defined(ISP_3DNR) || defined(ISP_3DNR_V2_V1)
case ISPIOC_R_3DNR:
viv_check_retval(copy_from_user
(&dev->dnr3, args, sizeof(dev->dnr3)));
ret = isp_r_3dnr(dev);
break;
#endif
case ISPIOC_S_IS:
viv_check_retval(copy_from_user
(&dev->is, args, sizeof(dev->is)));
ret = isp_s_is(dev);
break;
case ISPIOC_S_RAW_IS:
viv_check_retval(copy_from_user
(&dev->rawis, args, sizeof(dev->rawis)));
ret = isp_s_raw_is(dev);
break;
case ISPIOC_S_CC:
viv_check_retval(copy_from_user
(&dev->cc, args, sizeof(dev->cc)));
ret = isp_s_cc(dev);
break;
case ISPIOC_S_EE:
viv_check_retval(copy_from_user
(&dev->ee, args, sizeof(dev->ee)));
ret = isp_s_ee(dev);
break;
case ISPIOC_S_IE:
viv_check_retval(copy_from_user
(&dev->ie, args, sizeof(dev->ie)));
ret = isp_s_ie(dev);
break;
case ISPIOC_S_TPG:
viv_check_retval(copy_from_user
(&dev->tpg, args, sizeof(dev->tpg)));
ret = isp_s_tpg(dev);
break;
case ISPIOC_S_BLS:
viv_check_retval(copy_from_user
(&dev->bls, args, sizeof(dev->bls)));
ret = isp_s_bls(dev);
break;
case ISPIOC_BYPASS_MCM:
viv_check_retval(copy_from_user
(&dev->mcm, args, sizeof(dev->mcm)));
ret = isp_bypass_mcm(dev);
break;
case ISPIOC_S_MCM_WR:
viv_check_retval(copy_from_user
(&dev->mcm, args, sizeof(dev->mcm)));
ret = isp_s_mcm_wr(dev);
break;
case ISPIOC_S_MUX:
viv_check_retval(copy_from_user
(&dev->mux, args, sizeof(dev->mux)));
ret = isp_s_mux(dev);
break;
case ISPIOC_S_AWB:
viv_check_retval(copy_from_user
(&dev->awb, args, sizeof(dev->awb)));
ret = isp_s_awb(dev);
break;
case ISPIOC_S_LSC_TBL:
viv_check_retval(copy_from_user
(&dev->lsc, args, sizeof(dev->lsc)));
ret = isp_s_lsc_tbl(dev);
break;
case ISPIOC_S_LSC_SEC:
viv_check_retval(copy_from_user
(&dev->lsc, args, sizeof(dev->lsc)));
ret = isp_s_lsc_sec(dev);
break;
case ISPIOC_S_DPF:
viv_check_retval(copy_from_user
(&dev->dpf, args, sizeof(dev->dpf)));
ret = isp_s_dpf(dev);
break;
case ISPIOC_S_EXP:
viv_check_retval(copy_from_user
(&dev->exp, args, sizeof(dev->exp)));
ret = isp_s_exp(dev);
break;
case ISPIOC_S_HDREXP:
viv_check_retval(copy_from_user
(&dev->hdrexp, args, sizeof(dev->hdrexp)));
ret = isp_s_hdrexp(dev);
break;
case ISPIOC_S_CNR:
viv_check_retval(copy_from_user
(&dev->cnr, args, sizeof(dev->cnr)));
ret = isp_s_cnr(dev);
break;
case ISPIOC_S_FLT:
{
viv_check_retval(copy_from_user
(&dev->flt, args, sizeof(dev->flt)));
ret = isp_s_flt(dev);
break;
}
case ISPIOC_S_CAC:
viv_check_retval(copy_from_user
(&dev->cac, args, sizeof(dev->cac)));
ret = isp_s_cac(dev);
break;
case ISPIOC_S_DEG:
viv_check_retval(copy_from_user
(&dev->deg, args, sizeof(dev->deg)));
ret = isp_s_deg(dev);
break;
case ISPIOC_S_VSM:
viv_check_retval(copy_from_user
(&dev->vsm, args, sizeof(dev->vsm)));
ret = isp_s_vsm(dev);
break;
case ISPIOC_S_AFM:
viv_check_retval(copy_from_user
(&dev->afm, args, sizeof(dev->afm)));
ret = isp_s_afm(dev);
break;
case ISPIOC_S_HDR:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
ret = isp_s_hdr(dev);
break;
case ISPIOC_ENABLE_HDR:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
ret = isp_enable_hdr(dev);
break;
case ISPIOC_DISABLE_HDR:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
ret = isp_disable_hdr(dev);
break;
case ISPIOC_S_HIST:
viv_check_retval(copy_from_user
(&dev->hist, args, sizeof(dev->hist)));
ret = isp_s_hist(dev);
break;
case ISPIOC_S_HDRHIST:
viv_check_retval(copy_from_user
(&dev->hdrhist, args, sizeof(dev->hdrhist)));
ret = isp_s_hdrhist(dev);
break;
#ifdef ISP_HIST64
case ISPIOC_S_HIST64:
viv_check_retval(copy_from_user
(&dev->hist64, args, sizeof(dev->hist64)));
ret = isp_s_hist64(dev);
break;
case ISPIOC_U_HIST64:
viv_check_retval(copy_from_user
(&dev->hist64, args, sizeof(dev->hist64)));
ret = isp_update_hist64(dev);
break;
#endif
case ISPIOC_S_DPCC:
viv_check_retval(copy_from_user
(&dev->dpcc, args, sizeof(dev->dpcc)));
ret = isp_s_dpcc(dev);
break;
case ISPIOC_ENABLE_WDR3:
ret = isp_enable_wdr3(dev);
break;
case ISPIOC_DISABLE_WDR3:
ret = isp_disable_wdr3(dev);
break;
case ISPIOC_U_WDR3:
viv_check_retval(copy_from_user
(&dev->wdr3, args, sizeof(dev->wdr3)));
ret = isp_u_wdr3(dev);
break;
case ISPIOC_S_WDR3:
viv_check_retval(copy_from_user
(&dev->wdr3, args, sizeof(dev->wdr3)));
ret = isp_s_wdr3(dev);
break;
#ifdef ISP_WDR_V4
case ISPIOC_ENABLE_WDR4:
ret = isp_enable_wdr4(dev);
break;
case ISPIOC_DISABLE_WDR4:
ret = isp_disable_wdr4(dev);
break;
case ISPIOC_U_WDR4:
viv_check_retval(copy_from_user
(&dev->wdr4, args, sizeof(dev->wdr4)));
ret = isp_u_wdr4(dev);
break;
case ISPIOC_S_WDR4:
viv_check_retval(copy_from_user
(&dev->wdr4, args, sizeof(dev->wdr4)));
ret = isp_s_wdr4(dev);
break;
#endif
case ISPIOC_S_EXP2:
viv_check_retval(copy_from_user
(&dev->exp2, args, sizeof(dev->exp2)));
ret = isp_s_exp2(dev);
break;
case ISPIOC_S_EXP2_INPUTSEL:
viv_check_retval(copy_from_user
(&dev->exp2.input_select, args,
sizeof(dev->exp2.input_select)));
ret = isp_s_exp2_inputsel(dev);
break;
case ISPIOC_S_EXP2_SIZERATIO: {
u32 ratio;
viv_check_retval(copy_from_user(&ratio, args, sizeof(ratio)));
ret = isp_s_exp2_sizeratio(dev, ratio);
break;
}
case ISPIOC_S_2DNR:
viv_check_retval(copy_from_user
(&dev->dnr2, args, sizeof(dev->dnr2)));
#ifdef ISP_2DNR_V5
ret = isp_tdnr_s_2dnr(dev);
#else
ret = isp_s_2dnr(dev);
#endif
break;
case ISPIOC_S_SIMP:
viv_check_retval(copy_from_user
(&dev->simp, args, sizeof(dev->simp)));
ret = isp_s_simp(dev);
break;
case ISPIOC_S_COMP:
viv_check_retval(copy_from_user
(&dev->comp, args, sizeof(dev->comp)));
ret = isp_s_comp(dev);
break;
case ISPIOC_S_CPROC:
viv_check_retval(copy_from_user
(&dev->cproc, args, sizeof(dev->cproc)));
ret = isp_s_cproc(dev);
break;
case ISPIOC_S_XTALK:
viv_check_retval(copy_from_user
(&dev->xtalk, args, sizeof(dev->xtalk)));
ret = isp_s_xtalk(dev);
break;
case ISPIOC_S_ELAWB:
viv_check_retval(copy_from_user
(&dev->elawb, args, sizeof(dev->elawb)));
ret = isp_s_elawb(dev);
break;
case ISPIOC_S_INPUT:
viv_check_retval(copy_from_user
(&dev->ctx, args, sizeof(dev->ctx)));
ret = isp_s_input(dev);
break;
case ISPIOC_S_DEMOSAIC:
viv_check_retval(copy_from_user
(&dev->ctx, args, sizeof(dev->ctx)));
ret = isp_s_demosaic(dev);
break;
case ISPIOC_MI_START:
viv_check_retval(copy_from_user
(&dev->mi, args, sizeof(dev->mi)));
ret = isp_mi_start(dev);
break;
case ISPIOC_S_HDR_WB:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
ret = isp_s_hdr_wb(dev);
break;
case ISPIOC_S_HDR_BLS:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
ret = isp_s_hdr_bls(dev);
break;
case ISPIOC_S_HDR_DIGITAL_GAIN:
viv_check_retval(copy_from_user
(&dev->hdr, args, sizeof(dev->hdr)));
// ret = isp_s_hdr_digal_gain(dev);
break;
case ISPIOC_S_GAMMA_OUT:{
viv_check_retval(copy_from_user
(&dev->gamma_out, args,
sizeof(dev->gamma_out)));
ret = isp_s_gamma_out(dev);
break;
}
case ISPIOC_SET_BUFFER:{
struct isp_buffer_context buf;
viv_check_retval(copy_from_user
(&buf, args, sizeof(buf)));
#if defined(__KERNEL__) && defined(ENABLE_IRQ)
if (dev->alloc)
ret = dev->alloc(dev, &buf);
#else
ret = isp_set_buffer(dev, &buf);
#endif
break;
}
case ISPIOC_SET_BP_BUFFER:{
struct isp_bp_buffer_context buf;
viv_check_retval(copy_from_user
(&buf, args, sizeof(buf)));
ret = isp_set_bp_buffer(dev, &buf);
break;
}
case ISPIOC_START_CAPTURE:{
u32 num;
viv_check_retval(copy_from_user
(&num, args, sizeof(num)));
ret = isp_start_stream(dev, num);
if(!ret) {
dev->streaming = true;
}
break;
}
#if defined(ISP_3DNR_V2) || defined(ISP_3DNR_V2_V1)
case ISPIOC_S_3DNR_CMP: {
viv_check_retval(
copy_from_user(&dev->dnr3.compress, args, sizeof(dev->dnr3.compress)));
ret = isp_s_3dnr_cmp(dev);
break;
}
#endif
#if defined(ISP_3DNR) || defined(ISP_3DNR_V2)
case ISPIOC_U_3DNR:{
struct isp_3dnr_update param;
viv_check_retval(copy_from_user
(&param, args, sizeof(param)));
ret = isp_u_3dnr(dev, &param);
break;
}
case ISPIOC_S_3DNR:
viv_check_retval(copy_from_user
(&dev->dnr3, args, sizeof(dev->dnr3)));
ret = isp_s_3dnr(dev);
break;
case ISPIOC_U_3DNR_STRENGTH: {
viv_check_retval(
copy_from_user(&dev->dnr3, args, sizeof(dev->dnr3)));
ret = isp_u_3dnr_strength(dev);
break;
}
case ISPIOC_S_3DNR_MOT:{
viv_check_retval(copy_from_user
(&dev->dnr3, args, sizeof(dev->dnr3)));
ret = isp_s_3dnr_motion(dev);
break;
}
case ISPIOC_S_3DNR_DLT:{
viv_check_retval(copy_from_user
(&dev->dnr3, args, sizeof(dev->dnr3)));
ret = isp_s_3dnr_delta(dev);
break;
}
case ISPIOC_G_3DNR:{
u32 avg;
ret = isp_g_3dnr(dev, &avg);
viv_check_retval(copy_to_user(args, &avg, sizeof(avg)));
break;
}
#endif
case ISPIOC_G_AWBMEAN:{
struct isp_awb_mean mean;
ret = isp_g_awbmean(dev, &mean);
viv_check_retval(copy_to_user
(args, &mean, sizeof(mean)));
break;
}
case ISPIOC_G_EXPMEAN:{
u8 mean[25];
ret = isp_g_expmean(dev, mean);
viv_check_retval(copy_to_user
(args, mean, sizeof(mean)));
break;
}
case ISPIOC_G_HDREXPMEAN:{
u8 mean[75];
ret = isp_g_hdrexpmean(dev, mean);
viv_check_retval(copy_to_user
(args, mean, sizeof(mean)));
break;
}
case ISPIOC_G_HISTMEAN:{
u32 mean[HIST_BIN_TOTAL];
ret = isp_g_histmean(dev, mean);
viv_check_retval(copy_to_user
(args, mean, sizeof(mean)));
break;
}
case ISPIOC_G_HDRHISTMEAN:{
u32 mean[48];
ret = isp_g_hdrhistmean(dev, mean);
viv_check_retval(copy_to_user
(args, mean, sizeof(mean)));
break;
}
#ifdef ISP_HIST64
case ISPIOC_G_HIST64MEAN:{
u32 mean[HIST64_BIN_TOTAL];
ret = isp_g_hist64mean(dev, mean);
viv_check_retval(copy_to_user
(args, mean, sizeof(mean)));
break;
}
case ISPIOC_G_HIST64VSTART_STATUS:{
u32 status = 0;
ret = isp_g_hist64_vstart_status(dev, &status);
viv_check_retval(copy_to_user
(args, &status, sizeof(status)));
break;
}
#endif
case ISPIOC_G_VSM:{
struct isp_vsm_result vsm;
ret = isp_g_vsm(dev, &vsm);
viv_check_retval(copy_to_user(args, &vsm, sizeof(vsm)));
break;
}
case ISPIOC_G_AFM:{
struct isp_afm_result afm;
ret = isp_g_afm(dev, &afm);
viv_check_retval(copy_to_user(args, &afm, sizeof(afm)));
break;
}
case ISPIOC_G_STATUS:
ret = isp_ioc_g_status(dev, args);
break;
case ISPIOC_G_FEATURE:
ret = isp_ioc_g_feature(dev, args);
break;
case ISPIOC_G_FEATURE_VERSION:
ret = isp_ioc_g_feature_veresion(dev, args);
break;
case ISPIOC_WDR_CONFIG:
viv_check_retval(copy_from_user
(&dev->wdr, args, sizeof(dev->wdr)));
ret = isp_s_wdr(dev);
break;
case ISPIOC_S_WDR_CURVE:
viv_check_retval(copy_from_user
(&dev->wdr, args, sizeof(dev->wdr)));
ret = isp_s_wdr_curve(dev);
break;
case ISPIOC_ENABLE_GCMONO:
viv_check_retval(copy_from_user
(&dev->gcmono.mode, args, sizeof(u32)));
ret = isp_enable_gcmono(dev);
break;
case ISPIOC_DISABLE_GCMONO:
ret = isp_disable_gcmono(dev);
break;
case ISPIOC_S_GCMONO:{
struct isp_gcmono_data *data;
#ifdef __KERNEL__
data = (struct isp_gcmono_data *)
kmalloc(sizeof(struct isp_gcmono_data), GFP_KERNEL);
#else
data = (struct isp_gcmono_data *)
malloc(sizeof(struct isp_gcmono_data));
#endif
if (data == NULL) {
isp_err("%s, malloc mem for rgb gamma failed.", __func__);
ret = -1;
} else {
viv_check_retval(copy_from_user
(data, args,
sizeof(struct
isp_gcmono_data)));
ret = isp_s_gcmono(dev, data);
#ifdef __KERNEL__
kfree(data);
#else
free(data);
#endif
}
break;
}
case ISPIOC_ENABLE_RGBGAMMA:
ret = isp_enable_rgbgamma(dev);
break;
case ISPIOC_DISABLE_RGBGAMMA:
ret = isp_disable_rgbgamma(dev);
break;
case ISPIOC_S_RGBGAMMA:{
struct isp_rgbgamma_data *data;
#ifdef __KERNEL__
data = (struct isp_rgbgamma_data *)
kmalloc(sizeof(struct isp_rgbgamma_data),
GFP_KERNEL);
#else
data = (struct isp_rgbgamma_data *)
malloc(sizeof(struct isp_rgbgamma_data));
#endif
if (data == NULL) {
isp_err("%s, malloc mem for rgb gamma failed.", __func__);
ret = -1;
} else {
viv_check_retval(copy_from_user
(data, args,
sizeof(struct
isp_rgbgamma_data)));
ret = isp_s_rgbgamma(dev, data);
#ifdef __KERNEL__
kfree(data);
#else
free(data);
#endif
}
break;
}
case ISPIOC_S_GREENEQUILIBRATE:
viv_check_retval(copy_from_user
(&dev->ge, args, sizeof(dev->ge)));
ret = isp_s_ge(dev);
break;
case ISPIOC_S_COLOR_ADJUST:
viv_check_retval(copy_from_user
(&dev->ca, args, sizeof(dev->ca)));
ret = isp_s_ca(dev);
break;
#ifdef __KERNEL__
case VIDIOC_QUERYCAP:
ret = isp_ioc_qcap(dev, args);
break;
#endif
case ISPIOC_G_QUERY_EXTMEM:
ret = isp_get_extmem(dev, args);
break;
case ISPIOC_ENABLE_RGBIR:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_enable_rgbir(dev);
break;
case ISPIOC_S_RGBIR:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_s_rgbir(dev);
break;
case ISPIOC_RGBIR_HW_INIT:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_hw_init(dev);
break;
case ISPIOC_RGBIR_S_IR_DNR:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_ir_dnr(dev);
break;
case ISPIOC_RGBIR_S_SHARPEN:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_sharpen(dev);
break;
case ISPIOC_RGBIR_S_DES:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_des(dev);
break;
case ISPIOC_RGBIR_S_CC_MATRIX:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_cc_matrix(dev);
break;
case ISPIOC_RGBIR_S_DPCC:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_dpcc(dev);
break;
case ISPIOC_RGBIR_S_GAIN:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_gain(dev);
break;
case ISPIOC_RGBIR_S_BLS:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_s_bls(dev);
break;
case ISPIOC_RGBIR_S_IR_RAW_OUT:
viv_check_retval(copy_from_user
(&dev->rgbir, args, sizeof(dev->rgbir)));
ret = isp_rgbir_out_ir_raw(dev);
break;
case ISPIOC_S_CROP:
viv_check_retval(copy_from_user
(&dev->crop, args, sizeof(struct isp_crop_context) * 3));
ret = isp_set_crop(dev);
break;
#ifdef ISP_3DNR_V3
case ISPIOC_S_TDNR:
viv_check_retval(copy_from_user
(&dev->tdnr, args, sizeof(dev->tdnr)));
ret = isp_s_tdnr(dev);
break;
case ISPIOC_TDNR_ENABLE:
ret = isp_tdnr_enable(dev);
break;
case ISPIOC_TDNR_DISABLE:
ret = isp_tdnr_disable(dev);
break;
case ISPIOC_TDNR_ENABLE_TDNR:
ret = isp_tdnr_enable_tdnr(dev);
break;
case ISPIOC_TDNR_DISABLE_TDNR:
ret = isp_tdnr_disable_tdnr(dev);
break;
case ISPIOC_TDNR_ENABLE_2DNR:
ret = isp_tdnr_enable_2dnr(dev);
break;
case ISPIOC_TDNR_DISABLE_2DNR:
ret = isp_tdnr_disable_2dnr(dev);
break;
case ISPIOC_S_TDNR_CURVE:
viv_check_retval(copy_from_user
(&dev->tdnr.curve, args, sizeof(dev->tdnr.curve)));
ret = isp_tdnr_cfg_gamma(dev);
break;
case ISPIOC_G_TDNR: {
struct isp_tdnr_stats stats;
ret = isp_tdnr_g_stats(dev, &stats);
viv_check_retval(copy_to_user(args, &stats, sizeof(stats)));
}
break;
case ISPIOC_S_TDNR_STRENGTH:
viv_check_retval(copy_from_user
(&dev->tdnr, args, sizeof(dev->tdnr)));
ret = isp_tdnr_set_strength(dev);
break;
case ISPIOC_U_TDNR_NOISE:
viv_check_retval(copy_from_user
(&dev->tdnr, args, sizeof(dev->tdnr)));
ret = isp_tdnr_u_noise(dev);
break;
case ISPIOC_U_TDNR_THR:
viv_check_retval(copy_from_user
(&dev->tdnr, args, sizeof(dev->tdnr)));
ret = isp_tdnr_u_thr(dev);
break;
case ISPIOC_R_TDNR_REFER:
ret = isp_r_tdnr_refer(dev);
break;
case ISPIOC_R_TDNR_MOTION:
ret = isp_r_tdnr_motion(dev);
break;
case ISPIOC_S_TDNR_BUF:
viv_check_retval(copy_from_user
(&dev->tdnr.buf, args, sizeof(dev->tdnr.buf)));
ret = isp_tdnr_s_buf(dev);
break;
#endif
#ifdef ISP_MI_PP_WRITE
case ISPIOC_GET_PPW_LINE_CNT:
{
u16 ppw_pic_cnt;
ret = isp_get_ppw_pic_cnt(dev, &ppw_pic_cnt);
viv_check_retval(copy_to_user
(args, &ppw_pic_cnt, sizeof(ppw_pic_cnt)));
break;
}
case ISPIOC_SET_PPW_LINE_NUM:
{
viv_check_retval(copy_from_user
(&dev->pp_write, args, sizeof(dev->pp_write)));
ret = isp_set_ppw_line_num(dev);
break;
}
#endif
#ifdef ISP_MI_PP_READ
case ISPIOC_CFG_DMA_LINE_ENTRY:
viv_check_retval(copy_from_user
(&dev->pp_dma_line_entry, args, sizeof(dev->pp_dma_line_entry)));
ret = isp_cfg_pp_dma_line_entry(dev);
break;
#endif
case ISPIOC_GET_FRAME_MASK_INFO_ADDR: {
unsigned long addr;
addr = dev->frame_mark_info_addr;
pr_info("ISPIOC_GET_FRAME_MASK_INFO_ADDR %lx\n", addr);
viv_check_retval(copy_to_user(args, &addr, sizeof(addr)));
ret = 0;
}
break;
default:
isp_err("unsupported command %d", cmd);
break;
}
if (cmd != ISPIOC_WRITE_REG) //frame end isp update shd registers.
ISP_GEN_CFG_UPDATE(dev);
return ret;
}