pcipnp.h revision 1.1.70.1       1  1.1  garbled /* $NetBSD: pcipnp.h,v 1.1.70.1 2008/06/02 13:22:34 mjf Exp $ */
      2  1.1  garbled /*-
      3  1.1  garbled  * Copyright (c) 2006 The NetBSD Foundation, Inc.
      4  1.1  garbled  * All rights reserved.
      5  1.1  garbled  *
      6  1.1  garbled  * This code is derived from software contributed to The NetBSD Foundation
      7  1.1  garbled  * by Tim Rightnour
      8  1.1  garbled  *
      9  1.1  garbled  * Redistribution and use in source and binary forms, with or without
     10  1.1  garbled  * modification, are permitted provided that the following conditions
     11  1.1  garbled  * are met:
     12  1.1  garbled  * 1. Redistributions of source code must retain the above copyright
     13  1.1  garbled  *    notice, this list of conditions and the following disclaimer.
     14  1.1  garbled  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1  garbled  *    notice, this list of conditions and the following disclaimer in the
     16  1.1  garbled  *    documentation and/or other materials provided with the distribution.
     17  1.1  garbled  *
     18  1.1  garbled  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     19  1.1  garbled  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     20  1.1  garbled  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     21  1.1  garbled  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     22  1.1  garbled  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     23  1.1  garbled  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     24  1.1  garbled  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     25  1.1  garbled  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     26  1.1  garbled  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     27  1.1  garbled  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     28  1.1  garbled  * POSSIBILITY OF SUCH DAMAGE.
     29  1.1  garbled  */
     30  1.1  garbled /*
     31  1.1  garbled  * Based on:
     32  1.1  garbled  * IBM Power Personal Systems Architecture: Residual Data
     33  1.1  garbled  * Document Number: PPS-AR-FW0001 Rev 0.5  April 3, 1996
     34  1.1  garbled  */
     35  1.1  garbled 
     36  1.1  garbled #ifndef _PCIPNP_H_
     37  1.1  garbled #define _PCIPNP_H_
     38  1.1  garbled 
     39  1.1  garbled #define MAX_PCI_INTRS	4
     40  1.1  garbled 
     41  1.1  garbled typedef enum _IntrTypes {
     42  1.1  garbled 	IntrInvalid = 0,
     43  1.1  garbled 	Intr8259 = 1,
     44  1.1  garbled 	IntrMPIC = 2,
     45  1.1  garbled 	IntrRS6K = 3
     46  1.1  garbled } _IntrTypes;
     47  1.1  garbled 
     48  1.1  garbled /* PCI to system conversion map */
     49  1.1  garbled typedef struct _IntrMap {
     50  1.1  garbled 	uint8_t slotnum;		/* First = 1, integrated = 0 */
     51  1.1  garbled 	uint8_t devfunc;
     52  1.1  garbled 	uint8_t intrctrltype;		/* interrupt type */
     53  1.1  garbled 	uint8_t intrctrlnum;		/* 8259 = 0
     54  1.1  garbled 					 * MPIC = 1
     55  1.1  garbled 					 * RS6K = buid ???? */
     56  1.1  garbled 	uint16_t intr[MAX_PCI_INTRS];	/* Index 0-3 == A-D
     57  1.1  garbled 					 * 0xFFFF == not usable
     58  1.1  garbled 					 * 0x8nnn == edge sensitive
     59  1.1  garbled 					 */
     60  1.1  garbled } IntrMap;
     61  1.1  garbled 
     62  1.1  garbled typedef struct _PCIInfoPack {
     63  1.1  garbled 	uint8_t tag;			/* large tag = 0x84 */
     64  1.1  garbled 	uint8_t count0;
     65  1.1  garbled 	uint8_t count1;
     66  1.1  garbled 	  /* count = number of PCI slots * sizeof(IntrMap) + 21 */
     67  1.1  garbled 	uint8_t type;			/* == 3 PCI Bridge */
     68  1.1  garbled 	uint8_t configbaseaddr[8];	/* Base addr of PCI configuration
     69  1.1  garbled 					 *   system real address */
     70  1.1  garbled 	uint8_t configbasedata[8];	/* base addr of PCI config data
     71  1.1  garbled 					 *   system real address */
     72  1.1  garbled 	uint8_t busnum;			/* PCI Bus Number */
     73  1.1  garbled 	uint8_t reserved[3];		/* reserved, padded with 0 */
     74  1.1  garbled 	IntrMap map[1];			/* Interrupt map array for each PCI
     75  1.1  garbled 					 * slots that are pluggable.
     76  1.1  garbled 					 * number = (count-21)/sizeof(IntrMap)*/
     77  1.1  garbled } PCIInfoPack;
     78  1.1  garbled 
     79  1.1  garbled #endif /* _PCIPNP_H_ */
     80