Commit 6e0a0431 authored by Martin Schwidefsky's avatar Martin Schwidefsky Committed by Christian Borntraeger

KVM: s390/mm: cleanup gmap function arguments, variable names

Make the order of arguments for the gmap calls more consistent,
if the gmap pointer is passed it is always the first argument.
In addition distinguish between guest address and user address
by naming the variables gaddr for a guest address and vmaddr for
a user address.
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
Reviewed-by: default avatarCornelia Huck <cornelia.huck@de.ibm.com>
Signed-off-by: default avatarChristian Borntraeger <borntraeger@de.ibm.com>
parent 9da4e380
...@@ -834,7 +834,7 @@ struct gmap_pgtable { ...@@ -834,7 +834,7 @@ struct gmap_pgtable {
*/ */
struct gmap_notifier { struct gmap_notifier {
struct list_head list; struct list_head list;
void (*notifier_call)(struct gmap *gmap, unsigned long address); void (*notifier_call)(struct gmap *gmap, unsigned long gaddr);
}; };
struct gmap *gmap_alloc(struct mm_struct *mm); struct gmap *gmap_alloc(struct mm_struct *mm);
...@@ -844,12 +844,12 @@ void gmap_disable(struct gmap *gmap); ...@@ -844,12 +844,12 @@ void gmap_disable(struct gmap *gmap);
int gmap_map_segment(struct gmap *gmap, unsigned long from, int gmap_map_segment(struct gmap *gmap, unsigned long from,
unsigned long to, unsigned long len); unsigned long to, unsigned long len);
int gmap_unmap_segment(struct gmap *gmap, unsigned long to, unsigned long len); int gmap_unmap_segment(struct gmap *gmap, unsigned long to, unsigned long len);
unsigned long __gmap_translate(unsigned long address, struct gmap *); unsigned long __gmap_translate(struct gmap *, unsigned long gaddr);
unsigned long gmap_translate(unsigned long address, struct gmap *); unsigned long gmap_translate(struct gmap *, unsigned long gaddr);
unsigned long __gmap_fault(unsigned long address, struct gmap *); unsigned long __gmap_fault(struct gmap *, unsigned long gaddr);
unsigned long gmap_fault(unsigned long address, struct gmap *); unsigned long gmap_fault(struct gmap *, unsigned long gaddr);
void gmap_discard(unsigned long from, unsigned long to, struct gmap *); void gmap_discard(struct gmap *, unsigned long from, unsigned long to);
void __gmap_zap(unsigned long address, struct gmap *); void __gmap_zap(struct gmap *, unsigned long gaddr);
bool gmap_test_and_clear_dirty(unsigned long address, struct gmap *); bool gmap_test_and_clear_dirty(unsigned long address, struct gmap *);
......
...@@ -37,13 +37,13 @@ static int diag_release_pages(struct kvm_vcpu *vcpu) ...@@ -37,13 +37,13 @@ static int diag_release_pages(struct kvm_vcpu *vcpu)
/* we checked for start > end above */ /* we checked for start > end above */
if (end < prefix || start >= prefix + 2 * PAGE_SIZE) { if (end < prefix || start >= prefix + 2 * PAGE_SIZE) {
gmap_discard(start, end, vcpu->arch.gmap); gmap_discard(vcpu->arch.gmap, start, end);
} else { } else {
if (start < prefix) if (start < prefix)
gmap_discard(start, prefix, vcpu->arch.gmap); gmap_discard(vcpu->arch.gmap, start, prefix);
if (end >= prefix) if (end >= prefix)
gmap_discard(prefix + 2 * PAGE_SIZE, gmap_discard(vcpu->arch.gmap,
end, vcpu->arch.gmap); prefix + 2 * PAGE_SIZE, end);
} }
return 0; return 0;
} }
......
...@@ -1241,7 +1241,7 @@ static int kvm_s390_adapter_map(struct kvm *kvm, unsigned int id, __u64 addr) ...@@ -1241,7 +1241,7 @@ static int kvm_s390_adapter_map(struct kvm *kvm, unsigned int id, __u64 addr)
} }
INIT_LIST_HEAD(&map->list); INIT_LIST_HEAD(&map->list);
map->guest_addr = addr; map->guest_addr = addr;
map->addr = gmap_translate(addr, kvm->arch.gmap); map->addr = gmap_translate(kvm->arch.gmap, addr);
if (map->addr == -EFAULT) { if (map->addr == -EFAULT) {
ret = -EFAULT; ret = -EFAULT;
goto out; goto out;
......
...@@ -1096,7 +1096,7 @@ long kvm_arch_fault_in_page(struct kvm_vcpu *vcpu, gpa_t gpa, int writable) ...@@ -1096,7 +1096,7 @@ long kvm_arch_fault_in_page(struct kvm_vcpu *vcpu, gpa_t gpa, int writable)
hva_t hva; hva_t hva;
long rc; long rc;
hva = gmap_fault(gpa, vcpu->arch.gmap); hva = gmap_fault(vcpu->arch.gmap, gpa);
if (IS_ERR_VALUE(hva)) if (IS_ERR_VALUE(hva))
return (long)hva; return (long)hva;
down_read(&mm->mmap_sem); down_read(&mm->mmap_sem);
...@@ -1683,7 +1683,7 @@ long kvm_arch_vcpu_ioctl(struct file *filp, ...@@ -1683,7 +1683,7 @@ long kvm_arch_vcpu_ioctl(struct file *filp,
} }
#endif #endif
case KVM_S390_VCPU_FAULT: { case KVM_S390_VCPU_FAULT: {
r = gmap_fault(arg, vcpu->arch.gmap); r = gmap_fault(vcpu->arch.gmap, arg);
if (!IS_ERR_VALUE(r)) if (!IS_ERR_VALUE(r))
r = 0; r = 0;
break; break;
......
...@@ -729,7 +729,7 @@ static int handle_essa(struct kvm_vcpu *vcpu) ...@@ -729,7 +729,7 @@ static int handle_essa(struct kvm_vcpu *vcpu)
/* invalid entry */ /* invalid entry */
break; break;
/* try to free backing */ /* try to free backing */
__gmap_zap(cbrle, gmap); __gmap_zap(gmap, cbrle);
} }
up_read(&gmap->mm->mmap_sem); up_read(&gmap->mm->mmap_sem);
if (i < entries) if (i < entries)
......
...@@ -445,7 +445,7 @@ static inline int do_exception(struct pt_regs *regs, int access) ...@@ -445,7 +445,7 @@ static inline int do_exception(struct pt_regs *regs, int access)
gmap = (struct gmap *) gmap = (struct gmap *)
((current->flags & PF_VCPU) ? S390_lowcore.gmap : 0); ((current->flags & PF_VCPU) ? S390_lowcore.gmap : 0);
if (gmap) { if (gmap) {
address = __gmap_fault(address, gmap); address = __gmap_fault(gmap, address);
if (address == -EFAULT) { if (address == -EFAULT) {
fault = VM_FAULT_BADMAP; fault = VM_FAULT_BADMAP;
goto out_up; goto out_up;
......
...@@ -295,7 +295,7 @@ static int gmap_alloc_table(struct gmap *gmap, ...@@ -295,7 +295,7 @@ static int gmap_alloc_table(struct gmap *gmap,
/** /**
* gmap_unmap_segment - unmap segment from the guest address space * gmap_unmap_segment - unmap segment from the guest address space
* @gmap: pointer to the guest address space structure * @gmap: pointer to the guest address space structure
* @addr: address in the guest address space * @to: address in the guest address space
* @len: length of the memory area to unmap * @len: length of the memory area to unmap
* *
* Returns 0 if the unmap succeeded, -EINVAL if not. * Returns 0 if the unmap succeeded, -EINVAL if not.
...@@ -348,6 +348,7 @@ EXPORT_SYMBOL_GPL(gmap_unmap_segment); ...@@ -348,6 +348,7 @@ EXPORT_SYMBOL_GPL(gmap_unmap_segment);
* @gmap: pointer to the guest address space structure * @gmap: pointer to the guest address space structure
* @from: source address in the parent address space * @from: source address in the parent address space
* @to: target address in the guest address space * @to: target address in the guest address space
* @len: length of the memory area to map
* *
* Returns 0 if the mmap succeeded, -EINVAL or -ENOMEM if not. * Returns 0 if the mmap succeeded, -EINVAL or -ENOMEM if not.
*/ */
...@@ -405,30 +406,30 @@ int gmap_map_segment(struct gmap *gmap, unsigned long from, ...@@ -405,30 +406,30 @@ int gmap_map_segment(struct gmap *gmap, unsigned long from,
} }
EXPORT_SYMBOL_GPL(gmap_map_segment); EXPORT_SYMBOL_GPL(gmap_map_segment);
static unsigned long *gmap_table_walk(unsigned long address, struct gmap *gmap) static unsigned long *gmap_table_walk(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long *table; unsigned long *table;
table = gmap->table + ((address >> 53) & 0x7ff); table = gmap->table + ((gaddr >> 53) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) if (unlikely(*table & _REGION_ENTRY_INVALID))
return ERR_PTR(-EFAULT); return ERR_PTR(-EFAULT);
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 42) & 0x7ff); table = table + ((gaddr >> 42) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) if (unlikely(*table & _REGION_ENTRY_INVALID))
return ERR_PTR(-EFAULT); return ERR_PTR(-EFAULT);
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 31) & 0x7ff); table = table + ((gaddr >> 31) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) if (unlikely(*table & _REGION_ENTRY_INVALID))
return ERR_PTR(-EFAULT); return ERR_PTR(-EFAULT);
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 20) & 0x7ff); table = table + ((gaddr >> 20) & 0x7ff);
return table; return table;
} }
/** /**
* __gmap_translate - translate a guest address to a user space address * __gmap_translate - translate a guest address to a user space address
* @address: guest address
* @gmap: pointer to guest mapping meta data structure * @gmap: pointer to guest mapping meta data structure
* @gaddr: guest address
* *
* Returns user space address which corresponds to the guest address or * Returns user space address which corresponds to the guest address or
* -EFAULT if no such mapping exists. * -EFAULT if no such mapping exists.
...@@ -436,14 +437,14 @@ static unsigned long *gmap_table_walk(unsigned long address, struct gmap *gmap) ...@@ -436,14 +437,14 @@ static unsigned long *gmap_table_walk(unsigned long address, struct gmap *gmap)
* The mmap_sem of the mm that belongs to the address space must be held * The mmap_sem of the mm that belongs to the address space must be held
* when this function gets called. * when this function gets called.
*/ */
unsigned long __gmap_translate(unsigned long address, struct gmap *gmap) unsigned long __gmap_translate(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long *segment_ptr, vmaddr, segment; unsigned long *segment_ptr, vmaddr, segment;
struct gmap_pgtable *mp; struct gmap_pgtable *mp;
struct page *page; struct page *page;
current->thread.gmap_addr = address; current->thread.gmap_addr = gaddr;
segment_ptr = gmap_table_walk(address, gmap); segment_ptr = gmap_table_walk(gmap, gaddr);
if (IS_ERR(segment_ptr)) if (IS_ERR(segment_ptr))
return PTR_ERR(segment_ptr); return PTR_ERR(segment_ptr);
/* Convert the gmap address to an mm address. */ /* Convert the gmap address to an mm address. */
...@@ -451,10 +452,10 @@ unsigned long __gmap_translate(unsigned long address, struct gmap *gmap) ...@@ -451,10 +452,10 @@ unsigned long __gmap_translate(unsigned long address, struct gmap *gmap)
if (!(segment & _SEGMENT_ENTRY_INVALID)) { if (!(segment & _SEGMENT_ENTRY_INVALID)) {
page = pfn_to_page(segment >> PAGE_SHIFT); page = pfn_to_page(segment >> PAGE_SHIFT);
mp = (struct gmap_pgtable *) page->index; mp = (struct gmap_pgtable *) page->index;
return mp->vmaddr | (address & ~PMD_MASK); return mp->vmaddr | (gaddr & ~PMD_MASK);
} else if (segment & _SEGMENT_ENTRY_PROTECT) { } else if (segment & _SEGMENT_ENTRY_PROTECT) {
vmaddr = segment & _SEGMENT_ENTRY_ORIGIN; vmaddr = segment & _SEGMENT_ENTRY_ORIGIN;
return vmaddr | (address & ~PMD_MASK); return vmaddr | (gaddr & ~PMD_MASK);
} }
return -EFAULT; return -EFAULT;
} }
...@@ -462,26 +463,27 @@ EXPORT_SYMBOL_GPL(__gmap_translate); ...@@ -462,26 +463,27 @@ EXPORT_SYMBOL_GPL(__gmap_translate);
/** /**
* gmap_translate - translate a guest address to a user space address * gmap_translate - translate a guest address to a user space address
* @address: guest address
* @gmap: pointer to guest mapping meta data structure * @gmap: pointer to guest mapping meta data structure
* @gaddr: guest address
* *
* Returns user space address which corresponds to the guest address or * Returns user space address which corresponds to the guest address or
* -EFAULT if no such mapping exists. * -EFAULT if no such mapping exists.
* This function does not establish potentially missing page table entries. * This function does not establish potentially missing page table entries.
*/ */
unsigned long gmap_translate(unsigned long address, struct gmap *gmap) unsigned long gmap_translate(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long rc; unsigned long rc;
down_read(&gmap->mm->mmap_sem); down_read(&gmap->mm->mmap_sem);
rc = __gmap_translate(address, gmap); rc = __gmap_translate(gmap, gaddr);
up_read(&gmap->mm->mmap_sem); up_read(&gmap->mm->mmap_sem);
return rc; return rc;
} }
EXPORT_SYMBOL_GPL(gmap_translate); EXPORT_SYMBOL_GPL(gmap_translate);
static int gmap_connect_pgtable(unsigned long address, unsigned long segment, static int gmap_connect_pgtable(struct gmap *gmap, unsigned long gaddr,
unsigned long *segment_ptr, struct gmap *gmap) unsigned long segment,
unsigned long *segment_ptr)
{ {
unsigned long vmaddr; unsigned long vmaddr;
struct vm_area_struct *vma; struct vm_area_struct *vma;
...@@ -521,7 +523,7 @@ static int gmap_connect_pgtable(unsigned long address, unsigned long segment, ...@@ -521,7 +523,7 @@ static int gmap_connect_pgtable(unsigned long address, unsigned long segment,
mp = (struct gmap_pgtable *) page->index; mp = (struct gmap_pgtable *) page->index;
rmap->gmap = gmap; rmap->gmap = gmap;
rmap->entry = segment_ptr; rmap->entry = segment_ptr;
rmap->vmaddr = address & PMD_MASK; rmap->vmaddr = gaddr & PMD_MASK;
spin_lock(&mm->page_table_lock); spin_lock(&mm->page_table_lock);
if (*segment_ptr == segment) { if (*segment_ptr == segment) {
list_add(&rmap->list, &mp->mapper); list_add(&rmap->list, &mp->mapper);
...@@ -560,15 +562,15 @@ static void gmap_disconnect_pgtable(struct mm_struct *mm, unsigned long *table) ...@@ -560,15 +562,15 @@ static void gmap_disconnect_pgtable(struct mm_struct *mm, unsigned long *table)
/* /*
* this function is assumed to be called with mmap_sem held * this function is assumed to be called with mmap_sem held
*/ */
unsigned long __gmap_fault(unsigned long address, struct gmap *gmap) unsigned long __gmap_fault(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long *segment_ptr, segment; unsigned long *segment_ptr, segment;
struct gmap_pgtable *mp; struct gmap_pgtable *mp;
struct page *page; struct page *page;
int rc; int rc;
current->thread.gmap_addr = address; current->thread.gmap_addr = gaddr;
segment_ptr = gmap_table_walk(address, gmap); segment_ptr = gmap_table_walk(gmap, gaddr);
if (IS_ERR(segment_ptr)) if (IS_ERR(segment_ptr))
return -EFAULT; return -EFAULT;
/* Convert the gmap address to an mm address. */ /* Convert the gmap address to an mm address. */
...@@ -578,24 +580,24 @@ unsigned long __gmap_fault(unsigned long address, struct gmap *gmap) ...@@ -578,24 +580,24 @@ unsigned long __gmap_fault(unsigned long address, struct gmap *gmap)
/* Page table is present */ /* Page table is present */
page = pfn_to_page(segment >> PAGE_SHIFT); page = pfn_to_page(segment >> PAGE_SHIFT);
mp = (struct gmap_pgtable *) page->index; mp = (struct gmap_pgtable *) page->index;
return mp->vmaddr | (address & ~PMD_MASK); return mp->vmaddr | (gaddr & ~PMD_MASK);
} }
if (!(segment & _SEGMENT_ENTRY_PROTECT)) if (!(segment & _SEGMENT_ENTRY_PROTECT))
/* Nothing mapped in the gmap address space. */ /* Nothing mapped in the gmap address space. */
break; break;
rc = gmap_connect_pgtable(address, segment, segment_ptr, gmap); rc = gmap_connect_pgtable(gmap, gaddr, segment, segment_ptr);
if (rc) if (rc)
return rc; return rc;
} }
return -EFAULT; return -EFAULT;
} }
unsigned long gmap_fault(unsigned long address, struct gmap *gmap) unsigned long gmap_fault(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long rc; unsigned long rc;
down_read(&gmap->mm->mmap_sem); down_read(&gmap->mm->mmap_sem);
rc = __gmap_fault(address, gmap); rc = __gmap_fault(gmap, gaddr);
up_read(&gmap->mm->mmap_sem); up_read(&gmap->mm->mmap_sem);
return rc; return rc;
...@@ -620,14 +622,14 @@ static void gmap_zap_swap_entry(swp_entry_t entry, struct mm_struct *mm) ...@@ -620,14 +622,14 @@ static void gmap_zap_swap_entry(swp_entry_t entry, struct mm_struct *mm)
/** /**
* The mm->mmap_sem lock must be held * The mm->mmap_sem lock must be held
*/ */
static void gmap_zap_unused(struct mm_struct *mm, unsigned long address) static void gmap_zap_unused(struct mm_struct *mm, unsigned long vmaddr)
{ {
unsigned long ptev, pgstev; unsigned long ptev, pgstev;
spinlock_t *ptl; spinlock_t *ptl;
pgste_t pgste; pgste_t pgste;
pte_t *ptep, pte; pte_t *ptep, pte;
ptep = get_locked_pte(mm, address, &ptl); ptep = get_locked_pte(mm, vmaddr, &ptl);
if (unlikely(!ptep)) if (unlikely(!ptep))
return; return;
pte = *ptep; pte = *ptep;
...@@ -640,7 +642,7 @@ static void gmap_zap_unused(struct mm_struct *mm, unsigned long address) ...@@ -640,7 +642,7 @@ static void gmap_zap_unused(struct mm_struct *mm, unsigned long address)
if (((pgstev & _PGSTE_GPS_USAGE_MASK) == _PGSTE_GPS_USAGE_UNUSED) || if (((pgstev & _PGSTE_GPS_USAGE_MASK) == _PGSTE_GPS_USAGE_UNUSED) ||
((pgstev & _PGSTE_GPS_ZERO) && (ptev & _PAGE_INVALID))) { ((pgstev & _PGSTE_GPS_ZERO) && (ptev & _PAGE_INVALID))) {
gmap_zap_swap_entry(pte_to_swp_entry(pte), mm); gmap_zap_swap_entry(pte_to_swp_entry(pte), mm);
pte_clear(mm, address, ptep); pte_clear(mm, vmaddr, ptep);
} }
pgste_set_unlock(ptep, pgste); pgste_set_unlock(ptep, pgste);
out_pte: out_pte:
...@@ -650,14 +652,14 @@ static void gmap_zap_unused(struct mm_struct *mm, unsigned long address) ...@@ -650,14 +652,14 @@ static void gmap_zap_unused(struct mm_struct *mm, unsigned long address)
/* /*
* this function is assumed to be called with mmap_sem held * this function is assumed to be called with mmap_sem held
*/ */
void __gmap_zap(unsigned long address, struct gmap *gmap) void __gmap_zap(struct gmap *gmap, unsigned long gaddr)
{ {
unsigned long *table, *segment_ptr; unsigned long *table, *segment_ptr;
unsigned long segment, pgstev, ptev; unsigned long segment, vmaddr, pgstev, ptev;
struct gmap_pgtable *mp; struct gmap_pgtable *mp;
struct page *page; struct page *page;
segment_ptr = gmap_table_walk(address, gmap); segment_ptr = gmap_table_walk(gmap, gaddr);
if (IS_ERR(segment_ptr)) if (IS_ERR(segment_ptr))
return; return;
segment = *segment_ptr; segment = *segment_ptr;
...@@ -665,61 +667,61 @@ void __gmap_zap(unsigned long address, struct gmap *gmap) ...@@ -665,61 +667,61 @@ void __gmap_zap(unsigned long address, struct gmap *gmap)
return; return;
page = pfn_to_page(segment >> PAGE_SHIFT); page = pfn_to_page(segment >> PAGE_SHIFT);
mp = (struct gmap_pgtable *) page->index; mp = (struct gmap_pgtable *) page->index;
address = mp->vmaddr | (address & ~PMD_MASK); vmaddr = mp->vmaddr | (gaddr & ~PMD_MASK);
/* Page table is present */ /* Page table is present */
table = (unsigned long *)(segment & _SEGMENT_ENTRY_ORIGIN); table = (unsigned long *)(segment & _SEGMENT_ENTRY_ORIGIN);
table = table + ((address >> 12) & 0xff); table = table + ((vmaddr >> 12) & 0xff);
pgstev = table[PTRS_PER_PTE]; pgstev = table[PTRS_PER_PTE];
ptev = table[0]; ptev = table[0];
/* quick check, checked again with locks held */ /* quick check, checked again with locks held */
if (((pgstev & _PGSTE_GPS_USAGE_MASK) == _PGSTE_GPS_USAGE_UNUSED) || if (((pgstev & _PGSTE_GPS_USAGE_MASK) == _PGSTE_GPS_USAGE_UNUSED) ||
((pgstev & _PGSTE_GPS_ZERO) && (ptev & _PAGE_INVALID))) ((pgstev & _PGSTE_GPS_ZERO) && (ptev & _PAGE_INVALID)))
gmap_zap_unused(gmap->mm, address); gmap_zap_unused(gmap->mm, vmaddr);
} }
EXPORT_SYMBOL_GPL(__gmap_zap); EXPORT_SYMBOL_GPL(__gmap_zap);
void gmap_discard(unsigned long from, unsigned long to, struct gmap *gmap) void gmap_discard(struct gmap *gmap, unsigned long from, unsigned long to)
{ {
unsigned long *table, address, size; unsigned long *table, gaddr, size;
struct vm_area_struct *vma; struct vm_area_struct *vma;
struct gmap_pgtable *mp; struct gmap_pgtable *mp;
struct page *page; struct page *page;
down_read(&gmap->mm->mmap_sem); down_read(&gmap->mm->mmap_sem);
address = from; gaddr = from;
while (address < to) { while (gaddr < to) {
/* Walk the gmap address space page table */ /* Walk the gmap address space page table */
table = gmap->table + ((address >> 53) & 0x7ff); table = gmap->table + ((gaddr >> 53) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) { if (unlikely(*table & _REGION_ENTRY_INVALID)) {
address = (address + PMD_SIZE) & PMD_MASK; gaddr = (gaddr + PMD_SIZE) & PMD_MASK;
continue; continue;
} }
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 42) & 0x7ff); table = table + ((gaddr >> 42) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) { if (unlikely(*table & _REGION_ENTRY_INVALID)) {
address = (address + PMD_SIZE) & PMD_MASK; gaddr = (gaddr + PMD_SIZE) & PMD_MASK;
continue; continue;
} }
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 31) & 0x7ff); table = table + ((gaddr >> 31) & 0x7ff);
if (unlikely(*table & _REGION_ENTRY_INVALID)) { if (unlikely(*table & _REGION_ENTRY_INVALID)) {
address = (address + PMD_SIZE) & PMD_MASK; gaddr = (gaddr + PMD_SIZE) & PMD_MASK;
continue; continue;
} }
table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN);
table = table + ((address >> 20) & 0x7ff); table = table + ((gaddr >> 20) & 0x7ff);
if (unlikely(*table & _SEGMENT_ENTRY_INVALID)) { if (unlikely(*table & _SEGMENT_ENTRY_INVALID)) {
address = (address + PMD_SIZE) & PMD_MASK; gaddr = (gaddr + PMD_SIZE) & PMD_MASK;
continue; continue;
} }
page = pfn_to_page(*table >> PAGE_SHIFT); page = pfn_to_page(*table >> PAGE_SHIFT);
mp = (struct gmap_pgtable *) page->index; mp = (struct gmap_pgtable *) page->index;
vma = find_vma(gmap->mm, mp->vmaddr); vma = find_vma(gmap->mm, mp->vmaddr);
size = min(to - address, PMD_SIZE - (address & ~PMD_MASK)); size = min(to - gaddr, PMD_SIZE - (gaddr & ~PMD_MASK));
zap_page_range(vma, mp->vmaddr | (address & ~PMD_MASK), zap_page_range(vma, mp->vmaddr | (gaddr & ~PMD_MASK),
size, NULL); size, NULL);
address = (address + PMD_SIZE) & PMD_MASK; gaddr = (gaddr + PMD_SIZE) & PMD_MASK;
} }
up_read(&gmap->mm->mmap_sem); up_read(&gmap->mm->mmap_sem);
} }
...@@ -755,7 +757,7 @@ EXPORT_SYMBOL_GPL(gmap_unregister_ipte_notifier); ...@@ -755,7 +757,7 @@ EXPORT_SYMBOL_GPL(gmap_unregister_ipte_notifier);
/** /**
* gmap_ipte_notify - mark a range of ptes for invalidation notification * gmap_ipte_notify - mark a range of ptes for invalidation notification
* @gmap: pointer to guest mapping meta data structure * @gmap: pointer to guest mapping meta data structure
* @start: virtual address in the guest address space * @gaddr: virtual address in the guest address space
* @len: size of area * @len: size of area
* *
* Returns 0 if for each page in the given range a gmap mapping exists and * Returns 0 if for each page in the given range a gmap mapping exists and
...@@ -763,7 +765,7 @@ EXPORT_SYMBOL_GPL(gmap_unregister_ipte_notifier); ...@@ -763,7 +765,7 @@ EXPORT_SYMBOL_GPL(gmap_unregister_ipte_notifier);
* for one or more pages -EFAULT is returned. If no memory could be allocated * for one or more pages -EFAULT is returned. If no memory could be allocated
* -ENOMEM is returned. This function establishes missing page table entries. * -ENOMEM is returned. This function establishes missing page table entries.
*/ */
int gmap_ipte_notify(struct gmap *gmap, unsigned long start, unsigned long len) int gmap_ipte_notify(struct gmap *gmap, unsigned long gaddr, unsigned long len)
{ {
unsigned long addr; unsigned long addr;
spinlock_t *ptl; spinlock_t *ptl;
...@@ -771,12 +773,12 @@ int gmap_ipte_notify(struct gmap *gmap, unsigned long start, unsigned long len) ...@@ -771,12 +773,12 @@ int gmap_ipte_notify(struct gmap *gmap, unsigned long start, unsigned long len)
pgste_t pgste; pgste_t pgste;
int rc = 0; int rc = 0;
if ((start & ~PAGE_MASK) || (len & ~PAGE_MASK)) if ((gaddr & ~PAGE_MASK) || (len & ~PAGE_MASK))
return -EINVAL; return -EINVAL;
down_read(&gmap->mm->mmap_sem); down_read(&gmap->mm->mmap_sem);
while (len) { while (len) {
/* Convert gmap address and connect the page tables */ /* Convert gmap address and connect the page tables */
addr = __gmap_fault(start, gmap); addr = __gmap_fault(gmap, gaddr);
if (IS_ERR_VALUE(addr)) { if (IS_ERR_VALUE(addr)) {
rc = addr; rc = addr;
break; break;
...@@ -796,7 +798,7 @@ int gmap_ipte_notify(struct gmap *gmap, unsigned long start, unsigned long len) ...@@ -796,7 +798,7 @@ int gmap_ipte_notify(struct gmap *gmap, unsigned long start, unsigned long len)
pgste = pgste_get_lock(ptep); pgste = pgste_get_lock(ptep);
pgste_val(pgste) |= PGSTE_IN_BIT; pgste_val(pgste) |= PGSTE_IN_BIT;
pgste_set_unlock(ptep, pgste); pgste_set_unlock(ptep, pgste);
start += PAGE_SIZE; gaddr += PAGE_SIZE;
len -= PAGE_SIZE; len -= PAGE_SIZE;
} }
spin_unlock(ptl); spin_unlock(ptl);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment