Skip to content

Commit e269b08

Browse files
antonblanchardtorvalds
authored andcommitted
iommu: inline iommu_num_pages
A profile of a network benchmark showed iommu_num_pages rather high up: 0.52% iommu_num_pages Looking at the profile, an integer divide is taking almost all of the time: % : c000000000376ea4 <.iommu_num_pages>: 1.93 : c000000000376ea4: fb e1 ff f8 std r31,-8(r1) 0.00 : c000000000376ea8: f8 21 ff c1 stdu r1,-64(r1) 0.00 : c000000000376eac: 7c 3f 0b 78 mr r31,r1 3.86 : c000000000376eb0: 38 84 ff ff addi r4,r4,-1 0.00 : c000000000376eb4: 38 05 ff ff addi r0,r5,-1 0.00 : c000000000376eb8: 7c 84 2a 14 add r4,r4,r5 46.95 : c000000000376ebc: 7c 00 18 38 and r0,r0,r3 45.66 : c000000000376ec0: 7c 84 02 14 add r4,r4,r0 0.00 : c000000000376ec4: 7c 64 2b 92 divdu r3,r4,r5 0.00 : c000000000376ec8: 38 3f 00 40 addi r1,r31,64 0.00 : c000000000376ecc: eb e1 ff f8 ld r31,-8(r1) 1.61 : c000000000376ed0: 4e 80 00 20 blr Since every caller of iommu_num_pages passes in a constant power of two we can inline this such that the divide is replaced by a shift. The entire function is only a few instructions once optimised, so it is a good candidate for inlining overall. Signed-off-by: Anton Blanchard <[email protected]> Cc: Akinobu Mita <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
1 parent 85c9fe8 commit e269b08

File tree

2 files changed

+10
-11
lines changed

2 files changed

+10
-11
lines changed

include/linux/iommu-helper.h

+10-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,8 @@
11
#ifndef _LINUX_IOMMU_HELPER_H
22
#define _LINUX_IOMMU_HELPER_H
33

4+
#include <linux/kernel.h>
5+
46
static inline unsigned long iommu_device_max_index(unsigned long size,
57
unsigned long offset,
68
u64 dma_mask)
@@ -20,7 +22,13 @@ extern unsigned long iommu_area_alloc(unsigned long *map, unsigned long size,
2022
unsigned long boundary_size,
2123
unsigned long align_mask);
2224

23-
extern unsigned long iommu_num_pages(unsigned long addr, unsigned long len,
24-
unsigned long io_page_size);
25+
static inline unsigned long iommu_num_pages(unsigned long addr,
26+
unsigned long len,
27+
unsigned long io_page_size)
28+
{
29+
unsigned long size = (addr & (io_page_size - 1)) + len;
30+
31+
return DIV_ROUND_UP(size, io_page_size);
32+
}
2533

2634
#endif

lib/iommu-helper.c

-9
Original file line numberDiff line numberDiff line change
@@ -38,12 +38,3 @@ unsigned long iommu_area_alloc(unsigned long *map, unsigned long size,
3838
return -1;
3939
}
4040
EXPORT_SYMBOL(iommu_area_alloc);
41-
42-
unsigned long iommu_num_pages(unsigned long addr, unsigned long len,
43-
unsigned long io_page_size)
44-
{
45-
unsigned long size = (addr & (io_page_size - 1)) + len;
46-
47-
return DIV_ROUND_UP(size, io_page_size);
48-
}
49-
EXPORT_SYMBOL(iommu_num_pages);

0 commit comments

Comments
 (0)