101a6221aSDavid Daney /*
201a6221aSDavid Daney  * This file is subject to the terms and conditions of the GNU General Public
301a6221aSDavid Daney  * License.  See the file "COPYING" in the main directory of this archive
401a6221aSDavid Daney  * for more details.
501a6221aSDavid Daney  *
601a6221aSDavid Daney  * Copyright (C) 2005-2009 Cavium Networks
701a6221aSDavid Daney  */
801a6221aSDavid Daney 
901a6221aSDavid Daney #ifndef __PCI_OCTEON_H__
1001a6221aSDavid Daney #define __PCI_OCTEON_H__
1101a6221aSDavid Daney 
1201a6221aSDavid Daney #include <linux/pci.h>
1301a6221aSDavid Daney 
1401a6221aSDavid Daney /*
152b5987abSDavid Daney  * The physical memory base mapped by BAR1.  256MB at the end of the
162b5987abSDavid Daney  * first 4GB.
172b5987abSDavid Daney  */
182b5987abSDavid Daney #define CVMX_PCIE_BAR1_PHYS_BASE ((1ull << 32) - (1ull << 28))
192b5987abSDavid Daney #define CVMX_PCIE_BAR1_PHYS_SIZE (1ull << 28)
202b5987abSDavid Daney 
212b5987abSDavid Daney /*
222b5987abSDavid Daney  * The RC base of BAR1.	 gen1 has a 39-bit BAR2, gen2 has 41-bit BAR2,
232b5987abSDavid Daney  * place BAR1 so it is the same for both.
242b5987abSDavid Daney  */
252b5987abSDavid Daney #define CVMX_PCIE_BAR1_RC_BASE (1ull << 41)
262b5987abSDavid Daney 
272b5987abSDavid Daney /*
2801a6221aSDavid Daney  * pcibios_map_irq() is defined inside pci-octeon.c. All it does is
2901a6221aSDavid Daney  * call the Octeon specific version pointed to by this variable. This
3001a6221aSDavid Daney  * function needs to change for PCI or PCIe based hosts.
3101a6221aSDavid Daney  */
3201a6221aSDavid Daney extern int (*octeon_pcibios_map_irq)(const struct pci_dev *dev,
3301a6221aSDavid Daney 				     u8 slot, u8 pin);
3401a6221aSDavid Daney 
3501a6221aSDavid Daney /*
36b93b2abcSDavid Daney  * For PCI (not PCIe) the BAR2 base address.
37b93b2abcSDavid Daney  */
38b93b2abcSDavid Daney #define OCTEON_BAR2_PCI_ADDRESS 0x8000000000ull
39b93b2abcSDavid Daney 
40b93b2abcSDavid Daney /*
41b93b2abcSDavid Daney  * For PCI (not PCIe) the base of the memory mapped by BAR1
42b93b2abcSDavid Daney  */
43b93b2abcSDavid Daney extern u64 octeon_bar1_pci_phys;
44b93b2abcSDavid Daney 
45b93b2abcSDavid Daney /*
4601a6221aSDavid Daney  * The following defines are used when octeon_dma_bar_type =
4701a6221aSDavid Daney  * OCTEON_DMA_BAR_TYPE_BIG
4801a6221aSDavid Daney  */
4901a6221aSDavid Daney #define OCTEON_PCI_BAR1_HOLE_BITS 5
5001a6221aSDavid Daney #define OCTEON_PCI_BAR1_HOLE_SIZE (1ul<<(OCTEON_PCI_BAR1_HOLE_BITS+3))
5101a6221aSDavid Daney 
5201a6221aSDavid Daney enum octeon_dma_bar_type {
5301a6221aSDavid Daney 	OCTEON_DMA_BAR_TYPE_INVALID,
5401a6221aSDavid Daney 	OCTEON_DMA_BAR_TYPE_SMALL,
5501a6221aSDavid Daney 	OCTEON_DMA_BAR_TYPE_BIG,
56714c1f5cSDavid Daney 	OCTEON_DMA_BAR_TYPE_PCIE,
57714c1f5cSDavid Daney 	OCTEON_DMA_BAR_TYPE_PCIE2
5801a6221aSDavid Daney };
5901a6221aSDavid Daney 
6001a6221aSDavid Daney /*
6101a6221aSDavid Daney  * This tells the DMA mapping system in dma-octeon.c how to map PCI
6201a6221aSDavid Daney  * DMA addresses.
6301a6221aSDavid Daney  */
6401a6221aSDavid Daney extern enum octeon_dma_bar_type octeon_dma_bar_type;
6501a6221aSDavid Daney 
66a330a9c5SChristoph Hellwig void octeon_pci_dma_init(void);
6701a6221aSDavid Daney #endif
68