Skip to content

Commit 9bc98c8

Browse files
aikmpe
authored andcommitted
powerpc/powernv: Rework TCE level allocation
This moves actual pages allocation to a separate function which is going to be reused later in on-demand TCE allocation. While we are at it, remove unnecessary level size round up as the caller does this already. Reviewed-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
1 parent 090bad3 commit 9bc98c8

File tree

1 file changed

+19
-11
lines changed

1 file changed

+19
-11
lines changed

arch/powerpc/platforms/powernv/pci-ioda-tce.c

Lines changed: 19 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,23 @@ void pnv_pci_setup_iommu_table(struct iommu_table *tbl,
3131
tbl->it_type = TCE_PCI;
3232
}
3333

34+
static __be64 *pnv_alloc_tce_level(int nid, unsigned int shift)
35+
{
36+
struct page *tce_mem = NULL;
37+
__be64 *addr;
38+
39+
tce_mem = alloc_pages_node(nid, GFP_KERNEL, shift - PAGE_SHIFT);
40+
if (!tce_mem) {
41+
pr_err("Failed to allocate a TCE memory, level shift=%d\n",
42+
shift);
43+
return NULL;
44+
}
45+
addr = page_address(tce_mem);
46+
memset(addr, 0, 1UL << shift);
47+
48+
return addr;
49+
}
50+
3451
static __be64 *pnv_tce(struct iommu_table *tbl, bool user, long idx)
3552
{
3653
__be64 *tmp = user ? tbl->it_userspace : (__be64 *) tbl->it_base;
@@ -165,21 +182,12 @@ static __be64 *pnv_pci_ioda2_table_do_alloc_pages(int nid, unsigned int shift,
165182
unsigned int levels, unsigned long limit,
166183
unsigned long *current_offset, unsigned long *total_allocated)
167184
{
168-
struct page *tce_mem = NULL;
169185
__be64 *addr, *tmp;
170-
unsigned int order = max_t(unsigned int, shift, PAGE_SHIFT) -
171-
PAGE_SHIFT;
172-
unsigned long allocated = 1UL << (order + PAGE_SHIFT);
186+
unsigned long allocated = 1UL << shift;
173187
unsigned int entries = 1UL << (shift - 3);
174188
long i;
175189

176-
tce_mem = alloc_pages_node(nid, GFP_KERNEL, order);
177-
if (!tce_mem) {
178-
pr_err("Failed to allocate a TCE memory, order=%d\n", order);
179-
return NULL;
180-
}
181-
addr = page_address(tce_mem);
182-
memset(addr, 0, allocated);
190+
addr = pnv_alloc_tce_level(nid, shift);
183191
*total_allocated += allocated;
184192

185193
--levels;

0 commit comments

Comments
 (0)