Skip to content

Commit 1bfde03

Browse files
committed
Merge tag 'dma-mapping-5.8-5' of git://git.infradead.org/users/hch/dma-mapping
Pull dma-mapping fixes from Christoph Hellwig: - add a warning when the atomic pool is depleted (David Rientjes) - protect the parameters of the new scatterlist helper macros (Marek Szyprowski ) * tag 'dma-mapping-5.8-5' of git://git.infradead.org/users/hch/dma-mapping: scatterlist: protect parameters of the sg_table related macros dma-mapping: warn when coherent pool is depleted
2 parents 25aadbd + 68d2370 commit 1bfde03

File tree

2 files changed

+9
-5
lines changed

2 files changed

+9
-5
lines changed

include/linux/scatterlist.h

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -155,15 +155,15 @@ static inline void sg_set_buf(struct scatterlist *sg, const void *buf,
155155
* Loop over each sg element in the given sg_table object.
156156
*/
157157
#define for_each_sgtable_sg(sgt, sg, i) \
158-
for_each_sg(sgt->sgl, sg, sgt->orig_nents, i)
158+
for_each_sg((sgt)->sgl, sg, (sgt)->orig_nents, i)
159159

160160
/*
161161
* Loop over each sg element in the given *DMA mapped* sg_table object.
162162
* Please use sg_dma_address(sg) and sg_dma_len(sg) to extract DMA addresses
163163
* of the each element.
164164
*/
165165
#define for_each_sgtable_dma_sg(sgt, sg, i) \
166-
for_each_sg(sgt->sgl, sg, sgt->nents, i)
166+
for_each_sg((sgt)->sgl, sg, (sgt)->nents, i)
167167

168168
/**
169169
* sg_chain - Chain two sglists together
@@ -451,7 +451,7 @@ sg_page_iter_dma_address(struct sg_dma_page_iter *dma_iter)
451451
* See also for_each_sg_page(). In each loop it operates on PAGE_SIZE unit.
452452
*/
453453
#define for_each_sgtable_page(sgt, piter, pgoffset) \
454-
for_each_sg_page(sgt->sgl, piter, sgt->orig_nents, pgoffset)
454+
for_each_sg_page((sgt)->sgl, piter, (sgt)->orig_nents, pgoffset)
455455

456456
/**
457457
* for_each_sgtable_dma_page - iterate over the DMA mapped sg_table object
@@ -465,7 +465,7 @@ sg_page_iter_dma_address(struct sg_dma_page_iter *dma_iter)
465465
* unit.
466466
*/
467467
#define for_each_sgtable_dma_page(sgt, dma_iter, pgoffset) \
468-
for_each_sg_dma_page(sgt->sgl, dma_iter, sgt->nents, pgoffset)
468+
for_each_sg_dma_page((sgt)->sgl, dma_iter, (sgt)->nents, pgoffset)
469469

470470

471471
/*

kernel/dma/pool.c

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -239,12 +239,16 @@ void *dma_alloc_from_pool(struct device *dev, size_t size,
239239
}
240240

241241
val = gen_pool_alloc(pool, size);
242-
if (val) {
242+
if (likely(val)) {
243243
phys_addr_t phys = gen_pool_virt_to_phys(pool, val);
244244

245245
*ret_page = pfn_to_page(__phys_to_pfn(phys));
246246
ptr = (void *)val;
247247
memset(ptr, 0, size);
248+
} else {
249+
WARN_ONCE(1, "DMA coherent pool depleted, increase size "
250+
"(recommended min coherent_pool=%zuK)\n",
251+
gen_pool_size(pool) >> 9);
248252
}
249253
if (gen_pool_avail(pool) < atomic_pool_size)
250254
schedule_work(&atomic_pool_work);

0 commit comments

Comments
 (0)