summaryrefslogtreecommitdiff
path: root/src/atimach64.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/atimach64.c')
-rw-r--r--src/atimach64.c1235
1 files changed, 0 insertions, 1235 deletions
diff --git a/src/atimach64.c b/src/atimach64.c
deleted file mode 100644
index 72f4a10..0000000
--- a/src/atimach64.c
+++ /dev/null
@@ -1,1235 +0,0 @@
-/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/ati/atimach64.c,v 1.52 2003/04/23 21:51:28 tsi Exp $ */
-/*
- * Copyright 1997 through 2003 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.
- */
-/*
- * Copyright 1999-2000 Precision Insight, Inc., Cedar Park, Texas.
- * All Rights Reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to
- * deal in the Software without restriction, including without limitation the
- * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
- * sell copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice (including the next
- * paragraph) shall be included in all copies or substantial portions of the
- * Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
- * PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- */
-/*
- * DRI support by:
- * Manuel Teira
- * Leif Delgass <ldelgass@retinalburn.net>
- */
-
-#include "ati.h"
-#include "atibus.h"
-#include "atichip.h"
-#include "atidac.h"
-#include "atimach64.h"
-#include "atimach64accel.h"
-#include "atimach64io.h"
-#include "atirgb514.h"
-
-#ifndef DPMS_SERVER
-# define DPMS_SERVER
-#endif
-#include "extensions/dpms.h"
-
-/*
- * ATIMach64PreInit --
- *
- * This function fills in the Mach64 portion of an ATIHWRec that is common to
- * all video modes generated by the driver.
- */
-void
-ATIMach64PreInit
-(
- ScrnInfoPtr pScreenInfo,
- ATIPtr pATI,
- ATIHWPtr pATIHW
-)
-{
- CARD32 bus_cntl, config_cntl;
- int tmp;
-
-#ifndef AVOID_CPIO
-
- if (pATI->depth <= 4)
- {
- pATIHW->crtc_off_pitch = SetBits(pATI->displayWidth >> 4, CRTC_PITCH);
- }
- else
-
-#endif /* AVOID_CPIO */
-
- {
- pATIHW->crtc_off_pitch = SetBits(pATI->displayWidth >> 3, CRTC_PITCH);
- }
-
- if ((pATI->LockData.crtc_gen_cntl & CRTC_CSYNC_EN) && !pATI->OptionCSync)
- {
- xf86DrvMsg(pScreenInfo->scrnIndex, X_NOTICE,
- "Using composite sync to match input timing.\n");
- pATI->OptionCSync = TRUE;
- }
-
- pATIHW->bus_cntl = bus_cntl = inr(BUS_CNTL);
- if (pATI->Chip < ATI_CHIP_264VT4)
- pATIHW->bus_cntl = (pATIHW->bus_cntl & ~BUS_HOST_ERR_INT_EN) |
- BUS_HOST_ERR_INT;
- if (pATI->Chip < ATI_CHIP_264VTB)
- {
- pATIHW->bus_cntl &= ~(BUS_FIFO_ERR_INT_EN | BUS_ROM_DIS);
- pATIHW->bus_cntl |= SetBits(15, BUS_FIFO_WS) | BUS_FIFO_ERR_INT;
- }
- else if (pATI->MMIOInLinear)
- {
- pATIHW->bus_cntl &= ~BUS_APER_REG_DIS;
- }
- else
- {
- pATIHW->bus_cntl |= BUS_APER_REG_DIS;
- }
- if (pATI->Chip >= ATI_CHIP_264VT)
- pATIHW->bus_cntl |= BUS_EXT_REG_EN; /* Enable Block 1 */
-
-#ifdef AVOID_CPIO
-
- pATIHW->mem_vga_wp_sel = SetBits(0, MEM_VGA_WPS0) |
- SetBits(1, MEM_VGA_WPS1);
- pATIHW->mem_vga_rp_sel = SetBits(0, MEM_VGA_RPS0) |
- SetBits(1, MEM_VGA_RPS1);
-
-#else /* AVOID_CPIO */
-
- pATIHW->mem_vga_wp_sel = SetBits(0, MEM_VGA_WPS0) |
- SetBits(pATIHW->nPlane, MEM_VGA_WPS1);
- pATIHW->mem_vga_rp_sel = SetBits(0, MEM_VGA_RPS0) |
- SetBits(pATIHW->nPlane, MEM_VGA_RPS1);
-
-#endif /* AVOID_CPIO */
-
- pATIHW->dac_cntl = inr(DAC_CNTL) &
- ~(DAC1_CLK_SEL | DAC_PALETTE_ACCESS_CNTL | DAC_8BIT_EN);
- if (pATI->Chip >= ATI_CHIP_264CT)
- pATIHW->dac_cntl &= ~DAC_FEA_CON_EN;
- if (pATI->rgbBits == 8)
- pATIHW->dac_cntl |= DAC_8BIT_EN;
-
- pATIHW->gen_test_cntl = pATI->LockData.gen_test_cntl & ~GEN_CUR_EN;
- if (pATI->DAC == ATI_DAC_IBMRGB514)
- pATIHW->gen_test_cntl |= GEN_OVR_OUTPUT_EN;
-
- pATIHW->config_cntl = config_cntl = inr(CONFIG_CNTL);
-
-#ifndef AVOID_CPIO
-
- if (pATI->UseSmallApertures)
- {
- pATIHW->config_cntl |= CFG_MEM_VGA_AP_EN;
- }
- else
-
-#endif /* AVOID_CPIO */
-
- {
- pATIHW->config_cntl &= ~CFG_MEM_VGA_AP_EN;
- }
-
- if (pATI->LinearBase && (pATI->Chip < ATI_CHIP_264CT))
- {
- /* Replace linear aperture size and address */
- pATIHW->config_cntl &= ~(CFG_MEM_AP_LOC | CFG_MEM_AP_SIZE);
- pATIHW->config_cntl |= SetBits(pATI->LinearBase >> 22, CFG_MEM_AP_LOC);
- if ((pATI->Chip < ATI_CHIP_264CT) && (pATI->VideoRAM < 4096))
- pATIHW->config_cntl |= SetBits(1, CFG_MEM_AP_SIZE);
- else
- pATIHW->config_cntl |= SetBits(2, CFG_MEM_AP_SIZE);
- }
-
- if (pATI->Chip >= ATI_CHIP_264VTB)
- {
- pATIHW->mem_cntl = (pATI->LockData.mem_cntl &
- ~(CTL_MEM_LOWER_APER_ENDIAN | CTL_MEM_UPPER_APER_ENDIAN)) |
- SetBits(CTL_MEM_APER_BYTE_ENDIAN, CTL_MEM_LOWER_APER_ENDIAN);
-
- switch (pATI->bitsPerPixel)
- {
- default:
- pATIHW->mem_cntl |= SetBits(CTL_MEM_APER_BYTE_ENDIAN,
- CTL_MEM_UPPER_APER_ENDIAN);
- break;
-
- case 16:
- pATIHW->mem_cntl |= SetBits(CTL_MEM_APER_WORD_ENDIAN,
- CTL_MEM_UPPER_APER_ENDIAN);
- break;
-
- case 32:
- pATIHW->mem_cntl |= SetBits(CTL_MEM_APER_LONG_ENDIAN,
- CTL_MEM_UPPER_APER_ENDIAN);
- break;
- }
-
- pATIHW->mpp_config = inr(MPP_CONFIG);
- pATIHW->mpp_config &=
- ~(MPP_PRESCALE | MPP_NSTATES | MPP_FORMAT | MPP_WAIT_STATE |
- MPP_INSERT_WAIT | MPP_TRISTATE_ADDR | MPP_AUTO_INC_EN |
- MPP_CHKREQ_EN | MPP_BUFFER_SIZE | MPP_BUFFER_MODE | MPP_BUSY);
- pATIHW->mpp_config |=
- (MPP_NSTATES_8 | MPP_FORMAT_DA8 | SetBits(4, MPP_WAIT_STATE) |
- MPP_CHKRDY_EN | MPP_READ_EARLY | MPP_RW_MODE | MPP_EN);
- pATIHW->mpp_strobe_seq = inr(MPP_STROBE_SEQ);
- pATIHW->mpp_strobe_seq &= ~(MPP_STB0_SEQ | MPP_STB1_SEQ);
- pATIHW->mpp_strobe_seq |=
- SetBits(0x0087U, MPP_STB0_SEQ) | SetBits(0x0083U, MPP_STB1_SEQ);
- pATIHW->tvo_cntl = 0;
- }
-
- /* Draw engine setup */
- if (pATI->Block0Base)
- {
- /* Ensure apertures are enabled */
- outr(BUS_CNTL, pATIHW->bus_cntl);
- outr(CONFIG_CNTL, pATIHW->config_cntl);
-
- /*
- * When possible, max out command FIFO size.
- */
- if (pATI->Chip >= ATI_CHIP_264VT4)
-
-#ifdef XF86DRI
-
- /* Changing the FIFO depth seems to interfere with DMA, so use
- * default of 128 entries (0x01)
- */
- pATIHW->gui_cntl = (inm(GUI_CNTL) & ~CMDFIFO_SIZE_MODE) | 0x01;
-
-#else /* XF86DRI */
-
- pATIHW->gui_cntl = inm(GUI_CNTL) & ~CMDFIFO_SIZE_MODE;
-
-#endif /* XF86DRI */
-
- /* Initialise destination registers */
- pATIHW->dst_off_pitch =
- SetBits((pATI->displayWidth * pATI->XModifier) >> 3, DST_PITCH);
- pATIHW->dst_cntl = DST_X_DIR | DST_Y_DIR | DST_LAST_PEL;
-
- /* Initialise source registers */
- pATIHW->src_off_pitch = pATIHW->dst_off_pitch;
- pATIHW->src_width1 = pATIHW->src_height1 =
- pATIHW->src_width2 = pATIHW->src_height2 = 1;
- pATIHW->src_cntl = SRC_LINE_X_DIR;
-
- /* Initialise scissor, allowing for offscreen areas */
- pATIHW->sc_right = (pATI->displayWidth * pATI->XModifier) - 1;
- tmp = pATI->displayWidth * pATI->bitsPerPixel;
- tmp = (((pScreenInfo->videoRam * (1024 * 8)) + tmp - 1) / tmp) - 1;
- if (tmp > ATIMach64MaxY)
- tmp = ATIMach64MaxY;
- pATIHW->sc_bottom = tmp;
- pATI->sc_left_right = SetWord(pATI->NewHW.sc_right, 1) |
- SetWord(pATI->NewHW.sc_left, 0);
- pATI->sc_top_bottom = SetWord(pATI->NewHW.sc_bottom, 1) |
- SetWord(pATI->NewHW.sc_top, 0);
-
- /* Initialise data path */
- pATIHW->dp_frgd_clr = (CARD32)(-1);
- pATIHW->dp_write_mask = (CARD32)(-1);
-
- switch (pATI->depth)
- {
- case 8:
- pATIHW->dp_chain_mask = DP_CHAIN_8BPP;
- pATIHW->dp_pix_width =
- SetBits(PIX_WIDTH_8BPP, DP_DST_PIX_WIDTH) |
- SetBits(PIX_WIDTH_8BPP, DP_SRC_PIX_WIDTH) |
- SetBits(PIX_WIDTH_1BPP, DP_HOST_PIX_WIDTH);
- break;
-
- case 15:
- pATIHW->dp_chain_mask = DP_CHAIN_15BPP_1555;
- pATIHW->dp_pix_width =
- SetBits(PIX_WIDTH_15BPP, DP_DST_PIX_WIDTH) |
- SetBits(PIX_WIDTH_15BPP, DP_SRC_PIX_WIDTH) |
- SetBits(PIX_WIDTH_1BPP, DP_HOST_PIX_WIDTH);
- break;
-
- case 16:
- pATIHW->dp_chain_mask = DP_CHAIN_16BPP_565;
- pATIHW->dp_pix_width =
- SetBits(PIX_WIDTH_16BPP, DP_DST_PIX_WIDTH) |
- SetBits(PIX_WIDTH_16BPP, DP_SRC_PIX_WIDTH) |
- SetBits(PIX_WIDTH_1BPP, DP_HOST_PIX_WIDTH);
- break;
-
- case 24:
- if (pATI->bitsPerPixel == 24)
- {
- pATIHW->dp_chain_mask = DP_CHAIN_24BPP_888;
- pATIHW->dp_pix_width =
- SetBits(PIX_WIDTH_8BPP, DP_DST_PIX_WIDTH) |
- SetBits(PIX_WIDTH_8BPP, DP_SRC_PIX_WIDTH) |
- SetBits(PIX_WIDTH_1BPP, DP_HOST_PIX_WIDTH);
- }
- else
- {
- pATIHW->dp_chain_mask = DP_CHAIN_32BPP_8888;
- pATIHW->dp_pix_width =
- SetBits(PIX_WIDTH_32BPP, DP_DST_PIX_WIDTH) |
- SetBits(PIX_WIDTH_32BPP, DP_SRC_PIX_WIDTH) |
- SetBits(PIX_WIDTH_1BPP, DP_HOST_PIX_WIDTH);
- }
- break;
-
- default:
- break;
- }
-
-#if X_BYTE_ORDER == X_LITTLE_ENDIAN
-
- pATIHW->dp_pix_width |= DP_BYTE_PIX_ORDER;
-
-#endif /* X_BYTE_ORDER */
-
- pATIHW->dp_mix = SetBits(MIX_SRC, DP_FRGD_MIX) |
- SetBits(MIX_DST, DP_BKGD_MIX);
- pATIHW->dp_src = DP_MONO_SRC_ALLONES |
- SetBits(SRC_FRGD, DP_FRGD_SRC) | SetBits(SRC_BKGD, DP_BKGD_SRC);
-
- /* Initialise colour compare */
- pATIHW->clr_cmp_msk = (1 << pATI->depth) - 1;
-
- if (pATI->Block1Base)
- {
- pATIHW->overlay_y_x_start = SetBits(0, OVERLAY_Y_START) |
- SetBits(0, OVERLAY_X_START) | OVERLAY_LOCK_START;
- pATIHW->overlay_y_x_end = SetBits(0, OVERLAY_Y_END) |
- SetBits(0, OVERLAY_X_END) | OVERLAY_LOCK_END;
-
- pATIHW->overlay_graphics_key_clr =
- (3 << ((2 * pATI->depth) / 3)) |
- (2 << ((1 * pATI->depth) / 3)) |
- (1 << ((0 * pATI->depth) / 3));
- pATIHW->overlay_graphics_key_msk = (1 << pATI->depth) - 1;
-
- pATIHW->overlay_key_cntl =
- SetBits(OVERLAY_MIX_FALSE, OVERLAY_VIDEO_FN) |
- SetBits(OVERLAY_MIX_EQUAL, OVERLAY_GRAPHICS_FN);
-
- pATIHW->overlay_scale_cntl = SCALE_EN;
-
- pATIHW->video_format = VIDEO_IN_VYUY422 | SCALER_IN_VYUY422;
-
- if (pATI->Chip >= ATI_CHIP_264GTPRO)
- {
- /* These values are documented voodoo */
- pATIHW->scaler_h_coeff0 = SetByte(0x20U, 1);
- pATIHW->scaler_h_coeff1 = SetByte(0x0DU, 0) |
- SetByte(0x20U, 1) | SetByte(0x06U, 2) | SetByte(0x0DU, 3);
- pATIHW->scaler_h_coeff2 = SetByte(0x0DU, 0) |
- SetByte(0x1CU, 1) | SetByte(0x0AU, 2) | SetByte(0x0DU, 3);
- pATIHW->scaler_h_coeff3 = SetByte(0x0CU, 0) |
- SetByte(0x1AU, 1) | SetByte(0x0EU, 2) | SetByte(0x0CU, 3);
- pATIHW->scaler_h_coeff4 = SetByte(0x0CU, 0) |
- SetByte(0x14U, 1) | SetByte(0x14U, 2) | SetByte(0x0CU, 3);
- }
- }
-
- /* Restore aperture enablement */
- outr(BUS_CNTL, bus_cntl);
- outr(CONFIG_CNTL, config_cntl);
- }
-}
-
-/*
- * ATIMach64Save --
- *
- * This function is called to save the Mach64 portion of the current video
- * state.
- */
-void
-ATIMach64Save
-(
- ATIPtr pATI,
- ATIHWPtr pATIHW
-)
-{
- pATIHW->crtc_h_total_disp = inr(CRTC_H_TOTAL_DISP);
- pATIHW->crtc_h_sync_strt_wid = inr(CRTC_H_SYNC_STRT_WID);
- pATIHW->crtc_v_total_disp = inr(CRTC_V_TOTAL_DISP);
- pATIHW->crtc_v_sync_strt_wid = inr(CRTC_V_SYNC_STRT_WID);
-
- pATIHW->crtc_off_pitch = inr(CRTC_OFF_PITCH);
-
- pATIHW->crtc_gen_cntl = inr(CRTC_GEN_CNTL);
-
- pATIHW->ovr_clr = inr(OVR_CLR);
- pATIHW->ovr_wid_left_right = inr(OVR_WID_LEFT_RIGHT);
- pATIHW->ovr_wid_top_bottom = inr(OVR_WID_TOP_BOTTOM);
-
- pATIHW->cur_clr0 = inr(CUR_CLR0);
- pATIHW->cur_clr1 = inr(CUR_CLR1);
- pATIHW->cur_offset = inr(CUR_OFFSET);
- pATIHW->cur_horz_vert_posn = inr(CUR_HORZ_VERT_POSN);
- pATIHW->cur_horz_vert_off = inr(CUR_HORZ_VERT_OFF);
-
- pATIHW->clock_cntl = inr(CLOCK_CNTL);
-
- pATIHW->bus_cntl = inr(BUS_CNTL);
-
- pATIHW->mem_vga_wp_sel = inr(MEM_VGA_WP_SEL);
- pATIHW->mem_vga_rp_sel = inr(MEM_VGA_RP_SEL);
-
- pATIHW->dac_cntl = inr(DAC_CNTL);
-
- pATIHW->config_cntl = inr(CONFIG_CNTL);
-
- pATIHW->gen_test_cntl = inr(GEN_TEST_CNTL) & ~GEN_CUR_EN;
-
- if (pATI->Chip >= ATI_CHIP_264VTB)
- {
- pATIHW->mem_cntl = inr(MEM_CNTL);
- pATIHW->mpp_config = inr(MPP_CONFIG);
- pATIHW->mpp_strobe_seq = inr(MPP_STROBE_SEQ);
- pATIHW->tvo_cntl = inr(TVO_CNTL);
- }
-
- /* Save draw engine state */
- if (pATI->Block0Base && (pATIHW == &pATI->OldHW))
- {
- /* Ensure apertures are enabled */
- outr(BUS_CNTL, pATI->NewHW.bus_cntl);
- outr(CONFIG_CNTL, pATI->NewHW.config_cntl);
-
- ATIMach64WaitForIdle(pATI);
-
- /* Save FIFO size */
- if (pATI->Chip >= ATI_CHIP_264VT4)
- pATIHW->gui_cntl = inm(GUI_CNTL);
-
- /* Save destination registers */
- pATIHW->dst_off_pitch = inm(DST_OFF_PITCH);
- pATIHW->dst_x = inm(DST_X);
- pATIHW->dst_y = inm(DST_Y);
- pATIHW->dst_height = inm(DST_HEIGHT);
- pATIHW->dst_bres_err = inm(DST_BRES_ERR);
- pATIHW->dst_bres_inc = inm(DST_BRES_INC);
- pATIHW->dst_bres_dec = inm(DST_BRES_DEC);
- pATIHW->dst_cntl = inm(DST_CNTL);
-
- /* Save source registers */
- pATIHW->src_off_pitch = inm(SRC_OFF_PITCH);
- pATIHW->src_x = inm(SRC_X);
- pATIHW->src_y = inm(SRC_Y);
- pATIHW->src_width1 = inm(SRC_WIDTH1);
- pATIHW->src_height1 = inm(SRC_HEIGHT1);
- pATIHW->src_x_start = inm(SRC_X_START);
- pATIHW->src_y_start = inm(SRC_Y_START);
- pATIHW->src_width2 = inm(SRC_WIDTH2);
- pATIHW->src_height2 = inm(SRC_HEIGHT2);
- pATIHW->src_cntl = inm(SRC_CNTL);
-
- /* Save host data register */
- pATIHW->host_cntl = inm(HOST_CNTL);
-
- /* Save pattern registers */
- pATIHW->pat_reg0 = inm(PAT_REG0);
- pATIHW->pat_reg1 = inm(PAT_REG1);
- pATIHW->pat_cntl = inm(PAT_CNTL);
-
- /* Save scissor registers */
- pATIHW->sc_left = pATI->sc_left = inm(SC_LEFT);
- pATIHW->sc_right = pATI->sc_right = inm(SC_RIGHT);
- pATIHW->sc_top = pATI->sc_top = inm(SC_TOP);
- pATIHW->sc_bottom = pATI->sc_bottom = inm(SC_BOTTOM);
-
- /* Save data path registers */
- pATIHW->dp_bkgd_clr = inm(DP_BKGD_CLR);
- pATIHW->dp_frgd_clr = inm(DP_FRGD_CLR);
- pATIHW->dp_write_mask = inm(DP_WRITE_MASK);
- pATIHW->dp_chain_mask = inm(DP_CHAIN_MASK);
- pATIHW->dp_pix_width = inm(DP_PIX_WIDTH);
- pATIHW->dp_mix = inm(DP_MIX);
- pATIHW->dp_src = inm(DP_SRC);
-
- /* Save colour compare registers */
- pATIHW->clr_cmp_clr = inm(CLR_CMP_CLR);
- pATIHW->clr_cmp_msk = inm(CLR_CMP_MSK);
- pATIHW->clr_cmp_cntl = inm(CLR_CMP_CNTL);
-
- /* Save context */
- pATIHW->context_mask = inm(CONTEXT_MASK);
-
- if (pATI->Block1Base)
- {
- /* Save overlay & scaler registers */
- pATIHW->overlay_y_x_start = inm(OVERLAY_Y_X_START);
- pATIHW->overlay_y_x_end = inm(OVERLAY_Y_X_END);
-
- pATIHW->overlay_graphics_key_clr = inm(OVERLAY_GRAPHICS_KEY_CLR);
- pATIHW->overlay_graphics_key_msk = inm(OVERLAY_GRAPHICS_KEY_MSK);
-
- pATIHW->overlay_key_cntl = inm(OVERLAY_KEY_CNTL);
-
- pATIHW->overlay_scale_inc = inm(OVERLAY_SCALE_INC);
- pATIHW->overlay_scale_cntl = inm(OVERLAY_SCALE_CNTL);
-
- pATIHW->scaler_height_width = inm(SCALER_HEIGHT_WIDTH);
-
- pATIHW->scaler_test = inm(SCALER_TEST);
-
- pATIHW->video_format = inm(VIDEO_FORMAT);
-
- if (pATI->Chip < ATI_CHIP_264VTB)
- {
- pATIHW->buf0_offset = inm(BUF0_OFFSET);
- pATIHW->buf0_pitch = inm(BUF0_PITCH);
- pATIHW->buf1_offset = inm(BUF1_OFFSET);
- pATIHW->buf1_pitch = inm(BUF1_PITCH);
- }
- else
- {
- pATIHW->scaler_buf0_offset = inm(SCALER_BUF0_OFFSET);
- pATIHW->scaler_buf1_offset = inm(SCALER_BUF1_OFFSET);
- pATIHW->scaler_buf_pitch = inm(SCALER_BUF_PITCH);
-
- pATIHW->overlay_exclusive_horz = inm(OVERLAY_EXCLUSIVE_HORZ);
- pATIHW->overlay_exclusive_vert = inm(OVERLAY_EXCLUSIVE_VERT);
-
- if (pATI->Chip >= ATI_CHIP_264GTPRO)
- {
- pATIHW->scaler_colour_cntl = inm(SCALER_COLOUR_CNTL);
-
- pATIHW->scaler_h_coeff0 = inm(SCALER_H_COEFF0);
- pATIHW->scaler_h_coeff1 = inm(SCALER_H_COEFF1);
- pATIHW->scaler_h_coeff2 = inm(SCALER_H_COEFF2);
- pATIHW->scaler_h_coeff3 = inm(SCALER_H_COEFF3);
- pATIHW->scaler_h_coeff4 = inm(SCALER_H_COEFF4);
-
- pATIHW->scaler_buf0_offset_u = inm(SCALER_BUF0_OFFSET_U);
- pATIHW->scaler_buf0_offset_v = inm(SCALER_BUF0_OFFSET_V);
- pATIHW->scaler_buf1_offset_u = inm(SCALER_BUF1_OFFSET_U);
- pATIHW->scaler_buf1_offset_v = inm(SCALER_BUF1_OFFSET_V);
- }
- }
- }
-
- /* Restore aperture enablement */
- outr(BUS_CNTL, pATIHW->bus_cntl);
- outr(CONFIG_CNTL, pATIHW->config_cntl);
- }
-}
-
-/*
- * ATIMach64Calculate --
- *
- * This function is called to fill in the Mach64 portion of an ATIHWRec.
- */
-void
-ATIMach64Calculate
-(
- ATIPtr pATI,
- ATIHWPtr pATIHW,
- DisplayModePtr pMode
-)
-{
- int VDisplay;
-
- /* If not already done adjust horizontal timings */
- if (!pMode->CrtcHAdjusted)
- {
- pMode->CrtcHAdjusted = TRUE;
- /* XXX Deal with Blank Start/End and overscan later */
- pMode->CrtcHDisplay = (pMode->HDisplay >> 3) - 1;
- pMode->CrtcHSyncStart = (pMode->HSyncStart >> 3) - 1;
- pMode->CrtcHSyncEnd = (pMode->HSyncEnd >> 3) - 1;
- pMode->CrtcHTotal = (pMode->HTotal >> 3) - 1;
-
- /* Make adjustments if sync pulse width is out-of-bounds */
- if ((pMode->CrtcHSyncEnd - pMode->CrtcHSyncStart) >
- (int)MaxBits(CRTC_H_SYNC_WID))
- {
- pMode->CrtcHSyncEnd =
- pMode->CrtcHSyncStart + MaxBits(CRTC_H_SYNC_WID);
- }
- else if (pMode->CrtcHSyncStart == pMode->CrtcHSyncEnd)
- {
- if (pMode->CrtcHDisplay < pMode->CrtcHSyncStart)
- pMode->CrtcHSyncStart--;
- else if (pMode->CrtcHSyncEnd < pMode->CrtcHTotal)
- pMode->CrtcHSyncEnd++;
- }
- }
-
- /*
- * Always re-do vertical adjustments.
- */
- pMode->CrtcVDisplay = pMode->VDisplay;
- pMode->CrtcVSyncStart = pMode->VSyncStart;
- pMode->CrtcVSyncEnd = pMode->VSyncEnd;
- pMode->CrtcVTotal = pMode->VTotal;
-
- if ((pATI->Chip >= ATI_CHIP_264CT) &&
- ((pMode->Flags & V_DBLSCAN) || (pMode->VScan > 1)))
- {
- pMode->CrtcVDisplay <<= 1;
- pMode->CrtcVSyncStart <<= 1;
- pMode->CrtcVSyncEnd <<= 1;
- pMode->CrtcVTotal <<= 1;
- }
-
- /*
- * Might as well default to the same as VGA with respect to sync
- * polarities.
- */
- if ((!(pMode->Flags & (V_PHSYNC | V_NHSYNC))) ||
- (!(pMode->Flags & (V_PVSYNC | V_NVSYNC))))
- {
- pMode->Flags &= ~(V_PHSYNC | V_NHSYNC | V_PVSYNC | V_NVSYNC);
-
- if (pATI->OptionPanelDisplay && (pATI->LCDPanelID >= 0))
- VDisplay = pATI->LCDVertical;
- else
- VDisplay = pMode->CrtcVDisplay;
-
- if (VDisplay < 400)
- pMode->Flags |= V_PHSYNC | V_NVSYNC;
- else if (VDisplay < 480)
- pMode->Flags |= V_NHSYNC | V_PVSYNC;
- else if (VDisplay < 768)
- pMode->Flags |= V_NHSYNC | V_NVSYNC;
- else
- pMode->Flags |= V_PHSYNC | V_PVSYNC;
- }
-
- pMode->CrtcVDisplay--;
- pMode->CrtcVSyncStart--;
- pMode->CrtcVSyncEnd--;
- pMode->CrtcVTotal--;
- /* Make sure sync pulse is not too wide */
- if ((pMode->CrtcVSyncEnd - pMode->CrtcVSyncStart) >
- (int)MaxBits(CRTC_V_SYNC_WID))
- pMode->CrtcVSyncEnd = pMode->CrtcVSyncStart + MaxBits(CRTC_V_SYNC_WID);
- pMode->CrtcVAdjusted = TRUE; /* Redundant */
-
- /* Build register contents */
- pATIHW->crtc_h_total_disp =
- SetBits(pMode->CrtcHTotal, CRTC_H_TOTAL) |
- SetBits(pMode->CrtcHDisplay, CRTC_H_DISP);
- pATIHW->crtc_h_sync_strt_wid =
- SetBits(pMode->CrtcHSyncStart, CRTC_H_SYNC_STRT) |
- SetBits(pMode->CrtcHSkew, CRTC_H_SYNC_DLY) | /* ? */
- SetBits(GetBits(pMode->CrtcHSyncStart, 0x0100U),
- CRTC_H_SYNC_STRT_HI) |
- SetBits(pMode->CrtcHSyncEnd - pMode->CrtcHSyncStart,
- CRTC_H_SYNC_WID);
- if (pMode->Flags & V_NHSYNC)
- pATIHW->crtc_h_sync_strt_wid |= CRTC_H_SYNC_POL;
-
- pATIHW->crtc_v_total_disp =
- SetBits(pMode->CrtcVTotal, CRTC_V_TOTAL) |
- SetBits(pMode->CrtcVDisplay, CRTC_V_DISP);
- pATIHW->crtc_v_sync_strt_wid =
- SetBits(pMode->CrtcVSyncStart, CRTC_V_SYNC_STRT) |
- SetBits(pMode->CrtcVSyncEnd - pMode->CrtcVSyncStart,
- CRTC_V_SYNC_WID);
- if (pMode->Flags & V_NVSYNC)
- pATIHW->crtc_v_sync_strt_wid |= CRTC_V_SYNC_POL;
-
- pATIHW->crtc_gen_cntl = inr(CRTC_GEN_CNTL) &
- ~(CRTC_DBL_SCAN_EN | CRTC_INTERLACE_EN |
- CRTC_HSYNC_DIS | CRTC_VSYNC_DIS | CRTC_CSYNC_EN |
- CRTC_PIX_BY_2_EN | CRTC_DISPLAY_DIS | CRTC_VGA_XOVERSCAN |
- CRTC_PIX_WIDTH | CRTC_BYTE_PIX_ORDER |
- CRTC_VGA_128KAP_PAGING | CRTC_VFC_SYNC_TRISTATE |
- CRTC_LOCK_REGS | /* Already off, but ... */
- CRTC_SYNC_TRISTATE | CRTC_DISP_REQ_EN |
- CRTC_VGA_TEXT_132 | CRTC_CUR_B_TEST);
- pATIHW->crtc_gen_cntl |=
- CRTC_EXT_DISP_EN | CRTC_EN | CRTC_VGA_LINEAR | CRTC_CNT_EN;
- switch (pATI->depth)
- {
-
-#ifndef AVOID_CPIO
-
- case 1:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_1BPP, CRTC_PIX_WIDTH);
- break;
-
- case 4:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_4BPP, CRTC_PIX_WIDTH);
- break;
-
-#endif /* AVOID_CPIO */
-
- case 8:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_8BPP, CRTC_PIX_WIDTH);
- break;
-
- case 15:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_15BPP, CRTC_PIX_WIDTH);
- break;
-
- case 16:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_16BPP, CRTC_PIX_WIDTH);
- break;
-
- case 24:
- if (pATI->bitsPerPixel == 24)
- {
- pATIHW->crtc_gen_cntl |=
- SetBits(PIX_WIDTH_24BPP, CRTC_PIX_WIDTH);
- break;
- }
- if (pATI->bitsPerPixel != 32)
- break;
- /* Fall through */
-
- case 32:
- pATIHW->crtc_gen_cntl |= SetBits(PIX_WIDTH_32BPP, CRTC_PIX_WIDTH);
- break;
-
- default:
- break;
- }
- if ((pMode->Flags & V_DBLSCAN) || (pMode->VScan > 1))
- pATIHW->crtc_gen_cntl |= CRTC_DBL_SCAN_EN;
- if (pMode->Flags & V_INTERLACE)
- pATIHW->crtc_gen_cntl |= CRTC_INTERLACE_EN;
- if (pATI->OptionCSync || (pMode->Flags & (V_CSYNC | V_PCSYNC)))
- pATIHW->crtc_gen_cntl |= CRTC_CSYNC_EN;
- /* For now, set display FIFO low water mark as high as possible */
- if (pATI->Chip < ATI_CHIP_264VTB)
- pATIHW->crtc_gen_cntl |= CRTC_FIFO_LWM;
-}
-
-/*
- * ATIMach64Set --
- *
- * This function is called to load a Mach64's accelerator CRTC and draw engine.
- */
-void
-ATIMach64Set
-(
- ATIPtr pATI,
- ATIHWPtr pATIHW
-)
-{
-
-#ifndef AVOID_CPIO
-
- if (pATIHW->crtc == ATI_CRTC_MACH64)
-
-#endif /* AVOID_CPIO */
-
- {
- if ((pATIHW->FeedbackDivider > 0) &&
- (pATI->ProgrammableClock != ATI_CLOCK_NONE))
- ATIClockSet(pATI, pATIHW); /* Programme clock */
-
- if (pATI->DAC == ATI_DAC_IBMRGB514)
- ATIRGB514Set(pATI, pATIHW);
-
- /* Load Mach64 CRTC registers */
- outr(CRTC_H_TOTAL_DISP, pATIHW->crtc_h_total_disp);
- outr(CRTC_H_SYNC_STRT_WID, pATIHW->crtc_h_sync_strt_wid);
- outr(CRTC_V_TOTAL_DISP, pATIHW->crtc_v_total_disp);
- outr(CRTC_V_SYNC_STRT_WID, pATIHW->crtc_v_sync_strt_wid);
-
- outr(CRTC_OFF_PITCH, pATIHW->crtc_off_pitch);
-
- /* Load overscan registers */
- outr(OVR_CLR, pATIHW->ovr_clr);
- outr(OVR_WID_LEFT_RIGHT, pATIHW->ovr_wid_left_right);
- outr(OVR_WID_TOP_BOTTOM, pATIHW->ovr_wid_top_bottom);
-
- /* Load hardware cursor registers */
- outr(CUR_CLR0, pATIHW->cur_clr0);
- outr(CUR_CLR1, pATIHW->cur_clr1);
- outr(CUR_OFFSET, pATIHW->cur_offset);
- outr(CUR_HORZ_VERT_POSN, pATIHW->cur_horz_vert_posn);
- outr(CUR_HORZ_VERT_OFF, pATIHW->cur_horz_vert_off);
-
- /* Set pixel clock */
- outr(CLOCK_CNTL, pATIHW->clock_cntl | CLOCK_STROBE);
-
- outr(GEN_TEST_CNTL, pATIHW->gen_test_cntl | GEN_GUI_EN);
- outr(GEN_TEST_CNTL, pATIHW->gen_test_cntl);
- outr(GEN_TEST_CNTL, pATIHW->gen_test_cntl | GEN_GUI_EN);
-
- /* Finalise CRTC setup and turn on the screen */
- outr(CRTC_GEN_CNTL, pATIHW->crtc_gen_cntl);
- }
-
- /* Load draw engine */
- if (pATI->Block0Base)
- {
- /* Clobber MMIO cache */
- (void)memset(pATI->MMIOCached, 0, SizeOf(pATI->MMIOCached));
-
- /* Ensure apertures are enabled */
- outr(BUS_CNTL, pATI->NewHW.bus_cntl);
- outr(CONFIG_CNTL, pATI->NewHW.config_cntl);
-
- pATI->EngineIsBusy = TRUE; /* Force engine poll */
- ATIMach64WaitForIdle(pATI);
-
- /* Load FIFO size */
- if (pATI->Chip >= ATI_CHIP_264VT4)
- {
- outm(GUI_CNTL, pATIHW->gui_cntl);
- pATI->nAvailableFIFOEntries = 0;
- ATIMach64PollEngineStatus(pATI);
- }
-
- /* Set FIFO depth */
- pATI->nFIFOEntries = pATI->nAvailableFIFOEntries;
-
- /* Load destination registers */
- ATIMach64WaitForFIFO(pATI, 7);
- outf(DST_OFF_PITCH, pATIHW->dst_off_pitch);
- outf(DST_Y_X, SetWord(pATIHW->dst_x, 1) | SetWord(pATIHW->dst_y, 0));
- outf(DST_HEIGHT, pATIHW->dst_height);
- outf(DST_BRES_ERR, pATIHW->dst_bres_err);
- outf(DST_BRES_INC, pATIHW->dst_bres_inc);
- outf(DST_BRES_DEC, pATIHW->dst_bres_dec);
- outf(DST_CNTL, pATIHW->dst_cntl);
-
- /* Load source registers */
- ATIMach64WaitForFIFO(pATI, 6);
- outf(SRC_OFF_PITCH, pATIHW->src_off_pitch);
- outf(SRC_Y_X, SetWord(pATIHW->src_x, 1) | SetWord(pATIHW->src_y, 0));
- outf(SRC_HEIGHT1_WIDTH1,
- SetWord(pATIHW->src_width1, 1) | SetWord(pATIHW->src_height1, 0));
- outf(SRC_Y_X_START,
- SetWord(pATIHW->src_x_start, 1) | SetWord(pATIHW->src_y_start, 0));
- outf(SRC_HEIGHT2_WIDTH2,
- SetWord(pATIHW->src_width2, 1) | SetWord(pATIHW->src_height2, 0));
- outf(SRC_CNTL, pATIHW->src_cntl);
-
- /* Load host data register */
- ATIMach64WaitForFIFO(pATI, 1);
- outf(HOST_CNTL, pATIHW->host_cntl);
-
- /* Set host transfer window address and size clamp */
- pATI->pHOST_DATA =
- (CARD8 *)pATI->pBlock[GetBits(HOST_DATA_0, BLOCK_SELECT)] +
- (HOST_DATA_0 & MM_IO_SELECT);
- pATI->nHostFIFOEntries = pATI->nFIFOEntries >> 1;
- if (pATI->nHostFIFOEntries > 16)
- pATI->nHostFIFOEntries = 16;
-
- /* Load pattern registers */
- ATIMach64WaitForFIFO(pATI, 3);
- outf(PAT_REG0, pATIHW->pat_reg0);
- outf(PAT_REG1, pATIHW->pat_reg1);
- outf(PAT_CNTL, pATIHW->pat_cntl);
-
- /* Load scissor registers */
- ATIMach64WaitForFIFO(pATI, 2);
- outf(SC_LEFT_RIGHT,
- SetWord(pATIHW->sc_right, 1) | SetWord(pATIHW->sc_left, 0));
- outf(SC_TOP_BOTTOM,
- SetWord(pATIHW->sc_bottom, 1) | SetWord(pATIHW->sc_top, 0));
- pATI->sc_left = pATIHW->sc_left;
- pATI->sc_right = pATIHW->sc_right;
- pATI->sc_top = pATIHW->sc_top;
- pATI->sc_bottom = pATIHW->sc_bottom;
-
- /* Load data path registers */
- ATIMach64WaitForFIFO(pATI, 7);
- outf(DP_BKGD_CLR, pATIHW->dp_bkgd_clr);
- outf(DP_FRGD_CLR, pATIHW->dp_frgd_clr);
- outf(DP_WRITE_MASK, pATIHW->dp_write_mask);
- outf(DP_CHAIN_MASK, pATIHW->dp_chain_mask);
- outf(DP_PIX_WIDTH, pATIHW->dp_pix_width);
- outf(DP_MIX, pATIHW->dp_mix);
- outf(DP_SRC, pATIHW->dp_src);
-
- /* Load colour compare registers */
- ATIMach64WaitForFIFO(pATI, 3);
- outf(CLR_CMP_CLR, pATIHW->clr_cmp_clr);
- outf(CLR_CMP_MSK, pATIHW->clr_cmp_msk);
- outf(CLR_CMP_CNTL, pATIHW->clr_cmp_cntl);
-
- /* Load context mask */
- ATIMach64WaitForFIFO(pATI, 1);
- outf(CONTEXT_MASK, pATIHW->context_mask);
-
- if (pATI->Block1Base)
- {
- /* Load overlay & scaler registers */
- ATIMach64WaitForFIFO(pATI, 10);
- outf(OVERLAY_Y_X_START, pATIHW->overlay_y_x_start);
- outf(OVERLAY_Y_X_END, pATIHW->overlay_y_x_end);
-
- outf(OVERLAY_GRAPHICS_KEY_CLR, pATIHW->overlay_graphics_key_clr);
- outf(OVERLAY_GRAPHICS_KEY_MSK, pATIHW->overlay_graphics_key_msk);
-
- outf(OVERLAY_KEY_CNTL, pATIHW->overlay_key_cntl);
-
- outf(OVERLAY_SCALE_INC, pATIHW->overlay_scale_inc);
- outf(OVERLAY_SCALE_CNTL, pATIHW->overlay_scale_cntl);
-
- outf(SCALER_HEIGHT_WIDTH, pATIHW->scaler_height_width);
-
- outf(SCALER_TEST, pATIHW->scaler_test);
-
- outf(VIDEO_FORMAT, pATIHW->video_format);
-
- if (pATI->Chip < ATI_CHIP_264VTB)
- {
- ATIMach64WaitForFIFO(pATI, 4);
- outf(BUF0_OFFSET, pATIHW->buf0_offset);
- outf(BUF0_PITCH, pATIHW->buf0_pitch);
- outf(BUF1_OFFSET, pATIHW->buf1_offset);
- outf(BUF1_PITCH, pATIHW->buf1_pitch);
- }
- else
- {
- ATIMach64WaitForFIFO(pATI, 5);
- outf(SCALER_BUF0_OFFSET, pATIHW->scaler_buf0_offset);
- outf(SCALER_BUF1_OFFSET, pATIHW->scaler_buf1_offset);
- outf(SCALER_BUF_PITCH, pATIHW->scaler_buf_pitch);
-
- outf(OVERLAY_EXCLUSIVE_HORZ, pATIHW->overlay_exclusive_horz);
- outf(OVERLAY_EXCLUSIVE_VERT, pATIHW->overlay_exclusive_vert);
-
- if (pATI->Chip >= ATI_CHIP_264GTPRO)
- {
- ATIMach64WaitForFIFO(pATI, 10);
- outf(SCALER_COLOUR_CNTL, pATIHW->scaler_colour_cntl);
-
- outf(SCALER_H_COEFF0, pATIHW->scaler_h_coeff0);
- outf(SCALER_H_COEFF1, pATIHW->scaler_h_coeff1);
- outf(SCALER_H_COEFF2, pATIHW->scaler_h_coeff2);
- outf(SCALER_H_COEFF3, pATIHW->scaler_h_coeff3);
- outf(SCALER_H_COEFF4, pATIHW->scaler_h_coeff4);
-
- outf(SCALER_BUF0_OFFSET_U, pATIHW->scaler_buf0_offset_u);
- outf(SCALER_BUF0_OFFSET_V, pATIHW->scaler_buf0_offset_v);
- outf(SCALER_BUF1_OFFSET_U, pATIHW->scaler_buf1_offset_u);
- outf(SCALER_BUF1_OFFSET_V, pATIHW->scaler_buf1_offset_v);
- }
- }
- }
-
- ATIMach64WaitForIdle(pATI);
-
- if (pATI->OptionMMIOCache)
- {
- /*
- * Enable write caching for selected MMIO registers. This can only
- * be done for those registers whose value does not change without
- * driver intervention.
- */
-
- CacheRegister(SRC_CNTL);
-
- CacheRegister(HOST_CNTL);
-
- CacheRegister(PAT_REG0);
- CacheRegister(PAT_REG1);
- CacheRegister(PAT_CNTL);
-
- CacheRegister(SC_LEFT_RIGHT);
- CacheRegister(SC_TOP_BOTTOM);
-
- CacheRegister(DP_BKGD_CLR);
- CacheRegister(DP_FRGD_CLR);
- CacheRegister(DP_WRITE_MASK);
- CacheRegister(DP_MIX);
-
- CacheRegister(CLR_CMP_CLR);
- CacheRegister(CLR_CMP_MSK);
- CacheRegister(CLR_CMP_CNTL);
-
- if (pATI->Block1Base)
- {
- CacheRegister(OVERLAY_Y_X_START);
- CacheRegister(OVERLAY_Y_X_END);
-
- CacheRegister(OVERLAY_GRAPHICS_KEY_CLR);
- CacheRegister(OVERLAY_GRAPHICS_KEY_MSK);
-
- CacheRegister(OVERLAY_KEY_CNTL);
-
- CacheRegister(OVERLAY_SCALE_INC);
- CacheRegister(OVERLAY_SCALE_CNTL);
-
- CacheRegister(SCALER_HEIGHT_WIDTH);
-
- CacheRegister(SCALER_TEST);
-
- CacheRegister(VIDEO_FORMAT);
-
- if (pATI->Chip < ATI_CHIP_264VTB)
- {
- CacheRegister(BUF0_OFFSET);
- CacheRegister(BUF0_PITCH);
- CacheRegister(BUF1_OFFSET);
- CacheRegister(BUF1_PITCH);
- }
- else
- {
- CacheRegister(SCALER_BUF0_OFFSET);
- CacheRegister(SCALER_BUF1_OFFSET);
- CacheRegister(SCALER_BUF_PITCH);
-
- CacheRegister(OVERLAY_EXCLUSIVE_HORZ);
- CacheRegister(OVERLAY_EXCLUSIVE_VERT);
-
- if (pATI->Chip >= ATI_CHIP_264GTPRO)
- {
- CacheRegister(SCALER_COLOUR_CNTL);
-
- CacheRegister(SCALER_H_COEFF0);
- CacheRegister(SCALER_H_COEFF1);
- CacheRegister(SCALER_H_COEFF2);
- CacheRegister(SCALER_H_COEFF3);
- CacheRegister(SCALER_H_COEFF4);
-
- CacheRegister(SCALER_BUF0_OFFSET_U);
- CacheRegister(SCALER_BUF0_OFFSET_V);
- CacheRegister(SCALER_BUF1_OFFSET_U);
- CacheRegister(SCALER_BUF1_OFFSET_V);
- }
- }
- }
- }
- }
-
-#ifndef AVOID_CPIO
-
- if (pATIHW->crtc == ATI_CRTC_MACH64)
-
-#endif /* AVOID_CPIO */
-
- {
- /* Aperture setup */
- outr(MEM_VGA_WP_SEL, pATIHW->mem_vga_wp_sel);
- outr(MEM_VGA_RP_SEL, pATIHW->mem_vga_rp_sel);
-
- outr(DAC_CNTL, pATIHW->dac_cntl);
-
- outr(CONFIG_CNTL, pATIHW->config_cntl);
- outr(BUS_CNTL, pATIHW->bus_cntl);
-
- if (pATI->Chip >= ATI_CHIP_264VTB)
- {
- outr(MEM_CNTL, pATIHW->mem_cntl);
- outr(MPP_CONFIG, pATIHW->mpp_config);
- outr(MPP_STROBE_SEQ, pATIHW->mpp_strobe_seq);
- outr(TVO_CNTL, pATIHW->tvo_cntl);
- }
- }
-}
-
-/*
- * ATIMach64SaveScreen --
- *
- * This function blanks or unblanks a Mach64 screen.
- */
-void
-ATIMach64SaveScreen
-(
- ATIPtr pATI,
- int Mode
-)
-{
- CARD32 crtc_gen_cntl = inr(CRTC_GEN_CNTL);
-
- switch (Mode)
- {
- case SCREEN_SAVER_OFF:
- case SCREEN_SAVER_FORCER:
- outr(CRTC_GEN_CNTL, crtc_gen_cntl & ~CRTC_DISPLAY_DIS);
- break;
-
- case SCREEN_SAVER_ON:
- case SCREEN_SAVER_CYCLE:
- outr(CRTC_GEN_CNTL, crtc_gen_cntl | CRTC_DISPLAY_DIS);
- break;
-
- default:
- break;
- }
-}
-
-/*
- * ATIMach64SetDPMSMode --
- *
- * This function sets a Mach64's VESA Display Power Management Signaling mode.
- */
-void
-ATIMach64SetDPMSMode
-(
- ScrnInfoPtr pScreenInfo,
- ATIPtr pATI,
- int DPMSMode
-)
-{
- CARD32 crtc_gen_cntl =
- inr(CRTC_GEN_CNTL) & ~(CRTC_HSYNC_DIS | CRTC_VSYNC_DIS);
-
- switch (DPMSMode)
- {
- case DPMSModeOn: /* HSync on, VSync on */
- break;
-
- case DPMSModeStandby: /* HSync off, VSync on */
- crtc_gen_cntl |= CRTC_HSYNC_DIS;
- break;
-
- case DPMSModeSuspend: /* HSync on, VSync off */
- crtc_gen_cntl |= CRTC_VSYNC_DIS;
- break;
-
- case DPMSModeOff: /* HSync off, VSync off */
- crtc_gen_cntl |= CRTC_HSYNC_DIS | CRTC_VSYNC_DIS;
- break;
-
- default: /* Muffle compiler */
- return;
- }
-
-#ifdef XF86DRI
-
- /* XAA Sync requires the DRM lock if DRI enabled */
- ATIDRILock(pScreenInfo);
-
-#endif /* XF86DRI */
-
- ATIMach64Sync(pScreenInfo);
-
- outr(CRTC_GEN_CNTL, crtc_gen_cntl);
-
- if (pATI->OptionPanelDisplay && (pATI->LCDPanelID >= 0))
- {
- CARD32 lcd_index = 0;
-
- /*
- * ATI's BIOS simply turns the panel on and off, so do the same by
- * default, but keep the previous behaviour around for reference.
- */
- if (pATI->OptionDevel)
- {
- CARD32 power_management;
-
- if (pATI->Chip == ATI_CHIP_264LT)
- {
- power_management = inr(POWER_MANAGEMENT);
- }
- else /* if ((pATI->Chip == ATI_CHIP_264LTPRO) ||
- (pATI->Chip == ATI_CHIP_264XL) ||
- (pATI->Chip == ATI_CHIP_MOBILITY)) */
- {
- lcd_index = inr(LCD_INDEX);
- power_management = ATIMach64GetLCDReg(LCD_POWER_MANAGEMENT);
- }
-
- power_management &= ~(STANDBY_NOW | SUSPEND_NOW);
-
- switch (DPMSMode)
- {
- case DPMSModeOn:
- break;
-
- case DPMSModeStandby:
- power_management |= STANDBY_NOW;
- break;
-
- case DPMSModeSuspend:
- power_management |= SUSPEND_NOW;
- break;
-
- case DPMSModeOff:
- power_management |= STANDBY_NOW | SUSPEND_NOW; /* ? */
- break;
-
- default: /* Muffle compiler */
- return;
- }
-
- if (pATI->Chip == ATI_CHIP_264LT)
- {
- outr(POWER_MANAGEMENT, power_management);
- }
- else /* if ((pATI->Chip == ATI_CHIP_264LTPRO) ||
- (pATI->Chip == ATI_CHIP_264XL) ||
- (pATI->Chip == ATI_CHIP_MOBILITY)) */
- {
- ATIMach64PutLCDReg(LCD_POWER_MANAGEMENT, power_management);
- outr(LCD_INDEX, lcd_index);
- }
- }
- else
- {
- CARD32 lcd_gen_ctrl;
-
- if (pATI->Chip == ATI_CHIP_264LT)
- {
- lcd_gen_ctrl = inr(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);
- }
-
- if (DPMSMode == DPMSModeOn)
- lcd_gen_ctrl |= LCD_ON;
- else
- lcd_gen_ctrl &= ~LCD_ON;
-
- if (pATI->Chip == ATI_CHIP_264LT)
- outr(LCD_GEN_CTRL, lcd_gen_ctrl);
- else /* if ((pATI->Chip == ATI_CHIP_264LTPRO) ||
- (pATI->Chip == ATI_CHIP_264XL) ||
- (pATI->Chip == ATI_CHIP_MOBILITY)) */
- {
- ATIMach64PutLCDReg(LCD_GEN_CNTL, lcd_gen_ctrl);
- outr(LCD_INDEX, lcd_index);
- }
- }
- }
-
-#ifdef XF86DRI
-
- ATIDRIUnlock(pScreenInfo);
-
-#endif /* XF86DRI */
-
-}