Commit e60c72e8 authored by Anton Blanchard's avatar Anton Blanchard

ppc64: hash_page whitespace and comment changes

parent 6375f9b6
...@@ -873,7 +873,8 @@ int hash_page(unsigned long ea, unsigned long access) ...@@ -873,7 +873,8 @@ int hash_page(unsigned long ea, unsigned long access)
old_pte = *ptep; old_pte = *ptep;
/* At this point we have found a pte (which was present). /*
* At this point we have found a pte (which was present).
* The spinlocks prevent this status from changing * The spinlocks prevent this status from changing
* The hash_table_lock prevents the _PAGE_HASHPTE status * The hash_table_lock prevents the _PAGE_HASHPTE status
* from changing (RPN, DIRTY and ACCESSED too) * from changing (RPN, DIRTY and ACCESSED too)
...@@ -881,41 +882,29 @@ int hash_page(unsigned long ea, unsigned long access) ...@@ -881,41 +882,29 @@ int hash_page(unsigned long ea, unsigned long access)
* invalidated or modified * invalidated or modified
*/ */
/* At this point, we have a pte (old_pte) which can be used to build or update /*
* an HPTE. There are 5 cases: * At this point, we have a pte (old_pte) which can be used to build
* or update an HPTE. There are 2 cases:
* *
* 1. There is a valid (present) pte with no associated HPTE (this is * 1. There is a valid (present) pte with no associated HPTE (this is
* the most common case) * the most common case)
* 2. There is a valid (present) pte with an associated HPTE. The * 2. There is a valid (present) pte with an associated HPTE. The
* current values of the pp bits in the HPTE prevent access because the * current values of the pp bits in the HPTE prevent access
* user doesn't have appropriate access rights. * because we are doing software DIRTY bit management and the
* 3. There is a valid (present) pte with an associated HPTE. The * page is currently not DIRTY.
* current values of the pp bits in the HPTE prevent access because we are
* doing software DIRTY bit management and the page is currently not DIRTY.
* 4. This is a Kernel address (0xC---) for which there is no page directory.
* There is an HPTE for this page, but the pp bits prevent access.
* Since we always set up kernel pages with R/W access for the kernel
* this case only comes about for users trying to access the kernel.
* This case is always an error and is not dealt with further here.
* 5. This is a Kernel address (0xC---) for which there is no page directory.
* There is no HPTE for this page.
*/ */
/* User has appropriate access rights. */
new_pte = old_pte; new_pte = old_pte;
/* If the attempted access was a store */ /* If the attempted access was a store */
if ( access & _PAGE_RW ) if (access & _PAGE_RW)
pte_val(new_pte) |= _PAGE_ACCESSED | _PAGE_DIRTY; pte_val(new_pte) |= _PAGE_ACCESSED | _PAGE_DIRTY;
else else
pte_val(new_pte) |= _PAGE_ACCESSED; pte_val(new_pte) |= _PAGE_ACCESSED;
/* Only cases 1, 3 and 5 still in play */ newpp = computeHptePP(pte_val(new_pte));
newpp = computeHptePP( pte_val(new_pte) );
/* Check if pte already has an hpte (case 3) */ /* Check if pte already has an hpte (case 2) */
if ( pte_val(old_pte) & _PAGE_HASHPTE ) { if (pte_val(old_pte) & _PAGE_HASHPTE) {
/* There MIGHT be an HPTE for this pte */ /* There MIGHT be an HPTE for this pte */
unsigned long hash, slot, secondary; unsigned long hash, slot, secondary;
/* Local copy of first doubleword of HPTE */ /* Local copy of first doubleword of HPTE */
...@@ -923,34 +912,36 @@ int hash_page(unsigned long ea, unsigned long access) ...@@ -923,34 +912,36 @@ int hash_page(unsigned long ea, unsigned long access)
unsigned long d; unsigned long d;
Hpte_dword0 h; Hpte_dword0 h;
} hpte_dw0; } hpte_dw0;
hash = hpt_hash(vpn, 0); hash = hpt_hash(vpn, 0);
secondary = (pte_val(old_pte) & _PAGE_SECONDARY) >> 15; secondary = (pte_val(old_pte) & _PAGE_SECONDARY) >> 15;
if ( secondary ) if (secondary)
hash = ~hash; hash = ~hash;
slot = (hash & htab_data.htab_hash_mask) * HPTES_PER_GROUP; slot = (hash & htab_data.htab_hash_mask) * HPTES_PER_GROUP;
slot += (pte_val(old_pte) & _PAGE_GROUP_IX) >> 12; slot += (pte_val(old_pte) & _PAGE_GROUP_IX) >> 12;
/* If there is an HPTE for this page it is indexed by slot */ /* If there is an HPTE for this page it is indexed by slot */
hpte_dw0.d = ppc_md.hpte_getword0( slot ); hpte_dw0.d = ppc_md.hpte_getword0(slot);
if ( (hpte_dw0.h.avpn == (vpn >> 11) ) && if ((hpte_dw0.h.avpn == (vpn >> 11)) &&
(hpte_dw0.h.v) && (hpte_dw0.h.v) &&
(hpte_dw0.h.h == secondary ) ){ (hpte_dw0.h.h == secondary)){
/* HPTE matches */ /* HPTE matches */
ppc_md.hpte_updatepp( slot, newpp, va ); ppc_md.hpte_updatepp(slot, newpp, va);
if ( !pte_same( old_pte, new_pte ) ) if (!pte_same(old_pte, new_pte))
*ptep = new_pte; *ptep = new_pte;
} else { } else {
/* HPTE is not for this pte */ /* HPTE is not for this pte */
pte_val(old_pte) &= ~_PAGE_HPTEFLAGS; pte_val(old_pte) &= ~_PAGE_HPTEFLAGS;
} }
} }
if ( !( pte_val(old_pte) & _PAGE_HASHPTE ) ) {
/* Cases 1 and 5 */ if (!(pte_val(old_pte) & _PAGE_HASHPTE)) {
/* For these cases we need to create a new /*
* HPTE and update the linux pte (for * Case 1
* case 1). For case 5 there is no linux pte. * For these cases we need to create a new
* * HPTE and update the linux pte
* Find an available HPTE slot
*/ */
/* Find an available HPTE slot */
slot = ppc_md.hpte_selectslot(vpn); slot = ppc_md.hpte_selectslot(vpn);
hash_ind = 0; hash_ind = 0;
......
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