0009-ioremap_uc.patch 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. From 9c0380701b988307a75832e0eb1c083291fddc7c Mon Sep 17 00:00:00 2001
  2. From: Tuowen Zhao <ztuowen@gmail.com>
  3. Date: Wed, 16 Oct 2019 15:06:28 -0600
  4. Subject: [PATCH 09/10] ioremap_uc
  5. ---
  6. .../driver-api/driver-model/devres.rst | 1 +
  7. drivers/mfd/intel-lpss.c | 2 +-
  8. include/linux/io.h | 2 ++
  9. lib/devres.c | 19 +++++++++++++++++++
  10. 4 files changed, 23 insertions(+), 1 deletion(-)
  11. diff --git a/Documentation/driver-api/driver-model/devres.rst b/Documentation/driver-api/driver-model/devres.rst
  12. index a100bef54952..92628fdc2f11 100644
  13. --- a/Documentation/driver-api/driver-model/devres.rst
  14. +++ b/Documentation/driver-api/driver-model/devres.rst
  15. @@ -314,6 +314,7 @@ IOMAP
  16. devm_ioport_unmap()
  17. devm_ioremap()
  18. devm_ioremap_nocache()
  19. + devm_ioremap_uc()
  20. devm_ioremap_wc()
  21. devm_ioremap_resource() : checks resource, requests memory region, ioremaps
  22. devm_iounmap()
  23. diff --git a/drivers/mfd/intel-lpss.c b/drivers/mfd/intel-lpss.c
  24. index 277f48f1cc1c..06106c9320bb 100644
  25. --- a/drivers/mfd/intel-lpss.c
  26. +++ b/drivers/mfd/intel-lpss.c
  27. @@ -395,7 +395,7 @@ int intel_lpss_probe(struct device *dev,
  28. if (!lpss)
  29. return -ENOMEM;
  30. - lpss->priv = devm_ioremap(dev, info->mem->start + LPSS_PRIV_OFFSET,
  31. + lpss->priv = devm_ioremap_uc(dev, info->mem->start + LPSS_PRIV_OFFSET,
  32. LPSS_PRIV_SIZE);
  33. if (!lpss->priv)
  34. return -ENOMEM;
  35. diff --git a/include/linux/io.h b/include/linux/io.h
  36. index accac822336a..a59834bc0a11 100644
  37. --- a/include/linux/io.h
  38. +++ b/include/linux/io.h
  39. @@ -64,6 +64,8 @@ static inline void devm_ioport_unmap(struct device *dev, void __iomem *addr)
  40. void __iomem *devm_ioremap(struct device *dev, resource_size_t offset,
  41. resource_size_t size);
  42. +void __iomem *devm_ioremap_uc(struct device *dev, resource_size_t offset,
  43. + resource_size_t size);
  44. void __iomem *devm_ioremap_nocache(struct device *dev, resource_size_t offset,
  45. resource_size_t size);
  46. void __iomem *devm_ioremap_wc(struct device *dev, resource_size_t offset,
  47. diff --git a/lib/devres.c b/lib/devres.c
  48. index 6a0e9bd6524a..17624d35e82d 100644
  49. --- a/lib/devres.c
  50. +++ b/lib/devres.c
  51. @@ -9,6 +9,7 @@
  52. enum devm_ioremap_type {
  53. DEVM_IOREMAP = 0,
  54. DEVM_IOREMAP_NC,
  55. + DEVM_IOREMAP_UC,
  56. DEVM_IOREMAP_WC,
  57. };
  58. @@ -39,6 +40,9 @@ static void __iomem *__devm_ioremap(struct device *dev, resource_size_t offset,
  59. case DEVM_IOREMAP_NC:
  60. addr = ioremap_nocache(offset, size);
  61. break;
  62. + case DEVM_IOREMAP_UC:
  63. + addr = ioremap_uc(offset, size);
  64. + break;
  65. case DEVM_IOREMAP_WC:
  66. addr = ioremap_wc(offset, size);
  67. break;
  68. @@ -68,6 +72,21 @@ void __iomem *devm_ioremap(struct device *dev, resource_size_t offset,
  69. }
  70. EXPORT_SYMBOL(devm_ioremap);
  71. +/**
  72. + * devm_ioremap_uc - Managed ioremap_uc()
  73. + * @dev: Generic device to remap IO address for
  74. + * @offset: Resource address to map
  75. + * @size: Size of map
  76. + *
  77. + * Managed ioremap_uc(). Map is automatically unmapped on driver detach.
  78. + */
  79. +void __iomem *devm_ioremap_uc(struct device *dev, resource_size_t offset,
  80. + resource_size_t size)
  81. +{
  82. + return __devm_ioremap(dev, offset, size, DEVM_IOREMAP_UC);
  83. +}
  84. +EXPORT_SYMBOL_GPL(devm_ioremap_uc);
  85. +
  86. /**
  87. * devm_ioremap_nocache - Managed ioremap_nocache()
  88. * @dev: Generic device to remap IO address for
  89. --
  90. 2.24.1