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

📄 atiprint.c

📁 x.org上有关ati系列显卡最新驱动
💻 C
📖 第 1 页 / 共 2 页
字号:
/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/ati/atiprint.c,v 1.28 2003/11/07 13:45:26 tsi Exp $ *//* * Copyright 1997 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 <string.h>#include <ctype.h>#include "ati.h"#include "atiadapter.h"#include "atichip.h"#include "atidac.h"#include "atimach64io.h"#include "atiprint.h"#include "atiwonderio.h"/* * ATIPrintBIOS -- * * Display various parts of the BIOS when the server is invoked with -verbose. */voidATIPrintBIOS(    const CARD8        *BIOS,    const unsigned int Length   /* A multiple of 512 */){    unsigned char *Char = NULL;    unsigned int  Index;    unsigned char Printable[17];    if (xf86GetVerbosity() <= 4)        return;    (void)memset(Printable, 0, SizeOf(Printable));    xf86ErrorFVerb(5, "\n BIOS image:");    for (Index = 0;  Index < Length;  Index++)    {        if (!(Index & (4U - 1U)))        {            if (!(Index & (16U - 1U)))            {                if (Printable[0])                    xf86ErrorFVerb(5, "  |%s|", Printable);                Char = Printable;                xf86ErrorFVerb(5, "\n 0x%08X: ", Index);            }            xf86ErrorFVerb(5, " ");        }        xf86ErrorFVerb(5, "%02X", BIOS[Index]);        if (isprint(BIOS[Index]))            *Char++ = BIOS[Index];        else            *Char++ = '.';    }    xf86ErrorFVerb(5, "  |%s|\n", Printable);}#ifndef AVOID_CPIO/* * ATIPrintIndexedRegisters -- * * Display a set of indexed byte-size registers when the server is invoked with * -verbose. */static voidATIPrintIndexedRegisters(    const IOADDRESS Port,    const CARD8     StartIndex,    const CARD8     EndIndex,    const char      *Name,    const IOADDRESS GenS1){    int Index;    xf86ErrorFVerb(4, "\n %s register values:", Name);    for (Index = StartIndex;  Index < EndIndex;  Index++)    {        if (!(Index & (4U - 1U)))        {            if (!(Index & (16U - 1U)))                xf86ErrorFVerb(4, "\n 0x%02X: ", Index);            xf86ErrorFVerb(4, " ");        }        if (Port == ATTRX)            (void)inb(GenS1);           /* Reset flip-flop */        xf86ErrorFVerb(4, "%02X", GetReg(Port, Index));    }    if (Port == ATTRX)    {        (void)inb(GenS1);               /* Reset flip-flop */        outb(ATTRX, 0x20U);             /* Turn on PAS bit */    }    xf86ErrorFVerb(4, "\n");}#endif /* AVOID_CPIO *//* * ATIMach64PrintRegisters -- * * Display a Mach64's main register bank when the server is invoked with * -verbose. */static voidATIMach64PrintRegisters(    ATIPtr     pATI,    CARD8      *crtc,    const char *Description){    CARD32 IOValue;    CARD8 dac_read, dac_mask, dac_data, dac_write;    int Index, Limit;#ifndef AVOID_CPIO    int Step;#endif /* AVOID_CPIO */    xf86ErrorFVerb(4, "\n Mach64 %s register values:", Description);#ifdef AVOID_CPIO    if (pATI->pBlock[1])        Limit = DWORD_SELECT;    else        Limit = MM_IO_SELECT;    for (Index = 0;  Index <= Limit;  Index += UnitOf(MM_IO_SELECT))    {        if (!(Index & SetBits(3, MM_IO_SELECT)))            xf86ErrorFVerb(4, "\n 0x%04X: ", Index);        if (Index == (DAC_REGS & DWORD_SELECT))        {            dac_read = in8(DAC_REGS + 3);            DACDelay;            dac_mask = in8(DAC_REGS + 2);            DACDelay;            dac_data = in8(DAC_REGS + 1);            DACDelay;            dac_write = in8(DAC_REGS + 0);            DACDelay;            xf86ErrorFVerb(4, " %02X%02X%02X%02X",                dac_read, dac_mask, dac_data, dac_write);            out8(DAC_REGS + 2, dac_mask);            DACDelay;            out8(DAC_REGS + 3, dac_read);            DACDelay;        }        else        {            IOValue = inm(Index);            if ((Index == (CRTC_GEN_CNTL & DWORD_SELECT)) &&                (IOValue & CRTC_EXT_DISP_EN))                *crtc = ATI_CRTC_MACH64;            xf86ErrorFVerb(4, " %08lX", (unsigned long)IOValue);        }    }#else /* AVOID_CPIO */    Limit = ATIIOPort(IOPortTag(0x1FU, 0x3FU));    Step = ATIIOPort(IOPortTag(0x01U, 0x01U)) - pATI->CPIOBase;    for (Index = pATI->CPIOBase;  Index <= Limit;  Index += Step)    {        if (!(((Index - pATI->CPIOBase) / Step) & 0x03U))            xf86ErrorFVerb(4, "\n 0x%04X: ", Index);        if (Index == (int)ATIIOPort(DAC_REGS))        {            dac_read = in8(DAC_REGS + 3);            DACDelay;            dac_mask = in8(DAC_REGS + 2);            DACDelay;            dac_data = in8(DAC_REGS + 1);            DACDelay;            dac_write = in8(DAC_REGS + 0);            DACDelay;            xf86ErrorFVerb(4, " %02X%02X%02X%02X",                dac_read, dac_mask, dac_data, dac_write);            out8(DAC_REGS + 2, dac_mask);            DACDelay;            out8(DAC_REGS + 3, dac_read);            DACDelay;        }        else        {            IOValue = inl(Index);            if ((Index == (int)ATIIOPort(CRTC_GEN_CNTL)) &&                (IOValue & CRTC_EXT_DISP_EN))                *crtc = ATI_CRTC_MACH64;            xf86ErrorFVerb(4, " %08lX", (unsigned long)IOValue);        }    }#endif /* AVOID_CPIO */    xf86ErrorFVerb(4, "\n");}/* * ATIMach64PrintPLLRegisters -- * * Display an integrated Mach64's PLL registers when the server is invoked with * -verbose. */static voidATIMach64PrintPLLRegisters(    ATIPtr pATI){    int Index, Limit;    CARD8 PLLReg[MaxBits(PLL_ADDR) + 1];    for (Limit = 0;  Limit < SizeOf(PLLReg);  Limit++)        PLLReg[Limit] = ATIMach64GetPLLReg(Limit);    /* Determine how many PLL registers there really are */    while ((Limit = Limit >> 1))        for (Index = 0;  Index < Limit;  Index++)            if (PLLReg[Index] != PLLReg[Index + Limit])                goto FoundLimit;FoundLimit:    Limit <<= 1;    xf86ErrorFVerb(4, "\n Mach64 PLL register values:");    for (Index = 0;  Index < Limit;  Index++)    {        if (!(Index & 3))        {            if (!(Index & 15))                xf86ErrorFVerb(4, "\n 0x%02X: ", Index);            xf86ErrorFVerb(4, " ");        }        xf86ErrorFVerb(4, "%02X", PLLReg[Index]);    }    xf86ErrorFVerb(4, "\n");}/* * ATIRGB514PrintRegisters -- * * Display IBM RGB 514 registers when the server is invoked with -verbose. */static voidATIRGB514PrintRegisters(    ATIPtr pATI){    CARD32 crtc_gen_cntl, dac_cntl;    CARD8  index_lo, index_hi, index_ctl;    int    Index;    /* Temporarily switch to Mach64 CRTC */    crtc_gen_cntl = inr(CRTC_GEN_CNTL);    if (!(crtc_gen_cntl & CRTC_EXT_DISP_EN))        outr(CRTC_GEN_CNTL, crtc_gen_cntl | CRTC_EXT_DISP_EN);    /* Temporarily switch to IBM RGB 514 registers */    dac_cntl = inr(DAC_CNTL);    outr(DAC_CNTL, (dac_cntl & ~DAC_EXT_SEL_RS3) | DAC_EXT_SEL_RS2);    index_lo = in8(M64_DAC_WRITE);    index_hi = in8(M64_DAC_DATA);    index_ctl = in8(M64_DAC_READ);    out8(M64_DAC_WRITE, 0x00U);    out8(M64_DAC_DATA, 0x00U);    out8(M64_DAC_READ, 0x01U);  /* Auto-increment */    xf86ErrorFVerb(4, "\n IBM RGB 514 registers:");    for (Index = 0;  Index < 0x0800;  Index++)    {        if (!(Index & 3))        {            if (!(Index & 15))            {                xf86ErrorFVerb(4, "\n 0x%04X: ", Index);                /* Need to rewrite index every so often... */                if ((Index == 0x0100) || (Index == 0x0500))                {                    out8(M64_DAC_WRITE, 0x00U);                    out8(M64_DAC_DATA, Index >> 8);                }            }            xf86ErrorFVerb(4, " ");        }        xf86ErrorFVerb(4, "%02X", in8(M64_DAC_MASK));    }    /* Restore registers */    out8(M64_DAC_WRITE, index_lo);    out8(M64_DAC_DATA, index_hi);    out8(M64_DAC_READ, index_ctl);    outr(DAC_CNTL, dac_cntl);    if (!(crtc_gen_cntl & CRTC_EXT_DISP_EN))        outr(CRTC_GEN_CNTL, crtc_gen_cntl);    xf86ErrorFVerb(4, "\n");}/* * ATIPrintRegisters -- * * Display various registers when the server is invoked with -verbose. */voidATIPrintRegisters(    ATIPtr pATI){    pciVideoPtr  pVideo;    pciConfigPtr pPCI;    int          Index;    CARD32       lcd_index, tv_out_index, lcd_gen_ctrl;    CARD8        dac_read, dac_mask, dac_write;    CARD8        crtc;#ifndef AVOID_CPIO    CARD8 genmo, seq1 = 0;    crtc = ATI_CRTC_VGA;    if (pATI->VGAAdapter != ATI_ADAPTER_NONE)    {        xf86ErrorFVerb(4, "\n Miscellaneous output register value:  0x%02X.\n",            genmo = inb(R_GENMO));        if (genmo & 0x01U)        {            if (pATI->Chip == ATI_CHIP_264LT)            {                lcd_gen_ctrl = inr(LCD_GEN_CTRL);                outr(LCD_GEN_CTRL, lcd_gen_ctrl & ~SHADOW_RW_EN);                ATIPrintIndexedRegisters(CRTX(ColourIOBase), 0, 64,                    "Non-shadow colour CRT controller", 0);                outr(LCD_GEN_CTRL, lcd_gen_ctrl | SHADOW_RW_EN);                ATIPrintIndexedRegisters(CRTX(ColourIOBase), 0, 64,                    "Shadow colour CRT controller", 0);                outr(LCD_GEN_CTRL, lcd_gen_ctrl);            }            else if ((pATI->Chip == ATI_CHIP_264LTPRO) ||                     (pATI->Chip == ATI_CHIP_264XL) ||                     (pATI->Chip == ATI_CHIP_MOBILITY))            {                lcd_index = inr(LCD_INDEX);                lcd_gen_ctrl = ATIMach64GetLCDReg(LCD_GEN_CNTL);                ATIMach64PutLCDReg(LCD_GEN_CNTL,                    lcd_gen_ctrl & ~(CRTC_RW_SELECT | SHADOW_RW_EN));                ATIPrintIndexedRegisters(CRTX(ColourIOBase), 0, 64,                    "Non-shadow colour CRT controller", 0);                ATIMach64PutLCDReg(LCD_GEN_CNTL,                    (lcd_gen_ctrl & ~CRTC_RW_SELECT) | SHADOW_RW_EN);                ATIPrintIndexedRegisters(CRTX(ColourIOBase), 0, 64,                    "Shadow colour CRT controller", 0);                ATIMach64PutLCDReg(LCD_GEN_CNTL, lcd_gen_ctrl);                outr(LCD_INDEX, lcd_index);            }            else            {                ATIPrintIndexedRegisters(CRTX(ColourIOBase), 0, 64,                    "Colour CRT controller", 0);            }            ATIPrintIndexedRegisters(ATTRX, 0, 32, "Attribute controller",

⌨️ 快捷键说明

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