blob: b69769dbf6597ada1960403ceaa370a75a6303d0 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * File: pcieport_if.h
4 * Purpose: PCI Express Port Bus Driver's IF Data Structure
5 *
6 * Copyright (C) 2004 Intel
7 * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
8 */
9
10#ifndef _PCIEPORT_IF_H_
11#define _PCIEPORT_IF_H_
12
13/* Port Type */
Kenji Kaneshige694f88e2009-11-25 21:06:15 +090014#define PCIE_ANY_PORT (~0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070015
16/* Service Type */
Rafael J. Wysockib43d4512009-01-24 00:23:22 +010017#define PCIE_PORT_SERVICE_PME_SHIFT 0 /* Power Management Event */
18#define PCIE_PORT_SERVICE_PME (1 << PCIE_PORT_SERVICE_PME_SHIFT)
19#define PCIE_PORT_SERVICE_AER_SHIFT 1 /* Advanced Error Reporting */
20#define PCIE_PORT_SERVICE_AER (1 << PCIE_PORT_SERVICE_AER_SHIFT)
21#define PCIE_PORT_SERVICE_HP_SHIFT 2 /* Native Hotplug */
22#define PCIE_PORT_SERVICE_HP (1 << PCIE_PORT_SERVICE_HP_SHIFT)
23#define PCIE_PORT_SERVICE_VC_SHIFT 3 /* Virtual Channel */
24#define PCIE_PORT_SERVICE_VC (1 << PCIE_PORT_SERVICE_VC_SHIFT)
Keith Busch10126ac2016-05-02 15:10:31 -050025#define PCIE_PORT_SERVICE_DPC_SHIFT 4 /* Downstream Port Containment */
26#define PCIE_PORT_SERVICE_DPC (1 << PCIE_PORT_SERVICE_DPC_SHIFT)
Linus Torvalds1da177e2005-04-16 15:20:36 -070027
Linus Torvalds1da177e2005-04-16 15:20:36 -070028struct pcie_device {
Bjorn Helgaasf7625982013-11-14 11:28:18 -070029 int irq; /* Service IRQ/MSI/MSI-X Vector */
Rafael J. Wysocki22106362009-01-13 14:46:46 +010030 struct pci_dev *port; /* Root/Upstream/Downstream Port */
31 u32 service; /* Port service this device represents */
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 void *priv_data; /* Service Private Data */
33 struct device device; /* Generic Device Interface */
34};
35#define to_pcie_device(d) container_of(d, struct pcie_device, device)
36
37static inline void set_service_data(struct pcie_device *dev, void *data)
38{
39 dev->priv_data = data;
40}
41
Bjorn Helgaas96291d52017-09-01 16:35:50 -050042static inline void *get_service_data(struct pcie_device *dev)
Linus Torvalds1da177e2005-04-16 15:20:36 -070043{
44 return dev->priv_data;
45}
46
47struct pcie_port_service_driver {
48 const char *name;
Rafael J. Wysocki0516c8b2009-01-13 14:44:19 +010049 int (*probe) (struct pcie_device *dev);
Linus Torvalds1da177e2005-04-16 15:20:36 -070050 void (*remove) (struct pcie_device *dev);
Rafael J. Wysocki3a3c2442009-02-15 22:32:48 +010051 int (*suspend) (struct pcie_device *dev);
Linus Torvalds1da177e2005-04-16 15:20:36 -070052 int (*resume) (struct pcie_device *dev);
53
Christoph Hellwigc5dc3c62017-06-19 20:04:58 +020054 /* Device driver may resume normal operations */
55 void (*error_resume)(struct pci_dev *dev);
Zhang, Yanmin6c2b3742006-07-31 15:21:33 +080056
57 /* Link Reset Capability - AER service driver specific */
58 pci_ers_result_t (*reset_link) (struct pci_dev *dev);
59
Rafael J. Wysocki22106362009-01-13 14:46:46 +010060 int port_type; /* Type of the port this driver can handle */
61 u32 service; /* Port service this device represents */
62
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 struct device_driver driver;
64};
65#define to_service_driver(d) \
66 container_of(d, struct pcie_port_service_driver, driver)
67
Bjorn Helgaasf39d5b72013-04-12 12:02:59 -060068int pcie_port_service_register(struct pcie_port_service_driver *new);
69void pcie_port_service_unregister(struct pcie_port_service_driver *new);
Linus Torvalds1da177e2005-04-16 15:20:36 -070070
71#endif /* _PCIEPORT_IF_H_ */