129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
/* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/bus/netbsdPci.c,v 1.4 2003/08/24 17:37:04 dawes Exp $ */
 | 
						|
/*
 | 
						|
 * Copyright (C) 1994-2003 The XFree86 Project, Inc.  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 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 XFREE86 PROJECT 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 XFree86 Project
 | 
						|
 * 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 XFree86 Project.
 | 
						|
 */
 | 
						|
 | 
						|
#include <sys/types.h>
 | 
						|
#include <sys/mman.h>
 | 
						|
#include <sys/ioctl.h>
 | 
						|
#include <fcntl.h>
 | 
						|
#include <stdio.h>
 | 
						|
#include <unistd.h>
 | 
						|
#include <dev/pci/pciio.h>
 | 
						|
 | 
						|
#include "xf86.h"
 | 
						|
#include "xf86Priv.h"
 | 
						|
#include "xf86OSpriv.h"
 | 
						|
 | 
						|
#include "Pci.h"
 | 
						|
 | 
						|
static CARD32 netbsdPciConfRead(PCITAG, int);
 | 
						|
static void netbsdPciConfWrite(PCITAG, int, CARD32);
 | 
						|
static void netbsdPciSetBits(PCITAG, int, CARD32, CARD32);
 | 
						|
 | 
						|
static int devpci = -1;
 | 
						|
 | 
						|
static pciBusFuncs_t netbsdFuncs0 = {
 | 
						|
/* pciReadLong      */	netbsdPciConfRead,
 | 
						|
/* pciWriteLong     */	netbsdPciConfWrite,
 | 
						|
/* pciSetBitsLong   */	netbsdPciSetBits,
 | 
						|
/* pciAddrHostToBus */	pciAddrNOOP,
 | 
						|
/* pciAddrBusToHost */	pciAddrNOOP
 | 
						|
};
 | 
						|
 | 
						|
static pciBusInfo_t netbsdPci0 = {
 | 
						|
/* configMech  */	PCI_CFG_MECH_OTHER,
 | 
						|
/* numDevices  */	32,
 | 
						|
/* secondary   */	FALSE,
 | 
						|
/* primary_bus */	0,
 | 
						|
/* funcs       */	&netbsdFuncs0,
 | 
						|
/* pciBusPriv  */	NULL,
 | 
						|
/* bridge      */	NULL
 | 
						|
};
 | 
						|
 | 
						|
void
 | 
						|
netbsdPciInit()
 | 
						|
{
 | 
						|
	struct pciio_businfo pci_businfo;
 | 
						|
 | 
						|
	devpci = open("/dev/pci0", O_RDWR);
 | 
						|
	if (devpci == -1)
 | 
						|
		FatalError("netbsdPciInit: can't open /dev/pci0\n");
 | 
						|
 | 
						|
	pciNumBuses    = 1;
 | 
						|
	pciBusInfo[0]  = &netbsdPci0;
 | 
						|
	pciFindFirstFP = pciGenFindFirst;
 | 
						|
	pciFindNextFP  = pciGenFindNext;
 | 
						|
	/* use businfo to get the number of devs */
 | 
						|
	if (ioctl(devpci, PCI_IOC_BUSINFO, &pci_businfo) != 0)
 | 
						|
	    FatalError("netbsdPciInit: not a PCI bus device");
 | 
						|
	netbsdPci0.numDevices = pci_businfo.maxdevs;
 | 
						|
}
 | 
						|
 | 
						|
static CARD32
 | 
						|
netbsdPciConfRead(PCITAG tag, int reg)
 | 
						|
{
 | 
						|
	struct pciio_bdf_cfgreg bdfr;
 | 
						|
 | 
						|
	bdfr.bus      = PCI_BUS_FROM_TAG(tag);
 | 
						|
	bdfr.device   = PCI_DEV_FROM_TAG(tag);
 | 
						|
	bdfr.function = PCI_FUNC_FROM_TAG(tag);
 | 
						|
	bdfr.cfgreg.reg = reg;
 | 
						|
 | 
						|
	if (ioctl(devpci, PCI_IOC_BDF_CFGREAD, &bdfr) == -1)
 | 
						|
		FatalError("netbsdPciConfRead: failed on %d/%d/%d\n",
 | 
						|
		    bdfr.bus, bdfr.device, bdfr.function);
 | 
						|
 | 
						|
	return (bdfr.cfgreg.val);
 | 
						|
}
 | 
						|
 | 
						|
static void
 | 
						|
netbsdPciConfWrite(PCITAG tag, int reg, CARD32 val)
 | 
						|
{
 | 
						|
	struct pciio_bdf_cfgreg bdfr;
 | 
						|
 | 
						|
	bdfr.bus      = PCI_BUS_FROM_TAG(tag);
 | 
						|
	bdfr.device   = PCI_DEV_FROM_TAG(tag);
 | 
						|
	bdfr.function = PCI_FUNC_FROM_TAG(tag);
 | 
						|
	bdfr.cfgreg.reg = reg;
 | 
						|
	bdfr.cfgreg.val = val;
 | 
						|
 | 
						|
	if (ioctl(devpci, PCI_IOC_BDF_CFGWRITE, &bdfr) == -1)
 | 
						|
		FatalError("netbsdPciConfWrite: failed on %d/%d/%d\n",
 | 
						|
		    bdfr.bus, bdfr.device, bdfr.function);
 | 
						|
}
 | 
						|
 | 
						|
static void
 | 
						|
netbsdPciSetBits(PCITAG tag, int reg, CARD32 mask, CARD32 bits)
 | 
						|
{
 | 
						|
	CARD32 val;
 | 
						|
 | 
						|
	val = netbsdPciConfRead(tag, reg);
 | 
						|
	val = (val & ~mask) | (bits & mask);
 | 
						|
	netbsdPciConfWrite(tag, reg, val);
 | 
						|
}
 |