staging: tidspbridge: add pud code

And fix the following warning for passing an incorrect
variable type.

../tiomap3430.c: In function 'user_va2_pa':
../tiomap3430.c:1555:
    warning: passing argument 1 of 'pmd_offset' from
    incompatible pointer type
arch/arm/include/asm/pgtable-2level.h:156:
    note: expected 'struct pud_t *' but argument is of
    type 'pmdval_t (*)[2]'

While at it, eliminate 'if' nesting to increase readability.

Signed-off-by: Omar Ramirez Luna <omar.ramirez@copitl.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Omar Ramirez Luna 2012-06-29 13:49:17 -05:00 committed by Greg Kroah-Hartman
parent 0e7e10fe49
commit a454ad15e0

View File

@ -1547,20 +1547,27 @@ EXIT_LOOP:
static u32 user_va2_pa(struct mm_struct *mm, u32 address) static u32 user_va2_pa(struct mm_struct *mm, u32 address)
{ {
pgd_t *pgd; pgd_t *pgd;
pud_t *pud;
pmd_t *pmd; pmd_t *pmd;
pte_t *ptep, pte; pte_t *ptep, pte;
pgd = pgd_offset(mm, address); pgd = pgd_offset(mm, address);
if (!(pgd_none(*pgd) || pgd_bad(*pgd))) { if (pgd_none(*pgd) || pgd_bad(*pgd))
pmd = pmd_offset(pgd, address); return 0;
if (!(pmd_none(*pmd) || pmd_bad(*pmd))) {
ptep = pte_offset_map(pmd, address); pud = pud_offset(pgd, address);
if (ptep) { if (pud_none(*pud) || pud_bad(*pud))
pte = *ptep; return 0;
if (pte_present(pte))
return pte & PAGE_MASK; pmd = pmd_offset(pud, address);
} if (pmd_none(*pmd) || pmd_bad(*pmd))
} return 0;
ptep = pte_offset_map(pmd, address);
if (ptep) {
pte = *ptep;
if (pte_present(pte))
return pte & PAGE_MASK;
} }
return 0; return 0;