2 * Copyright 2014 IBM Corp.
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version
7 * 2 of the License, or (at your option) any later version.
10 #include <linux/pci.h>
14 static int cxl_dma_set_mask(struct pci_dev
*pdev
, u64 dma_mask
)
16 if (dma_mask
< DMA_BIT_MASK(64)) {
17 pr_info("%s only 64bit DMA supported on CXL", __func__
);
21 *(pdev
->dev
.dma_mask
) = dma_mask
;
25 static int cxl_pci_probe_mode(struct pci_bus
*bus
)
27 return PCI_PROBE_NORMAL
;
30 static int cxl_setup_msi_irqs(struct pci_dev
*pdev
, int nvec
, int type
)
35 static void cxl_teardown_msi_irqs(struct pci_dev
*pdev
)
38 * MSI should never be set but need still need to provide this call
43 static bool cxl_pci_enable_device_hook(struct pci_dev
*dev
)
45 struct pci_controller
*phb
;
47 struct cxl_context
*ctx
;
49 phb
= pci_bus_to_host(dev
->bus
);
50 afu
= (struct cxl_afu
*)phb
->private_data
;
51 set_dma_ops(&dev
->dev
, &dma_direct_ops
);
52 set_dma_offset(&dev
->dev
, PAGE_OFFSET
);
55 * Allocate a context to do cxl things too. If we eventually do real
56 * DMA ops, we'll need a default context to attach them to
58 ctx
= cxl_dev_context_init(dev
);
61 dev
->dev
.archdata
.cxl_ctx
= ctx
;
63 return (cxl_afu_check_and_enable(afu
) == 0);
66 static void cxl_pci_disable_device(struct pci_dev
*dev
)
68 struct cxl_context
*ctx
= cxl_get_context(dev
);
71 if (ctx
->status
== STARTED
) {
72 dev_err(&dev
->dev
, "Default context started\n");
75 dev
->dev
.archdata
.cxl_ctx
= NULL
;
76 cxl_release_context(ctx
);
80 static resource_size_t
cxl_pci_window_alignment(struct pci_bus
*bus
,
86 static void cxl_pci_reset_secondary_bus(struct pci_dev
*dev
)
88 /* Should we do an AFU reset here ? */
91 static int cxl_pcie_cfg_record(u8 bus
, u8 devfn
)
93 return (bus
<< 8) + devfn
;
96 static unsigned long cxl_pcie_cfg_addr(struct pci_controller
* phb
,
97 u8 bus
, u8 devfn
, int offset
)
99 int record
= cxl_pcie_cfg_record(bus
, devfn
);
101 return (unsigned long)phb
->cfg_addr
+ ((unsigned long)phb
->cfg_data
* record
) + offset
;
105 static int cxl_pcie_config_info(struct pci_bus
*bus
, unsigned int devfn
,
107 volatile void __iomem
**ioaddr
,
108 u32
*mask
, int *shift
)
110 struct pci_controller
*phb
;
114 phb
= pci_bus_to_host(bus
);
116 return PCIBIOS_DEVICE_NOT_FOUND
;
117 afu
= (struct cxl_afu
*)phb
->private_data
;
119 if (cxl_pcie_cfg_record(bus
->number
, devfn
) > afu
->crs_num
)
120 return PCIBIOS_DEVICE_NOT_FOUND
;
121 if (offset
>= (unsigned long)phb
->cfg_data
)
122 return PCIBIOS_BAD_REGISTER_NUMBER
;
123 addr
= cxl_pcie_cfg_addr(phb
, bus
->number
, devfn
, offset
);
125 *ioaddr
= (void *)(addr
& ~0x3ULL
);
126 *shift
= ((addr
& 0x3) * 8);
142 static inline bool cxl_config_link_ok(struct pci_bus
*bus
)
144 struct pci_controller
*phb
;
147 /* Config space IO is based on phb->cfg_addr, which is based on
148 * afu_desc_mmio. This isn't safe to read/write when the link
149 * goes down, as EEH tears down MMIO space.
151 * Check if the link is OK before proceeding.
154 phb
= pci_bus_to_host(bus
);
157 afu
= (struct cxl_afu
*)phb
->private_data
;
158 return cxl_adapter_link_ok(afu
->adapter
);
161 static int cxl_pcie_read_config(struct pci_bus
*bus
, unsigned int devfn
,
162 int offset
, int len
, u32
*val
)
164 volatile void __iomem
*ioaddr
;
168 rc
= cxl_pcie_config_info(bus
, devfn
, offset
, len
, &ioaddr
,
173 if (!cxl_config_link_ok(bus
))
174 return PCIBIOS_DEVICE_NOT_FOUND
;
176 /* Can only read 32 bits */
177 *val
= (in_le32(ioaddr
) >> shift
) & mask
;
178 return PCIBIOS_SUCCESSFUL
;
181 static int cxl_pcie_write_config(struct pci_bus
*bus
, unsigned int devfn
,
182 int offset
, int len
, u32 val
)
184 volatile void __iomem
*ioaddr
;
188 rc
= cxl_pcie_config_info(bus
, devfn
, offset
, len
, &ioaddr
,
193 if (!cxl_config_link_ok(bus
))
194 return PCIBIOS_DEVICE_NOT_FOUND
;
196 /* Can only write 32 bits so do read-modify-write */
200 v
= (in_le32(ioaddr
) & ~mask
) || (val
& mask
);
203 return PCIBIOS_SUCCESSFUL
;
206 static struct pci_ops cxl_pcie_pci_ops
=
208 .read
= cxl_pcie_read_config
,
209 .write
= cxl_pcie_write_config
,
213 static struct pci_controller_ops cxl_pci_controller_ops
=
215 .probe_mode
= cxl_pci_probe_mode
,
216 .enable_device_hook
= cxl_pci_enable_device_hook
,
217 .disable_device
= cxl_pci_disable_device
,
218 .release_device
= cxl_pci_disable_device
,
219 .window_alignment
= cxl_pci_window_alignment
,
220 .reset_secondary_bus
= cxl_pci_reset_secondary_bus
,
221 .setup_msi_irqs
= cxl_setup_msi_irqs
,
222 .teardown_msi_irqs
= cxl_teardown_msi_irqs
,
223 .dma_set_mask
= cxl_dma_set_mask
,
226 int cxl_pci_vphb_add(struct cxl_afu
*afu
)
228 struct pci_dev
*phys_dev
;
229 struct pci_controller
*phb
, *phys_phb
;
231 phys_dev
= to_pci_dev(afu
->adapter
->dev
.parent
);
232 phys_phb
= pci_bus_to_host(phys_dev
->bus
);
234 /* Alloc and setup PHB data structure */
235 phb
= pcibios_alloc_controller(phys_phb
->dn
);
240 /* Setup parent in sysfs */
241 phb
->parent
= &phys_dev
->dev
;
243 /* Setup the PHB using arch provided callback */
244 phb
->ops
= &cxl_pcie_pci_ops
;
245 phb
->cfg_addr
= afu
->afu_desc_mmio
+ afu
->crs_offset
;
246 phb
->cfg_data
= (void *)(u64
)afu
->crs_len
;
247 phb
->private_data
= afu
;
248 phb
->controller_ops
= cxl_pci_controller_ops
;
251 pcibios_scan_phb(phb
);
252 if (phb
->bus
== NULL
)
255 /* Claim resources. This might need some rework as well depending
256 * whether we are doing probe-only or not, like assigning unassigned
259 pcibios_claim_one_bus(phb
->bus
);
261 /* Add probed PCI devices to the device model */
262 pci_bus_add_devices(phb
->bus
);
269 void cxl_pci_vphb_reconfigure(struct cxl_afu
*afu
)
271 /* When we are reconfigured, the AFU's MMIO space is unmapped
272 * and remapped. We need to reflect this in the PHB's view of
275 afu
->phb
->cfg_addr
= afu
->afu_desc_mmio
+ afu
->crs_offset
;
278 void cxl_pci_vphb_remove(struct cxl_afu
*afu
)
280 struct pci_controller
*phb
;
282 /* If there is no configuration record we won't have one of these */
283 if (!afu
|| !afu
->phb
)
288 pci_remove_root_bus(phb
->bus
);
291 struct cxl_afu
*cxl_pci_to_afu(struct pci_dev
*dev
)
293 struct pci_controller
*phb
;
295 phb
= pci_bus_to_host(dev
->bus
);
297 return (struct cxl_afu
*)phb
->private_data
;
299 EXPORT_SYMBOL_GPL(cxl_pci_to_afu
);
301 unsigned int cxl_pci_to_cfg_record(struct pci_dev
*dev
)
303 return cxl_pcie_cfg_record(dev
->bus
->number
, dev
->devfn
);
305 EXPORT_SYMBOL_GPL(cxl_pci_to_cfg_record
);