289 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			289 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
| /*
 | |
|  * Pci.c - New server PCI access functions
 | |
|  *
 | |
|  * The XFree86 server PCI access functions have been reimplemented as a
 | |
|  * framework that allows each supported platform/OS to have their own
 | |
|  * platform/OS specific pci driver.
 | |
|  *
 | |
|  * All of the public PCI access functions exported to the other parts of
 | |
|  * the server are declared in Pci.h and defined herein.  These include:
 | |
|  *	pciInit()              - Initialize PCI access functions
 | |
|  *	pciReadLong()          - Read a 32 bit value from a device's cfg space
 | |
|  *	pciReadWord()          - Read a 16 bit value from a device's cfg space
 | |
|  *	pciReadByte()          - Read an 8 bit value from a device's cfg space
 | |
|  *	pciWriteLong()         - Write a 32 bit value to a device's cfg space
 | |
|  *	pciWriteWord()         - Write a 16 bit value to a device's cfg space
 | |
|  *	pciWriteByte()         - Write an 8 bit value to a device's cfg space
 | |
|  *	pciSetBitsLong()       - Write a 32 bit value against a mask
 | |
|  *	pciSetBitsByte()       - Write an 8 bit value against a mask
 | |
|  *	pciTag()               - Return tag for a given PCI bus, device, &
 | |
|  *                               function
 | |
|  *	pciBusAddrToHostAddr() - Convert a PCI address to a host address
 | |
|  *	xf86scanpci()          - Return info about all PCI devices
 | |
|  *	xf86MapDomainMemory()  - Like xf86MapPciMem() but can handle
 | |
|  *                               domain/host address translation
 | |
|  *	xf86MapLegacyIO()      - Maps PCI I/O spaces
 | |
|  *
 | |
|  * The actual PCI backend driver is selected by the pciInit() function
 | |
|  * (see below)  using either compile time definitions, run-time checks,
 | |
|  * or both.
 | |
|  *
 | |
|  * Certain generic functions are provided that make the implementation
 | |
|  * of certain well behaved platforms (e.g. those supporting PCI config
 | |
|  * mechanism 1 or some thing close to it) very easy.
 | |
|  *
 | |
|  * Less well behaved platforms/OS's can roll their own functions.
 | |
|  *
 | |
|  * To add support for another platform/OS, add a call to fooPciInit() within
 | |
|  * pciInit() below under the correct compile time definition or run-time
 | |
|  * conditional.
 | |
|  *
 | |
|  * The fooPciInit() procedure must do three things:
 | |
|  *	1) Initialize the pciBusTable[] for all primary PCI buses including
 | |
|  *	   the per domain PCI access functions (readLong, writeLong,
 | |
|  *	   addrBusToHost, and addrHostToBus).
 | |
|  *
 | |
|  *	2) Add entries to pciBusTable[] for configured secondary buses.  This
 | |
|  *	   step may be skipped if a platform is using the generic findFirst/
 | |
|  *	   findNext functions because these procedures will automatically
 | |
|  *	   discover and add secondary buses dynamically.
 | |
|  *
 | |
|  *      3) Overide default settings for global PCI access functions if
 | |
|  *	   required. These include pciFindFirstFP, pciFindNextFP,
 | |
|  *	   Of course, if you choose not to use one of the generic
 | |
|  *	   functions, you will need to provide a platform specifc replacement.
 | |
|  *
 | |
|  * Gary Barton
 | |
|  * Concurrent Computer Corporation
 | |
|  * garyb@gate.net
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Copyright 1998 by Concurrent Computer Corporation
 | |
|  *
 | |
|  * 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 Concurrent Computer
 | |
|  * Corporation not be used in advertising or publicity pertaining to
 | |
|  * distribution of the software without specific, written prior
 | |
|  * permission.  Concurrent Computer Corporation makes no representations
 | |
|  * about the suitability of this software for any purpose.  It is
 | |
|  * provided "as is" without express or implied warranty.
 | |
|  *
 | |
|  * CONCURRENT COMPUTER CORPORATION DISCLAIMS ALL WARRANTIES WITH REGARD
 | |
|  * TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 | |
|  * AND FITNESS, IN NO EVENT SHALL CONCURRENT COMPUTER CORPORATION 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 1998 by Metro Link Incorporated
 | |
|  *
 | |
|  * 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 Metro Link
 | |
|  * Incorporated not be used in advertising or publicity pertaining to
 | |
|  * distribution of the software without specific, written prior
 | |
|  * permission.  Metro Link Incorporated makes no representations
 | |
|  * about the suitability of this software for any purpose.  It is
 | |
|  * provided "as is" without express or implied warranty.
 | |
|  *
 | |
|  * METRO LINK INCORPORATED DISCLAIMS ALL WARRANTIES WITH REGARD
 | |
|  * TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 | |
|  * AND FITNESS, IN NO EVENT SHALL METRO LINK INCORPORATED 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.
 | |
|  *
 | |
|  * This software is derived from the original XFree86 PCI code
 | |
|  * which includes the following copyright notices as well:
 | |
|  *
 | |
|  * Copyright 1995 by Robin Cutshaw <robin@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 names of the above listed copyright holder(s)
 | |
|  * not be used in advertising or publicity pertaining to distribution of
 | |
|  * the software without specific, written prior permission.  The above listed
 | |
|  * copyright holder(s) make(s) no representations about the suitability of this
 | |
|  * software for any purpose.  It is provided "as is" without express or
 | |
|  * implied warranty.
 | |
|  *
 | |
|  * THE ABOVE LISTED COPYRIGHT HOLDER(S) DISCLAIM(S) ALL WARRANTIES WITH REGARD
 | |
|  * TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 | |
|  * AND FITNESS, IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDER(S) 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.
 | |
|  *
 | |
|  * This code is also based heavily on the code in FreeBSD-current, which was
 | |
|  * written by Wolfgang Stanglmeier, and contains the following copyright:
 | |
|  *
 | |
|  * Redistribution and use in source and binary forms, with or without
 | |
|  * modification, are permitted provided that the following conditions
 | |
|  * are met:
 | |
|  * 1. Redistributions of source code must retain the above copyright
 | |
|  *    notice, this list of conditions and the following disclaimer.
 | |
|  * 2. Redistributions in binary form must reproduce the above copyright
 | |
|  *    notice, this list of conditions and the following disclaimer in the
 | |
|  *    documentation and/or other materials provided with the distribution.
 | |
|  * 3. The name of the author may not be used to endorse or promote products
 | |
|  *    derived from this software without specific prior written permission.
 | |
|  *
 | |
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 | |
|  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 | |
|  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 | |
|  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 | |
|  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 | |
|  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 | |
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 | |
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | |
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 | |
|  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
|  *
 | |
|  */
 | |
