OSDN Git Service

iommu/io-pgtable-arm: Stricter double-map checking
authorMitchel Humpherys <mitchelh@codeaurora.org>
Wed, 23 Sep 2015 20:56:27 +0000 (13:56 -0700)
committerDavid Keitel <dkeitel@codeaurora.org>
Tue, 22 Mar 2016 18:14:18 +0000 (11:14 -0700)
Currently there's a check to make sure that a mapping isn't being
installed on top of an existing leaf mapping.  However, mapping on top
of an existing table mapping is silently ignored.  Make the check more
strict by testing for any valid page table entry (table, block, or page
descriptor) and by making any overlap fatal.

Change-Id: Ibdffbfdb2b44cf9da5044c2c1828a32979a39760
Signed-off-by: Mitchel Humpherys <mitchelh@codeaurora.org>
drivers/iommu/io-pgtable-arm.c

index 9876f6b..90d0438 100644 (file)
@@ -282,8 +282,8 @@ static int arm_lpae_init_pte(struct arm_lpae_io_pgtable *data,
        arm_lpae_iopte pte = prot;
 
        /* We require an unmap first */
-       if (iopte_leaf(*ptep, lvl)) {
-               WARN_ON(!suppress_map_failures);
+       if (*ptep & ARM_LPAE_PTE_VALID) {
+               BUG_ON(!suppress_map_failures);
                return -EEXIST;
        }