Blame view

kernel/linux-rt-4.4.41/arch/xtensa/include/asm/pci-bridge.h 2.16 KB
5113f6f70   김현기   kernel add
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
  /*
   * include/asm-xtensa/pci-bridge.h
   *
   * This file is subject to the terms and conditions of the GNU General
   * Public License.  See the file "COPYING" in the main directory of
   * this archive for more details.
   *
   * Copyright (C) 2005 Tensilica Inc.
   */
  
  #ifndef _XTENSA_PCI_BRIDGE_H
  #define _XTENSA_PCI_BRIDGE_H
  
  #ifdef __KERNEL__
  
  struct device_node;
  struct pci_controller;
  
  /*
   * pciauto_bus_scan() enumerates the pci space.
   */
  
  extern int pciauto_bus_scan(struct pci_controller *, int);
  
  struct pci_space {
  	unsigned long start;
  	unsigned long end;
  	unsigned long base;
  };
  
  /*
   * Structure of a PCI controller (host bridge)
   */
  
  struct pci_controller {
  	int index;			/* used for pci_controller_num */
  	struct pci_controller *next;
  	struct pci_bus *bus;
  	void *arch_data;
  
  	int first_busno;
  	int last_busno;
  
  	struct pci_ops *ops;
  	volatile unsigned int *cfg_addr;
  	volatile unsigned char *cfg_data;
  
  	/* Currently, we limit ourselves to 1 IO range and 3 mem
  	 * ranges since the common pci_bus structure can't handle more
  	 */
  	struct resource	io_resource;
  	struct resource mem_resources[3];
  	int mem_resource_count;
  
  	/* Host bridge I/O and Memory space
  	 * Used for BAR placement algorithms
  	 */
  	struct pci_space io_space;
  	struct pci_space mem_space;
  
  	/* Return the interrupt number fo a device. */
  	int (*map_irq)(struct pci_dev*, u8, u8);
  
  };
  
  static inline void pcibios_init_resource(struct resource *res,
  		unsigned long start, unsigned long end, int flags, char *name)
  {
  	res->start = start;
  	res->end = end;
  	res->flags = flags;
  	res->name = name;
  	res->parent = NULL;
  	res->sibling = NULL;
  	res->child = NULL;
  }
  
  
  /* These are used for config access before all the PCI probing has been done. */
  int early_read_config_byte(struct pci_controller*, int, int, int, u8*);
  int early_read_config_word(struct pci_controller*, int, int, int, u16*);
  int early_read_config_dword(struct pci_controller*, int, int, int, u32*);
  int early_write_config_byte(struct pci_controller*, int, int, int, u8);
  int early_write_config_word(struct pci_controller*, int, int, int, u16);
  int early_write_config_dword(struct pci_controller*, int, int, int, u32);
  
  #endif	/* __KERNEL__ */
  #endif	/* _XTENSA_PCI_BRIDGE_H */