900-ssb-reject-PCI-writes-setting-CardBus-bridge-resourc.patch 1.1 KB

123456789101112131415161718192021222324252627282930
  1. From 5c81397a0147ea59c778d1de14ef54e2268221f6 Mon Sep 17 00:00:00 2001
  2. From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <zajec5@gmail.com>
  3. Date: Wed, 8 Apr 2015 06:58:11 +0200
  4. Subject: [PATCH] ssb: reject PCI writes setting CardBus bridge resources
  5. MIME-Version: 1.0
  6. Content-Type: text/plain; charset=UTF-8
  7. Content-Transfer-Encoding: 8bit
  8. If SoC has a CardBus we can set resources of device at slot 1 only. It's
  9. impossigle to set bridge resources as it simply overwrites device 1
  10. configuration and usually results in Data bus error-s.
  11. Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
  12. ---
  13. drivers/ssb/driver_pcicore.c | 4 ++++
  14. 1 file changed, 4 insertions(+)
  15. --- a/drivers/ssb/driver_pcicore.c
  16. +++ b/drivers/ssb/driver_pcicore.c
  17. @@ -164,6 +164,10 @@ static int ssb_extpci_write_config(struc
  18. SSB_WARN_ON(!pc->hostmode);
  19. if (unlikely(len != 1 && len != 2 && len != 4))
  20. goto out;
  21. + /* CardBus SoCs allow configuring dev 1 resources only */
  22. + if (extpci_core->cardbusmode && dev != 1 &&
  23. + off >= PCI_BASE_ADDRESS_0 && off <= PCI_BASE_ADDRESS_5)
  24. + goto out;
  25. addr = get_cfgspace_addr(pc, bus, dev, func, off);
  26. if (unlikely(!addr))
  27. goto out;