|
@@ -549,7 +549,7 @@ swiotlb_alloc_coherent(struct device *hwdev, size_t size,
|
|
|
dma_mask = hwdev->coherent_dma_mask;
|
|
|
|
|
|
ret = (void *)__get_free_pages(flags, order);
|
|
|
- if (ret && swiotlb_virt_to_bus(hwdev, ret) + size > dma_mask) {
|
|
|
+ if (ret && swiotlb_virt_to_bus(hwdev, ret) + size - 1 > dma_mask) {
|
|
|
/*
|
|
|
* The allocated memory isn't reachable by the device.
|
|
|
*/
|
|
@@ -571,7 +571,7 @@ swiotlb_alloc_coherent(struct device *hwdev, size_t size,
|
|
|
dev_addr = swiotlb_virt_to_bus(hwdev, ret);
|
|
|
|
|
|
/* Confirm address can be DMA'd by device */
|
|
|
- if (dev_addr + size > dma_mask) {
|
|
|
+ if (dev_addr + size - 1 > dma_mask) {
|
|
|
printk("hwdev DMA mask = 0x%016Lx, dev_addr = 0x%016Lx\n",
|
|
|
(unsigned long long)dma_mask,
|
|
|
(unsigned long long)dev_addr);
|