diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-06 14:36:58 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-06 14:36:58 -0400 |
commit | 171c2bcbcb58a6699dad64d0c0b615af4f6ecb74 (patch) | |
tree | edb419c09e62949e3d8df97dfd0809096f7c1a93 /kernel/resource.c | |
parent | 423ea3255424b954947d167681b71ded1b8fca53 (diff) | |
parent | f6c6010a07734103a31faa0cc977641b358c45b0 (diff) |
Merge branch 'core-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull unified TLB flushing from Ingo Molnar:
"This contains the generic mmu_gather feature from Peter Zijlstra,
which is an all-arch unification of TLB flushing APIs, via the
following (broad) steps:
- enhance the <asm-generic/tlb.h> APIs to cover more arch details
- convert most TLB flushing arch implementations to the generic
<asm-generic/tlb.h> APIs.
- remove leftovers of per arch implementations
After this series every single architecture makes use of the unified
TLB flushing APIs"
* 'core-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
mm/resource: Use resource_overlaps() to simplify region_intersects()
ia64/tlb: Eradicate tlb_migrate_finish() callback
asm-generic/tlb: Remove tlb_table_flush()
asm-generic/tlb: Remove tlb_flush_mmu_free()
asm-generic/tlb: Remove CONFIG_HAVE_GENERIC_MMU_GATHER
asm-generic/tlb: Remove arch_tlb*_mmu()
s390/tlb: Convert to generic mmu_gather
asm-generic/tlb: Introduce CONFIG_HAVE_MMU_GATHER_NO_GATHER=y
arch/tlb: Clean up simple architectures
um/tlb: Convert to generic mmu_gather
sh/tlb: Convert SH to generic mmu_gather
ia64/tlb: Convert to generic mmu_gather
arm/tlb: Convert to generic mmu_gather
asm-generic/tlb, arch: Invert CONFIG_HAVE_RCU_TABLE_INVALIDATE
asm-generic/tlb, ia64: Conditionally provide tlb_migrate_finish()
asm-generic/tlb: Provide generic tlb_flush() based on flush_tlb_mm()
asm-generic/tlb, arch: Provide generic tlb_flush() based on flush_tlb_range()
asm-generic/tlb, arch: Provide generic VIPT cache flush
asm-generic/tlb, arch: Provide CONFIG_HAVE_MMU_GATHER_PAGE_SIZE
asm-generic/tlb: Provide a comment
Diffstat (limited to 'kernel/resource.c')
-rw-r--r-- | kernel/resource.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/kernel/resource.c b/kernel/resource.c index 92190f62ebc5..8c15f846e8ef 100644 --- a/kernel/resource.c +++ b/kernel/resource.c | |||
@@ -520,21 +520,20 @@ EXPORT_SYMBOL_GPL(page_is_ram); | |||
520 | int region_intersects(resource_size_t start, size_t size, unsigned long flags, | 520 | int region_intersects(resource_size_t start, size_t size, unsigned long flags, |
521 | unsigned long desc) | 521 | unsigned long desc) |
522 | { | 522 | { |
523 | resource_size_t end = start + size - 1; | 523 | struct resource res; |
524 | int type = 0; int other = 0; | 524 | int type = 0; int other = 0; |
525 | struct resource *p; | 525 | struct resource *p; |
526 | 526 | ||
527 | res.start = start; | ||
528 | res.end = start + size - 1; | ||
529 | |||
527 | read_lock(&resource_lock); | 530 | read_lock(&resource_lock); |
528 | for (p = iomem_resource.child; p ; p = p->sibling) { | 531 | for (p = iomem_resource.child; p ; p = p->sibling) { |
529 | bool is_type = (((p->flags & flags) == flags) && | 532 | bool is_type = (((p->flags & flags) == flags) && |
530 | ((desc == IORES_DESC_NONE) || | 533 | ((desc == IORES_DESC_NONE) || |
531 | (desc == p->desc))); | 534 | (desc == p->desc))); |
532 | 535 | ||
533 | if (start >= p->start && start <= p->end) | 536 | if (resource_overlaps(p, &res)) |
534 | is_type ? type++ : other++; | ||
535 | if (end >= p->start && end <= p->end) | ||
536 | is_type ? type++ : other++; | ||
537 | if (p->start >= start && p->end <= end) | ||
538 | is_type ? type++ : other++; | 537 | is_type ? type++ : other++; |
539 | } | 538 | } |
540 | read_unlock(&resource_lock); | 539 | read_unlock(&resource_lock); |