| /*
 | |
|  * Copyright (c) 1999-2003 by The XFree86 Project, Inc.
 | |
|  *
 | |
|  * 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 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 NONINFRINGEMENT.  IN NO EVENT SHALL
 | |
|  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) 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.
 | |
|  *
 | |
|  * Except as contained in this notice, the name of the copyright holder(s)
 | |
|  * and author(s) shall not be used in advertising or otherwise to promote
 | |
|  * the sale, use or other dealings in this Software without prior written
 | |
|  * authorization from the copyright holder(s) and author(s).
 | |
|  */
 | |
| 
 | |
| #ifdef HAVE_XORG_CONFIG_H
 | |
| #include <xorg-config.h>
 | |
| #endif
 | |
| 
 | |
| #include <errno.h>
 | |
| #include <signal.h>
 | |
| #include <X11/Xarch.h>
 | |
| #include "compiler.h"
 | |
| #include "xf86.h"
 | |
| #include "xf86Priv.h"
 | |
| #define XF86_OS_PRIVS
 | |
| #include "xf86_OSproc.h"
 | |
| #include "Pci.h"
 | |
| 
 | |
| #include <pciaccess.h>
 | |
| 
 | |
| #if 0
 | |
| #include <stdio.h>
 | |
| #include <unistd.h>
 | |
| #include <sys/types.h>
 | |
| #include <sys/stat.h>
 | |
| #include <fcntl.h>
 | |
| #endif
 | |
| 
 | |
| #define PCI_MFDEV_SUPPORT   1 /* Include PCI multifunction device support */
 | |
| #define PCI_BRIDGE_SUPPORT  1 /* Include support for PCI-to-PCI bridges */
 | |
| 
 | |
| /*
 | |
|  * Global data
 | |
|  */
 | |
| 
 | |
| pciBusInfo_t  *pciBusInfo[MAX_PCI_BUSES] = { NULL, };
 | |
| _X_EXPORT int            pciNumBuses = 0;     /* Actual number of PCI buses */
 | |
| int            pciMaxBusNum = MAX_PCI_BUSES;
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * pciInit - choose correct platform/OS specific PCI init routine
 | |
|  */
 | |
| static void
 | |
| pciInit(void)
 | |
| {
 | |
|     static int pciInitialized = 0;
 | |
| 
 | |
|     if (!pciInitialized) {
 | |
| 	pciInitialized = 1;
 | |
| 
 | |
| 	/* XXX */
 | |
| #if defined(DEBUGPCI)
 | |
| 	if (DEBUGPCI >= xf86Verbose) {
 | |
| 	    xf86Verbose = DEBUGPCI;
 | |
| 	}
 | |
| #endif
 | |
| 
 | |
| 	ARCH_PCI_INIT();
 | |
|     }
 | |
| }
 | |
| 
 | |
| _X_EXPORT ADDRESS
 | |
| pciBusAddrToHostAddr(PCITAG tag, PciAddrType type, ADDRESS addr)
 | |
| {
 | |
|   int bus = PCI_BUS_FROM_TAG(tag);
 | |
| 
 | |
|   pciInit();
 | |
| 
 | |
|   if ((bus >= 0) && (bus < pciNumBuses) && pciBusInfo[bus] &&
 | |
| 	pciBusInfo[bus]->funcs->pciAddrBusToHost)
 | |
| 	  return (*pciBusInfo[bus]->funcs->pciAddrBusToHost)(tag, type, addr);
 | |
|   else
 | |
| 	  return(addr);
 | |
| }
 | |
| 
 | |
| _X_EXPORT PCITAG
 | |
| pciTag(int busnum, int devnum, int funcnum)
 | |
| {
 | |
| 	return(PCI_MAKE_TAG(busnum,devnum,funcnum));
 | |
| }
 | |
| 
 | |
| ADDRESS
 | |
| pciAddrNOOP(PCITAG tag, PciAddrType type, ADDRESS addr)
 | |
| {
 | |
| 	return(addr);
 | |
| }
 | |
| 
 | |
| _X_EXPORT Bool
 | |
| xf86scanpci(void)
 | |
| {
 | |
|     static Bool  done = FALSE;
 | |
|     static Bool  success = FALSE;
 | |
| 
 | |
|     /*
 | |
|      * if we haven't found PCI devices checking for pci_devp may
 | |
|      * result in an endless recursion if platform/OS specific PCI
 | |
|      * bus probing code calls this function from with in it.
 | |
|      */
 | |
|     if (done)
 | |
| 	return success;
 | |
| 
 | |
|     done = TRUE;
 | |
| 
 | |
|     success = (pci_system_init() == 0);
 | |
|     pciInit();
 | |
| 
 | |
|     return success;
 | |
| }
 |