qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] target/alpha: fix icount handling for timer instructions


From: Pavel Dovgalyuk
Subject: Re: [PATCH] target/alpha: fix icount handling for timer instructions
Date: Mon, 5 Apr 2021 08:50:19 +0300
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.1

Ping.

On 29.03.2021 10:42, Pavel Dovgalyuk wrote:
This patch handles icount mode for timer read/write instructions,
because it is required to call gen_io_start in such cases.

Signed-off-by: Pavel Dovgalyuk <pavel.dovgalyuk@ispras.ru>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
  target/alpha/translate.c |    9 +++++++--
  1 file changed, 7 insertions(+), 2 deletions(-)

diff --git a/target/alpha/translate.c b/target/alpha/translate.c
index a02b4e70b7..f454adea5e 100644
--- a/target/alpha/translate.c
+++ b/target/alpha/translate.c
@@ -1330,7 +1330,7 @@ static DisasJumpType gen_mfpr(DisasContext *ctx, TCGv va, 
int regno)
      case 249: /* VMTIME */
          helper = gen_helper_get_vmtime;
      do_helper:
-        if (icount_enabled()) {
+        if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
              gen_io_start();
              helper(va);
              return DISAS_PC_STALE;
@@ -1366,6 +1366,7 @@ static DisasJumpType gen_mfpr(DisasContext *ctx, TCGv va, 
int regno)
  static DisasJumpType gen_mtpr(DisasContext *ctx, TCGv vb, int regno)
  {
      int data;
+    DisasJumpType ret = DISAS_NEXT;
switch (regno) {
      case 255:
@@ -1395,6 +1396,10 @@ static DisasJumpType gen_mtpr(DisasContext *ctx, TCGv 
vb, int regno)
case 251:
          /* ALARM */
+        if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
+            gen_io_start();
+            ret = DISAS_PC_STALE;
+        }
          gen_helper_set_alarm(cpu_env, vb);
          break;
@@ -1434,7 +1439,7 @@ static DisasJumpType gen_mtpr(DisasContext *ctx, TCGv vb, int regno)
          break;
      }
- return DISAS_NEXT;
+    return ret;
  }
  #endif /* !USER_ONLY*/




reply via email to

[Prev in Thread] Current Thread [Next in Thread]