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;
 | 
						|
}
 |