SmartAudio/lichee/linux-4.9/drivers/media/platform/sunxi-vin/top_reg.h

64 lines
1.9 KiB
C

/*
* linux-4.9/drivers/media/platform/sunxi-vin/top_reg.h
*
* Copyright (c) 2007-2017 Allwinnertech Co., Ltd.
*
* This software is licensed under the terms of the GNU General Public
* License version 2, as published by the Free Software Foundation, and
* may be copied, distributed, and modified under those terms.
*
* 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.
*
*/
#ifndef __CSIC__TOP__REG__H__
#define __CSIC__TOP__REG__H__
#include <linux/types.h>
#define MAX_CSIC_TOP_NUM 2
/*register value*/
/*register data struct*/
struct csic_feature_list {
unsigned int dma_num;
unsigned int vipp_num;
unsigned int isp_num;
unsigned int ncsi_num;
unsigned int mcsi_num;
unsigned int parser_num;
};
struct csic_version {
unsigned int ver_big;
unsigned int ver_small;
};
int csic_top_set_base_addr(unsigned int sel, unsigned long addr);
void csic_top_enable(unsigned int sel);
void csic_top_disable(unsigned int sel);
void csic_top_sram_pwdn(unsigned int sel, unsigned int en);
void csic_top_version_read_en(unsigned int sel, unsigned int en);
void csic_isp_input_select(unsigned int sel, unsigned int isp, unsigned int in,
unsigned int psr, unsigned int ch);
void csic_vipp_input_select(unsigned int sel, unsigned int vipp,
unsigned int isp, unsigned int ch);
void csic_feature_list_get(unsigned int sel, struct csic_feature_list *fl);
void csic_version_get(unsigned int sel, struct csic_version *v);
void csic_ptn_generation_en(unsigned int sel, unsigned int en);
void csic_ptn_control(unsigned int sel, int mode, int dw, int port);
void csic_ptn_length(unsigned int sel, unsigned int len);
void csic_ptn_addr(unsigned int sel, unsigned long dma_addr);
void csic_ptn_size(unsigned int sel, unsigned int w, unsigned int h);
#endif /* __CSIC__TOP__REG__H__ */