📄 theatre200.c
字号:
#if 0static CARD32 dsp_set_sharpness(TheatrePtr t, int sharpness){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = 0 | (73 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_sharpness: %x\n", result); return result;}#endifstatic CARD32 dsp_set_tint(TheatrePtr t, CARD8 tint){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((tint << 8) & 0xff00) | (75 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_tint: %x\n", result); return result;}static CARD32 dsp_set_saturation(TheatrePtr t, CARD8 saturation){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((saturation << 8) & 0xff00) | (69 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_saturation: %x\n", result); return result;}static CARD32 dsp_set_video_scaler_horizontal(TheatrePtr t, CARD16 output_width, CARD16 horz_start, CARD16 horz_end){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((output_width << 8) & 0x00ffff00) | (195 & 0xff); fb_scratch1 = ((horz_end << 16) & 0xffff0000) | (horz_start & 0xffff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_video_scaler_horizontal: %x\n", result); return result;}static CARD32 dsp_set_video_scaler_vertical(TheatrePtr t, CARD16 output_height, CARD16 vert_start, CARD16 vert_end){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((output_height << 8) & 0x00ffff00) | (196 & 0xff); fb_scratch1 = ((vert_end << 16) & 0xffff0000) | (vert_start & 0xffff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_video_scaler_vertical: %x\n", result); return result;}static CARD32 dsp_audio_mute(TheatrePtr t, CARD8 left, CARD8 right){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((right << 16) & 0xff0000) | ((left << 8) & 0xff00) | (21 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_audio_mute: %x\n", result); return result;}static CARD32 dsp_set_audio_volume(TheatrePtr t, CARD8 left, CARD8 right, CARD8 auto_mute){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((auto_mute << 24) & 0xff000000) | ((right << 16) & 0xff0000) | ((left << 8) & 0xff00) | (22 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_set_audio_volume: %x\n", result); return result;}#if 0static CARD32 dsp_audio_detection(TheatrePtr t, CARD8 option){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((option << 8) & 0xff00) | (16 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_audio_detection: %x\n", result); return result;}#endifstatic CARD32 dsp_configure_i2s_port(TheatrePtr t, CARD8 tx_mode, CARD8 rx_mode, CARD8 clk_mode){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((clk_mode << 24) & 0xff000000) | ((rx_mode << 16) & 0xff0000) | ((tx_mode << 8) & 0xff00) | (40 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_configure_i2s_port: %x\n", result); return result;}static CARD32 dsp_configure_spdif_port(TheatrePtr t, CARD8 state){ CARD32 fb_scratch1 = 0; CARD32 fb_scratch0 = 0; CARD32 result; int screen = t->VIP->scrnIndex; fb_scratch0 = ((state << 8) & 0xff00) | (41 & 0xff); result = dsp_send_command(t, fb_scratch1, fb_scratch0); DEBUG("dsp_configure_spdif_port: %x\n", result); return result;}enum{fld_tmpReg1=0,fld_tmpReg2,fld_tmpReg3,fld_LP_CONTRAST,fld_LP_BRIGHTNESS,fld_CP_HUE_CNTL,fld_LUMA_FILTER,fld_H_SCALE_RATIO,fld_H_SHARPNESS,fld_V_SCALE_RATIO,fld_V_DEINTERLACE_ON,fld_V_BYPSS,fld_V_DITHER_ON,fld_EVENF_OFFSET,fld_ODDF_OFFSET,fld_INTERLACE_DETECTED,fld_VS_LINE_COUNT,fld_VS_DETECTED_LINES,fld_VS_ITU656_VB,fld_VBI_CC_DATA,fld_VBI_CC_WT,fld_VBI_CC_WT_ACK,fld_VBI_CC_HOLD,fld_VBI_DECODE_EN,fld_VBI_CC_DTO_P,fld_VBI_20BIT_DTO_P,fld_VBI_CC_LEVEL,fld_VBI_20BIT_LEVEL,fld_VBI_CLK_RUNIN_GAIN,fld_H_VBI_WIND_START,fld_H_VBI_WIND_END,fld_V_VBI_WIND_START,fld_V_VBI_WIND_END,fld_VBI_20BIT_DATA0,fld_VBI_20BIT_DATA1,fld_VBI_20BIT_WT,fld_VBI_20BIT_WT_ACK,fld_VBI_20BIT_HOLD,fld_VBI_CAPTURE_ENABLE,fld_VBI_EDS_DATA,fld_VBI_EDS_WT,fld_VBI_EDS_WT_ACK,fld_VBI_EDS_HOLD,fld_VBI_SCALING_RATIO,fld_VBI_ALIGNER_ENABLE,fld_H_ACTIVE_START,fld_H_ACTIVE_END,fld_V_ACTIVE_START,fld_V_ACTIVE_END,fld_CH_HEIGHT,fld_CH_KILL_LEVEL,fld_CH_AGC_ERROR_LIM,fld_CH_AGC_FILTER_EN,fld_CH_AGC_LOOP_SPEED,fld_HUE_ADJ,fld_STANDARD_SEL,fld_STANDARD_YC,fld_ADC_PDWN,fld_INPUT_SELECT,fld_ADC_PREFLO,fld_H_SYNC_PULSE_WIDTH,fld_HS_GENLOCKED,fld_HS_SYNC_IN_WIN,fld_VIN_ASYNC_RST,fld_DVS_ASYNC_RST,fld_VIP_VENDOR_ID,fld_VIP_DEVICE_ID,fld_VIP_REVISION_ID,fld_BLACK_INT_START,fld_BLACK_INT_LENGTH,fld_UV_INT_START,fld_U_INT_LENGTH,fld_V_INT_LENGTH,fld_CRDR_ACTIVE_GAIN,fld_CBDB_ACTIVE_GAIN,fld_DVS_DIRECTION,fld_DVS_VBI_CARD8_SWAP,fld_DVS_CLK_SELECT,fld_CONTINUOUS_STREAM,fld_DVSOUT_CLK_DRV,fld_DVSOUT_DATA_DRV,fld_COMB_CNTL0,fld_COMB_CNTL1,fld_COMB_CNTL2,fld_COMB_LENGTH,fld_SYNCTIP_REF0,fld_SYNCTIP_REF1,fld_CLAMP_REF,fld_AGC_PEAKWHITE,fld_VBI_PEAKWHITE,fld_WPA_THRESHOLD,fld_WPA_TRIGGER_LO,fld_WPA_TRIGGER_HIGH,fld_LOCKOUT_START,fld_LOCKOUT_END,fld_CH_DTO_INC,fld_PLL_SGAIN,fld_PLL_FGAIN,fld_CR_BURST_GAIN,fld_CB_BURST_GAIN,fld_VERT_LOCKOUT_START,fld_VERT_LOCKOUT_END,fld_H_IN_WIND_START,fld_V_IN_WIND_START,fld_H_OUT_WIND_WIDTH,fld_V_OUT_WIND_WIDTH,fld_HS_LINE_TOTAL,fld_MIN_PULSE_WIDTH,fld_MAX_PULSE_WIDTH,fld_WIN_CLOSE_LIMIT,fld_WIN_OPEN_LIMIT,fld_VSYNC_INT_TRIGGER,fld_VSYNC_INT_HOLD,fld_VIN_M0,fld_VIN_N0,fld_MNFLIP_EN,fld_VIN_P,fld_REG_CLK_SEL,fld_VIN_M1,fld_VIN_N1,fld_VIN_DRIVER_SEL,fld_VIN_MNFLIP_REQ,fld_VIN_MNFLIP_DONE,fld_TV_LOCK_TO_VIN,fld_TV_P_FOR_WINCLK,fld_VINRST,fld_VIN_CLK_SEL,fld_VS_FIELD_BLANK_START,fld_VS_FIELD_BLANK_END,fld_VS_FIELD_IDLOCATION,fld_VS_FRAME_TOTAL,fld_SYNC_TIP_START,fld_SYNC_TIP_LENGTH,fld_GAIN_FORCE_DATA,fld_GAIN_FORCE_EN,fld_I_CLAMP_SEL,fld_I_AGC_SEL,fld_EXT_CLAMP_CAP,fld_EXT_AGC_CAP,fld_DECI_DITHER_EN,fld_ADC_PREFHI,fld_ADC_CH_GAIN_SEL,fld_HS_PLL_SGAIN,fld_NREn,fld_NRGainCntl,fld_NRBWTresh,fld_NRGCTresh,fld_NRCoefDespeclMode,fld_GPIO_5_OE,fld_GPIO_6_OE,fld_GPIO_5_OUT,fld_GPIO_6_OUT,regRT_MAX_REGS} a;typedef struct { CARD8 size; CARD32 fld_id; CARD32 dwRegAddrLSBs; CARD32 dwFldOffsetLSBs; CARD32 dwMaskLSBs; CARD32 addr2; CARD32 offs2; CARD32 mask2; CARD32 dwCurrValue; CARD32 rw; } RTREGMAP;#define READONLY 1#define WRITEONLY 2#define READWRITE 3/* Rage Theatre's Register Mappings, including the default values: */RTREGMAP RT_RegMap[regRT_MAX_REGS]={/*{size, fidname, AddrOfst, Ofst, Mask, Addr, Ofst, Mask, Cur, R/W*/{32 , fld_tmpReg1 ,0x151 , 0, 0x0, 0, 0,0, 0,READWRITE },{1 , fld_tmpReg2 ,VIP_VIP_SUB_VENDOR_DEVICE_ID , 3, 0xFFFFFFFF, 0, 0,0, 0,READWRITE },{1 , fld_tmpReg3 ,VIP_VIP_COMMAND_STATUS , 3, 0xFFFFFFFF, 0, 0,0, 0,READWRITE },{8 , fld_LP_CONTRAST ,VIP_LP_CONTRAST , 0, 0xFFFFFF00, 0, 0,0, fld_LP_CONTRAST_def ,READWRITE },{14 , fld_LP_BRIGHTNESS ,VIP_LP_BRIGHTNESS , 0, 0xFFFFC000, 0, 0,0, fld_LP_BRIGHTNESS_def ,READWRITE },{8 , fld_CP_HUE_CNTL ,VIP_CP_HUE_CNTL , 0, 0xFFFFFF00, 0, 0,0, fld_CP_HUE_CNTL_def ,READWRITE },{1 , fld_LUMA_FILTER ,VIP_LP_BRIGHTNESS , 15, 0xFFFF7FFF, 0, 0,0, fld_LUMA_FILTER_def ,READWRITE },{21 , fld_H_SCALE_RATIO ,VIP_H_SCALER_CONTROL , 0, 0xFFE00000, 0, 0,0, fld_H_SCALE_RATIO_def ,READWRITE },{4 , fld_H_SHARPNESS ,VIP_H_SCALER_CONTROL , 25, 0xE1FFFFFF, 0, 0,0, fld_H_SHARPNESS_def ,READWRITE },{12 , fld_V_SCALE_RATIO ,VIP_V_SCALER_CONTROL , 0, 0xFFFFF000, 0, 0,0, fld_V_SCALE_RATIO_def ,READWRITE },{1 , fld_V_DEINTERLACE_ON,VIP_V_SCALER_CONTROL , 12, 0xFFFFEFFF, 0, 0,0, fld_V_DEINTERLACE_ON_def ,READWRITE },{1 , fld_V_BYPSS ,VIP_V_SCALER_CONTROL , 14, 0xFFFFBFFF, 0, 0,0, fld_V_BYPSS_def ,READWRITE },{1 , fld_V_DITHER_ON ,VIP_V_SCALER_CONTROL , 15, 0xFFFF7FFF, 0, 0,0, fld_V_DITHER_ON_def ,READWRITE },{11 , fld_EVENF_OFFSET ,VIP_V_DEINTERLACE_CONTROL , 0, 0xFFFFF800, 0, 0,0, fld_EVENF_OFFSET_def ,READWRITE },{11 , fld_ODDF_OFFSET ,VIP_V_DEINTERLACE_CONTROL , 11, 0xFFC007FF, 0, 0,0, fld_ODDF_OFFSET_def ,READWRITE },{1 , fld_INTERLACE_DETECTED ,VIP_VS_LINE_COUNT , 15, 0xFFFF7FFF, 0, 0,0, fld_INTERLACE_DETECTED_def,READONLY },{10 , fld_VS_LINE_COUNT ,VIP_VS_LINE_COUNT , 0, 0xFFFFFC00, 0, 0,0, fld_VS_LINE_COUNT_def ,READONLY },{10 , fld_VS_DETECTED_LINES ,VIP_VS_LINE_COUNT , 16, 0xFC00FFFF, 0, 0,0, fld_VS_DETECTED_LINES_def ,READONLY },{1 , fld_VS_ITU656_VB ,VIP_VS_LINE_COUNT , 13, 0xFFFFDFFF, 0, 0,0, fld_VS_ITU656_VB_def ,READONLY },{16 , fld_VBI_CC_DATA ,VIP_VBI_CC_CNTL , 0, 0xFFFF0000, 0, 0,0, fld_VBI_CC_DATA_def ,READWRITE },{1 , fld_VBI_CC_WT ,VIP_VBI_CC_CNTL , 24, 0xFEFFFFFF, 0, 0,0, fld_VBI_CC_WT_def ,READWRITE },{1 , fld_VBI_CC_WT_ACK ,VIP_VBI_CC_CNTL , 25, 0xFDFFFFFF, 0, 0,0, fld_VBI_CC_WT_ACK_def ,READONLY },{1 , fld_VBI_CC_HOLD ,VIP_VBI_CC_CNTL , 26, 0xFBFFFFFF, 0, 0,0, fld_VBI_CC_HOLD_def ,READWRITE },{1 , fld_VBI_DECODE_EN ,VIP_VBI_CC_CNTL , 31, 0x7FFFFFFF, 0, 0,0, fld_VBI_DECODE_EN_def ,READWRITE },{16 , fld_VBI_CC_DTO_P ,VIP_VBI_DTO_CNTL , 0, 0xFFFF0000, 0, 0,0, fld_VBI_CC_DTO_P_def ,READWRITE },{16 ,fld_VBI_20BIT_DTO_P,VIP_VBI_DTO_CNTL , 16, 0x0000FFFF, 0, 0,0, fld_VBI_20BIT_DTO_P_def ,READWRITE },{7 ,fld_VBI_CC_LEVEL ,VIP_VBI_LEVEL_CNTL , 0, 0xFFFFFF80, 0, 0,0, fld_VBI_CC_LEVEL_def ,READWRITE },{7 ,fld_VBI_20BIT_LEVEL,VIP_VBI_LEVEL_CNTL , 8, 0xFFFF80FF, 0, 0,0, fld_VBI_20BIT_LEVEL_def ,READWRITE },{9 ,fld_VBI_CLK_RUNIN_GAIN,VIP_VBI_LEVEL_CNTL , 16, 0xFE00FFFF, 0, 0,0, fld_VBI_CLK_RUNIN_GAIN_def,READWRITE },{11 ,fld_H_VBI_WIND_START,VIP_H_VBI_WINDOW , 0, 0xFFFFF800, 0, 0,0, fld_H_VBI_WIND_START_def ,READWRITE },{11 ,fld_H_VBI_WIND_END,VIP_H_VBI_WINDOW , 16, 0xF800FFFF, 0, 0,0, fld_H_VBI_WIND_END_def ,READWRITE },{10 ,fld_V_VBI_WIND_START,VIP_V_VBI_WINDOW , 0, 0xFFFFFC00, 0, 0,0, fld_V_VBI_WIND_START_def ,READWRITE },{10 ,fld_V_VBI_WIND_END,VIP_V_VBI_WINDOW , 16, 0xFC00FFFF, 0, 0,0, fld_V_VBI_WIND_END_def ,READWRITE }, /* CHK */{16 ,fld_VBI_20BIT_DATA0,VIP_VBI_20BIT_CNTL , 0, 0xFFFF0000, 0, 0,0, fld_VBI_20BIT_DATA0_def ,READWRITE },{4 ,fld_VBI_20BIT_DATA1,VIP_VBI_20BIT_CNTL , 16, 0xFFF0FFFF, 0, 0,0, fld_VBI_20BIT_DATA1_def ,READWRITE },{1 ,fld_VBI_20BIT_WT ,VIP_VBI_20BIT_CNTL , 24, 0xFEFFFFFF, 0, 0,0, fld_VBI_20BIT_WT_def ,READWRITE },{1 ,fld_VBI_20BIT_WT_ACK ,VIP_VBI_20BIT_CNTL , 25, 0xFDFFFFFF, 0, 0,0, fld_VBI_20BIT_WT_ACK_def ,READONLY },{1 ,fld_VBI_20BIT_HOLD ,VIP_VBI_20BIT_CNTL , 26, 0xFBFFFFFF, 0, 0,0, fld_VBI_20BIT_HOLD_def ,READWRITE },
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -