summaryrefslogtreecommitdiff
path: root/arch/mips/mach-octeon/include/mach/octeon_pci.h
blob: e28f5f9ee33ed6dfdfd1edfe12e58595071430db (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright (C) 2020 Marvell International Ltd.
 */

#ifndef __OCTEON_PCI_H__
#define __OCTEON_PCI_H__

/**
 * EEPROM entry struct
 */
union octeon_pcie_eeprom {
	u64 u64;
	struct octeon_data_s {
		/**
		 * 0x9DA1 valid entry, 0x6A5D end of table, 0xffff invalid
		 * access
		 */
		u64 preamble : 16;
u64: 1; /** Reserved */
		/** Physical function number accessed by the write operation. */
		u64 pf : 2;
		/**
		 * Specifies bit<31> of the address written by hardware.
		 * 1 = configuration mask register, 0 = configuration register
		 */
		u64 cs2 : 1;
		/**
		 * Specifies bits<11:0> of the address written by hardware.
		 * Bits<30:12> of this address are all 0s.
		 */
		u64 address : 12;
		u64 data : 32;
	} s;
};

void pci_dev_post_init(void);

int octeon_pci_io_readb(unsigned int reg);
void octeon_pci_io_writeb(int value, unsigned int reg);
int octeon_pci_io_readw(unsigned int reg);
void octeon_pci_io_writew(int value, unsigned int reg);
int octeon_pci_io_readl(unsigned int reg);
void octeon_pci_io_writel(int value, unsigned int reg);
int octeon_pci_mem1_readb(unsigned int reg);
void octeon_pci_mem1_writeb(int value, unsigned int reg);
int octeon_pci_mem1_readw(unsigned int reg);
void octeon_pci_mem1_writew(int value, unsigned int reg);
int octeon_pci_mem1_readl(unsigned int reg);
void octeon_pci_mem1_writel(int value, unsigned int reg);

/* In the TLB mapped case, these also work with virtual addresses,
** and do the required virt<->phys translations as well. */
u32 octeon_pci_phys_to_bus(u32 phys);
u32 octeon_pci_bus_to_phys(u32 bus);

/**
 * Searches PCIe EEPROM for override data specified by address and pf.
 *
 * @param	address - PCIe config space address
 * @param	pf	- PCIe config space pf num
 * @param[out]	id	- override device and vendor ID
 *
 * Return:	0 if override found, 1 if not found.
 */
int octeon_find_pcie_id_override(unsigned int address, unsigned int pf, u32 *id);

#endif /* __OCTEON_PCI_H__ */