aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pci/hotplug/pciehp.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/pci/hotplug/pciehp.h')
-rw-r--r--drivers/pci/hotplug/pciehp.h44
1 files changed, 22 insertions, 22 deletions
diff --git a/drivers/pci/hotplug/pciehp.h b/drivers/pci/hotplug/pciehp.h
index 3e17e3d4dd65..314989a3a933 100644
--- a/drivers/pci/hotplug/pciehp.h
+++ b/drivers/pci/hotplug/pciehp.h
@@ -32,8 +32,6 @@
32#include <linux/types.h> 32#include <linux/types.h>
33#include <linux/pci.h> 33#include <linux/pci.h>
34#include <linux/delay.h> 34#include <linux/delay.h>
35#include <asm/semaphore.h>
36#include <asm/io.h>
37#include <linux/pcieport_if.h> 35#include <linux/pcieport_if.h>
38#include "pci_hotplug.h" 36#include "pci_hotplug.h"
39 37
@@ -62,13 +60,7 @@ struct slot {
62 u8 device; 60 u8 device;
63 u16 status; 61 u16 status;
64 u32 number; 62 u32 number;
65 u8 is_a_board;
66 u8 configured;
67 u8 state; 63 u8 state;
68 u8 switch_save;
69 u8 presence_save;
70 u32 capabilities;
71 u16 reserved2;
72 struct timer_list task_event; 64 struct timer_list task_event;
73 u8 hp_slot; 65 u8 hp_slot;
74 struct controller *ctrl; 66 struct controller *ctrl;
@@ -82,27 +74,42 @@ struct event_info {
82 u8 hp_slot; 74 u8 hp_slot;
83}; 75};
84 76
77typedef u8(*php_intr_callback_t) (u8 hp_slot, void *instance_id);
78
79struct php_ctlr_state_s {
80 struct php_ctlr_state_s *pnext;
81 struct pci_dev *pci_dev;
82 unsigned int irq;
83 unsigned long flags; /* spinlock's */
84 u32 slot_device_offset;
85 u32 num_slots;
86 struct timer_list int_poll_timer; /* Added for poll event */
87 php_intr_callback_t attention_button_callback;
88 php_intr_callback_t switch_change_callback;
89 php_intr_callback_t presence_change_callback;
90 php_intr_callback_t power_fault_callback;
91 void *callback_instance_id;
92 struct ctrl_reg *creg; /* Ptr to controller register space */
93};
94
95#define MAX_EVENTS 10
85struct controller { 96struct controller {
86 struct controller *next; 97 struct controller *next;
87 struct semaphore crit_sect; /* critical section semaphore */ 98 struct semaphore crit_sect; /* critical section semaphore */
88 void *hpc_ctlr_handle; /* HPC controller handle */ 99 struct php_ctlr_state_s *hpc_ctlr_handle; /* HPC controller handle */
89 int num_slots; /* Number of slots on ctlr */ 100 int num_slots; /* Number of slots on ctlr */
90 int slot_num_inc; /* 1 or -1 */ 101 int slot_num_inc; /* 1 or -1 */
91 struct pci_dev *pci_dev; 102 struct pci_dev *pci_dev;
92 struct pci_bus *pci_bus; 103 struct pci_bus *pci_bus;
93 struct event_info event_queue[10]; 104 struct event_info event_queue[MAX_EVENTS];
94 struct slot *slot; 105 struct slot *slot;
95 struct hpc_ops *hpc_ops; 106 struct hpc_ops *hpc_ops;
96 wait_queue_head_t queue; /* sleep & wake process */ 107 wait_queue_head_t queue; /* sleep & wake process */
97 u8 next_event; 108 u8 next_event;
98 u8 seg;
99 u8 bus; 109 u8 bus;
100 u8 device; 110 u8 device;
101 u8 function; 111 u8 function;
102 u8 rev;
103 u8 slot_device_offset; 112 u8 slot_device_offset;
104 u8 add_support;
105 enum pci_bus_speed speed;
106 u32 first_slot; /* First physical slot number */ /* PCIE only has 1 slot */ 113 u32 first_slot; /* First physical slot number */ /* PCIE only has 1 slot */
107 u8 slot_bus; /* Bus where the slots handled by this controller sit */ 114 u8 slot_bus; /* Bus where the slots handled by this controller sit */
108 u8 ctrlcap; 115 u8 ctrlcap;
@@ -250,14 +257,7 @@ enum php_ctlr_type {
250 ACPI 257 ACPI
251}; 258};
252 259
253typedef u8(*php_intr_callback_t) (unsigned int change_id, void *instance_id); 260int pcie_init(struct controller *ctrl, struct pcie_device *dev);
254
255int pcie_init(struct controller *ctrl, struct pcie_device *dev,
256 php_intr_callback_t attention_button_callback,
257 php_intr_callback_t switch_change_callback,
258 php_intr_callback_t presence_change_callback,
259 php_intr_callback_t power_fault_callback);
260
261 261
262/* This has no meaning for PCI Express, as there is only 1 slot per port */ 262/* This has no meaning for PCI Express, as there is only 1 slot per port */
263int pcie_get_ctlr_slot_config(struct controller *ctrl, 263int pcie_get_ctlr_slot_config(struct controller *ctrl,