Re: [PATCH 2/2] target/hppa: Fix B,GATE for wide mode

2024-03-22 Thread Helge Deller

On 3/21/24 20:28, Richard Henderson wrote:

Do not clobber the high bits of the address by using a 32-bit deposit.

Signed-off-by: Richard Henderson 


Reviewed-by: Helge Deller 

Helge


---
  target/hppa/translate.c | 2 +-
  1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/target/hppa/translate.c b/target/hppa/translate.c
index 1766a63001..f875d76a23 100644
--- a/target/hppa/translate.c
+++ b/target/hppa/translate.c
@@ -3880,7 +3880,7 @@ static bool trans_b_gate(DisasContext *ctx, arg_b_gate *a)
  }
  /* No change for non-gateway pages or for priv decrease.  */
  if (type >= 4 && type - 4 < ctx->privilege) {
-dest = deposit32(dest, 0, 2, type - 4);
+dest = deposit64(dest, 0, 2, type - 4);
  }
  } else {
  dest &= -4;  /* priv = 0 */





Re: [PATCH 2/2] target/hppa: Fix B,GATE for wide mode

2024-03-21 Thread Richard Henderson

On 3/21/24 09:34, Philippe Mathieu-Daudé wrote:

On 21/3/24 20:28, Richard Henderson wrote:

Do not clobber the high bits of the address by using a 32-bit deposit.

Signed-off-by: Richard Henderson 
---
  target/hppa/translate.c | 2 +-
  1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/target/hppa/translate.c b/target/hppa/translate.c
index 1766a63001..f875d76a23 100644
--- a/target/hppa/translate.c
+++ b/target/hppa/translate.c
@@ -3880,7 +3880,7 @@ static bool trans_b_gate(DisasContext *ctx, arg_b_gate *a)
  }
  /* No change for non-gateway pages or for priv decrease.  */
  if (type >= 4 && type - 4 < ctx->privilege) {
-    dest = deposit32(dest, 0, 2, type - 4);
+    dest = deposit64(dest, 0, 2, type - 4);
  }
  } else {
  dest &= -4;  /* priv = 0 */


Fixes: 43e056522f ("target/hppa: Implement B,GATE insn")


Certainly not.  That predates hppa64 support by years.


r~



Re: [PATCH 2/2] target/hppa: Fix B,GATE for wide mode

2024-03-21 Thread Philippe Mathieu-Daudé

On 21/3/24 20:28, Richard Henderson wrote:

Do not clobber the high bits of the address by using a 32-bit deposit.

Signed-off-by: Richard Henderson 
---
  target/hppa/translate.c | 2 +-
  1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/target/hppa/translate.c b/target/hppa/translate.c
index 1766a63001..f875d76a23 100644
--- a/target/hppa/translate.c
+++ b/target/hppa/translate.c
@@ -3880,7 +3880,7 @@ static bool trans_b_gate(DisasContext *ctx, arg_b_gate *a)
  }
  /* No change for non-gateway pages or for priv decrease.  */
  if (type >= 4 && type - 4 < ctx->privilege) {
-dest = deposit32(dest, 0, 2, type - 4);
+dest = deposit64(dest, 0, 2, type - 4);
  }
  } else {
  dest &= -4;  /* priv = 0 */


Fixes: 43e056522f ("target/hppa: Implement B,GATE insn")
Reviewed-by: Philippe Mathieu-Daudé 




[PATCH 2/2] target/hppa: Fix B,GATE for wide mode

2024-03-21 Thread Richard Henderson
Do not clobber the high bits of the address by using a 32-bit deposit.

Signed-off-by: Richard Henderson 
---
 target/hppa/translate.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/target/hppa/translate.c b/target/hppa/translate.c
index 1766a63001..f875d76a23 100644
--- a/target/hppa/translate.c
+++ b/target/hppa/translate.c
@@ -3880,7 +3880,7 @@ static bool trans_b_gate(DisasContext *ctx, arg_b_gate *a)
 }
 /* No change for non-gateway pages or for priv decrease.  */
 if (type >= 4 && type - 4 < ctx->privilege) {
-dest = deposit32(dest, 0, 2, type - 4);
+dest = deposit64(dest, 0, 2, type - 4);
 }
 } else {
 dest &= -4;  /* priv = 0 */
-- 
2.34.1