aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNiklas Cassel <niklas.cassel@axis.com>2018-03-28 07:50:06 -0400
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>2018-04-03 07:23:30 -0400
commitbf597574b6bee5ac741c58da763ad2f10df19065 (patch)
tree1b8f2ed4615897891dfd8a974f8a94e0e2c658d7
parent50ee106137f2947958b2931de853010582e9d719 (diff)
PCI: endpoint: BAR width should not depend on sizeof dma_addr_t
If a BAR supports 64-bit width or not depends on the hardware, and should thus not depend on sizeof(dma_addr_t). If a certain hardware doesn't support 64-bit BARs, its epc->ops->set_bar() implementation should return -EINVAL when PCI_BASE_ADDRESS_MEM_TYPE_64 is set. We can't change pci_epc_set_bar() to only set PCI_BASE_ADDRESS_MEM_TYPE_64 based on size, since if the user, for some reason, wants to configure a BAR with a 64-bit width, even though the BAR size is less than 4 GB, he should be able to do that. However, since pci-epf-test is simply a test and not an API, we can set PCI_BASE_ADDRESS_MEM_TYPE_64 in pci-epf-test itself only based on size. Signed-off-by: Niklas Cassel <niklas.cassel@axis.com> Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Acked-by: Kishon Vijay Abraham I <kishon@ti.com>
-rw-r--r--drivers/pci/endpoint/functions/pci-epf-test.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/pci/endpoint/functions/pci-epf-test.c b/drivers/pci/endpoint/functions/pci-epf-test.c
index 64d8a17f8094..f6c0c59b1bc8 100644
--- a/drivers/pci/endpoint/functions/pci-epf-test.c
+++ b/drivers/pci/endpoint/functions/pci-epf-test.c
@@ -70,7 +70,7 @@ struct pci_epf_test_data {
70 bool linkup_notifier; 70 bool linkup_notifier;
71}; 71};
72 72
73static int bar_size[] = { 512, 512, 1024, 16384, 131072, 1048576 }; 73static size_t bar_size[] = { 512, 512, 1024, 16384, 131072, 1048576 };
74 74
75static int pci_epf_test_copy(struct pci_epf_test *epf_test) 75static int pci_epf_test_copy(struct pci_epf_test *epf_test)
76{ 76{
@@ -367,12 +367,14 @@ static int pci_epf_test_set_bar(struct pci_epf *epf)
367 struct pci_epf_test *epf_test = epf_get_drvdata(epf); 367 struct pci_epf_test *epf_test = epf_get_drvdata(epf);
368 enum pci_barno test_reg_bar = epf_test->test_reg_bar; 368 enum pci_barno test_reg_bar = epf_test->test_reg_bar;
369 369
370 flags = PCI_BASE_ADDRESS_SPACE_MEMORY | PCI_BASE_ADDRESS_MEM_TYPE_32;
371 if (sizeof(dma_addr_t) == 0x8)
372 flags |= PCI_BASE_ADDRESS_MEM_TYPE_64;
373
374 for (bar = BAR_0; bar <= BAR_5; bar++) { 370 for (bar = BAR_0; bar <= BAR_5; bar++) {
375 epf_bar = &epf->bar[bar]; 371 epf_bar = &epf->bar[bar];
372
373 flags = PCI_BASE_ADDRESS_SPACE_MEMORY;
374 flags |= upper_32_bits(epf_bar->size) ?
375 PCI_BASE_ADDRESS_MEM_TYPE_64 :
376 PCI_BASE_ADDRESS_MEM_TYPE_32;
377
376 ret = pci_epc_set_bar(epc, epf->func_no, bar, 378 ret = pci_epc_set_bar(epc, epf->func_no, bar,
377 epf_bar->phys_addr, 379 epf_bar->phys_addr,
378 epf_bar->size, flags); 380 epf_bar->size, flags);