⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 theatre.c

📁 x.org上有关ati系列显卡最新驱动
💻 C
📖 第 1 页 / 共 5 页
字号:
#ifdef HAVE_CONFIG_H#include "config.h"#endif#include <unistd.h>#include "xf86.h"#include "generic_bus.h"#include "theatre.h"#include "theatre_reg.h"#undef read#undef write#undef ioctlstatic Bool theatre_read(TheatrePtr t,CARD32 reg, CARD32 *data){   if(t->theatre_num<0)return FALSE;   return t->VIP->read(t->VIP, ((t->theatre_num & 0x3)<<14) | reg,4, (CARD8 *) data);}static Bool theatre_write(TheatrePtr t,CARD32 reg, CARD32 data){   if(t->theatre_num<0)return FALSE;   return t->VIP->write(t->VIP,((t->theatre_num & 0x03)<<14) | reg,4, (CARD8 *) &data);}#define RT_regr(reg,data)	theatre_read(t,(reg),(data))#define RT_regw(reg,data)	theatre_write(t,(reg),(data))#define VIP_TYPE      "ATI VIP BUS"#if 0TheatrePtr DetectTheatre(GENERIC_BUS_Ptr b){   TheatrePtr t;     CARD32 i;   CARD32 val;   char s[20];      b->ioctl(b,GB_IOCTL_GET_TYPE,20,s);   if(strcmp(VIP_TYPE, s)){   xf86DrvMsg(b->scrnIndex, X_ERROR, "DetectTheatre must be called with bus of type \"%s\", not \"%s\"\n",          VIP_TYPE, s);   return NULL;   }      t = xcalloc(1,sizeof(TheatreRec));   t->VIP = b;   t->theatre_num = -1;   t->mode=MODE_UNINITIALIZED;      b->read(b, VIP_VIP_VENDOR_DEVICE_ID, 4, (CARD8 *)&val);   for(i=0;i<4;i++)   {	if(b->read(b, ((i & 0x03)<<14) | VIP_VIP_VENDOR_DEVICE_ID, 4, (CARD8 *)&val))        {	  if(val)xf86DrvMsg(b->scrnIndex, X_INFO, "Device %d on VIP bus ids as 0x%08x\n",i,val);	  if(t->theatre_num>=0)continue; /* already found one instance */	  switch(val){	  	case RT100_ATI_ID:	           t->theatre_num=i;		   t->theatre_id=RT100_ATI_ID;		   break;		case RT200_ATI_ID:	           t->theatre_num=i;		   t->theatre_id=RT200_ATI_ID;		   break;                }	} else {	  xf86DrvMsg(b->scrnIndex, X_INFO, "No response from device %d on VIP bus\n",i);		}   }   if(t->theatre_num>=0)xf86DrvMsg(b->scrnIndex, X_INFO, "Detected Rage Theatre as device %d on VIP bus with id 0x%08x\n",t->theatre_num,t->theatre_id);   if(t->theatre_id==RT200_ATI_ID){   	xf86DrvMsg(b->scrnIndex, X_INFO, "Rage Theatre 200 is not supported yet\n");	t->theatre_num=-1;	}   if(t->theatre_num < 0)   {   xfree(t);   return NULL;   }   RT_regr(VIP_VIP_REVISION_ID, &val);   xf86DrvMsg(b->scrnIndex, X_INFO, "Detected Rage Theatre revision %8.8X\n", val);#if 0DumpRageTheatreRegsByName(t);#endif   return t;}#endifenum{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  },

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -