1 /* $XdotOrg: driver/xf86-video-nv/src/nv_driver.c,v 1.21 2006/01/24 16:45:29 aplattner Exp $ */
2 /* $XConsortium: nv_driver.c /main/3 1996/10/28 05:13:37 kaleb $ */
4 * Copyright 1996-1997 David J. McKay
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * DAVID J. MCKAY BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
20 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
21 * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
25 /* Hacked together from mga driver and 3.3.4 NVIDIA driver by Jarno Paananen
28 /* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/nv/nv_driver.c,v 1.144 2006/06/16 00:19:32 mvojkovi Exp $ */
32 #include "nv_include.h"
34 #include "xf86int10.h"
38 extern DisplayModePtr xf86ModesAdd(DisplayModePtr Modes, DisplayModePtr Additions);
41 * Forward definitions for the functions that make up the driver.
43 /* Mandatory functions */
44 static const OptionInfoRec * NVAvailableOptions(int chipid, int busid);
45 static void NVIdentify(int flags);
46 #ifndef XSERVER_LIBPCIACCESS
47 static Bool NVProbe(DriverPtr drv, int flags);
48 #endif /* XSERVER_LIBPCIACCESS */
49 static Bool NVPreInit(ScrnInfoPtr pScrn, int flags);
50 static Bool NVScreenInit(int Index, ScreenPtr pScreen, int argc,
52 static Bool NVEnterVT(int scrnIndex, int flags);
53 static void NVLeaveVT(int scrnIndex, int flags);
54 static Bool NVCloseScreen(int scrnIndex, ScreenPtr pScreen);
55 static Bool NVSaveScreen(ScreenPtr pScreen, int mode);
57 /* Optional functions */
58 static void NVFreeScreen(int scrnIndex, int flags);
59 static ModeStatus NVValidMode(int scrnIndex, DisplayModePtr mode,
60 Bool verbose, int flags);
62 static Bool NVDriverFunc(ScrnInfoPtr pScrnInfo, xorgDriverFuncOp op,
66 /* Internally used functions */
68 static Bool NVMapMem(ScrnInfoPtr pScrn);
69 static Bool NVUnmapMem(ScrnInfoPtr pScrn);
70 static void NVSave(ScrnInfoPtr pScrn);
71 static void NVRestore(ScrnInfoPtr pScrn);
72 static Bool NVModeInit(ScrnInfoPtr pScrn, DisplayModePtr mode);
74 #ifdef XSERVER_LIBPCIACCESS
76 #define NOUVEAU_PCI_DEVICE(_vendor_id, _device_id) \
77 { (_vendor_id), (_device_id), PCI_MATCH_ANY, PCI_MATCH_ANY, 0x00030000, 0x00ffffff, 0 }
79 static const struct pci_id_match nouveau_device_match[] = {
80 NOUVEAU_PCI_DEVICE(PCI_VENDOR_NVIDIA, PCI_MATCH_ANY),
81 NOUVEAU_PCI_DEVICE(PCI_VENDOR_NVIDIA_SGS, PCI_MATCH_ANY),
85 static Bool NVPciProbe ( DriverPtr drv,
87 struct pci_device *dev,
88 intptr_t match_data );
90 #endif /* XSERVER_LIBPCIACCESS */
93 * This contains the functions needed by the server after loading the
94 * driver module. It must be supplied, and gets added the driver list by
95 * the Module Setup funtion in the dynamic case. In the static case a
96 * reference to this is compiled in, and this requires that the name of
97 * this DriverRec be an upper-case version of the driver name.
100 _X_EXPORT DriverRec NV = {
104 #ifdef XSERVER_LIBPCIACCESS
108 #endif /* XSERVER_LIBPCIACCESS */
113 #ifdef XSERVER_LIBPCIACCESS
114 nouveau_device_match,
116 #endif /* XSERVER_LIBPCIACCESS */
125 static struct NvFamily NVKnownFamilies[] =
127 { "RIVA TNT", "NV04" },
128 { "RIVA TNT2", "NV05" },
129 { "GeForce 256", "NV10" },
130 { "GeForce 2", "NV11, NV15" },
131 { "GeForce 4MX", "NV17, NV18" },
132 { "GeForce 3", "NV20" },
133 { "GeForce 4Ti", "NV25, NV28" },
134 { "GeForce FX", "NV3x" },
135 { "GeForce 6", "NV4x" },
136 { "GeForce 7", "G7x" },
137 { "GeForce 8", "G8x" },
142 * List of symbols from other modules that this module references. This
143 * list is used to tell the loader that it is OK for symbols here to be
144 * unresolved providing that it hasn't been told that they haven't been
145 * told that they are essential via a call to xf86LoaderReqSymbols() or
146 * xf86LoaderReqSymLists(). The purpose is this is to avoid warnings about
147 * unresolved symbols that are not required.
150 static const char *vgahwSymbols[] = {
165 static const char *fbSymbols[] = {
171 static const char *exaSymbols[] = {
177 static const char *ramdacSymbols[] = {
178 "xf86CreateCursorInfoRec",
179 "xf86DestroyCursorInfoRec",
184 static const char *ddcSymbols[] = {
187 "xf86SetDDCproperties",
191 static const char *vbeSymbols[] = {
198 static const char *i2cSymbols[] = {
199 "xf86CreateI2CBusRec",
204 static const char *shadowSymbols[] = {
209 static const char *int10Symbols[] = {
215 const char *drmSymbols[] = {
220 "drmAgpVersionMajor",
221 "drmAgpVersionMinor",
231 "drmCommandWriteRead",
234 "drmCtlUninstHandler",
237 "drmGetInterruptFromBusID",
243 const char *driSymbols[] = {
247 "DRIFinishScreenInit",
248 "DRIGetSAREAPrivate",
253 "GlxSetVisualConfigs",
259 static MODULESETUPPROTO(nouveauSetup);
261 static XF86ModuleVersionInfo nouveauVersRec =
267 XORG_VERSION_CURRENT,
268 NV_MAJOR_VERSION, NV_MINOR_VERSION, NV_PATCHLEVEL,
269 ABI_CLASS_VIDEODRV, /* This is a video driver */
270 ABI_VIDEODRV_VERSION,
275 _X_EXPORT XF86ModuleData nouveauModuleData = { &nouveauVersRec, nouveauSetup, NULL };
279 * This is intentionally screen-independent. It indicates the binding
280 * choice made in the first PreInit.
282 static int pix24bpp = 0;
285 NVGetRec(ScrnInfoPtr pScrn)
288 * Allocate an NVRec, and hook it into pScrn->driverPrivate.
289 * pScrn->driverPrivate is initialised to NULL, so we can check if
290 * the allocation has already been done.
292 if (pScrn->driverPrivate != NULL)
295 pScrn->driverPrivate = xnfcalloc(sizeof(NVRec), 1);
302 NVFreeRec(ScrnInfoPtr pScrn)
304 if (pScrn->driverPrivate == NULL)
306 xfree(pScrn->driverPrivate);
307 pScrn->driverPrivate = NULL;
312 nouveauSetup(pointer module, pointer opts, int *errmaj, int *errmin)
314 static Bool setupDone = FALSE;
316 /* This module should be loaded only once, but check to be sure. */
320 /* The 1 here is needed to turn off a backwards compatibility mode */
321 /* Otherwise NVPciProbe() is not called */
322 xf86AddDriver(&NV, module, 1);
325 * Modules that this driver always requires may be loaded here
326 * by calling LoadSubModule().
329 * Tell the loader about symbols from other modules that this module
332 LoaderRefSymLists(vgahwSymbols, exaSymbols, fbSymbols,
336 ramdacSymbols, shadowSymbols,
337 i2cSymbols, ddcSymbols, vbeSymbols,
341 * The return value must be non-NULL on success even though there
342 * is no TearDownProc.
346 if (errmaj) *errmaj = LDR_ONCEONLY;
351 static const OptionInfoRec *
352 NVAvailableOptions(int chipid, int busid)
359 NVIdentify(int flags)
361 struct NvFamily *family;
364 xf86DrvMsg(0, X_INFO, NV_NAME " driver " NV_DRIVER_DATE "\n");
365 xf86DrvMsg(0, X_INFO, NV_NAME " driver for NVIDIA chipset families :\n");
367 /* maximum length for alignment */
368 family = NVKnownFamilies;
369 while(family->name && family->chipset)
371 maxLen = max(maxLen, strlen(family->name));
376 family = NVKnownFamilies;
377 while(family->name && family->chipset)
379 size_t len = strlen(family->name);
380 xf86ErrorF("\t%s", family->name);
386 xf86ErrorF("(%s)\n", family->chipset);
393 NVGetScrnInfoRec(PciChipsets *chips, int chip)
397 pScrn = xf86ConfigPciEntity(NULL, 0, chip,
398 chips, NULL, NULL, NULL,
401 if(!pScrn) return FALSE;
403 pScrn->driverVersion = NV_VERSION;
404 pScrn->driverName = NV_DRIVER_NAME;
405 pScrn->name = NV_NAME;
407 #ifndef XSERVER_LIBPCIACCESS
408 pScrn->Probe = NVProbe;
412 pScrn->PreInit = NVPreInit;
413 pScrn->ScreenInit = NVScreenInit;
414 pScrn->SwitchMode = NVSwitchMode;
415 pScrn->AdjustFrame = NVAdjustFrame;
416 pScrn->EnterVT = NVEnterVT;
417 pScrn->LeaveVT = NVLeaveVT;
418 pScrn->FreeScreen = NVFreeScreen;
419 pScrn->ValidMode = NVValidMode;
424 /* This returns architecture in hexdecimal, so NV40 is 0x40 */
425 static int NVGetArchitecture (volatile CARD32 *regs)
427 int architecture = 0;
429 /* We're dealing with >=NV10 */
430 if ((regs[0] & 0x0f000000) > 0 ) {
431 /* Bit 27-20 contain the architecture in hex */
432 architecture = (regs[0] & 0xff00000) >> 20;
434 } else if ((regs[0] & 0xff00fff0) == 0x20004000) {
441 /* Reading the pci_id from the card registers is the most reliable way */
442 static CARD32 NVGetPCIID (volatile CARD32 *regs)
446 int architecture = NVGetArchitecture(regs);
448 /* Dealing with an unknown or unsupported card */
449 if (architecture == 0) {
453 if (architecture >= 0x40)
454 pci_id = regs[0x88000/4];
456 pci_id = regs[0x1800/4];
458 /* A pci-id can be inverted, we must correct this */
459 if ((pci_id & 0xffff) == PCI_VENDOR_NVIDIA) {
460 pci_id = (PCI_VENDOR_NVIDIA << 16) | (pci_id >> 16);
461 } else if ((pci_id & 0xffff) == PCI_VENDOR_NVIDIA_SGS) {
462 pci_id = (PCI_VENDOR_NVIDIA_SGS << 16) | (pci_id >> 16);
463 /* Checking endian issues */
465 /* PCI_VENDOR_NVIDIA = 0x10DE */
466 if ((pci_id & (0xffff << 16)) == (0xDE10 << 16)) { /* wrong endian */
467 pci_id = (PCI_VENDOR_NVIDIA << 16) | ((pci_id << 8) & 0x0000ff00) |
468 ((pci_id >> 8) & 0x000000ff);
469 /* PCI_VENDOR_NVIDIA_SGS = 0x12D2 */
470 } else if ((pci_id & (0xffff << 16)) == (0xD212 << 16)) { /* wrong endian */
471 pci_id = (PCI_VENDOR_NVIDIA_SGS << 16) | ((pci_id << 8) & 0x0000ff00) |
472 ((pci_id >> 8) & 0x000000ff);
479 #ifdef XSERVER_LIBPCIACCESS
481 static Bool NVPciProbe ( DriverPtr drv,
483 struct pci_device *dev,
484 intptr_t match_data )
486 ScrnInfoPtr pScrn = NULL;
488 volatile uint32_t *regs = NULL;
490 /* Temporary mapping to discover the architecture */
491 pci_device_map_range(dev, PCI_DEV_MEM_BASE(dev, 0), 0x90000, 0, (void **) ®s);
493 uint8_t architecture = NVGetArchitecture(regs);
495 CARD32 pci_id = NVGetPCIID(regs);
497 pci_device_unmap_range(dev, (void *) regs, 0x90000);
499 /* Currently NV04 up to NV83 is supported */
500 /* For safety the fictional NV8F is used */
501 if (architecture >= 0x04 && architecture <= 0x8F) {
503 /* At this stage the pci_id should be ok, so we generate this to avoid list duplication */
504 /* AGP bridge chips need their bridge chip id to be detected */
505 const PciChipsets NVChipsets[] = {
506 { pci_id, PCI_DEV_PCI_ID(dev), RES_SHARED_VGA },
507 { -1, -1, RES_UNDEFINED }
510 pScrn = xf86ConfigPciEntity(pScrn, 0, entity_num, NVChipsets,
511 NULL, NULL, NULL, NULL, NULL);
514 pScrn->driverVersion = NV_VERSION;
515 pScrn->driverName = NV_DRIVER_NAME;
516 pScrn->name = NV_NAME;
519 pScrn->PreInit = NVPreInit;
520 pScrn->ScreenInit = NVScreenInit;
521 pScrn->SwitchMode = NVSwitchMode;
522 pScrn->AdjustFrame = NVAdjustFrame;
523 pScrn->EnterVT = NVEnterVT;
524 pScrn->LeaveVT = NVLeaveVT;
525 pScrn->FreeScreen = NVFreeScreen;
526 pScrn->ValidMode = NVValidMode;
535 #endif /* XSERVER_LIBPCIACCESS */
537 #define MAX_CHIPS MAXSCREENS
539 #ifndef XSERVER_LIBPCIACCESS
542 NVProbe(DriverPtr drv, int flags)
545 GDevPtr *devSections;
547 SymTabRec NVChipsets[MAX_CHIPS + 1];
548 PciChipsets NVPciChipsets[MAX_CHIPS + 1];
552 Bool foundScreen = FALSE;
554 if ((numDevSections = xf86MatchDevice(NV_DRIVER_NAME, &devSections)) <= 0)
555 return FALSE; /* no matching device section */
557 if (!(ppPci = xf86GetPciVideoInfo()))
558 return FALSE; /* no PCI cards found */
562 /* Create the NVChipsets and NVPciChipsets from found devices */
563 while (*ppPci && (numUsed < MAX_CHIPS)) {
564 if (((*ppPci)->vendor == PCI_VENDOR_NVIDIA_SGS) ||
565 ((*ppPci)->vendor == PCI_VENDOR_NVIDIA))
567 volatile CARD32 *regs;
570 PCI_DEV_READ_LONG(*ppPci, PCI_CMD_STAT_REG, &pcicmd);
571 /* Enable reading memory? */
572 PCI_DEV_WRITE_LONG(*ppPci, PCI_CMD_STAT_REG, pcicmd | PCI_CMD_MEM_ENABLE);
574 regs = xf86MapPciMem(-1, VIDMEM_MMIO, PCI_DEV_TAG(*ppPci), PCI_DEV_MEM_BASE(*ppPci, 0), 0x90000);
575 int pciid = NVGetPCIID(regs);
577 int architecture = NVGetArchitecture(regs);
579 sprintf(name, "NVIDIA NV%02X", architecture);
580 /* NV04 upto NV83 is supported, NV8F is fictive limit */
581 if (architecture >= 0x04 && architecture <= 0x8F) {
582 NVChipsets[numUsed].token = pciid;
583 NVChipsets[numUsed].name = name;
584 NVPciChipsets[numUsed].numChipset = pciid;
585 /* AGP bridge chips need their bridge chip id to be detected */
586 NVPciChipsets[numUsed].PCIid = PCI_DEV_PCI_ID(*ppPci);
587 NVPciChipsets[numUsed].resList = RES_SHARED_VGA;
590 xf86UnMapVidMem(-1, (pointer)regs, 0x90000);
592 /* Reset previous state */
593 PCI_DEV_WRITE_LONG(*ppPci, PCI_CMD_STAT_REG, pcicmd);
598 /* terminate the list */
599 NVChipsets[numUsed].token = -1;
600 NVChipsets[numUsed].name = NULL;
601 NVPciChipsets[numUsed].numChipset = -1;
602 NVPciChipsets[numUsed].PCIid = -1;
603 NVPciChipsets[numUsed].resList = RES_UNDEFINED;
605 numUsed = xf86MatchPciInstances(NV_NAME, 0, NVChipsets, NVPciChipsets,
606 devSections, numDevSections, drv,
613 if (flags & PROBE_DETECT) {
616 for (i = 0; i < numUsed; i++) {
619 pPci = xf86GetPciInfoForEntity(usedChips[i]);
620 if (NVGetScrnInfoRec(NVPciChipsets, usedChips[i])) {
631 #endif /* XSERVER_LIBPCIACCESS */
634 NVSwitchMode(int scrnIndex, DisplayModePtr mode, int flags)
636 ScrnInfoPtr pScrn = xf86Screens[scrnIndex];
637 NVPtr pNv = NVPTR(pScrn);
639 if (pNv->randr12_enable) {
640 /* No rotation support for the moment */
641 return xf86SetSingleMode(pScrn, mode, RR_Rotate_0);
644 return NVModeInit(xf86Screens[scrnIndex], mode);
648 * This function is used to initialize the Start Address - the first
649 * displayed location in the video memory.
651 /* Usually mandatory */
653 NVAdjustFrame(int scrnIndex, int x, int y, int flags)
655 ScrnInfoPtr pScrn = xf86Screens[scrnIndex];
657 NVPtr pNv = NVPTR(pScrn);
658 NVFBLayout *pLayout = &pNv->CurrentLayout;
660 if (pNv->randr12_enable) {
661 xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(pScrn);
662 xf86CrtcPtr crtc = config->output[config->compat_output]->crtc;
664 if (crtc && crtc->enabled) {
665 NVCrtcSetBase(crtc, x, y);
668 startAddr = (((y*pLayout->displayWidth)+x)*(pLayout->bitsPerPixel/8));
669 startAddr += pNv->FB->offset;
670 NVSetStartAddress(pNv, startAddr);
675 NVResetCrtcConfig(ScrnInfoPtr pScrn, int set)
677 xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(pScrn);
678 NVPtr pNv = NVPTR(pScrn);
682 for (i = 0; i < config->num_crtc; i++) {
683 xf86CrtcPtr crtc = config->crtc[i];
684 NVCrtcPrivatePtr nv_crtc = crtc->driver_private;
689 regp = &pNv->ModeReg.crtc_reg[nv_crtc->head];
693 nvWriteCRTC(pNv, nv_crtc->head, NV_CRTC_FSEL, val);
698 NV50AcquireDisplay(ScrnInfoPtr pScrn)
700 if (!NV50DispInit(pScrn))
702 if (!NV50CursorAcquire(pScrn))
704 xf86SetDesiredModes(pScrn);
710 NV50ReleaseDisplay(ScrnInfoPtr pScrn)
712 NV50CursorRelease(pScrn);
713 NV50DispShutdown(pScrn);
718 * This is called when VT switching back to the X server. Its job is
719 * to reinitialise the video mode.
721 * We may wish to unmap video/MMIO memory too.
726 NVEnterVT(int scrnIndex, int flags)
728 ScrnInfoPtr pScrn = xf86Screens[scrnIndex];
729 NVPtr pNv = NVPTR(pScrn);
731 if (pNv->randr12_enable) {
732 xf86CrtcConfigPtr xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
734 pScrn->vtSema = TRUE;
736 if (pNv->Architecture == NV_ARCH_50) {
737 if (!NV50AcquireDisplay(pScrn))
742 /* Save the current state */
743 if (pNv->SaveGeneration != serverGeneration) {
744 pNv->SaveGeneration = serverGeneration;
748 for (i = 0; i < xf86_config->num_crtc; i++) {
749 NVCrtcLockUnlock(xf86_config->crtc[i], 0);
752 /* Reassign outputs so disabled outputs don't get stuck on the wrong crtc */
753 for (i = 0; i < xf86_config->num_output; i++) {
754 xf86OutputPtr output = xf86_config->output[i];
755 NVOutputPrivatePtr nv_output = output->driver_private;
756 if (nv_output->ramdac != -1) {
759 /* Disable any crosswired tmds, to avoid picking up a signal on a disabled output */
760 /* Example: TMDS1 crosswired to CRTC0 (by bios) reassigned to CRTC1 in xorg, disabled. */
761 /* But the bios reinits it to CRTC0 when going back to VT. */
762 /* Because it's disabled, it doesn't get a mode set, still it picks up the signal from CRTC0 (which is another output) */
763 /* A legitimately crosswired output will get set properly during mode set */
764 if ((tmds_reg4 = NVReadTMDS(pNv, nv_output->ramdac, 0x4)) & (1 << 3)) {
765 NVWriteTMDS(pNv, nv_output->ramdac, 0x4, tmds_reg4 & ~(1 << 3));
770 NVResetCrtcConfig(pScrn, 0);
771 if (!xf86SetDesiredModes(pScrn))
773 NVResetCrtcConfig(pScrn, 1);
776 if (!NVModeInit(pScrn, pScrn->currentMode))
780 NVAdjustFrame(scrnIndex, pScrn->frameX0, pScrn->frameY0, 0);
781 if(pNv->overlayAdaptor)
788 * This is called when VT switching away from the X server. Its job is
789 * to restore the previous (text) mode.
791 * We may wish to remap video/MMIO memory too.
796 NVLeaveVT(int scrnIndex, int flags)
798 ScrnInfoPtr pScrn = xf86Screens[scrnIndex];
799 NVPtr pNv = NVPTR(pScrn);
801 if (pNv->Architecture == NV_ARCH_50) {
802 NV50ReleaseDisplay(pScrn);
807 if (!pNv->randr12_enable)
808 NVLockUnlock(pNv, 1);
821 ScreenPtr pScreen = screenInfo.screens[i];
822 ScrnInfoPtr pScrnInfo = xf86Screens[i];
823 NVPtr pNv = NVPTR(pScrnInfo);
825 if (pNv->DMAKickoffCallback)
826 (*pNv->DMAKickoffCallback)(pNv);
828 pScreen->BlockHandler = pNv->BlockHandler;
829 (*pScreen->BlockHandler) (i, blockData, pTimeout, pReadmask);
830 pScreen->BlockHandler = NVBlockHandler;
832 if (pNv->VideoTimerCallback)
833 (*pNv->VideoTimerCallback)(pScrnInfo, currentTime.milliseconds);
839 * This is called at the end of each server generation. It restores the
840 * original (text) mode. It should also unmap the video memory, and free
841 * any per-generation data allocated by the driver. It should finish
842 * by unwrapping and calling the saved CloseScreen function.
847 NVCloseScreen(int scrnIndex, ScreenPtr pScreen)
849 ScrnInfoPtr pScrn = xf86Screens[scrnIndex];
850 NVPtr pNv = NVPTR(pScrn);
853 pScrn->vtSema = FALSE;
854 if (pNv->Architecture == NV_ARCH_50) {
855 NV50ReleaseDisplay(pScrn);
859 if (!pNv->randr12_enable)
860 NVLockUnlock(pNv, 1);
865 vgaHWUnmapMem(pScrn);
866 if (pNv->CursorInfoRec)
867 xf86DestroyCursorInfoRec(pNv->CursorInfoRec);
869 xfree(pNv->ShadowPtr);
870 if (pNv->overlayAdaptor)
871 xfree(pNv->overlayAdaptor);
872 if (pNv->blitAdaptor)
873 xfree(pNv->blitAdaptor);
875 pScrn->vtSema = FALSE;
876 pScreen->CloseScreen = pNv->CloseScreen;
877 pScreen->BlockHandler = pNv->BlockHandler;
878 return (*pScreen->CloseScreen)(scrnIndex, pScreen);
881 /* Free up any persistent data structures */
885 NVFreeScreen(int scrnIndex, int flags)
888 * This only gets called when a screen is being deleted. It does not
889 * get called routinely at the end of a server generation.
891 if (xf86LoaderCheckSymbol("vgaHWFreeHWRec"))
892 vgaHWFreeHWRec(xf86Screens[scrnIndex]);
893 NVFreeRec(xf86Screens[scrnIndex]);
897 /* Checks if a mode is suitable for the selected chipset. */
901 NVValidMode(int scrnIndex, DisplayModePtr mode, Bool verbose, int flags)
903 NVPtr pNv = NVPTR(xf86Screens[scrnIndex]);
905 if(pNv->fpWidth && pNv->fpHeight)
906 if((pNv->fpWidth < mode->HDisplay) || (pNv->fpHeight < mode->VDisplay))
913 nvProbeDDC(ScrnInfoPtr pScrn, int index)
917 if (xf86LoadSubModule(pScrn, "vbe")) {
918 pVbe = VBEInit(NULL,index);
919 ConfiguredMonitor = vbeDoEDID(pVbe, NULL);
925 Bool NVI2CInit(ScrnInfoPtr pScrn)
927 NVPtr pNv = NVPTR(pScrn);
930 if (xf86LoadSubModule(pScrn, mod)) {
931 xf86LoaderReqSymLists(i2cSymbols,NULL);
934 if(xf86LoadSubModule(pScrn, mod)) {
935 xf86LoaderReqSymLists(ddcSymbols, NULL);
936 /* randr-1.2 clients have their DDC's initialized elsewhere */
937 if (pNv->randr12_enable) {
940 return NVDACi2cInit(pScrn);
945 xf86DrvMsg(pScrn->scrnIndex, X_WARNING,
946 "Couldn't load %s module. DDC probing can't be done\n", mod);
951 static Bool NVPreInitDRI(ScrnInfoPtr pScrn)
953 NVPtr pNv = NVPTR(pScrn);
955 if (!NVDRIGetVersion(pScrn))
958 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
959 "[dri] Found DRI library version %d.%d.%d and kernel"
960 " module version %d.%d.%d\n",
961 pNv->pLibDRMVersion->version_major,
962 pNv->pLibDRMVersion->version_minor,
963 pNv->pLibDRMVersion->version_patchlevel,
964 pNv->pKernelDRMVersion->version_major,
965 pNv->pKernelDRMVersion->version_minor,
966 pNv->pKernelDRMVersion->version_patchlevel);
972 nv_xf86crtc_resize(ScrnInfoPtr pScrn, int width, int height)
974 ErrorF("nv_xf86crtc_resize is called with %dx%d resolution\n", width, height);
975 pScrn->virtualX = width;
976 pScrn->virtualY = height;
980 static const xf86CrtcConfigFuncsRec nv_xf86crtc_config_funcs = {
984 /* This is taken from the haiku driver */
985 /* We must accept crtc pitch constrains */
986 /* A hardware bug on some hardware requires twice the pitch */
987 static CARD8 NVGetCRTCMask(ScrnInfoPtr pScrn, CARD8 bpp)
992 mask = 0xf; /* 0x7 */
995 mask = 0x7; /* 0x3 */
998 mask = 0x7; /* 0x3 */
1001 mask = 0xf; /* 0x7 */
1004 mask = 0x3; /* 0x1 */
1007 ErrorF("Unkown color format\n");
1014 /* This is taken from the haiku driver */
1015 static CARD8 NVGetAccelerationMask(ScrnInfoPtr pScrn, CARD8 bpp)
1017 NVPtr pNv = NVPTR(pScrn);
1019 /* Identical for NV04 */
1020 if (pNv->Architecture == NV_ARCH_04) {
1021 return NVGetCRTCMask(pScrn, bpp);
1040 ErrorF("Unkown color format\n");
1048 static CARD32 NVGetVideoPitch(ScrnInfoPtr pScrn, CARD8 bpp)
1050 NVPtr pNv = NVPTR(pScrn);
1051 CARD8 crtc_mask, accel_mask = 0;
1052 crtc_mask = NVGetCRTCMask(pScrn, bpp);
1053 if (!pNv->NoAccel) {
1054 accel_mask = NVGetAccelerationMask(pScrn, bpp);
1057 /* adhere to the largest granularity imposed */
1058 if (accel_mask > crtc_mask) {
1059 return (pScrn->virtualX + accel_mask) & ~accel_mask;
1061 return (pScrn->virtualX + crtc_mask) & ~crtc_mask;
1065 #define NVPreInitFail(fmt, args...) do { \
1066 xf86DrvMsg(pScrn->scrnIndex, X_ERROR, "%d: "fmt, __LINE__, ##args); \
1068 xf86FreeInt10(pNv->pInt10); \
1075 NVPreInit(ScrnInfoPtr pScrn, int flags)
1077 xf86CrtcConfigPtr xf86_config;
1080 int i, max_width, max_height;
1081 ClockRangePtr clockRanges;
1083 int config_mon_rates = FALSE;
1086 if (flags & PROBE_DETECT) {
1087 EntityInfoPtr pEnt = xf86GetEntityInfo(pScrn->entityList[0]);
1095 nvProbeDDC(pScrn, i);
1100 * Note: This function is only called once at server startup, and
1101 * not at the start of each server generation. This means that
1102 * only things that are persistent across server generations can
1103 * be initialised here. xf86Screens[] is (pScrn is a pointer to one
1104 * of these). Privates allocated using xf86AllocateScrnInfoPrivateIndex()
1105 * are too, and should be used for data that must persist across
1106 * server generations.
1108 * Per-generation data should be allocated with
1109 * AllocateScreenPrivateIndex() from the ScreenInit() function.
1112 /* Check the number of entities, and fail if it isn't one. */
1113 if (pScrn->numEntities != 1)
1116 /* Allocate the NVRec driverPrivate */
1117 if (!NVGetRec(pScrn)) {
1122 /* Get the entity, and make sure it is PCI. */
1123 pNv->pEnt = xf86GetEntityInfo(pScrn->entityList[0]);
1124 if (pNv->pEnt->location.type != BUS_PCI)
1127 /* Find the PCI info for this screen */
1128 pNv->PciInfo = xf86GetPciInfoForEntity(pNv->pEnt->index);
1129 #ifndef XSERVER_LIBPCIACCESS
1130 pNv->PciTag = pciTag(pNv->PciInfo->bus, pNv->PciInfo->device,
1131 pNv->PciInfo->func);
1132 #endif /* XSERVER_LIBPCIACCESS */
1134 pNv->Primary = xf86IsPrimaryPci(pNv->PciInfo);
1136 /* Initialize the card through int10 interface if needed */
1137 if (xf86LoadSubModule(pScrn, "int10")) {
1138 xf86LoaderReqSymLists(int10Symbols, NULL);
1139 #if !defined(__alpha__) && !defined(__powerpc__)
1140 xf86DrvMsg(pScrn->scrnIndex, X_INFO, "Initializing int10\n");
1141 pNv->pInt10 = xf86InitInt10(pNv->pEnt->index);
1145 xf86SetOperatingState(resVgaIo, pNv->pEnt->index, ResUnusedOpr);
1146 xf86SetOperatingState(resVgaMem, pNv->pEnt->index, ResDisableOpr);
1148 /* Set pScrn->monitor */
1149 pScrn->monitor = pScrn->confScreen->monitor;
1151 volatile uint32_t *regs = NULL;
1152 #ifdef XSERVER_LIBPCIACCESS
1153 pci_device_map_range(pNv->PciInfo, PCI_DEV_MEM_BASE(pNv->PciInfo, 0), 0x90000, 0, (void **) ®s);
1154 pNv->Chipset = NVGetPCIID(regs) & 0xffff;
1155 pNv->NVArch = NVGetArchitecture(regs);
1156 pci_device_unmap_range(pNv->PciInfo, (void *) regs, 0x90000);
1159 PCI_DEV_READ_LONG(pNv->PciInfo, PCI_CMD_STAT_REG, &pcicmd);
1160 /* Enable reading memory? */
1161 PCI_DEV_WRITE_LONG(pNv->PciInfo, PCI_CMD_STAT_REG, pcicmd | PCI_CMD_MEM_ENABLE);
1162 regs = xf86MapPciMem(-1, VIDMEM_MMIO, pNv->PciTag, PCI_DEV_MEM_BASE(pNv->PciInfo, 0), 0x90000);
1163 pNv->Chipset = NVGetPCIID(regs) & 0xffff;
1164 pNv->NVArch = NVGetArchitecture(regs);
1165 xf86UnMapVidMem(-1, (pointer)regs, 0x90000);
1166 /* Reset previous state */
1167 PCI_DEV_WRITE_LONG(pNv->PciInfo, PCI_CMD_STAT_REG, pcicmd);
1168 #endif /* XSERVER_LIBPCIACCESS */
1170 pScrn->chipset = malloc(sizeof(char) * 25);
1171 sprintf(pScrn->chipset, "NVIDIA NV%02X", pNv->NVArch);
1173 if(!pScrn->chipset) {
1174 pScrn->chipset = "Unknown NVIDIA";
1178 * This shouldn't happen because such problems should be caught in
1179 * NVProbe(), but check it just in case.
1181 if (pScrn->chipset == NULL)
1182 NVPreInitFail("ChipID 0x%04X is not recognised\n", pNv->Chipset);
1184 if (pNv->NVArch < 0x04)
1185 NVPreInitFail("Chipset \"%s\" is not recognised\n", pScrn->chipset);
1187 xf86DrvMsg(pScrn->scrnIndex, X_PROBED, "Chipset: \"%s\"\n", pScrn->chipset);
1189 /* The highest architecture currently supported is NV5x */
1190 if (pNv->NVArch >= 0x50) {
1191 pNv->Architecture = NV_ARCH_50;
1192 } else if (pNv->NVArch >= 0x40) {
1193 pNv->Architecture = NV_ARCH_40;
1194 } else if (pNv->NVArch >= 0x30) {
1195 pNv->Architecture = NV_ARCH_30;
1196 } else if (pNv->NVArch >= 0x20) {
1197 pNv->Architecture = NV_ARCH_20;
1198 } else if (pNv->NVArch >= 0x10) {
1199 pNv->Architecture = NV_ARCH_10;
1200 } else if (pNv->NVArch >= 0x04) {
1201 pNv->Architecture = NV_ARCH_04;
1202 /* The lowest architecture currently supported is NV04 */
1208 * The first thing we should figure out is the depth, bpp, etc.
1211 if (!xf86SetDepthBpp(pScrn, 0, 0, 0, Support32bppFb)) {
1212 NVPreInitFail("\n");
1214 /* Check that the returned depth is one we support */
1215 switch (pScrn->depth) {
1223 NVPreInitFail("Given depth (%d) is not supported by this driver\n",
1227 xf86PrintDepthBpp(pScrn);
1229 /* Get the depth24 pixmap format */
1230 if (pScrn->depth == 24 && pix24bpp == 0)
1231 pix24bpp = xf86GetBppFromDepth(pScrn, 24);
1234 * This must happen after pScrn->display has been set because
1235 * xf86SetWeight references it.
1237 if (pScrn->depth > 8) {
1238 /* The defaults are OK for us */
1239 rgb zeros = {0, 0, 0};
1241 if (!xf86SetWeight(pScrn, zeros, zeros)) {
1242 NVPreInitFail("\n");
1246 if (!xf86SetDefaultVisual(pScrn, -1)) {
1247 NVPreInitFail("\n");
1249 /* We don't currently support DirectColor at > 8bpp */
1250 if (pScrn->depth > 8 && (pScrn->defaultVisual != TrueColor)) {
1251 NVPreInitFail("Given default visual"
1252 " (%s) is not supported at depth %d\n",
1253 xf86GetVisualName(pScrn->defaultVisual), pScrn->depth);
1258 /* The vgahw module should be loaded here when needed */
1259 if (!xf86LoadSubModule(pScrn, "vgahw")) {
1260 NVPreInitFail("\n");
1263 xf86LoaderReqSymLists(vgahwSymbols, NULL);
1266 * Allocate a vgaHWRec
1268 if (!vgaHWGetHWRec(pScrn)) {
1269 NVPreInitFail("\n");
1272 /* We use a programmable clock */
1273 pScrn->progClock = TRUE;
1275 /* Collect all of the relevant option flags (fill in pScrn->options) */
1276 xf86CollectOptions(pScrn, NULL);
1278 /* Process the options */
1279 if (!(pNv->Options = xalloc(sizeof(NVOptions))))
1281 memcpy(pNv->Options, NVOptions, sizeof(NVOptions));
1282 xf86ProcessOptions(pScrn->scrnIndex, pScrn->options, pNv->Options);
1284 /* Set the bits per RGB for 8bpp mode */
1285 if (pScrn->depth == 8)
1290 if (pNv->Architecture == NV_ARCH_50) {
1291 pNv->randr12_enable = TRUE;
1293 pNv->randr12_enable = FALSE;
1294 if (xf86ReturnOptValBool(pNv->Options, OPTION_RANDR12, FALSE)) {
1295 pNv->randr12_enable = TRUE;
1298 xf86DrvMsg(pScrn->scrnIndex, from, "Randr1.2 support %sabled\n", pNv->randr12_enable ? "en" : "dis");
1300 pNv->HWCursor = TRUE;
1302 * The preferred method is to use the "hw cursor" option as a tri-state
1303 * option, with the default set above.
1305 if (xf86GetOptValBool(pNv->Options, OPTION_HW_CURSOR, &pNv->HWCursor)) {
1308 /* For compatibility, accept this too (as an override) */
1309 if (xf86ReturnOptValBool(pNv->Options, OPTION_SW_CURSOR, FALSE)) {
1311 pNv->HWCursor = FALSE;
1313 xf86DrvMsg(pScrn->scrnIndex, from, "Using %s cursor\n",
1314 pNv->HWCursor ? "HW" : "SW");
1316 pNv->FpScale = TRUE;
1318 if (xf86GetOptValBool(pNv->Options, OPTION_FP_SCALE, &pNv->FpScale)) {
1319 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG, "Flat panel scaling %s\n",
1320 pNv->FpScale ? "on" : "off");
1322 if (xf86ReturnOptValBool(pNv->Options, OPTION_NOACCEL, FALSE)) {
1323 pNv->NoAccel = TRUE;
1324 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG, "Acceleration disabled\n");
1326 if (xf86ReturnOptValBool(pNv->Options, OPTION_SHADOW_FB, FALSE)) {
1327 pNv->ShadowFB = TRUE;
1328 pNv->NoAccel = TRUE;
1329 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG,
1330 "Using \"Shadow Framebuffer\" - acceleration disabled\n");
1334 pNv->RandRRotation = FALSE;
1335 if ((s = xf86GetOptValString(pNv->Options, OPTION_ROTATE))) {
1336 if(!xf86NameCmp(s, "CW")) {
1337 pNv->ShadowFB = TRUE;
1338 pNv->NoAccel = TRUE;
1339 pNv->HWCursor = FALSE;
1341 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG,
1342 "Rotating screen clockwise - acceleration disabled\n");
1344 if(!xf86NameCmp(s, "CCW")) {
1345 pNv->ShadowFB = TRUE;
1346 pNv->NoAccel = TRUE;
1347 pNv->HWCursor = FALSE;
1349 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG,
1350 "Rotating screen counter clockwise - acceleration disabled\n");
1352 if(!xf86NameCmp(s, "RandR")) {
1354 pNv->ShadowFB = TRUE;
1355 pNv->NoAccel = TRUE;
1356 pNv->HWCursor = FALSE;
1357 pNv->RandRRotation = TRUE;
1358 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG,
1359 "Using RandR rotation - acceleration disabled\n");
1361 xf86DrvMsg(pScrn->scrnIndex, X_WARNING,
1362 "This driver was not compiled with support for the Resize and "
1363 "Rotate extension. Cannot honor 'Option \"Rotate\" "
1367 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG,
1368 "\"%s\" is not a valid value for Option \"Rotate\"\n", s);
1369 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
1370 "Valid options are \"CW\", \"CCW\", and \"RandR\"\n");
1374 if(xf86GetOptValInteger(pNv->Options, OPTION_VIDEO_KEY, &(pNv->videoKey))) {
1375 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG, "video key set to 0x%x\n",
1378 pNv->videoKey = (1 << pScrn->offset.red) |
1379 (1 << pScrn->offset.green) |
1380 (((pScrn->mask.blue >> pScrn->offset.blue) - 1) << pScrn->offset.blue);
1383 if (xf86GetOptValBool(pNv->Options, OPTION_FLAT_PANEL, &(pNv->FlatPanel))) {
1384 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG, "forcing %s usage\n",
1385 pNv->FlatPanel ? "DFP" : "CRTC");
1387 pNv->FlatPanel = -1; /* autodetect later */
1390 pNv->FPDither = FALSE;
1391 if (xf86GetOptValBool(pNv->Options, OPTION_FP_DITHER, &(pNv->FPDither)))
1392 xf86DrvMsg(pScrn->scrnIndex, X_CONFIG, "enabling flat panel dither\n");
1394 //if (xf86GetOptValInteger(pNv->Options, OPTION_CRTC_NUMBER,
1395 // &pNv->CRTCnumber))
1397 //pNv->crtc_active[0] = FALSE;
1398 //pNv->crtc_active[1] = FALSE;
1402 if (xf86GetOptValInteger(pNv->Options, OPTION_FP_TWEAK,
1405 pNv->usePanelTweak = TRUE;
1407 pNv->usePanelTweak = FALSE;
1410 if (pNv->pEnt->device->MemBase != 0) {
1411 /* Require that the config file value matches one of the PCI values. */
1412 if (!xf86CheckPciMemBase(pNv->PciInfo, pNv->pEnt->device->MemBase)) {
1414 "MemBase 0x%08lX doesn't match any PCI base register.\n",
1415 pNv->pEnt->device->MemBase);
1417 pNv->VRAMPhysical = pNv->pEnt->device->MemBase;
1420 if (PCI_DEV_MEM_BASE(pNv->PciInfo, 1) != 0) {
1421 pNv->VRAMPhysical = PCI_DEV_MEM_BASE(pNv->PciInfo, 1) & 0xff800000;
1424 NVPreInitFail("No valid FB address in PCI config space\n");
1428 xf86DrvMsg(pScrn->scrnIndex, from, "Linear framebuffer at 0x%lX\n",
1429 (unsigned long)pNv->VRAMPhysical);
1431 if (pNv->pEnt->device->IOBase != 0) {
1432 /* Require that the config file value matches one of the PCI values. */
1433 if (!xf86CheckPciMemBase(pNv->PciInfo, pNv->pEnt->device->IOBase)) {
1434 NVPreInitFail("IOBase 0x%08lX doesn't match any PCI base register.\n",
1435 pNv->pEnt->device->IOBase);
1437 pNv->IOAddress = pNv->pEnt->device->IOBase;
1440 if (PCI_DEV_MEM_BASE(pNv->PciInfo, 0) != 0) {
1441 pNv->IOAddress = PCI_DEV_MEM_BASE(pNv->PciInfo, 0) & 0xffffc000;
1444 NVPreInitFail("No valid MMIO address in PCI config space\n");
1447 xf86DrvMsg(pScrn->scrnIndex, from, "MMIO registers at 0x%lX\n",
1448 (unsigned long)pNv->IOAddress);
1450 if (xf86RegisterResources(pNv->pEnt->index, NULL, ResExclusive)) {
1451 NVPreInitFail("xf86RegisterResources() found resource conflicts\n");
1454 pNv->alphaCursor = (pNv->NVArch >= 0x11);
1456 //pNv->alphaCursor = FALSE;
1458 if (pNv->randr12_enable) {
1459 /* Allocate an xf86CrtcConfig */
1460 xf86CrtcConfigInit(pScrn, &nv_xf86crtc_config_funcs);
1461 xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
1464 xf86CrtcSetSizeRange(pScrn, 320, 200, max_width, 2048);
1467 if (NVPreInitDRI(pScrn) == FALSE) {
1468 NVPreInitFail("\n");
1471 if (!pNv->randr12_enable) {
1472 if ((pScrn->monitor->nHsync == 0) &&
1473 (pScrn->monitor->nVrefresh == 0))
1474 config_mon_rates = FALSE;
1476 config_mon_rates = TRUE;
1479 NVCommonSetup(pScrn);
1481 if (pNv->randr12_enable) {
1482 if (pNv->Architecture < NV_ARCH_50) {
1485 num_crtc = pNv->twoHeads ? 2 : 1;
1486 for (i = 0; i < num_crtc; i++) {
1487 nv_crtc_init(pScrn, i);
1490 NvSetupOutputs(pScrn);
1492 if (!NV50DispPreInit(pScrn))
1493 NVPreInitFail("\n");
1494 if (!NV50CreateOutputs(pScrn))
1495 NVPreInitFail("\n");
1496 NV50DispCreateCrtcs(pScrn);
1499 if (!xf86InitialConfiguration(pScrn, FALSE))
1500 NVPreInitFail("No valid modes.\n");
1503 pScrn->videoRam = pNv->RamAmountKBytes;
1504 xf86DrvMsg(pScrn->scrnIndex, X_PROBED, "VideoRAM: %d kBytes\n",
1507 pNv->VRAMPhysicalSize = pScrn->videoRam * 1024;
1510 * If the driver can do gamma correction, it should call xf86SetGamma()
1515 Gamma zeros = {0.0, 0.0, 0.0};
1517 if (!xf86SetGamma(pScrn, zeros)) {
1518 NVPreInitFail("\n");
1523 * Setup the ClockRanges, which describe what clock ranges are available,
1524 * and what sort of modes they can be used for.
1527 clockRanges = xnfcalloc(sizeof(ClockRange), 1);
1528 clockRanges->next = NULL;
1529 clockRanges->minClock = pNv->MinVClockFreqKHz;
1530 clockRanges->maxClock = pNv->MaxVClockFreqKHz;
1531 clockRanges->clockIndex = -1; /* programmable */
1532 clockRanges->doubleScanAllowed = TRUE;
1533 if((pNv->Architecture == NV_ARCH_20) ||
1534 ((pNv->Architecture == NV_ARCH_10) &&
1535 ((pNv->Chipset & 0x0ff0) != CHIPSET_NV10) &&
1536 ((pNv->Chipset & 0x0ff0) != CHIPSET_NV15)))
1539 clockRanges->interlaceAllowed = FALSE;
1541 clockRanges->interlaceAllowed = TRUE;
1544 if(pNv->FlatPanel == 1) {
1545 clockRanges->interlaceAllowed = FALSE;
1546 clockRanges->doubleScanAllowed = FALSE;
1549 if(pNv->Architecture < NV_ARCH_10) {
1550 max_width = (pScrn->bitsPerPixel > 16) ? 2032 : 2048;
1553 max_width = (pScrn->bitsPerPixel > 16) ? 4080 : 4096;
1558 /* If DFP, add a modeline corresponding to its panel size */
1559 if (pNv->FlatPanel && !pNv->Television && pNv->fpWidth && pNv->fpHeight) {
1560 DisplayModePtr Mode;
1562 Mode = xnfcalloc(1, sizeof(DisplayModeRec));
1563 Mode = xf86CVTMode(pNv->fpWidth, pNv->fpHeight, 60.00, TRUE, FALSE);
1564 Mode->type = M_T_DRIVER;
1565 pScrn->monitor->Modes = xf86ModesAdd(pScrn->monitor->Modes, Mode);
1567 if (!config_mon_rates) {
1569 Mode->HSync = ((float) Mode->Clock ) / ((float) Mode->HTotal);
1570 if (!Mode->VRefresh)
1571 Mode->VRefresh = (1000.0 * ((float) Mode->Clock)) /
1572 ((float) (Mode->HTotal * Mode->VTotal));
1574 if (Mode->HSync < pScrn->monitor->hsync[0].lo)
1575 pScrn->monitor->hsync[0].lo = Mode->HSync;
1576 if (Mode->HSync > pScrn->monitor->hsync[0].hi)
1577 pScrn->monitor->hsync[0].hi = Mode->HSync;
1578 if (Mode->VRefresh < pScrn->monitor->vrefresh[0].lo)
1579 pScrn->monitor->vrefresh[0].lo = Mode->VRefresh;
1580 if (Mode->VRefresh > pScrn->monitor->vrefresh[0].hi)
1581 pScrn->monitor->vrefresh[0].hi = Mode->VRefresh;
1583 pScrn->monitor->nHsync = 1;
1584 pScrn->monitor->nVrefresh = 1;
1589 if (pNv->randr12_enable) {
1590 pScrn->displayWidth = NVGetVideoPitch(pScrn, pScrn->depth);
1593 * xf86ValidateModes will check that the mode HTotal and VTotal values
1594 * don't exceed the chipset's limit if pScrn->maxHValue and
1595 * pScrn->maxVValue are set. Since our NVValidMode() already takes
1596 * care of this, we don't worry about setting them here.
1598 i = xf86ValidateModes(pScrn, pScrn->monitor->Modes,
1599 pScrn->display->modes, clockRanges,
1600 NULL, 256, max_width,
1601 512, 128, max_height,
1602 pScrn->display->virtualX,
1603 pScrn->display->virtualY,
1604 pNv->VRAMPhysicalSize / 2,
1605 LOOKUP_BEST_REFRESH);
1608 NVPreInitFail("\n");
1611 /* Prune the modes marked as invalid */
1612 xf86PruneDriverModes(pScrn);
1615 * Set the CRTC parameters for all of the modes based on the type
1616 * of mode, and the chipset's interlace requirements.
1618 * Calling this is required if the mode->Crtc* values are used by the
1619 * driver and if the driver doesn't provide code to set them. They
1620 * are not pre-initialised at all.
1622 xf86SetCrtcForModes(pScrn, 0);
1625 if (pScrn->modes == NULL) {
1626 NVPreInitFail("No valid modes found\n");
1629 /* Set the current mode to the first in the list */
1630 pScrn->currentMode = pScrn->modes;
1632 /* Print the list of modes being used */
1633 xf86PrintModes(pScrn);
1635 /* Set display resolution */
1636 xf86SetDpi(pScrn, 0, 0);
1640 * XXX This should be taken into account in some way in the mode valdation
1644 if (xf86LoadSubModule(pScrn, "fb") == NULL) {
1645 NVPreInitFail("\n");
1648 xf86LoaderReqSymLists(fbSymbols, NULL);
1650 /* Load EXA if needed */
1651 if (!pNv->NoAccel) {
1652 if (!xf86LoadSubModule(pScrn, "exa")) {
1653 NVPreInitFail("\n");
1655 xf86LoaderReqSymLists(exaSymbols, NULL);
1658 /* Load ramdac if needed */
1659 if (pNv->HWCursor) {
1660 if (!xf86LoadSubModule(pScrn, "ramdac")) {
1661 NVPreInitFail("\n");
1663 xf86LoaderReqSymLists(ramdacSymbols, NULL);
1666 /* Load shadowfb if needed */
1667 if (pNv->ShadowFB) {
1668 if (!xf86LoadSubModule(pScrn, "shadowfb")) {
1669 NVPreInitFail("\n");
1671 xf86LoaderReqSymLists(shadowSymbols, NULL);
1674 pNv->CurrentLayout.bitsPerPixel = pScrn->bitsPerPixel;
1675 pNv->CurrentLayout.depth = pScrn->depth;
1676 pNv->CurrentLayout.displayWidth = pScrn->displayWidth;
1677 pNv->CurrentLayout.weight.red = pScrn->weight.red;
1678 pNv->CurrentLayout.weight.green = pScrn->weight.green;
1679 pNv->CurrentLayout.weight.blue = pScrn->weight.blue;
1680 pNv->CurrentLayout.mode = pScrn->currentMode;
1682 xf86FreeInt10(pNv->pInt10);
1690 * Map the framebuffer and MMIO memory.
1694 NVMapMem(ScrnInfoPtr pScrn)
1696 NVPtr pNv = NVPTR(pScrn);
1698 pNv->FB = NVAllocateMemory(pNv, NOUVEAU_MEM_FB, pNv->VRAMPhysicalSize/2);
1700 ErrorF("Failed to allocate memory for framebuffer!\n");
1703 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
1704 "Allocated %dMiB VRAM for framebuffer + offscreen pixmaps\n",
1705 (unsigned int)(pNv->FB->size >> 20));
1707 /*XXX: have to get these after we've allocated something, otherwise
1708 * they're uninitialised in the DRM!
1710 pNv->VRAMSize = NVDRMGetParam(pNv, NOUVEAU_GETPARAM_FB_SIZE);
1711 pNv->VRAMPhysical = NVDRMGetParam(pNv, NOUVEAU_GETPARAM_FB_PHYSICAL);
1712 pNv->AGPSize = NVDRMGetParam(pNv, NOUVEAU_GETPARAM_AGP_SIZE);
1713 pNv->AGPPhysical = NVDRMGetParam(pNv, NOUVEAU_GETPARAM_AGP_PHYSICAL);
1714 if ( ! pNv->AGPSize ) /*if no AGP*/
1716 pNv->SGPhysical = NVDRMGetParam(pNv, NOUVEAU_GETPARAM_PCI_PHYSICAL);
1718 int gart_scratch_size;
1721 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
1722 "AGPGART: %dMiB available\n",
1723 (unsigned int)(pNv->AGPSize >> 20));
1725 if (pNv->AGPSize > (16*1024*1024))
1726 gart_scratch_size = 16*1024*1024;
1728 gart_scratch_size = pNv->AGPSize;
1733 gart_scratch_size = (4 << 20) - (1 << 18) ;
1734 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
1735 "GART: PCI DMA - using %dKiB\n", gart_scratch_size >> 10);
1740 /*The DRM allocates AGP memory, PCI as a fallback */
1741 pNv->GARTScratch = NVAllocateMemory(pNv, NOUVEAU_MEM_AGP | NOUVEAU_MEM_PCI_ACCEPTABLE,
1744 if (!pNv->GARTScratch) {
1745 xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
1746 "Unable to allocate GART memory\n");
1748 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
1749 "GART: mapped %dMiB at %p, offset is %d\n",
1750 (unsigned int)(pNv->GARTScratch->size >> 20),
1751 pNv->GARTScratch->map, pNv->GARTScratch->offset);
1755 pNv->Cursor = NVAllocateMemory(pNv, NOUVEAU_MEM_FB, 64*1024);
1757 ErrorF("Failed to allocate memory for hardware cursor\n");
1761 pNv->ScratchBuffer = NVAllocateMemory(pNv, NOUVEAU_MEM_FB,
1762 pNv->Architecture <NV_ARCH_10 ? 8192 : 16384);
1763 if (!pNv->ScratchBuffer) {
1764 ErrorF("Failed to allocate memory for scratch buffer\n");
1768 if (pNv->Architecture >= NV_ARCH_50) {
1769 pNv->CLUT = NVAllocateMemory(pNv, NOUVEAU_MEM_FB, 0x1000);
1771 xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
1772 "Failed to allocate memory for CLUT\n");
1781 * Unmap the framebuffer and MMIO memory.
1785 NVUnmapMem(ScrnInfoPtr pScrn)
1787 NVPtr pNv = NVPTR(pScrn);
1789 NVFreeMemory(pNv, pNv->FB);
1790 NVFreeMemory(pNv, pNv->ScratchBuffer);
1791 NVFreeMemory(pNv, pNv->Cursor);
1798 * Initialise a new mode.
1802 NVModeInit(ScrnInfoPtr pScrn, DisplayModePtr mode)
1804 vgaHWPtr hwp = VGAHWPTR(pScrn);
1806 NVPtr pNv = NVPTR(pScrn);
1809 /* Initialise the ModeReg values */
1810 if (!vgaHWInit(pScrn, mode))
1812 pScrn->vtSema = TRUE;
1814 vgaReg = &hwp->ModeReg;
1815 nvReg = &pNv->ModeReg;
1817 if(!NVDACInit(pScrn, mode))
1820 NVLockUnlock(pNv, 0);
1822 nvWriteVGA(pNv, NV_VGA_CRTCX_OWNER, nvReg->crtcOwner);
1823 NVLockUnlock(pNv, 0);
1826 /* Program the registers */
1827 vgaHWProtect(pScrn, TRUE);
1829 NVDACRestore(pScrn, vgaReg, nvReg, FALSE);
1831 #if X_BYTE_ORDER == X_BIG_ENDIAN
1832 /* turn on LFB swapping */
1836 tmp = nvReadVGA(pNv, NV_VGA_CRTCX_SWAPPING);
1838 nvWriteVGA(pNv, NV_VGA_CRTCX_SWAPPING, tmp);
1843 NVResetGraphics(pScrn);
1845 vgaHWProtect(pScrn, FALSE);
1847 pNv->CurrentLayout.mode = mode;
1853 * Restore the initial (text) mode.
1856 NVRestore(ScrnInfoPtr pScrn)
1858 vgaHWPtr hwp = VGAHWPTR(pScrn);
1859 vgaRegPtr vgaReg = &hwp->SavedReg;
1860 NVPtr pNv = NVPTR(pScrn);
1861 NVRegPtr nvReg = &pNv->SavedReg;
1863 if (pNv->randr12_enable) {
1864 xf86CrtcConfigPtr xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
1866 int vgaflags = VGA_SR_CMAP | VGA_SR_MODE;
1868 for (i = 0; i < xf86_config->num_crtc; i++) {
1869 NVCrtcLockUnlock(xf86_config->crtc[i], 0);
1872 for (i = 0; i < xf86_config->num_crtc; i++) {
1873 xf86_config->crtc[i]->funcs->restore(xf86_config->crtc[i]);
1876 for (i = 0; i < xf86_config->num_output; i++) {
1877 xf86_config->output[i]->funcs->restore(xf86_config->
1882 vgaflags |= VGA_SR_FONTS;
1884 vgaHWRestore(pScrn, vgaReg, vgaflags);
1887 for (i = 0; i < xf86_config->num_crtc; i++) {
1888 NVCrtcLockUnlock(xf86_config->crtc[i], 1);
1891 NVLockUnlock(pNv, 0);
1894 nvWriteVGA(pNv, NV_VGA_CRTCX_OWNER, pNv->crtc_active[1] * 0x3);
1895 NVLockUnlock(pNv, 0);
1898 /* Only restore text mode fonts/text for the primary card */
1899 vgaHWProtect(pScrn, TRUE);
1900 NVDACRestore(pScrn, vgaReg, nvReg, pNv->Primary);
1902 nvWriteVGA(pNv, NV_VGA_CRTCX_OWNER, pNv->vtOWNER);
1904 vgaHWProtect(pScrn, FALSE);
1909 #define DEPTH_SHIFT(val, w) ((val << (8 - w)) | (val >> ((w << 1) - 8)))
1910 #define MAKE_INDEX(in, w) (DEPTH_SHIFT(in, w) * 3)
1913 NVLoadPalette(ScrnInfoPtr pScrn, int numColors, int *indices,
1914 LOCO * colors, VisualPtr pVisual)
1916 xf86CrtcConfigPtr xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
1918 NVPtr pNv = NVPTR(pScrn);
1921 for (c = 0; c < xf86_config->num_crtc; c++) {
1922 xf86CrtcPtr crtc = xf86_config->crtc[c];
1923 NVCrtcPrivatePtr nv_crtc = crtc->driver_private;
1926 regp = &pNv->ModeReg.crtc_reg[nv_crtc->head];
1928 if (crtc->enabled == 0)
1931 switch (pNv->CurrentLayout.depth) {
1933 for (i = 0; i < numColors; i++) {
1935 regp->DAC[MAKE_INDEX(index, 5) + 0] =
1937 regp->DAC[MAKE_INDEX(index, 5) + 1] =
1938 colors[index].green;
1939 regp->DAC[MAKE_INDEX(index, 5) + 2] =
1944 for (i = 0; i < numColors; i++) {
1946 regp->DAC[MAKE_INDEX(index, 6) + 1] =
1947 colors[index].green;
1949 regp->DAC[MAKE_INDEX(index, 5) +
1950 0] = colors[index].red;
1951 regp->DAC[MAKE_INDEX(index, 5) +
1952 2] = colors[index].blue;
1957 for (i = 0; i < numColors; i++) {
1959 regp->DAC[index * 3] = colors[index].red;
1960 regp->DAC[(index * 3) + 1] =
1961 colors[index].green;
1962 regp->DAC[(index * 3) + 2] =
1968 NVCrtcLoadPalette(crtc);
1972 //#define DEPTH_SHIFT(val, w) ((val << (8 - w)) | (val >> ((w << 1) - 8)))
1973 #define COLOR(c) (unsigned int)(0x3fff * ((c)/255.0))
1975 NV50LoadPalette(ScrnInfoPtr pScrn, int numColors, int *indices,
1976 LOCO * colors, VisualPtr pVisual)
1978 NVPtr pNv = NVPTR(pScrn);
1981 unsigned short red, green, blue, unused;
1982 } *lut = (void *) pNv->CLUT->map;
1984 switch (pScrn->depth) {
1986 for (i = 0; i < numColors; i++) {
1988 lut[DEPTH_SHIFT(index, 5)].red =
1989 COLOR(colors[index].red);
1990 lut[DEPTH_SHIFT(index, 5)].green =
1991 COLOR(colors[index].green);
1992 lut[DEPTH_SHIFT(index, 5)].blue =
1993 COLOR(colors[index].blue);
1997 for (i = 0; i < numColors; i++) {
1999 lut[DEPTH_SHIFT(index, 6)].green =
2000 COLOR(colors[index].green);
2002 lut[DEPTH_SHIFT(index, 5)].red =
2003 COLOR(colors[index].red);
2004 lut[DEPTH_SHIFT(index, 5)].blue =
2005 COLOR(colors[index].blue);
2010 for (i = 0; i < numColors; i++) {
2012 lut[index].red = COLOR(colors[index].red);
2013 lut[index].green = COLOR(colors[index].green);
2014 lut[index].blue = COLOR(colors[index].blue);
2021 static void NVBacklightEnable(NVPtr pNv, Bool on)
2023 /* This is done differently on each laptop. Here we
2024 define the ones we know for sure. */
2026 #if defined(__powerpc__)
2027 if((pNv->Chipset == 0x10DE0179) ||
2028 (pNv->Chipset == 0x10DE0189) ||
2029 (pNv->Chipset == 0x10DE0329))
2031 /* NV17,18,34 Apple iMac, iBook, PowerBook */
2032 CARD32 tmp_pmc, tmp_pcrt;
2033 tmp_pmc = nvReadMC(pNv, 0x10F0) & 0x7FFFFFFF;
2034 tmp_pcrt = nvReadCRTC0(pNv, NV_CRTC_081C) & 0xFFFFFFFC;
2036 tmp_pmc |= (1 << 31);
2039 nvWriteMC(pNv, 0x10F0, tmp_pmc);
2040 nvWriteCRTC0(pNv, NV_CRTC_081C, tmp_pcrt);
2045 if(pNv->twoHeads && ((pNv->Chipset & 0x0ff0) != CHIPSET_NV11)) {
2046 nvWriteMC(pNv, 0x130C, on ? 3 : 7);
2051 fpcontrol = nvReadCurRAMDAC(pNv, 0x848) & 0xCfffffCC;
2053 /* cut the TMDS output */
2054 if(on) fpcontrol |= pNv->fpSyncs;
2055 else fpcontrol |= 0x20000022;
2057 nvWriteCurRAMDAC(pNv, 0x0848, fpcontrol);
2062 NVDPMSSetLCD(ScrnInfoPtr pScrn, int PowerManagementMode, int flags)
2064 NVPtr pNv = NVPTR(pScrn);
2066 if (!pScrn->vtSema) return;
2068 vgaHWDPMSSet(pScrn, PowerManagementMode, flags);
2070 switch (PowerManagementMode) {
2071 case DPMSModeStandby: /* HSync: Off, VSync: On */
2072 case DPMSModeSuspend: /* HSync: On, VSync: Off */
2073 case DPMSModeOff: /* HSync: Off, VSync: Off */
2074 NVBacklightEnable(pNv, 0);
2076 case DPMSModeOn: /* HSync: On, VSync: On */
2077 NVBacklightEnable(pNv, 1);
2085 NVDPMSSet(ScrnInfoPtr pScrn, int PowerManagementMode, int flags)
2087 unsigned char crtc1A;
2088 vgaHWPtr hwp = VGAHWPTR(pScrn);
2090 if (!pScrn->vtSema) return;
2092 crtc1A = hwp->readCrtc(hwp, 0x1A) & ~0xC0;
2094 switch (PowerManagementMode) {
2095 case DPMSModeStandby: /* HSync: Off, VSync: On */
2098 case DPMSModeSuspend: /* HSync: On, VSync: Off */
2101 case DPMSModeOff: /* HSync: Off, VSync: Off */
2104 case DPMSModeOn: /* HSync: On, VSync: On */
2109 /* vgaHWDPMSSet will merely cut the dac output */
2110 vgaHWDPMSSet(pScrn, PowerManagementMode, flags);
2112 hwp->writeCrtc(hwp, 0x1A, crtc1A);
2118 /* This gets called at the start of each server generation */
2121 NVScreenInit(int scrnIndex, ScreenPtr pScreen, int argc, char **argv)
2128 unsigned char *FBStart;
2129 int width, height, displayWidth, shadowHeight;
2132 * First get the ScrnInfoRec
2134 pScrn = xf86Screens[pScreen->myNum];
2136 hwp = VGAHWPTR(pScrn);
2139 /* Map the VGA memory when the primary video */
2141 hwp->MapSize = 0x10000;
2142 if (!vgaHWMapMem(pScrn))
2146 /* First init DRI/DRM */
2147 if (!NVDRIScreenInit(pScrn))
2150 ret = drmCommandNone(pNv->drm_fd, DRM_NOUVEAU_CARD_INIT);
2152 xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
2153 "Error initialising the nouveau kernel module: %d\n",
2158 /* Allocate and map memory areas we need */
2159 if (!NVMapMem(pScrn))
2162 if (!pNv->NoAccel) {
2163 /* Init DRM - Alloc FIFO */
2164 if (!NVInitDma(pScrn))
2167 /* setup graphics objects */
2168 if (!NVAccelCommonInit(pScrn))
2172 if (!pNv->randr12_enable) {
2173 /* Save the current state */
2175 /* Initialise the first mode */
2176 if (!NVModeInit(pScrn, pScrn->currentMode))
2179 /* Darken the screen for aesthetic reasons and set the viewport */
2181 NVSaveScreen(pScreen, SCREEN_SAVER_ON);
2182 pScrn->AdjustFrame(scrnIndex, pScrn->frameX0, pScrn->frameY0, 0);
2185 pScrn->memPhysBase = pNv->VRAMPhysical;
2186 pScrn->fbOffset = 0;
2188 /* Gather some misc info before the randr stuff kicks in */
2189 pNv->misc_info.crtc_0_reg_52 = NVReadVGA0(pNv, NV_VGA_CRTCX_52);
2190 if (pNv->Architecture == NV_ARCH_40) {
2191 pNv->misc_info.ramdac_0_reg_580 = nvReadRAMDAC(pNv, 0, NV_RAMDAC_580);
2192 pNv->misc_info.reg_c040 = nvReadMC(pNv, 0xc040);
2194 pNv->misc_info.ramdac_0_pllsel = nvReadRAMDAC(pNv, 0, NV_RAMDAC_PLL_SELECT);
2195 pNv->misc_info.sel_clk = nvReadRAMDAC(pNv, 0, NV_RAMDAC_SEL_CLK);
2197 if (!NVEnterVT(scrnIndex, 0))
2199 NVSaveScreen(pScreen, SCREEN_SAVER_ON);
2204 * The next step is to setup the screen's visuals, and initialise the
2205 * framebuffer code. In cases where the framebuffer's default
2206 * choices for things like visual layouts and bits per RGB are OK,
2207 * this may be as simple as calling the framebuffer's ScreenInit()
2208 * function. If not, the visuals will need to be setup before calling
2209 * a fb ScreenInit() function and fixed up after.
2211 * For most PC hardware at depths >= 8, the defaults that fb uses
2212 * are not appropriate. In this driver, we fixup the visuals after.
2216 * Reset the visual list.
2218 miClearVisualTypes();
2220 /* Setup the visuals we support. */
2222 if (!miSetVisualTypes(pScrn->depth,
2223 miGetDefaultVisualMask(pScrn->depth), 8,
2224 pScrn->defaultVisual))
2226 if (!miSetPixmapDepths ()) return FALSE;
2229 * Call the framebuffer layer's ScreenInit function, and fill in other
2233 width = pScrn->virtualX;
2234 height = pScrn->virtualY;
2235 displayWidth = pScrn->displayWidth;
2239 height = pScrn->virtualX;
2240 width = pScrn->virtualY;
2243 /* If RandR rotation is enabled, leave enough space in the
2244 * framebuffer for us to rotate the screen dimensions without
2245 * changing the pitch.
2247 if(pNv->RandRRotation)
2248 shadowHeight = max(width, height);
2250 shadowHeight = height;
2253 pNv->ShadowPitch = BitmapBytePad(pScrn->bitsPerPixel * width);
2254 pNv->ShadowPtr = xalloc(pNv->ShadowPitch * shadowHeight);
2255 displayWidth = pNv->ShadowPitch / (pScrn->bitsPerPixel >> 3);
2256 FBStart = pNv->ShadowPtr;
2258 pNv->ShadowPtr = NULL;
2259 FBStart = pNv->FB->map;
2262 switch (pScrn->bitsPerPixel) {
2266 ret = fbScreenInit(pScreen, FBStart, width, height,
2267 pScrn->xDpi, pScrn->yDpi,
2268 displayWidth, pScrn->bitsPerPixel);
2271 xf86DrvMsg(scrnIndex, X_ERROR,
2272 "Internal error: invalid bpp (%d) in NVScreenInit\n",
2273 pScrn->bitsPerPixel);
2280 if (pScrn->bitsPerPixel > 8) {
2281 /* Fixup RGB ordering */
2282 visual = pScreen->visuals + pScreen->numVisuals;
2283 while (--visual >= pScreen->visuals) {
2284 if ((visual->class | DynamicClass) == DirectColor) {
2285 visual->offsetRed = pScrn->offset.red;
2286 visual->offsetGreen = pScrn->offset.green;
2287 visual->offsetBlue = pScrn->offset.blue;
2288 visual->redMask = pScrn->mask.red;
2289 visual->greenMask = pScrn->mask.green;
2290 visual->blueMask = pScrn->mask.blue;
2295 fbPictureInit (pScreen, 0, 0);
2297 xf86SetBlackWhitePixels(pScreen);
2299 if (!pNv->NoAccel) {
2301 NVResetGraphics(pScrn);
2304 miInitializeBackingStore(pScreen);
2305 xf86SetBackingStore(pScreen);
2306 xf86SetSilkenMouse(pScreen);
2308 /* Finish DRI init */
2309 NVDRIFinishScreenInit(pScrn);
2311 /* Initialize software cursor.
2312 Must precede creation of the default colormap */
2313 miDCInitialize(pScreen, xf86GetPointerScreenFuncs());
2315 /* Initialize HW cursor layer.
2316 Must follow software cursor initialization*/
2317 if (pNv->HWCursor) {
2318 if (pNv->Architecture < NV_ARCH_50 && !pNv->randr12_enable)
2319 ret = NVCursorInit(pScreen);
2320 else if (pNv->Architecture < NV_ARCH_50 && pNv->randr12_enable)
2321 ret = NVCursorInitRandr12(pScreen);
2323 ret = NV50CursorInit(pScreen);
2326 xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
2327 "Hardware cursor initialization failed\n");
2328 pNv->HWCursor = FALSE;
2332 /* Initialise default colourmap */
2333 if (!miCreateDefColormap(pScreen))
2336 /* Initialize colormap layer.
2337 Must follow initialization of the default colormap */
2338 if (!pNv->randr12_enable) {
2339 if(!xf86HandleColormaps(pScreen, 256, 8, NVDACLoadPalette,
2340 NULL, CMAP_RELOAD_ON_MODE_SWITCH | CMAP_PALETTED_TRUECOLOR))
2343 if (pNv->Architecture < NV_ARCH_50) {
2344 if (!xf86HandleColormaps(pScreen, 256, 8, NVLoadPalette,
2346 CMAP_RELOAD_ON_MODE_SWITCH |
2347 CMAP_PALETTED_TRUECOLOR))
2350 if (!xf86HandleColormaps(pScreen, 256, 8, NV50LoadPalette,
2351 NULL, CMAP_PALETTED_TRUECOLOR))
2356 if (pNv->randr12_enable) {
2357 xf86DPMSInit(pScreen, xf86DPMSSet, 0);
2359 if (!xf86CrtcScreenInit(pScreen))
2362 pNv->PointerMoved = pScrn->PointerMoved;
2363 pScrn->PointerMoved = NVPointerMoved;
2367 RefreshAreaFuncPtr refreshArea = NVRefreshArea;
2369 if(pNv->Rotate || pNv->RandRRotation) {
2370 pNv->PointerMoved = pScrn->PointerMoved;
2372 pScrn->PointerMoved = NVPointerMoved;
2374 switch(pScrn->bitsPerPixel) {
2375 case 8: refreshArea = NVRefreshArea8; break;
2376 case 16: refreshArea = NVRefreshArea16; break;
2377 case 32: refreshArea = NVRefreshArea32; break;
2379 if(!pNv->RandRRotation) {
2381 xf86DrvMsg(pScrn->scrnIndex, X_INFO,
2382 "Driver rotation enabled, RandR disabled\n");
2386 ShadowFBInit(pScreen, refreshArea);
2389 if (!pNv->randr12_enable) {
2391 xf86DPMSInit(pScreen, NVDPMSSetLCD, 0);
2393 xf86DPMSInit(pScreen, NVDPMSSet, 0);
2396 pScrn->memPhysBase = pNv->VRAMPhysical;
2397 pScrn->fbOffset = 0;
2399 if(pNv->Rotate == 0 && !pNv->RandRRotation)
2400 NVInitVideo(pScreen);
2402 pScreen->SaveScreen = NVSaveScreen;
2404 /* Wrap the current CloseScreen function */
2405 pNv->CloseScreen = pScreen->CloseScreen;
2406 pScreen->CloseScreen = NVCloseScreen;
2408 pNv->BlockHandler = pScreen->BlockHandler;
2409 pScreen->BlockHandler = NVBlockHandler;
2412 /* Install our DriverFunc. We have to do it this way instead of using the
2413 * HaveDriverFuncs argument to xf86AddDriver, because InitOutput clobbers
2414 * pScrn->DriverFunc */
2415 if (!pNv->randr12_enable)
2416 pScrn->DriverFunc = NVDriverFunc;
2419 /* Report any unused options (only for the first generation) */
2420 if (serverGeneration == 1) {
2421 xf86ShowUnusedOptions(pScrn->scrnIndex, pScrn->options);
2427 NVSaveScreen(ScreenPtr pScreen, int mode)
2429 ScrnInfoPtr pScrn = xf86Screens[pScreen->myNum];
2430 xf86CrtcConfigPtr xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
2431 NVPtr pNv = NVPTR(pScrn);
2433 Bool on = xf86IsUnblank(mode);
2435 if (pNv->randr12_enable) {
2436 if (pScrn->vtSema && pNv->Architecture < NV_ARCH_50) {
2437 for (i = 0; i < xf86_config->num_crtc; i++) {
2439 if (xf86_config->crtc[i]->enabled) {
2440 NVCrtcBlankScreen(xf86_config->crtc[i],
2449 return vgaHWSaveScreen(pScreen, mode);
2453 NVSave(ScrnInfoPtr pScrn)
2455 NVPtr pNv = NVPTR(pScrn);
2456 NVRegPtr nvReg = &pNv->SavedReg;
2457 vgaHWPtr pVga = VGAHWPTR(pScrn);
2458 vgaRegPtr vgaReg = &pVga->SavedReg;
2460 if (pNv->randr12_enable) {
2461 xf86CrtcConfigPtr xf86_config = XF86_CRTC_CONFIG_PTR(pScrn);
2462 int vgaflags = VGA_SR_CMAP | VGA_SR_MODE;
2465 for (i = 0; i < xf86_config->num_crtc; i++) {
2466 xf86_config->crtc[i]->funcs->save(xf86_config->crtc[i]);
2469 for (i = 0; i < xf86_config->num_output; i++) {
2470 xf86_config->output[i]->funcs->save(xf86_config->
2476 vgaflags |= VGA_SR_FONTS;
2478 vgaHWSave(pScrn, vgaReg, vgaflags);
2480 NVLockUnlock(pNv, 0);
2482 nvWriteVGA(pNv, NV_VGA_CRTCX_OWNER, pNv->crtc_active[1] * 0x3);
2483 NVLockUnlock(pNv, 0);
2486 NVDACSave(pScrn, vgaReg, nvReg, pNv->Primary);
2492 NVRandRGetInfo(ScrnInfoPtr pScrn, Rotation *rotations)
2494 NVPtr pNv = NVPTR(pScrn);
2496 if(pNv->RandRRotation)
2497 *rotations = RR_Rotate_0 | RR_Rotate_90 | RR_Rotate_270;
2499 *rotations = RR_Rotate_0;
2505 NVRandRSetConfig(ScrnInfoPtr pScrn, xorgRRConfig *config)
2507 NVPtr pNv = NVPTR(pScrn);
2509 switch(config->rotation) {
2512 pScrn->PointerMoved = pNv->PointerMoved;
2517 pScrn->PointerMoved = NVPointerMoved;
2522 pScrn->PointerMoved = NVPointerMoved;
2526 xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
2527 "Unexpected rotation in NVRandRSetConfig!\n");
2529 pScrn->PointerMoved = pNv->PointerMoved;
2537 NVDriverFunc(ScrnInfoPtr pScrn, xorgDriverFuncOp op, pointer data)
2541 return NVRandRGetInfo(pScrn, (Rotation*)data);
2543 return NVRandRSetConfig(pScrn, (xorgRRConfig*)data);