···885885static void __dma_page_cpu_to_dev(struct page *page, unsigned long off,886886 size_t size, enum dma_data_direction dir)887887{888888- unsigned long paddr;888888+ phys_addr_t paddr;889889890890 dma_cache_maint_page(page, off, size, dir, dmac_map_area);891891···901901static void __dma_page_dev_to_cpu(struct page *page, unsigned long off,902902 size_t size, enum dma_data_direction dir)903903{904904- unsigned long paddr = page_to_phys(page) + off;904904+ phys_addr_t paddr = page_to_phys(page) + off;905905906906 /* FIXME: non-speculating: not required */907907 /* in any case, don't bother invalidating if DMA to device */
+110
drivers/of/address.c
···721721 return ioremap(res.start, resource_size(&res));722722}723723EXPORT_SYMBOL(of_iomap);724724+725725+/**726726+ * of_dma_get_range - Get DMA range info727727+ * @np: device node to get DMA range info728728+ * @dma_addr: pointer to store initial DMA address of DMA range729729+ * @paddr: pointer to store initial CPU address of DMA range730730+ * @size: pointer to store size of DMA range731731+ *732732+ * Look in bottom up direction for the first "dma-ranges" property733733+ * and parse it.734734+ * dma-ranges format:735735+ * DMA addr (dma_addr) : naddr cells736736+ * CPU addr (phys_addr_t) : pna cells737737+ * size : nsize cells738738+ *739739+ * It returns -ENODEV if "dma-ranges" property was not found740740+ * for this device in DT.741741+ */742742+int of_dma_get_range(struct device_node *np, u64 *dma_addr, u64 *paddr, u64 *size)743743+{744744+ struct device_node *node = of_node_get(np);745745+ const __be32 *ranges = NULL;746746+ int len, naddr, nsize, pna;747747+ int ret = 0;748748+ u64 dmaaddr;749749+750750+ if (!node)751751+ return -EINVAL;752752+753753+ while (1) {754754+ naddr = of_n_addr_cells(node);755755+ nsize = of_n_size_cells(node);756756+ node = of_get_next_parent(node);757757+ if (!node)758758+ break;759759+760760+ ranges = of_get_property(node, "dma-ranges", &len);761761+762762+ /* Ignore empty ranges, they imply no translation required */763763+ if (ranges && len > 0)764764+ break;765765+766766+ /*767767+ * At least empty ranges has to be defined for parent node if768768+ * DMA is supported769769+ */770770+ if (!ranges)771771+ break;772772+ }773773+774774+ if (!ranges) {775775+ pr_debug("%s: no dma-ranges found for node(%s)\n",776776+ __func__, np->full_name);777777+ ret = -ENODEV;778778+ goto out;779779+ }780780+781781+ len /= sizeof(u32);782782+783783+ pna = of_n_addr_cells(node);784784+785785+ /* dma-ranges format:786786+ * DMA addr : naddr cells787787+ * CPU addr : pna cells788788+ * size : nsize cells789789+ */790790+ dmaaddr = of_read_number(ranges, naddr);791791+ *paddr = of_translate_dma_address(np, ranges);792792+ if (*paddr == OF_BAD_ADDR) {793793+ pr_err("%s: translation of DMA address(%pad) to CPU address failed node(%s)\n",794794+ __func__, dma_addr, np->full_name);795795+ ret = -EINVAL;796796+ goto out;797797+ }798798+ *dma_addr = dmaaddr;799799+800800+ *size = of_read_number(ranges + naddr + pna, nsize);801801+802802+ pr_debug("dma_addr(%llx) cpu_addr(%llx) size(%llx)\n",803803+ *dma_addr, *paddr, *size);804804+805805+out:806806+ of_node_put(node);807807+808808+ return ret;809809+}810810+EXPORT_SYMBOL_GPL(of_dma_get_range);811811+812812+/**813813+ * of_dma_is_coherent - Check if device is coherent814814+ * @np: device node815815+ *816816+ * It returns true if "dma-coherent" property was found817817+ * for this device in DT.818818+ */819819+bool of_dma_is_coherent(struct device_node *np)820820+{821821+ struct device_node *node = of_node_get(np);822822+823823+ while (node) {824824+ if (of_property_read_bool(node, "dma-coherent")) {825825+ of_node_put(node);826826+ return true;827827+ }828828+ node = of_get_next_parent(node);829829+ }830830+ of_node_put(node);831831+ return false;832832+}833833+EXPORT_SYMBOL_GPL(of_dma_is_coherent);
+59-6
drivers/of/platform.c
···189189EXPORT_SYMBOL(of_device_alloc);190190191191/**192192+ * of_dma_configure - Setup DMA configuration193193+ * @dev: Device to apply DMA configuration194194+ *195195+ * Try to get devices's DMA configuration from DT and update it196196+ * accordingly.197197+ *198198+ * In case if platform code need to use own special DMA configuration,it199199+ * can use Platform bus notifier and handle BUS_NOTIFY_ADD_DEVICE event200200+ * to fix up DMA configuration.201201+ */202202+static void of_dma_configure(struct platform_device *pdev)203203+{204204+ u64 dma_addr, paddr, size;205205+ int ret;206206+ struct device *dev = &pdev->dev;207207+208208+#if defined(CONFIG_MICROBLAZE)209209+ pdev->archdata.dma_mask = 0xffffffffUL;210210+#endif211211+212212+ /*213213+ * Set default dma-mask to 32 bit. Drivers are expected to setup214214+ * the correct supported dma_mask.215215+ */216216+ dev->coherent_dma_mask = DMA_BIT_MASK(32);217217+218218+ /*219219+ * Set it to coherent_dma_mask by default if the architecture220220+ * code has not set it.221221+ */222222+ if (!dev->dma_mask)223223+ dev->dma_mask = &dev->coherent_dma_mask;224224+225225+ /*226226+ * if dma-coherent property exist, call arch hook to setup227227+ * dma coherent operations.228228+ */229229+ if (of_dma_is_coherent(dev->of_node)) {230230+ set_arch_dma_coherent_ops(dev);231231+ dev_dbg(dev, "device is dma coherent\n");232232+ }233233+234234+ /*235235+ * if dma-ranges property doesn't exist - just return else236236+ * setup the dma offset237237+ */238238+ ret = of_dma_get_range(dev->of_node, &dma_addr, &paddr, &size);239239+ if (ret < 0) {240240+ dev_dbg(dev, "no dma range information to setup\n");241241+ return;242242+ }243243+244244+ /* DMA ranges found. Calculate and set dma_pfn_offset */245245+ dev->dma_pfn_offset = PFN_DOWN(paddr - dma_addr);246246+ dev_dbg(dev, "dma_pfn_offset(%#08lx)\n", dev->dma_pfn_offset);247247+}248248+249249+/**192250 * of_platform_device_create_pdata - Alloc, initialize and register an of_device193251 * @np: pointer to node to create device for194252 * @bus_id: name to assign device···271213 if (!dev)272214 return NULL;273215274274-#if defined(CONFIG_MICROBLAZE)275275- dev->archdata.dma_mask = 0xffffffffUL;276276-#endif277277- dev->dev.coherent_dma_mask = DMA_BIT_MASK(32);278278- if (!dev->dev.dma_mask)279279- dev->dev.dma_mask = &dev->dev.coherent_dma_mask;216216+ of_dma_configure(dev);280217 dev->dev.bus = &platform_bus_type;281218 dev->dev.platform_data = platform_data;282219
+2
include/linux/device.h
···685685 * @coherent_dma_mask: Like dma_mask, but for alloc_coherent mapping as not all686686 * hardware supports 64-bit addresses for consistent allocations687687 * such descriptors.688688+ * @dma_pfn_offset: offset of DMA memory range relatively of RAM688689 * @dma_parms: A low level driver may set these to teach IOMMU code about689690 * segment limitations.690691 * @dma_pools: Dma pools (if dma'ble device).···751750 not all hardware supports752751 64 bit addresses for consistent753752 allocations such descriptors. */753753+ unsigned long dma_pfn_offset;754754755755 struct device_dma_parameters *dma_parms;756756