qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: David Gibson <david@gibson.dropbear.id.au>
To: agraf@suse.de
Cc: David Gibson <david@gibson.dropbear.id.au>,
	qemu-ppc@nongnu.org, afaerber@suse.de, qemu-devel@nongnu.org
Subject: [Qemu-devel] [PATCH 33/45] mmu-hash32: Clean up BAT matching logic
Date: Wed,  6 Mar 2013 14:44:21 +1100	[thread overview]
Message-ID: <1362541473-4365-34-git-send-email-david@gibson.dropbear.id.au> (raw)
In-Reply-To: <1362541473-4365-1-git-send-email-david@gibson.dropbear.id.au>

The code to search for a matching BAT for a virtual address is somewhat
longwinded and awkward.  In particular, it relies on seperate size and
validity information being returned from the hash32_bat_size() function
(and 601 specific variant).

We simplify this by having hash32_bat_size() return instead a mask of the
virtual address bits to match, and 0 for invalid (since a BAT can never
match the entire address space).

Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
---
 target-ppc/mmu-hash32.c |   74 +++++++++++++++++++----------------------------
 target-ppc/mmu-hash32.h |    4 ---
 2 files changed, 30 insertions(+), 48 deletions(-)

diff --git a/target-ppc/mmu-hash32.c b/target-ppc/mmu-hash32.c
index 6c71ebd..40d3564 100644
--- a/target-ppc/mmu-hash32.c
+++ b/target-ppc/mmu-hash32.c
@@ -113,20 +113,15 @@ static int ppc_hash32_check_prot(int prot, int rwx)
     return ret;
 }
 
