[PATCH 31/38] target/hexagon: Add {TLB, k0}lock, cause code, wait_next_pc

Brian Cain posted 38 patches 1 month ago
Only 37 patches received!
[PATCH 31/38] target/hexagon: Add {TLB, k0}lock, cause code, wait_next_pc
Posted by Brian Cain via 1 month ago
From: Brian Cain <bcain@quicinc.com>

{TLB,k0}lock counts are used to represent the TLB, k0 locks among
hardware threads.

wait_next_pc represents the program counter to set when resuming from
a wait-for-interrupts state.

cause_code contains the precise exception cause.This will be used by
subsequent commits.

Signed-off-by: Brian Cain <brian.cain@oss.qualcomm.com>
---
 target/hexagon/cpu.h     | 4 ++++
 target/hexagon/cpu.c     | 4 ++++
 target/hexagon/machine.c | 4 ++++
 3 files changed, 12 insertions(+)

diff --git a/target/hexagon/cpu.h b/target/hexagon/cpu.h
index 0957faead3..ddc1158d8e 100644
--- a/target/hexagon/cpu.h
+++ b/target/hexagon/cpu.h
@@ -103,6 +103,7 @@ typedef struct {
 typedef struct CPUArchState {
     target_ulong gpr[TOTAL_PER_THREAD_REGS];
     target_ulong pred[NUM_PREGS];
+    target_ulong cause_code;
 
     /* For comparing with LLDB on target - see adjust_stack_ptrs function */
     target_ulong last_pc_dumped;
@@ -116,11 +117,14 @@ typedef struct CPUArchState {
     target_ulong *g_sreg;
 
     target_ulong greg[NUM_GREGS];
+    target_ulong wait_next_pc;
 
     /* This alias of CPUState.cpu_index is used by imported sources: */
     target_ulong threadId;
     hex_lock_state_t tlb_lock_state;
     hex_lock_state_t k0_lock_state;
+    target_ulong tlb_lock_count;
+    target_ulong k0_lock_count;
     target_ulong next_PC;
 #endif
     target_ulong new_value_usr;
diff --git a/target/hexagon/cpu.c b/target/hexagon/cpu.c
index c4b9df2fc3..7c34d015a3 100644
--- a/target/hexagon/cpu.c
+++ b/target/hexagon/cpu.c
@@ -312,7 +312,11 @@ static void hexagon_cpu_reset_hold(Object *obj, ResetType type)
     env->threadId = cs->cpu_index;
     env->tlb_lock_state = HEX_LOCK_UNLOCKED;
     env->k0_lock_state = HEX_LOCK_UNLOCKED;
+    env->tlb_lock_count = 0;
+    env->k0_lock_count = 0;
     env->next_PC = 0;
+    env->wait_next_pc = 0;
+    env->cause_code = -1;
 #endif
 }
 
diff --git a/target/hexagon/machine.c b/target/hexagon/machine.c
index dc900422f4..9fdafb4573 100644
--- a/target/hexagon/machine.c
+++ b/target/hexagon/machine.c
@@ -22,7 +22,11 @@ const VMStateDescription vmstate_hexagon_cpu = {
         VMSTATE_UINTTL(env.next_PC, HexagonCPU),
         VMSTATE_UINTTL(env.tlb_lock_state, HexagonCPU),
         VMSTATE_UINTTL(env.k0_lock_state, HexagonCPU),
+        VMSTATE_UINTTL(env.tlb_lock_count, HexagonCPU),
+        VMSTATE_UINTTL(env.k0_lock_count, HexagonCPU),
         VMSTATE_UINTTL(env.threadId, HexagonCPU),
+        VMSTATE_UINTTL(env.cause_code, HexagonCPU),
+        VMSTATE_UINTTL(env.wait_next_pc, HexagonCPU),
         VMSTATE_END_OF_LIST()
     },
 };
-- 
2.34.1

RE: [PATCH 31/38] target/hexagon: Add {TLB,k0}lock, cause code, wait_next_pc
Posted by Sid Manning 3 weeks ago

> -----Original Message-----
> From: Brian Cain <brian.cain@oss.qualcomm.com>
> Sent: Friday, February 28, 2025 11:26 PM
> To: qemu-devel@nongnu.org
> Cc: brian.cain@oss.qualcomm.com; richard.henderson@linaro.org;
> philmd@linaro.org; Matheus Bernardino (QUIC)
> <quic_mathbern@quicinc.com>; ale@rev.ng; anjo@rev.ng; Marco Liebel
> (QUIC) <quic_mliebel@quicinc.com>; ltaylorsimpson@gmail.com;
> alex.bennee@linaro.org; Mark Burton (QUIC)
> <quic_mburton@quicinc.com>; Sid Manning <sidneym@quicinc.com>; Brian
> Cain <bcain@quicinc.com>
> Subject: [PATCH 31/38] target/hexagon: Add {TLB,k0}lock, cause code,
> wait_next_pc
> 
> From: Brian Cain <bcain@quicinc.com>
> 
> {TLB,k0}lock counts are used to represent the TLB, k0 locks among hardware
> threads.
> 
> wait_next_pc represents the program counter to set when resuming from a
> wait-for-interrupts state.
> 
> cause_code contains the precise exception cause.This will be used by
> subsequent commits.
> 
> Signed-off-by: Brian Cain <brian.cain@oss.qualcomm.com>
> ---
>  target/hexagon/cpu.h     | 4 ++++
>  target/hexagon/cpu.c     | 4 ++++
>  target/hexagon/machine.c | 4 ++++
>  3 files changed, 12 insertions(+)
> 
> diff --git a/target/hexagon/cpu.h b/target/hexagon/cpu.h index
> 0957faead3..ddc1158d8e 100644
> --- a/target/hexagon/cpu.h
> +++ b/target/hexagon/cpu.h
> @@ -103,6 +103,7 @@ typedef struct {
>  typedef struct CPUArchState {
>      target_ulong gpr[TOTAL_PER_THREAD_REGS];
>      target_ulong pred[NUM_PREGS];
> +    target_ulong cause_code;
> 
>      /* For comparing with LLDB on target - see adjust_stack_ptrs function */
>      target_ulong last_pc_dumped;
> @@ -116,11 +117,14 @@ typedef struct CPUArchState {
>      target_ulong *g_sreg;
> 
>      target_ulong greg[NUM_GREGS];
> +    target_ulong wait_next_pc;
> 
>      /* This alias of CPUState.cpu_index is used by imported sources: */
>      target_ulong threadId;
>      hex_lock_state_t tlb_lock_state;
>      hex_lock_state_t k0_lock_state;
> +    target_ulong tlb_lock_count;
> +    target_ulong k0_lock_count;
>      target_ulong next_PC;
>  #endif
>      target_ulong new_value_usr;
> diff --git a/target/hexagon/cpu.c b/target/hexagon/cpu.c index
> c4b9df2fc3..7c34d015a3 100644
> --- a/target/hexagon/cpu.c
> +++ b/target/hexagon/cpu.c
> @@ -312,7 +312,11 @@ static void hexagon_cpu_reset_hold(Object *obj,
> ResetType type)
>      env->threadId = cs->cpu_index;
>      env->tlb_lock_state = HEX_LOCK_UNLOCKED;
>      env->k0_lock_state = HEX_LOCK_UNLOCKED;
> +    env->tlb_lock_count = 0;
> +    env->k0_lock_count = 0;
>      env->next_PC = 0;
> +    env->wait_next_pc = 0;
> +    env->cause_code = -1;
[Sid Manning] 
Instead of using -1 this could use HEX_CAUSE_NONE.

>  #endif
>  }
> 
> diff --git a/target/hexagon/machine.c b/target/hexagon/machine.c index
> dc900422f4..9fdafb4573 100644
> --- a/target/hexagon/machine.c
> +++ b/target/hexagon/machine.c
> @@ -22,7 +22,11 @@ const VMStateDescription vmstate_hexagon_cpu = {
>          VMSTATE_UINTTL(env.next_PC, HexagonCPU),
>          VMSTATE_UINTTL(env.tlb_lock_state, HexagonCPU),
>          VMSTATE_UINTTL(env.k0_lock_state, HexagonCPU),
> +        VMSTATE_UINTTL(env.tlb_lock_count, HexagonCPU),
> +        VMSTATE_UINTTL(env.k0_lock_count, HexagonCPU),
>          VMSTATE_UINTTL(env.threadId, HexagonCPU),
> +        VMSTATE_UINTTL(env.cause_code, HexagonCPU),
> +        VMSTATE_UINTTL(env.wait_next_pc, HexagonCPU),
>          VMSTATE_END_OF_LIST()
>      },
>  };
> --
> 2.34.1

RE: [PATCH 31/38] target/hexagon: Add {TLB, k0}lock, cause code, wait_next_pc
Posted by ltaylorsimpson@gmail.com 3 weeks, 1 day ago

> -----Original Message-----
> From: Brian Cain <brian.cain@oss.qualcomm.com>
> Sent: Friday, February 28, 2025 11:26 PM
> To: qemu-devel@nongnu.org
> Cc: brian.cain@oss.qualcomm.com; richard.henderson@linaro.org;
> philmd@linaro.org; quic_mathbern@quicinc.com; ale@rev.ng; anjo@rev.ng;
> quic_mliebel@quicinc.com; ltaylorsimpson@gmail.com;
> alex.bennee@linaro.org; quic_mburton@quicinc.com;
> sidneym@quicinc.com; Brian Cain <bcain@quicinc.com>
> Subject: [PATCH 31/38] target/hexagon: Add {TLB,k0}lock, cause code,
> wait_next_pc
> 
> From: Brian Cain <bcain@quicinc.com>
> 
> {TLB,k0}lock counts are used to represent the TLB, k0 locks among hardware
> threads.
> 
> wait_next_pc represents the program counter to set when resuming from a
> wait-for-interrupts state.
> 
> cause_code contains the precise exception cause.This will be used by
> subsequent commits.
> 
> Signed-off-by: Brian Cain <brian.cain@oss.qualcomm.com>

Reviewed-by: Taylor Simpson <ltaylorsimpson@gmail.com>