cx18-av-core.h
来自「trident tm5600的linux驱动」· C头文件 代码 · 共 327 行
H
327 行
/* * cx18 ADEC header * * Derived from cx25840-core.h * * Copyright (C) 2007 Hans Verkuil <hverkuil@xs4all.nl> * * 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; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. */#ifndef _CX18_AV_CORE_H_#define _CX18_AV_CORE_H_struct cx18;enum cx18_av_video_input { /* Composite video inputs In1-In8 */ CX18_AV_COMPOSITE1 = 1, CX18_AV_COMPOSITE2, CX18_AV_COMPOSITE3, CX18_AV_COMPOSITE4, CX18_AV_COMPOSITE5, CX18_AV_COMPOSITE6, CX18_AV_COMPOSITE7, CX18_AV_COMPOSITE8, /* S-Video inputs consist of one luma input (In1-In8) ORed with one chroma input (In5-In8) */ CX18_AV_SVIDEO_LUMA1 = 0x10, CX18_AV_SVIDEO_LUMA2 = 0x20, CX18_AV_SVIDEO_LUMA3 = 0x30, CX18_AV_SVIDEO_LUMA4 = 0x40, CX18_AV_SVIDEO_LUMA5 = 0x50, CX18_AV_SVIDEO_LUMA6 = 0x60, CX18_AV_SVIDEO_LUMA7 = 0x70, CX18_AV_SVIDEO_LUMA8 = 0x80, CX18_AV_SVIDEO_CHROMA4 = 0x400, CX18_AV_SVIDEO_CHROMA5 = 0x500, CX18_AV_SVIDEO_CHROMA6 = 0x600, CX18_AV_SVIDEO_CHROMA7 = 0x700, CX18_AV_SVIDEO_CHROMA8 = 0x800, /* S-Video aliases for common luma/chroma combinations */ CX18_AV_SVIDEO1 = 0x510, CX18_AV_SVIDEO2 = 0x620, CX18_AV_SVIDEO3 = 0x730, CX18_AV_SVIDEO4 = 0x840,};enum cx18_av_audio_input { /* Audio inputs: serial or In4-In8 */ CX18_AV_AUDIO_SERIAL1, CX18_AV_AUDIO_SERIAL2, CX18_AV_AUDIO4 = 4, CX18_AV_AUDIO5, CX18_AV_AUDIO6, CX18_AV_AUDIO7, CX18_AV_AUDIO8,};struct cx18_av_state { int radio; v4l2_std_id std; enum cx18_av_video_input vid_input; enum cx18_av_audio_input aud_input; u32 audclk_freq; int audmode; int vbi_line_offset; int default_volume; u32 id; u32 rev; int is_initialized;};/* Registers */#define CXADEC_CHIP_TYPE_TIGER 0x837#define CXADEC_CHIP_TYPE_MAKO 0x843#define CXADEC_HOST_REG1 0x000#define CXADEC_HOST_REG2 0x001#define CXADEC_CHIP_CTRL 0x100#define CXADEC_AFE_CTRL 0x104#define CXADEC_PLL_CTRL1 0x108#define CXADEC_VID_PLL_FRAC 0x10C#define CXADEC_AUX_PLL_FRAC 0x110#define CXADEC_PIN_CTRL1 0x114#define CXADEC_PIN_CTRL2 0x118#define CXADEC_PIN_CFG1 0x11C#define CXADEC_PIN_CFG2 0x120#define CXADEC_PIN_CFG3 0x124#define CXADEC_I2S_MCLK 0x127#define CXADEC_AUD_LOCK1 0x128#define CXADEC_AUD_LOCK2 0x12C#define CXADEC_POWER_CTRL 0x130#define CXADEC_AFE_DIAG_CTRL1 0x134#define CXADEC_AFE_DIAG_CTRL2 0x138#define CXADEC_AFE_DIAG_CTRL3 0x13C#define CXADEC_PLL_DIAG_CTRL 0x140#define CXADEC_TEST_CTRL1 0x144#define CXADEC_TEST_CTRL2 0x148#define CXADEC_BIST_STAT 0x14C#define CXADEC_DLL1_DIAG_CTRL 0x158#define CXADEC_DLL2_DIAG_CTRL 0x15C/* IR registers */#define CXADEC_IR_CTRL_REG 0x200#define CXADEC_IR_TXCLK_REG 0x204#define CXADEC_IR_RXCLK_REG 0x208#define CXADEC_IR_CDUTY_REG 0x20C#define CXADEC_IR_STAT_REG 0x210#define CXADEC_IR_IRQEN_REG 0x214#define CXADEC_IR_FILTER_REG 0x218#define CXADEC_IR_FIFO_REG 0x21C/* Video Registers */#define CXADEC_MODE_CTRL 0x400#define CXADEC_OUT_CTRL1 0x404#define CXADEC_OUT_CTRL2 0x408#define CXADEC_GEN_STAT 0x40C#define CXADEC_INT_STAT_MASK 0x410#define CXADEC_LUMA_CTRL 0x414#define CXADEC_BRIGHTNESS_CTRL_BYTE 0x414#define CXADEC_CONTRAST_CTRL_BYTE 0x415#define CXADEC_LUMA_CTRL_BYTE_3 0x416#define CXADEC_HSCALE_CTRL 0x418#define CXADEC_VSCALE_CTRL 0x41C#define CXADEC_CHROMA_CTRL 0x420#define CXADEC_USAT_CTRL_BYTE 0x420#define CXADEC_VSAT_CTRL_BYTE 0x421#define CXADEC_HUE_CTRL_BYTE 0x422#define CXADEC_VBI_LINE_CTRL1 0x424#define CXADEC_VBI_LINE_CTRL2 0x428#define CXADEC_VBI_LINE_CTRL3 0x42C#define CXADEC_VBI_LINE_CTRL4 0x430#define CXADEC_VBI_LINE_CTRL5 0x434#define CXADEC_VBI_FC_CFG 0x438#define CXADEC_VBI_MISC_CFG1 0x43C#define CXADEC_VBI_MISC_CFG2 0x440#define CXADEC_VBI_PAY1 0x444#define CXADEC_VBI_PAY2 0x448#define CXADEC_VBI_CUST1_CFG1 0x44C#define CXADEC_VBI_CUST1_CFG2 0x450#define CXADEC_VBI_CUST1_CFG3 0x454#define CXADEC_VBI_CUST2_CFG1 0x458#define CXADEC_VBI_CUST2_CFG2 0x45C#define CXADEC_VBI_CUST2_CFG3 0x460#define CXADEC_VBI_CUST3_CFG1 0x464#define CXADEC_VBI_CUST3_CFG2 0x468#define CXADEC_VBI_CUST3_CFG3 0x46C#define CXADEC_HORIZ_TIM_CTRL 0x470#define CXADEC_VERT_TIM_CTRL 0x474#define CXADEC_SRC_COMB_CFG 0x478#define CXADEC_CHROMA_VBIOFF_CFG 0x47C#define CXADEC_FIELD_COUNT 0x480#define CXADEC_MISC_TIM_CTRL 0x484#define CXADEC_DFE_CTRL1 0x488#define CXADEC_DFE_CTRL2 0x48C#define CXADEC_DFE_CTRL3 0x490#define CXADEC_PLL_CTRL2 0x494#define CXADEC_HTL_CTRL 0x498#define CXADEC_COMB_CTRL 0x49C#define CXADEC_CRUSH_CTRL 0x4A0#define CXADEC_SOFT_RST_CTRL 0x4A4#define CXADEC_MV_DT_CTRL2 0x4A8#define CXADEC_MV_DT_CTRL3 0x4AC#define CXADEC_MISC_DIAG_CTRL 0x4B8#define CXADEC_DL_CTL 0x800#define CXADEC_DL_CTL_ADDRESS_LOW 0x800 /* Byte 1 in DL_CTL */#define CXADEC_DL_CTL_ADDRESS_HIGH 0x801 /* Byte 2 in DL_CTL */#define CXADEC_DL_CTL_DATA 0x802 /* Byte 3 in DL_CTL */#define CXADEC_DL_CTL_CONTROL 0x803 /* Byte 4 in DL_CTL */#define CXADEC_STD_DET_STATUS 0x804#define CXADEC_STD_DET_CTL 0x808#define CXADEC_STD_DET_CTL_AUD_CTL 0x808 /* Byte 1 in STD_DET_CTL */#define CXADEC_STD_DET_CTL_PREF_MODE 0x809 /* Byte 2 in STD_DET_CTL */#define CXADEC_DW8051_INT 0x80C#define CXADEC_GENERAL_CTL 0x810#define CXADEC_AAGC_CTL 0x814#define CXADEC_IF_SRC_CTL 0x818#define CXADEC_ANLOG_DEMOD_CTL 0x81C#define CXADEC_ROT_FREQ_CTL 0x820#define CXADEC_FM1_CTL 0x824#define CXADEC_PDF_CTL 0x828#define CXADEC_DFT1_CTL1 0x82C#define CXADEC_DFT1_CTL2 0x830#define CXADEC_DFT_STATUS 0x834#define CXADEC_DFT2_CTL1 0x838#define CXADEC_DFT2_CTL2 0x83C#define CXADEC_DFT2_STATUS 0x840#define CXADEC_DFT3_CTL1 0x844#define CXADEC_DFT3_CTL2 0x848#define CXADEC_DFT3_STATUS 0x84C#define CXADEC_DFT4_CTL1 0x850#define CXADEC_DFT4_CTL2 0x854#define CXADEC_DFT4_STATUS 0x858#define CXADEC_AM_MTS_DET 0x85C#define CXADEC_ANALOG_MUX_CTL 0x860#define CXADEC_DIG_PLL_CTL1 0x864#define CXADEC_DIG_PLL_CTL2 0x868#define CXADEC_DIG_PLL_CTL3 0x86C#define CXADEC_DIG_PLL_CTL4 0x870#define CXADEC_DIG_PLL_CTL5 0x874#define CXADEC_DEEMPH_GAIN_CTL 0x878#define CXADEC_DEEMPH_COEF1 0x87C#define CXADEC_DEEMPH_COEF2 0x880#define CXADEC_DBX1_CTL1 0x884#define CXADEC_DBX1_CTL2 0x888#define CXADEC_DBX1_STATUS 0x88C#define CXADEC_DBX2_CTL1 0x890#define CXADEC_DBX2_CTL2 0x894#define CXADEC_DBX2_STATUS 0x898#define CXADEC_AM_FM_DIFF 0x89C/* NICAM registers go here */#define CXADEC_NICAM_STATUS 0x8C8#define CXADEC_DEMATRIX_CTL 0x8CC#define CXADEC_PATH1_CTL1 0x8D0#define CXADEC_PATH1_VOL_CTL 0x8D4#define CXADEC_PATH1_EQ_CTL 0x8D8#define CXADEC_PATH1_SC_CTL 0x8DC#define CXADEC_PATH2_CTL1 0x8E0#define CXADEC_PATH2_VOL_CTL 0x8E4#define CXADEC_PATH2_EQ_CTL 0x8E8#define CXADEC_PATH2_SC_CTL 0x8EC#define CXADEC_SRC_CTL 0x8F0#define CXADEC_SRC_LF_COEF 0x8F4#define CXADEC_SRC1_CTL 0x8F8#define CXADEC_SRC2_CTL 0x8FC#define CXADEC_SRC3_CTL 0x900#define CXADEC_SRC4_CTL 0x904#define CXADEC_SRC5_CTL 0x908#define CXADEC_SRC6_CTL 0x90C#define CXADEC_BASEBAND_OUT_SEL 0x910#define CXADEC_I2S_IN_CTL 0x914#define CXADEC_I2S_OUT_CTL 0x918#define CXADEC_AC97_CTL 0x91C#define CXADEC_QAM_PDF 0x920#define CXADEC_QAM_CONST_DEC 0x924#define CXADEC_QAM_ROTATOR_FREQ 0x948/* Bit defintions / settings used in Mako Audio */#define CXADEC_PREF_MODE_MONO_LANGA 0#define CXADEC_PREF_MODE_MONO_LANGB 1#define CXADEC_PREF_MODE_MONO_LANGC 2#define CXADEC_PREF_MODE_FALLBACK 3#define CXADEC_PREF_MODE_STEREO 4#define CXADEC_PREF_MODE_DUAL_LANG_AC 5#define CXADEC_PREF_MODE_DUAL_LANG_BC 6#define CXADEC_PREF_MODE_DUAL_LANG_AB 7#define CXADEC_DETECT_STEREO 1#define CXADEC_DETECT_DUAL 2#define CXADEC_DETECT_TRI 4#define CXADEC_DETECT_SAP 0x10#define CXADEC_DETECT_NO_SIGNAL 0xFF#define CXADEC_SELECT_AUDIO_STANDARD_BG 0xF0 /* NICAM BG and A2 BG */#define CXADEC_SELECT_AUDIO_STANDARD_DK1 0xF1 /* NICAM DK and A2 DK */#define CXADEC_SELECT_AUDIO_STANDARD_DK2 0xF2#define CXADEC_SELECT_AUDIO_STANDARD_DK3 0xF3#define CXADEC_SELECT_AUDIO_STANDARD_I 0xF4 /* NICAM I and A1 */#define CXADEC_SELECT_AUDIO_STANDARD_L 0xF5 /* NICAM L and System L AM */#define CXADEC_SELECT_AUDIO_STANDARD_BTSC 0xF6#define CXADEC_SELECT_AUDIO_STANDARD_EIAJ 0xF7#define CXADEC_SELECT_AUDIO_STANDARD_A2_M 0xF8 /* A2 M */#define CXADEC_SELECT_AUDIO_STANDARD_FM 0xF9 /* FM radio */#define CXADEC_SELECT_AUDIO_STANDARD_AUTO 0xFF /* Auto detect *//* ----------------------------------------------------------------------- *//* cx18_av-core.c */int cx18_av_write(struct cx18 *cx, u16 addr, u8 value);int cx18_av_write4(struct cx18 *cx, u16 addr, u32 value);int cx18_av_write4_noretry(struct cx18 *cx, u16 addr, u32 value);u8 cx18_av_read(struct cx18 *cx, u16 addr);u32 cx18_av_read4(struct cx18 *cx, u16 addr);u32 cx18_av_read4_noretry(struct cx18 *cx, u16 addr);int cx18_av_and_or(struct cx18 *cx, u16 addr, unsigned mask, u8 value);int cx18_av_and_or4(struct cx18 *cx, u16 addr, u32 mask, u32 value);int cx18_av_cmd(struct cx18 *cx, unsigned int cmd, void *arg);void cx18_av_std_setup(struct cx18 *cx);/* ----------------------------------------------------------------------- *//* cx18_av-firmware.c */int cx18_av_loadfw(struct cx18 *cx);/* ----------------------------------------------------------------------- *//* cx18_av-audio.c */int cx18_av_audio(struct cx18 *cx, unsigned int cmd, void *arg);void cx18_av_audio_set_path(struct cx18 *cx);/* ----------------------------------------------------------------------- *//* cx18_av-vbi.c */int cx18_av_vbi(struct cx18 *cx, unsigned int cmd, void *arg);#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?