.. | .. |
---|
8 | 8 | |
---|
9 | 9 | enum devm_ioremap_type { |
---|
10 | 10 | DEVM_IOREMAP = 0, |
---|
11 | | - DEVM_IOREMAP_NC, |
---|
12 | 11 | DEVM_IOREMAP_UC, |
---|
13 | 12 | DEVM_IOREMAP_WC, |
---|
14 | 13 | }; |
---|
.. | .. |
---|
36 | 35 | switch (type) { |
---|
37 | 36 | case DEVM_IOREMAP: |
---|
38 | 37 | addr = ioremap(offset, size); |
---|
39 | | - break; |
---|
40 | | - case DEVM_IOREMAP_NC: |
---|
41 | | - addr = ioremap_nocache(offset, size); |
---|
42 | 38 | break; |
---|
43 | 39 | case DEVM_IOREMAP_UC: |
---|
44 | 40 | addr = ioremap_uc(offset, size); |
---|
.. | .. |
---|
88 | 84 | EXPORT_SYMBOL_GPL(devm_ioremap_uc); |
---|
89 | 85 | |
---|
90 | 86 | /** |
---|
91 | | - * devm_ioremap_nocache - Managed ioremap_nocache() |
---|
92 | | - * @dev: Generic device to remap IO address for |
---|
93 | | - * @offset: Resource address to map |
---|
94 | | - * @size: Size of map |
---|
95 | | - * |
---|
96 | | - * Managed ioremap_nocache(). Map is automatically unmapped on driver |
---|
97 | | - * detach. |
---|
98 | | - */ |
---|
99 | | -void __iomem *devm_ioremap_nocache(struct device *dev, resource_size_t offset, |
---|
100 | | - resource_size_t size) |
---|
101 | | -{ |
---|
102 | | - return __devm_ioremap(dev, offset, size, DEVM_IOREMAP_NC); |
---|
103 | | -} |
---|
104 | | -EXPORT_SYMBOL(devm_ioremap_nocache); |
---|
105 | | - |
---|
106 | | -/** |
---|
107 | 87 | * devm_ioremap_wc - Managed ioremap_wc() |
---|
108 | 88 | * @dev: Generic device to remap IO address for |
---|
109 | 89 | * @offset: Resource address to map |
---|
.. | .. |
---|
133 | 113 | } |
---|
134 | 114 | EXPORT_SYMBOL(devm_iounmap); |
---|
135 | 115 | |
---|
136 | | -/** |
---|
137 | | - * devm_ioremap_resource() - check, request region, and ioremap resource |
---|
138 | | - * @dev: generic device to handle the resource for |
---|
139 | | - * @res: resource to be handled |
---|
140 | | - * |
---|
141 | | - * Checks that a resource is a valid memory region, requests the memory |
---|
142 | | - * region and ioremaps it. All operations are managed and will be undone |
---|
143 | | - * on driver detach. |
---|
144 | | - * |
---|
145 | | - * Returns a pointer to the remapped memory or an ERR_PTR() encoded error code |
---|
146 | | - * on failure. Usage example: |
---|
147 | | - * |
---|
148 | | - * res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
---|
149 | | - * base = devm_ioremap_resource(&pdev->dev, res); |
---|
150 | | - * if (IS_ERR(base)) |
---|
151 | | - * return PTR_ERR(base); |
---|
152 | | - */ |
---|
153 | | -void __iomem *devm_ioremap_resource(struct device *dev, |
---|
154 | | - const struct resource *res) |
---|
| 116 | +static void __iomem * |
---|
| 117 | +__devm_ioremap_resource(struct device *dev, const struct resource *res, |
---|
| 118 | + enum devm_ioremap_type type) |
---|
155 | 119 | { |
---|
156 | 120 | resource_size_t size; |
---|
157 | | - const char *name; |
---|
158 | 121 | void __iomem *dest_ptr; |
---|
| 122 | + char *pretty_name; |
---|
159 | 123 | |
---|
160 | 124 | BUG_ON(!dev); |
---|
161 | 125 | |
---|
.. | .. |
---|
165 | 129 | } |
---|
166 | 130 | |
---|
167 | 131 | size = resource_size(res); |
---|
168 | | - name = res->name ?: dev_name(dev); |
---|
169 | 132 | |
---|
170 | | - if (!devm_request_mem_region(dev, res->start, size, name)) { |
---|
| 133 | + if (res->name) |
---|
| 134 | + pretty_name = devm_kasprintf(dev, GFP_KERNEL, "%s %s", |
---|
| 135 | + dev_name(dev), res->name); |
---|
| 136 | + else |
---|
| 137 | + pretty_name = devm_kstrdup(dev, dev_name(dev), GFP_KERNEL); |
---|
| 138 | + if (!pretty_name) |
---|
| 139 | + return IOMEM_ERR_PTR(-ENOMEM); |
---|
| 140 | + |
---|
| 141 | + if (!devm_request_mem_region(dev, res->start, size, pretty_name)) { |
---|
171 | 142 | dev_err(dev, "can't request region for resource %pR\n", res); |
---|
172 | 143 | return IOMEM_ERR_PTR(-EBUSY); |
---|
173 | 144 | } |
---|
174 | 145 | |
---|
175 | | - dest_ptr = devm_ioremap(dev, res->start, size); |
---|
| 146 | + dest_ptr = __devm_ioremap(dev, res->start, size, type); |
---|
176 | 147 | if (!dest_ptr) { |
---|
177 | 148 | dev_err(dev, "ioremap failed for resource %pR\n", res); |
---|
178 | 149 | devm_release_mem_region(dev, res->start, size); |
---|
.. | .. |
---|
181 | 152 | |
---|
182 | 153 | return dest_ptr; |
---|
183 | 154 | } |
---|
| 155 | + |
---|
| 156 | +/** |
---|
| 157 | + * devm_ioremap_resource() - check, request region, and ioremap resource |
---|
| 158 | + * @dev: generic device to handle the resource for |
---|
| 159 | + * @res: resource to be handled |
---|
| 160 | + * |
---|
| 161 | + * Checks that a resource is a valid memory region, requests the memory |
---|
| 162 | + * region and ioremaps it. All operations are managed and will be undone |
---|
| 163 | + * on driver detach. |
---|
| 164 | + * |
---|
| 165 | + * Usage example: |
---|
| 166 | + * |
---|
| 167 | + * res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
---|
| 168 | + * base = devm_ioremap_resource(&pdev->dev, res); |
---|
| 169 | + * if (IS_ERR(base)) |
---|
| 170 | + * return PTR_ERR(base); |
---|
| 171 | + * |
---|
| 172 | + * Return: a pointer to the remapped memory or an ERR_PTR() encoded error code |
---|
| 173 | + * on failure. |
---|
| 174 | + */ |
---|
| 175 | +void __iomem *devm_ioremap_resource(struct device *dev, |
---|
| 176 | + const struct resource *res) |
---|
| 177 | +{ |
---|
| 178 | + return __devm_ioremap_resource(dev, res, DEVM_IOREMAP); |
---|
| 179 | +} |
---|
184 | 180 | EXPORT_SYMBOL(devm_ioremap_resource); |
---|
| 181 | + |
---|
| 182 | +/** |
---|
| 183 | + * devm_ioremap_resource_wc() - write-combined variant of |
---|
| 184 | + * devm_ioremap_resource() |
---|
| 185 | + * @dev: generic device to handle the resource for |
---|
| 186 | + * @res: resource to be handled |
---|
| 187 | + * |
---|
| 188 | + * Return: a pointer to the remapped memory or an ERR_PTR() encoded error code |
---|
| 189 | + * on failure. |
---|
| 190 | + */ |
---|
| 191 | +void __iomem *devm_ioremap_resource_wc(struct device *dev, |
---|
| 192 | + const struct resource *res) |
---|
| 193 | +{ |
---|
| 194 | + return __devm_ioremap_resource(dev, res, DEVM_IOREMAP_WC); |
---|
| 195 | +} |
---|
185 | 196 | |
---|
186 | 197 | /* |
---|
187 | 198 | * devm_of_iomap - Requests a resource and maps the memory mapped IO |
---|
.. | .. |
---|
198 | 209 | * @node: The device-tree node where the resource resides |
---|
199 | 210 | * @index: index of the MMIO range in the "reg" property |
---|
200 | 211 | * @size: Returns the size of the resource (pass NULL if not needed) |
---|
201 | | - * Returns a pointer to the requested and mapped memory or an ERR_PTR() encoded |
---|
202 | | - * error code on failure. Usage example: |
---|
| 212 | + * |
---|
| 213 | + * Usage example: |
---|
203 | 214 | * |
---|
204 | 215 | * base = devm_of_iomap(&pdev->dev, node, 0, NULL); |
---|
205 | 216 | * if (IS_ERR(base)) |
---|
206 | 217 | * return PTR_ERR(base); |
---|
| 218 | + * |
---|
| 219 | + * Please Note: This is not a one-to-one replacement for of_iomap() because the |
---|
| 220 | + * of_iomap() function does not track whether the region is already mapped. If |
---|
| 221 | + * two drivers try to map the same memory, the of_iomap() function will succeed |
---|
| 222 | + * but the devm_of_iomap() function will return -EBUSY. |
---|
| 223 | + * |
---|
| 224 | + * Return: a pointer to the requested and mapped memory or an ERR_PTR() encoded |
---|
| 225 | + * error code on failure. |
---|
207 | 226 | */ |
---|
208 | 227 | void __iomem *devm_of_iomap(struct device *dev, struct device_node *node, int index, |
---|
209 | 228 | resource_size_t *size) |
---|
.. | .. |
---|
241 | 260 | * |
---|
242 | 261 | * Managed ioport_map(). Map is automatically unmapped on driver |
---|
243 | 262 | * detach. |
---|
| 263 | + * |
---|
| 264 | + * Return: a pointer to the remapped memory or NULL on failure. |
---|
244 | 265 | */ |
---|
245 | 266 | void __iomem *devm_ioport_map(struct device *dev, unsigned long port, |
---|
246 | 267 | unsigned int nr) |
---|
.. | .. |
---|
283 | 304 | /* |
---|
284 | 305 | * PCI iomap devres |
---|
285 | 306 | */ |
---|
286 | | -#define PCIM_IOMAP_MAX PCI_ROM_RESOURCE |
---|
| 307 | +#define PCIM_IOMAP_MAX PCI_STD_NUM_BARS |
---|
287 | 308 | |
---|
288 | 309 | struct pcim_iomap_devres { |
---|
289 | 310 | void __iomem *table[PCIM_IOMAP_MAX]; |
---|