Skip to content

Commit

Permalink
o Relax locking assertions for vm_page_find_least()
Browse files Browse the repository at this point in the history
o Relax locking assertions for pmap_enter_object() and add them also
  to architectures that currently don't have any
o Introduce VM_OBJECT_LOCK_DOWNGRADE() which is basically a downgrade
  operation on the per-object rwlock
o Use all the mechanisms above to make vm_map_pmap_enter() to work
  mostl of the times only with readlocks.

Sponsored by:	EMC / Isilon storage division
Reviewed by:	alc
  • Loading branch information
attilio authored and attilio committed May 21, 2013
1 parent 05bd827 commit fdf82ef
Show file tree
Hide file tree
Showing 14 changed files with 40 additions and 13 deletions.
3 changes: 2 additions & 1 deletion sys/amd64/amd64/pmap.c
Expand Up @@ -3722,7 +3722,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m, mpte;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_WLOCKED(m_start->object);
VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
mpte = NULL;
m = m_start;
Expand Down
2 changes: 2 additions & 0 deletions sys/arm/arm/pmap-v6.c
Expand Up @@ -2931,6 +2931,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&pvh_global_lock);
Expand Down
2 changes: 2 additions & 0 deletions sys/arm/arm/pmap.c
Expand Up @@ -3587,6 +3587,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&pvh_global_lock);
Expand Down
3 changes: 2 additions & 1 deletion sys/i386/i386/pmap.c
Expand Up @@ -3677,7 +3677,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m, mpte;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_WLOCKED(m_start->object);
VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
mpte = NULL;
m = m_start;
Expand Down
3 changes: 2 additions & 1 deletion sys/i386/xen/pmap.c
Expand Up @@ -2871,7 +2871,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
multicall_entry_t *mclp = mcl;
int error, count = 0;

VM_OBJECT_ASSERT_WLOCKED(m_start->object);
VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
mpte = NULL;
m = m_start;
Expand Down
3 changes: 2 additions & 1 deletion sys/ia64/ia64/pmap.c
Expand Up @@ -1802,7 +1802,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_WLOCKED(m_start->object);
VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&pvh_global_lock);
Expand Down
3 changes: 2 additions & 1 deletion sys/mips/mips/pmap.c
Expand Up @@ -2399,7 +2399,8 @@ pmap_enter_object(pmap_t pmap, vm_offset_t start, vm_offset_t end,
vm_page_t m, mpte;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_WLOCKED(m_start->object);
VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
mpte = NULL;
m = m_start;
Expand Down
2 changes: 2 additions & 0 deletions sys/powerpc/aim/mmu_oea.c
Expand Up @@ -1217,6 +1217,8 @@ moea_enter_object(mmu_t mmu, pmap_t pm, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&pvh_global_lock);
Expand Down
2 changes: 2 additions & 0 deletions sys/powerpc/aim/mmu_oea64.c
Expand Up @@ -1360,6 +1360,8 @@ moea64_enter_object(mmu_t mmu, pmap_t pm, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
while (m != NULL && (diff = m->pindex - m_start->pindex) < psize) {
Expand Down
2 changes: 2 additions & 0 deletions sys/powerpc/booke/pmap.c
Expand Up @@ -1716,6 +1716,8 @@ mmu_booke_enter_object(mmu_t mmu, pmap_t pmap, vm_offset_t start,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&pvh_global_lock);
Expand Down
2 changes: 2 additions & 0 deletions sys/sparc64/sparc64/pmap.c
Expand Up @@ -1632,6 +1632,8 @@ pmap_enter_object(pmap_t pm, vm_offset_t start, vm_offset_t end,
vm_page_t m;
vm_pindex_t diff, psize;

VM_OBJECT_ASSERT_LOCKED(m_start->object);

psize = atop(end - start);
m = m_start;
rw_wlock(&tte_list_global_lock);
Expand Down
22 changes: 15 additions & 7 deletions sys/vm/vm_map.c
Expand Up @@ -1806,18 +1806,27 @@ vm_map_pmap_enter(vm_map_t map, vm_offset_t addr, vm_prot_t prot,

if ((prot & (VM_PROT_READ | VM_PROT_EXECUTE)) == 0 || object == NULL)
return;
VM_OBJECT_WLOCK(object);
VM_OBJECT_RLOCK(object);
if (object->type == OBJT_DEVICE || object->type == OBJT_SG) {
pmap_object_init_pt(map->pmap, addr, object, pindex, size);
goto unlock_return;
VM_OBJECT_RUNLOCK(object);
VM_OBJECT_WLOCK(object);
if (object->type == OBJT_DEVICE || object->type == OBJT_SG) {
pmap_object_init_pt(map->pmap, addr, object, pindex,
size);
VM_OBJECT_WUNLOCK(object);
return;
}
VM_OBJECT_LOCK_DOWNGRADE(object);
}

psize = atop(size);
if (psize > MAX_INIT_PT && (flags & MAP_PREFAULT_PARTIAL) != 0)
psize = MAX_INIT_PT;
if (psize + pindex > object->size) {
if (object->size < pindex)
goto unlock_return;
if (object->size < pindex) {
VM_OBJECT_RUNLOCK(object);
return;
}
psize = object->size - pindex;
}

Expand Down Expand Up @@ -1856,8 +1865,7 @@ vm_map_pmap_enter(vm_map_t map, vm_offset_t addr, vm_prot_t prot,
if (p_start != NULL)
pmap_enter_object(map->pmap, start, addr + ptoa(psize),
p_start, prot);
unlock_return:
VM_OBJECT_WUNLOCK(object);
VM_OBJECT_RUNLOCK(object);
}

/*
Expand Down
2 changes: 2 additions & 0 deletions sys/vm/vm_object.h
Expand Up @@ -223,6 +223,8 @@ extern struct vm_object kmem_object_store;
rw_assert(&(object)->lock, RA_RLOCKED)
#define VM_OBJECT_ASSERT_WLOCKED(object) \
rw_assert(&(object)->lock, RA_WLOCKED)
#define VM_OBJECT_LOCK_DOWNGRADE(object) \
rw_downgrade(&(object)->lock)
#define VM_OBJECT_RLOCK(object) \
rw_rlock(&(object)->lock)
#define VM_OBJECT_RUNLOCK(object) \
Expand Down
2 changes: 1 addition & 1 deletion sys/vm/vm_page.c
Expand Up @@ -959,7 +959,7 @@ vm_page_find_least(vm_object_t object, vm_pindex_t pindex)
{
vm_page_t m;

VM_OBJECT_ASSERT_WLOCKED(object);
VM_OBJECT_ASSERT_LOCKED(object);
if ((m = TAILQ_FIRST(&object->memq)) != NULL && m->pindex < pindex)
m = vm_radix_lookup_ge(&object->rtree, pindex);
return (m);
Expand Down

0 comments on commit fdf82ef

Please sign in to comment.