-static void hash32_bat_size(CPUPPCState *env, target_ulong *blp, int *validp,
-                            target_ulong batu, target_ulong batl)
+static target_ulong hash32_bat_size(CPUPPCState *env,
+                                    target_ulong batu, target_ulong batl)
 {
-    target_ulong bl;
-    int valid;
-
-    bl = (batu & BATU32_BL) << 15;
-    valid = 0;
-    if (((msr_pr == 0) && (batu & BATU32_VS)) ||
-        ((msr_pr != 0) && (batu & BATU32_VP))) {
-        valid = 1;
+    if ((msr_pr && !(batu & BATU32_VP))
+        || (!msr_pr && !(batu & BATU32_VS))) {
+        return 0;
     }
-    *blp = bl;
-    *validp = valid;
+
+    return BATU32_BEPI & ~((batu & BATU32_BL) << 15);
 }
 
 static int hash32_bat_prot(CPUPPCState *env,
@@ -145,18 +140,14 @@ static int hash32_bat_prot(CPUPPCState *env,
     return prot;
 }
 
-static void hash32_bat_601_size(CPUPPCState *env, target_ulong *blp, int *validp,
+static target_ulong hash32_bat_601_size(CPUPPCState *env,
                                 target_ulong batu, target_ulong batl)
 {
-    target_ulong bl;
-    int valid;
-
-    bl = (batl & BATL32_601_BL) << 17;
-    LOG_BATS("b %02x ==> bl " TARGET_FMT_lx " msk " TARGET_FMT_lx "\n",
-             (uint8_t)(batl & BATL32_601_BL), bl, ~bl);
-    valid = !!(batl & BATL32_601_V);
-    *blp = bl;
-    *validp = valid;
+    if (!(batl & BATL32_601_V)) {
+        return 0;
+    }
+
+    return BATU32_BEPI & ~((batl & BATL32_601_BL) << 17);
 }
 
 static int hash32_bat_601_prot(CPUPPCState *env,
@@ -177,8 +168,7 @@ static int ppc_hash32_get_bat(CPUPPCState *env, struct mmu_ctx_hash32 *ctx,
                               target_ulong virtual, int rwx)
 {
     target_ulong *BATlt, *BATut;
-    target_ulong BEPIl, BEPIu, bl;
-    int i, valid, prot;
+    int i, prot;
     int ret = -1;
 
     LOG_BATS("%s: %cBAT v " TARGET_FMT_lx "\n", __func__,
@@ -193,37 +183,33 @@ static int ppc_hash32_get_bat(CPUPPCState *env, struct mmu_ctx_hash32 *ctx,
     for (i = 0; i < env->nb_BATs; i++) {
         target_ulong batu = BATut[i];
         target_ulong batl = BATlt[i];
+        target_ulong mask;
 
-        BEPIu = batu & BATU32_BEPIU;
-        BEPIl = batu & BATU32_BEPIL;
         if (unlikely(env->mmu_model == POWERPC_MMU_601)) {
-            hash32_bat_601_size(env, &bl, &valid, batu, batl);
+            mask = hash32_bat_601_size(env, batu, batl);
             prot = hash32_bat_601_prot(env, batu, batl);
         } else {
-            hash32_bat_size(env, &bl, &valid, batu, batl);
+            mask = hash32_bat_size(env, batu, batl);
             prot = hash32_bat_prot(env, batu, batl);
         }
         LOG_BATS("%s: %cBAT%d v " TARGET_FMT_lx " BATu " TARGET_FMT_lx
                  " BATl " TARGET_FMT_lx "\n", __func__,
                  type == ACCESS_CODE ? 'I' : 'D', i, virtual, batu, batl);
-        if ((virtual & BATU32_BEPIU) == BEPIu &&
-            ((virtual & BATU32_BEPIL) & ~bl) == BEPIl) {
+
+        if (mask && ((virtual & mask) == (batu & BATU32_BEPI))) {
             /* BAT matches */
-            if (valid != 0) {
-                /* Get physical address */
-                ctx->raddr = (batl & BATL32_BRPNU) |
-                    ((virtual & BATU32_BEPIL & bl) | (batl & BATL32_BRPNL)) |
-                    (virtual & 0x0001F000);
-                /* Compute access rights */
-                ctx->prot = prot;
-                ret = ppc_hash32_check_prot(ctx->prot, rwx);
-                if (ret == 0) {
-                    LOG_BATS("BAT %d match: r " TARGET_FMT_plx " prot=%c%c\n",
-                             i, ctx->raddr, ctx->prot & PAGE_READ ? 'R' : '-',
-                             ctx->prot & PAGE_WRITE ? 'W' : '-');
-                }
-                break;
+            /* Get physical address */
+            ctx->raddr = (batl & mask) | (virtual & ~mask);
+            ctx->raddr &= TARGET_PAGE_MASK;
+            /* Compute access rights */
+            ctx->prot = prot;
+            ret = ppc_hash32_check_prot(ctx->prot, rwx);
+            if (ret == 0) {
+                LOG_BATS("BAT %d match: r " TARGET_FMT_plx " prot=%c%c\n",
+                         i, ctx->raddr, ctx->prot & PAGE_READ ? 'R' : '-',
+                         ctx->prot & PAGE_WRITE ? 'W' : '-');
             }
+            break;
         }
     }
     if (ret < 0) {
diff --git a/target-ppc/mmu-hash32.h b/target-ppc/mmu-hash32.h
index d6e9330..06cd0e6 100644
--- a/target-ppc/mmu-hash32.h
+++ b/target-ppc/mmu-hash32.h
@@ -20,16 +20,12 @@ int ppc_hash32_handle_mmu_fault(CPUPPCState *env, target_ulong address, int rw,
  * Block Address Translation (BAT) definitions
  */
 
-#define BATU32_BEPIU            0xf0000000
-#define BATU32_BEPIL            0x0ffe0000
 #define BATU32_BEPI             0xfffe0000
 #define BATU32_BL               0x00001ffc
 #define BATU32_VS               0x00000002
 #define BATU32_VP               0x00000001
 
 
-#define BATL32_BRPNU            0xf0000000
-#define BATL32_BRPNL            0x0ffe0000
 #define BATL32_BRPN             0xfffe0000
 #define BATL32_WIMG             0x00000078
 #define BATL32_PP               0x00000003
-- 
1.7.10.4

  parent reply	other threads:[~2013-03-06  3:46 UTC|newest]

Thread overview: 46+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-03-06  3:43 [Qemu-devel] [0/45] ppc: Clean up hash mmu implementation David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 01/45] target-ppc: Remove vestigial PowerPC 620 support David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 02/45] target-ppc: Trivial cleanups in mmu_helper.c David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 03/45] target-ppc: Remove address check for logging David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 04/45] target-ppc: Move SLB handling into a mmu-hash64.c David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 05/45] target-ppc: Disentangle pte_check() David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 06/45] target-ppc: Disentangle find_pte() David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 07/45] target-ppc: Disentangle get_segment() David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 08/45] target-ppc: Rework get_physical_address() David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 09/45] target-ppc: Disentangle get_physical_address() paths David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 10/45] target-ppc: Disentangle hash mmu paths for cpu_ppc_handle_mmu_fault David Gibson
2013-03-06  3:43 ` [Qemu-devel] [PATCH 11/45] target-ppc: Disentangle hash mmu versions of cpu_get_phys_page_debug() David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 12/45] target-ppc: Disentangle hash mmu helper functions David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 13/45] target-ppc: Don't share get_pteg_offset() between 32 and 64-bit David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 14/45] target-ppc: Disentangle BAT code for 32-bit hash MMUs David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 15/45] target-ppc: mmu_ctx_t should not be a global type David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 16/45] mmu-hash*: Add header file for definitions David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 17/45] mmu-hash*: Add hash pte load/store helpers David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 18/45] mmu-hash*: Reduce use of access_type David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 19/45] mmu-hash64: Remove nx from mmu_ctx_hash64 David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 20/45] mmu-hash*: Remove eaddr field from mmu_ctx_hash{32, 64} David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 21/45] mmu-hash*: Combine ppc_hash{32, 64}_get_physical_address and get_segment{32, 64}() David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 22/45] mmu-hash32: Split out handling of direct store segments David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 23/45] mmu-hash32: Split direct store segment handling into a helper David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 24/45] mmu-hash*: Cleanup segment-level NX check David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 25/45] mmu-hash*: Don't keep looking for PTEs after we find a match David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 26/45] mmu-hash*: Separate PTEG searching from permissions checking David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 27/45] mmu-hash*: Make find_pte{32, 64} do more of the job of finding ptes David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 28/45] mmu-hash*: Remove permission checking from find_pte{32, 64}() David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 29/45] mmu-hash64: Clean up ppc_hash64_htab_lookup() David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 30/45] mmu-hash*: Fold pte_check*() logic into caller David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 31/45] mmu-hash32: Remove odd pointer usage from BAT code David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 32/45] mmu-hash32: Split BAT size logic from permissions logic David Gibson
2013-03-06  3:44 ` David Gibson [this message]
2013-03-06  3:44 ` [Qemu-devel] [PATCH 34/45] mmu-hash32: Cleanup BAT lookup David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 35/45] mmu-hash32: Don't look up page tables on BAT permission error David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 36/45] mmu-hash*: Don't update PTE flags when permission is denied David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 37/45] mmu-hash32: Remove nx from context structure David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 38/45] mmu-hash*: Clean up permission checking David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 39/45] mmu-hash64: Factor SLB N bit into permissions bits David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 40/45] mmu-hash*: Clean up PTE flags update David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 41/45] mmu-hash*: Clean up real address calculation David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 42/45] mmu-hash*: Correctly mask RPN from hash PTE David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 43/45] mmu-hash*: Don't use full ppc_hash{32, 64}_translate() path for get_phys_page_debug() David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 44/45] mmu-hash*: Merge translate and fault handling functions David Gibson
2013-03-06  3:44 ` [Qemu-devel] [PATCH 45/45] mmu-hash64: Implement Virtual Page Class Key Protection David Gibson

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1362541473-4365-34-git-send-email-david@gibson.dropbear.id.au \
    --to=david@gibson.dropbear.id.au \
    --cc=afaerber@suse.de \
    --cc=agraf@suse.de \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-ppc@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).