xref: /openbsd-src/sys/arch/octeon/dev/octeon_pcibus.h (revision 0b0091d948f44453ed79ff130fa269194f49867b)
1*0b0091d9Sjasper /*	$OpenBSD: octeon_pcibus.h,v 1.3 2015/07/20 01:38:31 jasper Exp $	*/
262023fb5Ssyuu 
362023fb5Ssyuu /*
462023fb5Ssyuu  * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.com).
562023fb5Ssyuu  *
662023fb5Ssyuu  * Redistribution and use in source and binary forms, with or without
762023fb5Ssyuu  * modification, are permitted provided that the following conditions
862023fb5Ssyuu  * are met:
962023fb5Ssyuu  * 1. Redistributions of source code must retain the above copyright
1062023fb5Ssyuu  *    notice, this list of conditions and the following disclaimer.
1162023fb5Ssyuu  * 2. Redistributions in binary form must reproduce the above copyright
1262023fb5Ssyuu  *    notice, this list of conditions and the following disclaimer in the
1362023fb5Ssyuu  *    documentation and/or other materials provided with the distribution.
1462023fb5Ssyuu  *
1562023fb5Ssyuu  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
1662023fb5Ssyuu  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
1762023fb5Ssyuu  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1862023fb5Ssyuu  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
1962023fb5Ssyuu  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2062023fb5Ssyuu  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2162023fb5Ssyuu  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2262023fb5Ssyuu  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2362023fb5Ssyuu  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2462023fb5Ssyuu  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2562023fb5Ssyuu  * SUCH DAMAGE.
2662023fb5Ssyuu  *
2762023fb5Ssyuu  */
2862023fb5Ssyuu 
2962023fb5Ssyuu 
3062023fb5Ssyuu #ifndef ___OCTEON_PCIBUS_H__
3162023fb5Ssyuu #define ___OCTEON_PCIBUS_H__
3262023fb5Ssyuu 
33a81120d9Sjasper #include <machine/octeonreg.h>
3462023fb5Ssyuu 
3562023fb5Ssyuu #define OCTEON_PCIBUS_PCIIO_BASE	0x11A0000000000ULL
3662023fb5Ssyuu 
3762023fb5Ssyuu #define OCTEON_PCI_CFG0			0x80011F0000001804ULL
3862023fb5Ssyuu #define OCTEON_PCI_CFG1			0x80011F0000001800ULL
3962023fb5Ssyuu #define OCTEON_PCI_CONFIG_BASE0		0x8001190000000004ULL
4062023fb5Ssyuu #define OCTEON_PCI_CONFIG_BASE1		0x8001190000000000ULL
4162023fb5Ssyuu 
4262023fb5Ssyuu #define OCTEON_PCI_CFG2			(OCTEON_PCI_CFG0 + 0x08UL)
4362023fb5Ssyuu #define OCTEON_PCI_CFG3			(OCTEON_PCI_CFG1 + 0x08UL)
4462023fb5Ssyuu #define OCTEON_PCI_CFG4			(OCTEON_PCI_CFG0 + 0x10UL)
4562023fb5Ssyuu #define OCTEON_PCI_CFG5			(OCTEON_PCI_CFG1 + 0x10UL)
4662023fb5Ssyuu #define OCTEON_PCI_CFG6			(OCTEON_PCI_CFG0 + 0x18UL)
4762023fb5Ssyuu #define OCTEON_PCI_CFG7			(OCTEON_PCI_CFG1 + 0x18UL)
4862023fb5Ssyuu #define OCTEON_PCI_CFG8			(OCTEON_PCI_CFG0 + 0x20UL)
4962023fb5Ssyuu #define OCTEON_PCI_CFG9			(OCTEON_PCI_CFG1 + 0x20UL)
5062023fb5Ssyuu #define OCTEON_PCI_CFG10		(OCTEON_PCI_CFG0 + 0x28UL)
5162023fb5Ssyuu #define OCTEON_PCI_CFG11		(OCTEON_PCI_CFG1 + 0x28UL)
5262023fb5Ssyuu #define OCTEON_PCI_CFG12		(OCTEON_PCI_CFG0 + 0x30UL)
5362023fb5Ssyuu #define OCTEON_PCI_CFG13		(OCTEON_PCI_CFG1 + 0x30UL)
5462023fb5Ssyuu #define OCTEON_PCI_CFG14		(OCTEON_PCI_CFG0 + 0x38UL)
5562023fb5Ssyuu #define OCTEON_PCI_CFG15		(OCTEON_PCI_CFG1 + 0x38UL)
5662023fb5Ssyuu #define OCTEON_PCI_CFG16		(OCTEON_PCI_CFG0 + 0x40UL)
5762023fb5Ssyuu #define OCTEON_PCI_CFG17		(OCTEON_PCI_CFG1 + 0x40UL)
5862023fb5Ssyuu #define OCTEON_PCI_CFG18		(OCTEON_PCI_CFG0 + 0x48UL)
5962023fb5Ssyuu #define OCTEON_PCI_CFG19		(OCTEON_PCI_CFG1 + 0x48UL)
6062023fb5Ssyuu #define OCTEON_PCI_CFG20		(OCTEON_PCI_CFG0 + 0x50UL)
6162023fb5Ssyuu #define OCTEON_PCI_CFG21		(OCTEON_PCI_CFG1 + 0x50UL)
6262023fb5Ssyuu #define OCTEON_PCI_CFG22		(OCTEON_PCI_CFG0 + 0x58UL)
6362023fb5Ssyuu #define OCTEON_PCI_CFG23		(OCTEON_PCI_CFG1 + 0x58UL)
6462023fb5Ssyuu #define OCTEON_PCI_CFG24		(OCTEON_PCI_CFG0 + 0x60UL)
6562023fb5Ssyuu #define OCTEON_PCI_CFG25		(OCTEON_PCI_CFG1 + 0x60UL)
6662023fb5Ssyuu #define OCTEON_PCI_CFG26		(OCTEON_PCI_CFG0 + 0x68UL)
6762023fb5Ssyuu #define OCTEON_PCI_CFG27		(OCTEON_PCI_CFG1 + 0x68UL)
6862023fb5Ssyuu #define OCTEON_PCI_CFG28		(OCTEON_PCI_CFG0 + 0x70UL)
6962023fb5Ssyuu #define OCTEON_PCI_CFG29		(OCTEON_PCI_CFG1 + 0x70UL)
7062023fb5Ssyuu #define OCTEON_PCI_CFG30		(OCTEON_PCI_CFG0 + 0x78UL)
7162023fb5Ssyuu #define OCTEON_PCI_CFG31		(OCTEON_PCI_CFG1 + 0x78UL)
7262023fb5Ssyuu #define OCTEON_PCI_CFG32		(OCTEON_PCI_CFG0 + 0x80UL)
7362023fb5Ssyuu #define OCTEON_PCI_CFG33		(OCTEON_PCI_CFG1 + 0x80UL)
7462023fb5Ssyuu #define OCTEON_PCI_CFG34		(OCTEON_PCI_CFG0 + 0x88UL)
7562023fb5Ssyuu #define OCTEON_PCI_CFG35		(OCTEON_PCI_CFG1 + 0x88UL)
7662023fb5Ssyuu #define OCTEON_PCI_CFG36		(OCTEON_PCI_CFG0 + 0x90UL)
7762023fb5Ssyuu #define OCTEON_PCI_CFG37		(OCTEON_PCI_CFG1 + 0x90UL)
7862023fb5Ssyuu #define OCTEON_PCI_CFG38		(OCTEON_PCI_CFG0 + 0x98UL)
7962023fb5Ssyuu #define OCTEON_PCI_CFG39		(OCTEON_PCI_CFG1 + 0x98UL)
8062023fb5Ssyuu #define OCTEON_PCI_CFG40		(OCTEON_PCI_CFG0 + 0xA0UL)
8162023fb5Ssyuu #define OCTEON_PCI_CFG41		(OCTEON_PCI_CFG1 + 0xA0UL)
8262023fb5Ssyuu #define OCTEON_PCI_CFG42		(OCTEON_PCI_CFG0 + 0xA8UL)
8362023fb5Ssyuu #define OCTEON_PCI_CFG43		(OCTEON_PCI_CFG1 + 0xA8UL)
8462023fb5Ssyuu #define OCTEON_PCI_CFG44		(OCTEON_PCI_CFG0 + 0xB0UL)
8562023fb5Ssyuu #define OCTEON_PCI_CFG45		(OCTEON_PCI_CFG1 + 0xB0UL)
8662023fb5Ssyuu #define OCTEON_PCI_CFG46		(OCTEON_PCI_CFG0 + 0xB8UL)
8762023fb5Ssyuu #define OCTEON_PCI_CFG47		(OCTEON_PCI_CFG1 + 0xB8UL)
8862023fb5Ssyuu #define OCTEON_PCI_CFG48		(OCTEON_PCI_CFG0 + 0xC0UL)
8962023fb5Ssyuu #define OCTEON_PCI_CFG49		(OCTEON_PCI_CFG1 + 0xC0UL)
9062023fb5Ssyuu #define OCTEON_PCI_CFG50		(OCTEON_PCI_CFG0 + 0xC8UL)
9162023fb5Ssyuu #define OCTEON_PCI_CFG51		(OCTEON_PCI_CFG1 + 0xC8UL)
9262023fb5Ssyuu #define OCTEON_PCI_CFG52		(OCTEON_PCI_CFG0 + 0xD0UL)
9362023fb5Ssyuu #define OCTEON_PCI_CFG53		(OCTEON_PCI_CFG1 + 0xD0UL)
9462023fb5Ssyuu #define OCTEON_PCI_CFG54		(OCTEON_PCI_CFG0 + 0xD8UL)
9562023fb5Ssyuu #define OCTEON_PCI_CFG55		(OCTEON_PCI_CFG1 + 0xD8UL)
9662023fb5Ssyuu #define OCTEON_PCI_CFG56		(OCTEON_PCI_CFG0 + 0xE0UL)
9762023fb5Ssyuu #define OCTEON_PCI_CFG57		(OCTEON_PCI_CFG1 + 0xE0UL)
9862023fb5Ssyuu #define OCTEON_PCI_CFG58		(OCTEON_PCI_CFG0 + 0xE8UL)
9962023fb5Ssyuu #define OCTEON_PCI_CFG59		(OCTEON_PCI_CFG1 + 0xE8UL)
10062023fb5Ssyuu #define OCTEON_PCI_CFG60		(OCTEON_PCI_CFG0 + 0xF0UL)
10162023fb5Ssyuu #define OCTEON_PCI_CFG61		(OCTEON_PCI_CFG1 + 0xF0UL)
10262023fb5Ssyuu #define OCTEON_PCI_CFG62		(OCTEON_PCI_CFG0 + 0xF8UL)
10362023fb5Ssyuu #define OCTEON_PCI_CFG63		(OCTEON_PCI_CFG1 + 0xF8UL)
10462023fb5Ssyuu 
10562023fb5Ssyuu #define OCTEON_PCIBUS_PCIMAPCFG_TYPE1	0x00010000
10662023fb5Ssyuu 
10762023fb5Ssyuu #endif /* ___OCTEON_PCIBUS_H__ */
108