亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? atimach64i2c.c

?? x.org上有關ati系列顯卡最新驅動
?? C
字號:
/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/ati/atimach64i2c.c,v 1.1 2003/07/24 22:08:28 tsi Exp $ *//* * Copyright 2003 through 2004 by Marc Aurele La France (TSI @ UQV), tsi@xfree86.org * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that * the above copyright notice appear in all copies and that both that copyright * notice and this permission notice appear in supporting documentation, and * that the name of Marc Aurele La France not be used in advertising or * publicity pertaining to distribution of the software without specific, * written prior permission.  Marc Aurele La France makes no representations * about the suitability of this software for any purpose.  It is provided * "as-is" without express or implied warranty. * * MARC AURELE LA FRANCE DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.  IN NO * EVENT SHALL MARC AURELE LA FRANCE BE LIABLE FOR ANY SPECIAL, INDIRECT OR * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. */#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "ati.h"#include "atichip.h"#include "atii2c.h"#include "atimach64i2c.h"#include "atimach64io.h"#include "atituner.h"/* MPP_CONFIG register values */#define MPP_INIT     pATI->NewHW.mpp_config#define MPP_WRITE    (MPP_INIT                                               )#define MPP_WRITEINC (MPP_INIT | (MPP_AUTO_INC_EN                           ))#define MPP_READ     (MPP_INIT | (                  MPP_BUFFER_MODE_PREFETCH))#define MPP_READINC  (MPP_INIT | (MPP_AUTO_INC_EN | MPP_BUFFER_MODE_PREFETCH))/* * ATIMach64MPPWaitForIdle -- * * Support function to wait for the Multimedia Peripheral Port to become idle. * Currently, this function's return value indicates whether or not the port * became idle within 512 polling iterations.  For now, this value is ignored * by the rest of the code, but might be used in the future. */static BoolATIMach64MPPWaitForIdle(    ATIPtr pATI){    CARD32 Count = 0x0200;    while (in8(MPP_CONFIG + 3) & GetByte(MPP_BUSY, 3))    {        if (!--Count)            return FALSE;        usleep(1);              /* XXX Excessive? */    }    return TRUE;}/* * ATIMach64MPPSetAddress -- * * Sets a 16-bit ImpacTV address on the Multimedia Peripheral Port. */static voidATIMach64MPPSetAddress(    ATIPtr pATI,    CARD16 Address){    ATIMach64MPPWaitForIdle(pATI);    outr(MPP_CONFIG, MPP_WRITEINC);    outr(MPP_ADDR, 0x00000008U);    out8(MPP_DATA, (CARD8)Address);    ATIMach64MPPWaitForIdle(pATI);    out8(MPP_DATA, (CARD8)(Address >> 8));    ATIMach64MPPWaitForIdle(pATI);    outr(MPP_CONFIG, MPP_WRITE);    outr(MPP_ADDR, 0x00000018U);    ATIMach64MPPWaitForIdle(pATI);}/* * ATIMach64ImpacTVProbe -- * * This probes for an ImpacTV chip and returns its chip ID, or 0. */static intATIMach64ImpacTVProbe(    int    iScreen,    ATIPtr pATI){    CARD8 ChipID = 0;    /* Assume ATIModePreInit() has already been called */    outr(MPP_STROBE_SEQ, pATI->NewHW.mpp_strobe_seq);    outr(TVO_CNTL, pATI->NewHW.tvo_cntl);    outr(MPP_CONFIG, MPP_READ);    ATIMach64MPPWaitForIdle(pATI);    outr(MPP_ADDR, 0x0000000AU);    if (!(ChipID = in8(MPP_DATA)))    {         ATIMach64MPPWaitForIdle(pATI);         outr(MPP_ADDR, 0x00000023U);         if ((ChipID = in8(MPP_DATA)) != 0x54U)         {             ATIMach64MPPWaitForIdle(pATI);             outr(MPP_ADDR, 0x0000000BU);             ChipID = in8(MPP_DATA);         }    }    ATIMach64MPPWaitForIdle(pATI);    outr(MPP_CONFIG, MPP_WRITE);    if (ChipID)        xf86DrvMsg(iScreen, X_PROBED, "ImpacTV chip ID 0x%02X detected.\n",            ChipID);    return (int)(CARD16)ChipID;}/* * ATIMach64ImpacTVSetBits -- * * Controls I2C SDA and SCL lines through ImpacTV. */static voidATIMach64ImpacTVSetBits(    ATII2CPtr pATII2C,    ATIPtr    pATI,    CARD32    Bits){    pATII2C->I2CCur = Bits;    ATIMach64MPPSetAddress(pATI, IT_I2C_CNTL);    outr(MPP_CONFIG, MPP_WRITE);    out8(MPP_DATA, (CARD8)Bits);    ATIMach64MPPWaitForIdle(pATI);}/* * ATIMach64ImpacTVGetBits -- * * Returns the status of an ImpacTV's I2C control lines. */static CARD32ATIMach64ImpacTVGetBits(    ATIPtr    pATI){    ATIMach64MPPSetAddress(pATI, IT_I2C_CNTL);    outr(MPP_CONFIG, MPP_READ);    ATIMach64MPPWaitForIdle(pATI);    return in8(MPP_DATA);}/* * ATIMach64I2C_CNTLSetBits -- * * Controls SDA and SCL lines through a 3D Rage Pro's hardware assisted I2C. */static voidATIMach64I2C_CNTLSetBits(    ATII2CPtr pATII2C,    ATIPtr    pATI,    CARD32    Bits){    pATII2C->I2CCur = Bits;    out8(I2C_CNTL_0 + 1, (CARD8)Bits);}/* * ATIMach64I2C_CNTLGetBits -- * * Returns the status of a 3D Rage Pro's hardware assisted I2C control lines. */static CARD32ATIMach64I2C_CNTLGetBits(    ATIPtr    pATI){    return in8(I2C_CNTL_0 + 1);}/* * ATIMach64GP_IOSetBits -- * * Controls SDA and SCL control lines through a Mach64's GP_IO register. */static voidATIMach64GP_IOSetBits(    ATII2CPtr pATII2C,    ATIPtr    pATI,    CARD32    Bits){    pATII2C->I2CCur = Bits;    outr(GP_IO, Bits);}/* * ATIMach64GP_IOGetBits -- * * Returns the status of I2C control lines through a Mach64's GP_IO register. */static CARD32ATIMach64GP_IOGetBits(    ATIPtr    pATI){    return inr(GP_IO);}#define GPIO1_MASK \    (DAC_GIO_STATE_1 | DAC_GIO_DIR_1)#define GPIO2_MASK \    (GEN_GIO2_DATA_OUT | GEN_GIO2_DATA_IN | GEN_GIO2_WRITE)/* * ATIMach64DAC_GENSetBits -- * * Controls SDA and SCL control lines through a Mach64's GEN_TEST_CNTL and * DAC_CNTL registers. */static voidATIMach64DAC_GENSetBits(    ATII2CPtr pATII2C,    ATIPtr    pATI,    CARD32    Bits){    CARD32 tmp;    pATII2C->I2CCur = Bits;    tmp = inr(DAC_CNTL) & ~GPIO1_MASK;    outr(DAC_CNTL, tmp | (Bits & GPIO1_MASK));    tmp = inr(GEN_TEST_CNTL) & ~GPIO2_MASK;    outr(GEN_TEST_CNTL, tmp | (Bits & GPIO2_MASK));}/* * ATIMach64DAC_GENGetBits -- * * Returns the status of I2C control lines through a Mach64's GEN_TEST_CNTL and * DAC_CNTL registers. */static CARD32ATIMach64DAC_GENGetBits(    ATIPtr    pATI){    return (inr(DAC_CNTL) & GPIO1_MASK) | (inr(GEN_TEST_CNTL) & GPIO2_MASK);}/* * ATITVAddOnProbe -- * * Probe for an ATI-TV add-on card at specific addresses on an I2C bus. */static BoolATITVAddOnProbe(    ScrnInfoPtr pScreenInfo,    ATIPtr      pATI,    I2CBusPtr   pI2CBus){    I2CDevPtr pI2CDev = xnfcalloc(1, SizeOf(I2CDevRec));    int       Index;    I2CByte   tmp;    static const CARD8 ATITVAddOnAddresses[] = {0x70, 0x40, 0x78, 0x72, 0x42};    pI2CDev->DevName      = "ATI-TV Add-on";    pI2CDev->pI2CBus      = pI2CBus;    pI2CDev->StartTimeout = pI2CBus->StartTimeout;    pI2CDev->BitTimeout   = pI2CBus->BitTimeout;    pI2CDev->AcknTimeout  = pI2CBus->AcknTimeout;    pI2CDev->ByteTimeout  = pI2CBus->ByteTimeout;    for (Index = 0;  Index < NumberOf(ATITVAddOnAddresses);  Index++)    {        pI2CDev->SlaveAddr = ATITVAddOnAddresses[Index];        if (xf86I2CFindDev(pI2CBus, pI2CDev->SlaveAddr))            continue;        tmp = 0xFFU;        if (!(*pI2CBus->I2CWriteRead)(pI2CDev, &tmp, 1, NULL, 0) ||            !(*pI2CBus->I2CWriteRead)(pI2CDev, NULL, 0, &tmp, 1) ||            (tmp == 0xFFU) || ((tmp = tmp & 0x1FU) == /*ATI_TUNER_NONE*/0))            continue;        if (!xf86I2CDevInit(pI2CDev))        {            xf86DrvMsg(pScreenInfo->scrnIndex, X_WARNING,                "Failed to register I2C device for ATI-TV add-on.\n");            break;        }        if (pATI->Tuner != tmp)        {            if (pATI->Tuner != ATI_TUNER_NONE)                xf86DrvMsg(pScreenInfo->scrnIndex, X_WARNING,                    "Tuner type mismatch:  BIOS 0x%x, ATI-TV 0x%x.\n",                    pATI->Tuner, tmp);            pATI->Tuner = tmp;        }        xf86DrvMsg(pScreenInfo->scrnIndex, X_PROBED,            "%s tuner detected on ATI-TV add-on adapter at I2C bus address"            " 0x%2x.\n", ATITuners[pATI->Tuner].name, pI2CDev->SlaveAddr);        return TRUE;    }    xfree(pI2CDev);    return FALSE;}/* * ATIMach64I2CPreInit -- * * This function potentially allocates an I2CBusRec and initialises it with * ATI-specific and Mach64-specific information. */voidATIMach64I2CPreInit(    ScrnInfoPtr pScreenInfo,    ATIPtr      pATI){    I2CBusPtr pI2CBus;    ATII2CPtr pATII2C;    if ((pATI->Chip < ATI_CHIP_264CT) || (pATI->Chip >= ATI_CHIP_Mach64))        return;    /* Create an I2CBusRec and generically prime it */    if (!(pI2CBus = ATICreateI2CBusRec(pScreenInfo->scrnIndex, pATI, "Mach64")))        return;    pATII2C = pI2CBus->DriverPrivate.ptr;    switch (pATI->Chip)    {        case ATI_CHIP_264GTPRO:        case ATI_CHIP_264LTPRO:        case ATI_CHIP_264XL:        case ATI_CHIP_MOBILITY:            /*             * These have I2C-specific registers.  Assume older I2C access             * mechanisms are inoperative.             */            pATII2C->I2CSetBits = ATIMach64I2C_CNTLSetBits;            pATII2C->I2CGetBits = ATIMach64I2C_CNTLGetBits;            pATII2C->SCLDir = pATII2C->SDADir = 0;            pATII2C->SCLGet = pATII2C->SCLSet = GetByte(I2C_CNTL_SCL, 1);            pATII2C->SDAGet = pATII2C->SDASet = GetByte(I2C_CNTL_SDA, 1);            out8(I2C_CNTL_1 + 2, GetByte(I2C_SEL, 2));            out8(I2C_CNTL_0 + 0,                GetByte(I2C_CNTL_STAT | I2C_CNTL_HPTR_RST, 0));            break;        case ATI_CHIP_264VTB:        case ATI_CHIP_264GTB:        case ATI_CHIP_264VT3:        case ATI_CHIP_264GTDVD:        case ATI_CHIP_264LT:        case ATI_CHIP_264VT4:        case ATI_CHIP_264GT2C:            /* If an ImpacTV chip is found, use it to provide I2C access */            if (ATIMach64ImpacTVProbe(pScreenInfo->scrnIndex, pATI))            {                pATII2C->I2CSetBits = ATIMach64ImpacTVSetBits;                pATII2C->I2CGetBits = ATIMach64ImpacTVGetBits;                pATII2C->SCLDir = IT_SCL_DIR;                pATII2C->SCLGet = IT_SCL_GET;                pATII2C->SCLSet = IT_SCL_SET;                pATII2C->SDADir = IT_SDA_DIR;                pATII2C->SDAGet = IT_SDA_GET;                pATII2C->SDASet = IT_SDA_SET;                ATIMach64MPPSetAddress(pATI, IT_I2C_CNTL);                outr(MPP_CONFIG, MPP_WRITEINC);                out8(MPP_DATA, 0x00U);                out8(MPP_DATA, 0x55U);                out8(MPP_DATA, 0x00U);                out8(MPP_DATA, 0x00U);                ATIMach64MPPWaitForIdle(pATI);                break;            }            /* Otherwise, fall through to the older case */        case ATI_CHIP_264VT:        case ATI_CHIP_264GT:            /* First try GIO pins 11 (clock) and 4 (data) */            pATII2C->I2CSetBits = ATIMach64GP_IOSetBits;            pATII2C->I2CGetBits = ATIMach64GP_IOGetBits;            pATII2C->SCLDir = GP_IO_DIR_B;            pATII2C->SCLGet = pATII2C->SCLSet = GP_IO_B;            pATII2C->SDADir = GP_IO_DIR_4;            pATII2C->SDAGet = pATII2C->SDASet = GP_IO_4;            if (ATITVAddOnProbe(pScreenInfo, pATI, pI2CBus))                break;            /* Next, try pins 10 (clock) and 12 (data) */            pATII2C->SCLDir = GP_IO_DIR_A;            pATII2C->SCLGet = pATII2C->SCLSet = GP_IO_A;            pATII2C->SDADir = GP_IO_DIR_C;            pATII2C->SDAGet = pATII2C->SDASet = GP_IO_C;            if (ATITVAddOnProbe(pScreenInfo, pATI, pI2CBus))                break;            /* Otherwise, fall back to ATI's first I2C implementation */        default:            /*             * First generation integrated controllers access GIO pin 1 (clock)             * though DAC_CNTL, and pin 2 (data) through GEN_TEST_CNTL.             */            pATII2C->I2CSetBits = ATIMach64DAC_GENSetBits;            pATII2C->I2CGetBits = ATIMach64DAC_GENGetBits;            pATII2C->SCLDir = DAC_GIO_DIR_1;            pATII2C->SCLGet = pATII2C->SCLSet = DAC_GIO_STATE_1;            pATII2C->SDADir = GEN_GIO2_WRITE;            pATII2C->SDAGet = GEN_GIO2_DATA_IN;            pATII2C->SDASet = GEN_GIO2_DATA_OUT;            (void)ATITVAddOnProbe(pScreenInfo, pATI, pI2CBus);            break;    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲午夜高清国产拍精品| 一区二区激情小说| 欧美中文字幕一区二区三区| 久久爱另类一区二区小说| 最新成人av在线| 欧美精品一区二区三区高清aⅴ| 91理论电影在线观看| 国产一区二区在线影院| 亚洲成人av免费| 韩国av一区二区三区| 亚洲高清免费一级二级三级| 国产精品初高中害羞小美女文| 日韩欧美国产麻豆| 欧美午夜电影网| 91蜜桃免费观看视频| 粗大黑人巨茎大战欧美成人| 美女视频第一区二区三区免费观看网站| 亚洲欧洲综合另类| 久久看人人爽人人| 精品欧美一区二区在线观看| 欧美日韩一区二区不卡| 色偷偷久久人人79超碰人人澡| 成人性视频网站| 国产一区999| 狠狠狠色丁香婷婷综合激情 | 免费美女久久99| 午夜精品一区二区三区电影天堂 | 国产电影精品久久禁18| 青青草97国产精品免费观看 | 麻豆精品一二三| 亚洲成人动漫在线观看| 亚洲永久精品国产| 亚洲综合无码一区二区| 亚洲男人的天堂一区二区| 国产精品成人免费| 国产精品国产三级国产三级人妇| 中文一区二区完整视频在线观看| 26uuu亚洲综合色| 日韩一级大片在线观看| 欧美一二区视频| 日韩美女主播在线视频一区二区三区| 制服丝袜中文字幕亚洲| 在线播放/欧美激情| 555www色欧美视频| 精品少妇一区二区三区免费观看| 91精品国产综合久久婷婷香蕉| 欧美日韩性生活| 欧美一级片在线看| 精品剧情v国产在线观看在线| 日韩欧美一区中文| 精品国产一区二区三区久久久蜜月 | 国产精品一区二区无线| 国产一区二区毛片| 国产.欧美.日韩| 91片黄在线观看| 在线区一区二视频| 4438成人网| 国产情人综合久久777777| 国产精品福利一区二区| 亚洲激情中文1区| 天堂av在线一区| 久久精品99国产精品| 国产99精品国产| 色综合视频在线观看| 在线播放中文字幕一区| 精品少妇一区二区三区在线播放| 中日韩av电影| 亚洲第一激情av| 国产综合一区二区| 97久久超碰国产精品电影| 精品视频资源站| 日韩精品专区在线影院观看| 国产精品理论片| 五月天激情综合| 极品美女销魂一区二区三区 | 亚洲精品成人在线| 天堂久久一区二区三区| 懂色av中文一区二区三区| 91成人免费网站| 精品女同一区二区| 亚洲女女做受ⅹxx高潮| 蜜臀av一区二区三区| 波多野结衣中文一区| 欧美日韩国产首页| 国产精品网站在线观看| 日韩高清在线不卡| www.66久久| 欧美成人一区二区三区在线观看| 中文字幕一区二区三中文字幕| 午夜精品久久久久| 不卡av免费在线观看| 欧美一区二区三级| 樱花草国产18久久久久| 精品一二三四区| 欧美性猛片aaaaaaa做受| 欧美激情一区在线观看| 免费在线观看视频一区| 99精品欧美一区二区三区小说| 日韩一区二区免费在线电影| 亚洲激情一二三区| 国产精品一区二区果冻传媒| 欧美日韩一区三区四区| 综合电影一区二区三区 | 亚洲国产精品成人综合| 蜜桃在线一区二区三区| 欧洲人成人精品| 国产精品国产三级国产专播品爱网| 老司机一区二区| 欧美视频在线观看一区二区| 国产精品狼人久久影院观看方式| 久久国产人妖系列| 717成人午夜免费福利电影| 亚洲激情图片qvod| 99久久精品国产观看| 欧美国产视频在线| 精品一区二区免费视频| 3d动漫精品啪啪| 亚洲v精品v日韩v欧美v专区| 一本久久a久久精品亚洲| 国产精品色噜噜| 国产成人免费高清| 国产亚洲女人久久久久毛片| 美女脱光内衣内裤视频久久网站| 欧美日韩一二三| 一区二区三区不卡视频| 91福利精品视频| 亚洲综合无码一区二区| 在线免费观看日本欧美| 亚洲综合久久av| 欧美午夜精品一区二区蜜桃 | 东方aⅴ免费观看久久av| 精品久久久久香蕉网| 久久精品国产99| 精品国产伦一区二区三区观看体验| 日本欧美一区二区三区| 欧美一级日韩免费不卡| 蜜桃视频在线一区| 欧美成人三级在线| 国产一区高清在线| 久久精品人人做人人爽人人| 国产精品一区免费视频| 中文字幕欧美日本乱码一线二线| 国产成人在线观看免费网站| 国产日韩综合av| 不卡视频免费播放| 夜夜揉揉日日人人青青一国产精品| 色乱码一区二区三区88| 亚洲成人免费av| 制服丝袜激情欧洲亚洲| 久久99久久99| 国产精品三级av| 一本色道久久加勒比精品 | 欧美成人乱码一区二区三区| 激情五月激情综合网| 久久精品亚洲精品国产欧美kt∨| 成人综合在线网站| 亚洲人午夜精品天堂一二香蕉| 欧美中文字幕久久| 日韩精品午夜视频| 国产日韩亚洲欧美综合| 日本国产一区二区| 日本不卡一二三| 国产欧美精品一区| 日本国产一区二区| 久久精品久久久精品美女| 国产视频一区在线播放| 色婷婷国产精品久久包臀| 午夜精品久久久久久久99水蜜桃| 精品国产一二三区| 色综合久久天天| 奇米影视一区二区三区| 欧美国产精品一区| 欧美色图一区二区三区| 激情小说欧美图片| 亚洲综合精品久久| 欧美精品一区二区久久婷婷| 色8久久精品久久久久久蜜| 麻豆国产精品一区二区三区| 国产精品久久久久影视| 欧美日韩一区二区三区在线看| 韩国视频一区二区| 亚洲日本电影在线| 精品久久久久久久一区二区蜜臀| 99久久婷婷国产| 狠狠狠色丁香婷婷综合激情| 亚洲一区二区3| 久久精品夜色噜噜亚洲aⅴ| 欧美日韩一区小说| 丁香激情综合国产| 日本最新不卡在线| 亚洲欧美韩国综合色| 久久午夜免费电影| 日本高清不卡一区| 成人性生交大片免费看中文| 奇米777欧美一区二区| 亚洲免费av在线| 国产欧美视频一区二区三区| 在线成人av网站| 97se亚洲国产综合自在线不卡| 韩国毛片一区二区三区|