diff options
Diffstat (limited to 'lib/swiotlb.c')
| -rw-r--r-- | lib/swiotlb.c | 6 | 
1 files changed, 6 insertions, 0 deletions
| diff --git a/lib/swiotlb.c b/lib/swiotlb.c index 4e8686c7e5a4..e4399fa65ad6 100644 --- a/lib/swiotlb.c +++ b/lib/swiotlb.c @@ -38,6 +38,9 @@  #include <linux/bootmem.h>  #include <linux/iommu-helper.h> +#define CREATE_TRACE_POINTS +#include <trace/events/swiotlb.h> +  #define OFFSET(val,align) ((unsigned long)	\  	                   ( (val) & ( (align) - 1))) @@ -502,6 +505,7 @@ phys_addr_t swiotlb_tbl_map_single(struct device *hwdev,  not_found:  	spin_unlock_irqrestore(&io_tlb_lock, flags); +	dev_warn(hwdev, "swiotlb buffer is full\n");  	return SWIOTLB_MAP_ERROR;  found:  	spin_unlock_irqrestore(&io_tlb_lock, flags); @@ -726,6 +730,8 @@ dma_addr_t swiotlb_map_page(struct device *dev, struct page *page,  	if (dma_capable(dev, dev_addr, size) && !swiotlb_force)  		return dev_addr; +	trace_swiotlb_bounced(dev, dev_addr, size, swiotlb_force); +  	/* Oh well, have to allocate and map a bounce buffer. */  	map = map_single(dev, phys, size, dir);  	if (map == SWIOTLB_MAP_ERROR) { | 
