From: Richard Henderson <richard.henderson@linaro.org>
To: qemu-devel@nongnu.org
Cc: qemu-arm@nongnu.org, Pierrick Bouvier <pierrick.bouvier@linaro.org>
Subject: [PATCH v3 50/85] target/arm: Expand pstate to 64 bits
Date: Thu, 14 Aug 2025 22:57:17 +1000 [thread overview]
Message-ID: <20250814125752.164107-51-richard.henderson@linaro.org> (raw)
In-Reply-To: <20250814125752.164107-1-richard.henderson@linaro.org>
The ARM now defines 36 bits in SPSR_ELx in aarch64 mode, so
it's time to bite the bullet and extend PSTATE to match.
Most changes are straightforward, adjusting printf formats,
changing local variable types. More complex is migration,
where to maintain backward compatibility a new pstate64
record is introduced, and only when one of the extensions
that sets bits 32-35 are active.
The fate of gdbstub is left undecided for the moment.
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
target/arm/cpu.h | 8 +++---
target/arm/tcg/translate.h | 20 ++++++-------
target/arm/cpu.c | 6 ++--
target/arm/gdbstub64.c | 2 ++
target/arm/helper.c | 11 ++++----
target/arm/machine.c | 56 +++++++++++++++++++++++++++++++++++++
target/arm/tcg/helper-a64.c | 2 +-
7 files changed, 82 insertions(+), 23 deletions(-)
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
index 98360b70b8..7769c4ae3c 100644
--- a/target/arm/cpu.h
+++ b/target/arm/cpu.h
@@ -268,7 +268,7 @@ typedef struct CPUArchState {
uint64_t xregs[32];
uint64_t pc;
/* PSTATE isn't an architectural register for ARMv8. However, it is
- * convenient for us to assemble the underlying state into a 32 bit format
+ * convenient for us to assemble the underlying state into a 64 bit format
* identical to the architectural format used for the SPSR. (This is also
* what the Linux kernel's 'pstate' field in signal handlers and KVM's
* 'pstate' register are.) Of the PSTATE bits:
@@ -280,7 +280,7 @@ typedef struct CPUArchState {
* SM and ZA are kept in env->svcr
* all other bits are stored in their correct places in env->pstate
*/
- uint32_t pstate;
+ uint64_t pstate;
bool aarch64; /* True if CPU is in aarch64 state; inverse of PSTATE.nRW */
bool thumb; /* True if CPU is in thumb mode; cpsr[5] */
@@ -1556,7 +1556,7 @@ static inline unsigned int aarch64_pstate_mode(unsigned int el, bool handler)
* interprocessing, so we don't attempt to sync with the cpsr state used by
* the 32 bit decoder.
*/
-static inline uint32_t pstate_read(CPUARMState *env)
+static inline uint64_t pstate_read(CPUARMState *env)
{
int ZF;
@@ -1566,7 +1566,7 @@ static inline uint32_t pstate_read(CPUARMState *env)
| env->pstate | env->daif | (env->btype << 10);
}
-static inline void pstate_write(CPUARMState *env, uint32_t val)
+static inline void pstate_write(CPUARMState *env, uint64_t val)
{
env->ZF = (~val) & PSTATE_Z;
env->NF = val;
diff --git a/target/arm/tcg/translate.h b/target/arm/tcg/translate.h
index 3e63dad2b6..1479f5bf74 100644
--- a/target/arm/tcg/translate.h
+++ b/target/arm/tcg/translate.h
@@ -378,27 +378,27 @@ static inline TCGv_i32 get_ahp_flag(void)
}
/* Set bits within PSTATE. */
-static inline void set_pstate_bits(uint32_t bits)
+static inline void set_pstate_bits(uint64_t bits)
{
- TCGv_i32 p = tcg_temp_new_i32();
+ TCGv_i64 p = tcg_temp_new_i64();
tcg_debug_assert(!(bits & CACHED_PSTATE_BITS));
- tcg_gen_ld_i32(p, tcg_env, offsetof(CPUARMState, pstate));
- tcg_gen_ori_i32(p, p, bits);
- tcg_gen_st_i32(p, tcg_env, offsetof(CPUARMState, pstate));
+ tcg_gen_ld_i64(p, tcg_env, offsetof(CPUARMState, pstate));
+ tcg_gen_ori_i64(p, p, bits);
+ tcg_gen_st_i64(p, tcg_env, offsetof(CPUARMState, pstate));
}
/* Clear bits within PSTATE. */
-static inline void clear_pstate_bits(uint32_t bits)
+static inline void clear_pstate_bits(uint64_t bits)
{
- TCGv_i32 p = tcg_temp_new_i32();
+ TCGv_i64 p = tcg_temp_new_i64();
tcg_debug_assert(!(bits & CACHED_PSTATE_BITS));
- tcg_gen_ld_i32(p, tcg_env, offsetof(CPUARMState, pstate));
- tcg_gen_andi_i32(p, p, ~bits);
- tcg_gen_st_i32(p, tcg_env, offsetof(CPUARMState, pstate));
+ tcg_gen_ld_i64(p, tcg_env, offsetof(CPUARMState, pstate));
+ tcg_gen_andi_i64(p, p, ~bits);
+ tcg_gen_st_i64(p, tcg_env, offsetof(CPUARMState, pstate));
}
/* If the singlestep state is Active-not-pending, advance to Active-pending. */
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
index d9318c5325..ec63297165 100644
--- a/target/arm/cpu.c
+++ b/target/arm/cpu.c
@@ -1208,7 +1208,7 @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
{
ARMCPU *cpu = ARM_CPU(cs);
CPUARMState *env = &cpu->env;
- uint32_t psr = pstate_read(env);
+ uint64_t psr = pstate_read(env);
int i, j;
int el = arm_current_el(env);
uint64_t hcr = arm_hcr_el2_eff(env);
@@ -1230,7 +1230,7 @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
} else {
ns_status = "";
}
- qemu_fprintf(f, "PSTATE=%08x %c%c%c%c %sEL%d%c",
+ qemu_fprintf(f, "PSTATE=%016" PRIx64 " %c%c%c%c %sEL%d%c",
psr,
psr & PSTATE_N ? 'N' : '-',
psr & PSTATE_Z ? 'Z' : '-',
@@ -1247,7 +1247,7 @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
(FIELD_EX64(env->svcr, SVCR, SM) ? 'S' : '-'));
}
if (cpu_isar_feature(aa64_bti, cpu)) {
- qemu_fprintf(f, " BTYPE=%d", (psr & PSTATE_BTYPE) >> 10);
+ qemu_fprintf(f, " BTYPE=%d", (int)(psr & PSTATE_BTYPE) >> 10);
}
qemu_fprintf(f, "%s%s%s",
(hcr & HCR_NV) ? " NV" : "",
diff --git a/target/arm/gdbstub64.c b/target/arm/gdbstub64.c
index 08e2858539..d0d769df53 100644
--- a/target/arm/gdbstub64.c
+++ b/target/arm/gdbstub64.c
@@ -47,6 +47,7 @@ int aarch64_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n)
case 32:
return gdb_get_reg64(mem_buf, env->pc);
case 33:
+ /* pstate is now a 64-bit value; can we simply adjust the xml? */
return gdb_get_reg32(mem_buf, pstate_read(env));
}
/* Unknown register. */
@@ -75,6 +76,7 @@ int aarch64_cpu_gdb_write_register(CPUState *cs, uint8_t *mem_buf, int n)
return 8;
case 33:
/* CPSR */
+ /* pstate is now a 64-bit value; can we simply adjust the xml? */
pstate_write(env, tmp);
return 4;
}
diff --git a/target/arm/helper.c b/target/arm/helper.c
index 14f7129607..7d9b2762cf 100644
--- a/target/arm/helper.c
+++ b/target/arm/helper.c
@@ -9185,8 +9185,8 @@ static void arm_cpu_do_interrupt_aarch64(CPUState *cs)
CPUARMState *env = &cpu->env;
unsigned int new_el = env->exception.target_el;
vaddr addr = env->cp15.vbar_el[new_el];
- unsigned int new_mode = aarch64_pstate_mode(new_el, true);
- unsigned int old_mode;
+ uint64_t new_mode = aarch64_pstate_mode(new_el, true);
+ uint64_t old_mode;
unsigned int cur_el = arm_current_el(env);
int rt;
@@ -9334,7 +9334,7 @@ static void arm_cpu_do_interrupt_aarch64(CPUState *cs)
* If NV2 is disabled, change SPSR when NV,NV1 == 1,0 (I_ZJRNN)
* If NV2 is enabled, change SPSR when NV is 1 (I_DBTLM)
*/
- old_mode = deposit32(old_mode, 2, 2, 2);
+ old_mode = deposit64(old_mode, 2, 2, 2);
}
}
} else {
@@ -9347,7 +9347,7 @@ static void arm_cpu_do_interrupt_aarch64(CPUState *cs)
}
env->banked_spsr[aarch64_banked_spsr_index(new_el)] = old_mode;
- qemu_log_mask(CPU_LOG_INT, "...with SPSR 0x%x\n", old_mode);
+ qemu_log_mask(CPU_LOG_INT, "...with SPSR 0x%" PRIx64 "\n", old_mode);
qemu_log_mask(CPU_LOG_INT, "...with ELR 0x%" PRIx64 "\n",
env->elr_el[new_el]);
@@ -9401,7 +9401,8 @@ static void arm_cpu_do_interrupt_aarch64(CPUState *cs)
env->pc = addr;
- qemu_log_mask(CPU_LOG_INT, "...to EL%d PC 0x%" PRIx64 " PSTATE 0x%x\n",
+ qemu_log_mask(CPU_LOG_INT, "...to EL%d PC 0x%" PRIx64
+ " PSTATE 0x%" PRIx64 "\n",
new_el, env->pc, pstate_read(env));
}
diff --git a/target/arm/machine.c b/target/arm/machine.c
index 8dbeca2867..9b00c14b4a 100644
--- a/target/arm/machine.c
+++ b/target/arm/machine.c
@@ -836,6 +836,61 @@ static const VMStateInfo vmstate_cpsr = {
.put = put_cpsr,
};
+static int get_pstate64_1(QEMUFile *f, void *opaque, size_t size,
+ const VMStateField *field)
+{
+ ARMCPU *cpu = opaque;
+ CPUARMState *env = &cpu->env;
+ uint64_t val = qemu_get_be64(f);
+
+ env->aarch64 = ((val & PSTATE_nRW) == 0);
+ pstate_write(env, val);
+ return 0;
+}
+
+static int put_pstate64_1(QEMUFile *f, void *opaque, size_t size,
+ const VMStateField *field, JSONWriter *vmdesc)
+{
+ ARMCPU *cpu = opaque;
+ CPUARMState *env = &cpu->env;
+ uint64_t val = pstate_read(env);
+
+ qemu_put_be64(f, val);
+ return 0;
+}
+
+static const VMStateInfo vmstate_pstate64_1 = {
+ .name = "pstate64",
+ .get = get_pstate64_1,
+ .put = put_pstate64_1,
+};
+
+static bool pstate64_needed(void *opaque)
+{
+ ARMCPU *cpu = opaque;
+ CPUARMState *env = &cpu->env;
+
+ return is_a64(env) && pstate_read(env) > UINT32_MAX;
+}
+
+static const VMStateDescription vmstate_pstate64 = {
+ .name = "cpu/pstate64",
+ .version_id = 1,
+ .minimum_version_id = 1,
+ .needed = pstate64_needed,
+ .fields = (const VMStateField[]) {
+ {
+ .name = "pstate64",
+ .version_id = 0,
+ .size = sizeof(uint64_t),
+ .info = &vmstate_pstate64_1,
+ .flags = VMS_SINGLE,
+ .offset = 0,
+ },
+ VMSTATE_END_OF_LIST()
+ },
+};
+
static int get_power(QEMUFile *f, void *opaque, size_t size,
const VMStateField *field)
{
@@ -1119,6 +1174,7 @@ const VMStateDescription vmstate_arm_cpu = {
&vmstate_serror,
&vmstate_irq_line_state,
&vmstate_wfxt_timer,
+ &vmstate_pstate64,
NULL
}
};
diff --git a/target/arm/tcg/helper-a64.c b/target/arm/tcg/helper-a64.c
index 71c6c44ee8..f61adf1f80 100644
--- a/target/arm/tcg/helper-a64.c
+++ b/target/arm/tcg/helper-a64.c
@@ -639,7 +639,7 @@ void HELPER(exception_return)(CPUARMState *env, uint64_t new_pc)
ARMCPU *cpu = env_archcpu(env);
int cur_el = arm_current_el(env);
unsigned int spsr_idx = aarch64_banked_spsr_index(cur_el);
- uint32_t spsr = env->banked_spsr[spsr_idx];
+ uint64_t spsr = env->banked_spsr[spsr_idx];
int new_el;
bool return_to_aa64 = (spsr & PSTATE_nRW) == 0;
--
2.43.0
next prev parent reply other threads:[~2025-08-14 13:18 UTC|newest]
Thread overview: 87+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-08-14 12:56 [PATCH v3 00/85] target/arm: Implement FEAT_GCS Richard Henderson
2025-08-14 12:56 ` [PATCH v3 01/85] linux-user/aarch64: Split out signal_for_exception Richard Henderson
2025-08-14 12:56 ` [PATCH v3 02/85] linux-user/aarch64: Check syndrome for EXCP_UDEF Richard Henderson
2025-08-14 12:56 ` [PATCH v3 03/85] linux-user/aarch64: Generate ESR signal records Richard Henderson
2025-08-14 12:56 ` [PATCH v3 04/85] target/arm: Add prot_check parameter to pmsav8_mpu_lookup Richard Henderson
2025-08-14 12:56 ` [PATCH v3 05/85] target/arm: Add in_prot_check to S1Translate Richard Henderson
2025-08-14 12:56 ` [PATCH v3 06/85] target/arm: Skip permission check from arm_cpu_get_phys_page_attrs_debug Richard Henderson
2025-08-14 12:56 ` [PATCH v3 07/85] target/arm: Introduce get_phys_addr_for_at Richard Henderson
2025-08-14 12:56 ` [PATCH v3 08/85] target/arm: Skip AF and DB updates for AccessType_AT Richard Henderson
2025-08-14 12:56 ` [PATCH v3 09/85] target/arm: Add prot_check parameter to do_ats_write Richard Henderson
2025-08-14 12:56 ` [PATCH v3 10/85] target/arm: Fill in HFG[RWI]TR_EL2 bits for Arm v9.5 Richard Henderson
2025-08-14 12:56 ` [PATCH v3 11/85] target/arm: Remove outdated comment for ZCR_EL12 Richard Henderson
2025-08-14 12:56 ` [PATCH v3 12/85] target/arm: Implement FEAT_ATS1A Richard Henderson
2025-08-14 12:56 ` [PATCH v3 13/85] target/arm: Add isar feature test for FEAT_S1PIE, FEAT_S2PIE Richard Henderson
2025-08-14 12:56 ` [PATCH v3 14/85] target/arm: Enable TCR2_ELx.PIE Richard Henderson
2025-08-14 12:56 ` [PATCH v3 15/85] target/arm: Implement PIR_ELx, PIRE0_ELx, S2PIR_EL2 registers Richard Henderson
2025-08-14 12:56 ` [PATCH v3 16/85] target/arm: Force HPD for stage2 translations Richard Henderson
2025-08-14 12:56 ` [PATCH v3 17/85] target/arm: Cache NV1 early in get_phys_addr_lpae Richard Henderson
2025-08-14 12:56 ` [PATCH v3 18/85] target/arm: Populate PIE in aa64_va_parameters Richard Henderson
2025-08-14 12:56 ` [PATCH v3 19/85] target/arm: Implement get_S1prot_indirect Richard Henderson
2025-08-14 12:56 ` [PATCH v3 20/85] target/arm: Implement get_S2prot_indirect Richard Henderson
2025-08-14 12:56 ` [PATCH v3 21/85] target/arm: Do not migrate env->exception Richard Henderson
2025-08-14 12:56 ` [PATCH v3 22/85] target/arm: Expand CPUARMState.exception.syndrome to 64 bits Richard Henderson
2025-08-14 12:56 ` [PATCH v3 23/85] target/arm: Expand syndrome parameter to raise_exception* Richard Henderson
2025-08-14 12:56 ` [PATCH v3 24/85] target/arm: Implement dirtybit check for PIE Richard Henderson
2025-08-14 12:56 ` [PATCH v3 25/85] target/arm: Enable FEAT_S1PIE and FEAT_S2PIE on -cpu max Richard Henderson
2025-08-14 12:56 ` [PATCH v3 26/85] include/hw/core/cpu: Introduce MMUIdxMap Richard Henderson
2025-08-14 12:56 ` [PATCH v3 27/85] include/hw/core/cpu: Introduce cpu_tlb_fast Richard Henderson
2025-08-14 12:56 ` [PATCH v3 28/85] include/hw/core/cpu: Invert the indexing into CPUTLBDescFast Richard Henderson
2025-08-14 12:56 ` [PATCH v3 29/85] target/hppa: Adjust mmu indexes to begin with 0 Richard Henderson
2025-08-14 12:56 ` [PATCH v3 30/85] include/exec/memopidx: Adjust for 32 mmu indexes Richard Henderson
2025-08-14 12:56 ` [PATCH v3 31/85] include/hw/core/cpu: Widen MMUIdxMap Richard Henderson
2025-08-14 12:56 ` [PATCH v3 32/85] target/arm: Split out mmuidx.h from cpu.h Richard Henderson
2025-08-14 12:57 ` [PATCH v3 33/85] target/arm: Convert arm_mmu_idx_to_el from switch to table Richard Henderson
2025-08-14 12:57 ` [PATCH v3 34/85] target/arm: Remove unused env argument from regime_el Richard Henderson
2025-08-14 12:57 ` [PATCH v3 35/85] target/arm: Convert regime_el from switch to table Richard Henderson
2025-08-14 12:57 ` [PATCH v3 36/85] target/arm: Convert regime_has_2_ranges " Richard Henderson
2025-08-14 12:57 ` [PATCH v3 37/85] target/arm: Remove unused env argument from regime_is_pan Richard Henderson
2025-08-14 12:57 ` [PATCH v3 38/85] target/arm: Convert regime_is_pan from switch to table Richard Henderson
2025-08-14 12:57 ` [PATCH v3 39/85] target/arm: Remove unused env argument from regime_is_user Richard Henderson
2025-08-14 12:57 ` [PATCH v3 40/85] target/arm: Convert regime_is_user from switch to table Richard Henderson
2025-08-14 12:57 ` [PATCH v3 41/85] target/arm: Convert arm_mmu_idx_is_stage1_of_2 " Richard Henderson
2025-08-14 12:57 ` [PATCH v3 42/85] target/arm: Convert regime_is_stage2 " Richard Henderson
2025-08-14 12:57 ` [PATCH v3 43/85] target/arm: Introduce mmu indexes for GCS Richard Henderson
2025-08-14 12:57 ` [PATCH v3 44/85] target/arm: Introduce regime_to_gcs Richard Henderson
2025-08-14 12:57 ` [PATCH v3 45/85] target/arm: Support page protections for GCS mmu indexes Richard Henderson
2025-08-14 12:57 ` [PATCH v3 46/85] target/arm: Implement gcs bit for data abort Richard Henderson
2025-08-14 12:57 ` [PATCH v3 47/85] target/arm: Add GCS cpregs Richard Henderson
2025-08-14 12:57 ` [PATCH v3 48/85] target/arm: Add GCS enable and trap levels to DisasContext Richard Henderson
2025-08-14 12:57 ` [PATCH v3 49/85] target/arm: Implement FEAT_CHK Richard Henderson
2025-08-14 12:57 ` Richard Henderson [this message]
2025-08-14 12:57 ` [PATCH v3 51/85] target/arm: Add syndrome data for EC_GCS Richard Henderson
2025-08-14 12:57 ` [PATCH v3 52/85] target/arm: Implement EXLOCKException for ELR_ELx and SPSR_ELx Richard Henderson
2025-08-14 12:57 ` [PATCH v3 53/85] target/arm: Split {arm,core}_user_mem_index Richard Henderson
2025-08-14 12:57 ` [PATCH v3 54/85] target/arm: Introduce delay_exception{_el} Richard Henderson
2025-08-14 12:57 ` [PATCH v3 55/85] target/arm: Emit HSTR trap exception out of line Richard Henderson
2025-08-14 12:57 ` [PATCH v3 56/85] target/arm: Emit v7m LTPSIZE " Richard Henderson
2025-08-14 12:57 ` [PATCH v3 57/85] target/arm: Implement GCSSTR, GCSSTTR Richard Henderson
2025-08-14 12:57 ` [PATCH v3 58/85] target/arm: Implement GCSB Richard Henderson
2025-08-14 12:57 ` [PATCH v3 59/85] target/arm: Implement GCSPUSHM Richard Henderson
2025-08-14 12:57 ` [PATCH v3 60/85] target/arm: Implement GCSPOPM Richard Henderson
2025-08-14 12:57 ` [PATCH v3 61/85] target/arm: Implement GCSPUSHX Richard Henderson
2025-08-14 12:57 ` [PATCH v3 62/85] target/arm: Implement GCSPOPX Richard Henderson
2025-08-14 12:57 ` [PATCH v3 63/85] target/arm: Implement GCSPOPCX Richard Henderson
2025-08-14 12:57 ` [PATCH v3 64/85] target/arm: Implement GCSSS1 Richard Henderson
2025-08-14 12:57 ` [PATCH v3 65/85] target/arm: Implement GCSSS2 Richard Henderson
2025-08-14 12:57 ` [PATCH v3 66/85] target/arm: Add gcs record for BL Richard Henderson
2025-08-14 12:57 ` [PATCH v3 67/85] target/arm: Add gcs record for BLR Richard Henderson
2025-08-14 12:57 ` [PATCH v3 68/85] target/arm: Add gcs record for BLR with PAuth Richard Henderson
2025-08-14 12:57 ` [PATCH v3 69/85] target/arm: Load gcs record for RET Richard Henderson
2025-08-14 12:57 ` [PATCH v3 70/85] target/arm: Load gcs record for RET with PAuth Richard Henderson
2025-08-14 12:57 ` [PATCH v3 71/85] target/arm: Copy EXLOCKEn to EXLOCK on exception to the same EL Richard Henderson
2025-08-14 12:57 ` [PATCH v3 72/85] target/arm: Implement EXLOCK check during exception return Richard Henderson
2025-08-14 12:57 ` [PATCH v3 73/85] target/arm: Enable FEAT_GCS with -cpu max Richard Henderson
2025-08-14 12:57 ` [PATCH v3 74/85] linux-user/aarch64: Implement prctls for GCS Richard Henderson
2025-08-14 12:57 ` [PATCH v3 75/85] linux-user/aarch64: Allocate new gcs stack on clone Richard Henderson
2025-08-14 12:57 ` [PATCH v3 76/85] linux-user/aarch64: Release gcs stack on thread exit Richard Henderson
2025-08-14 12:57 ` [PATCH v3 77/85] linux-user/aarch64: Implement map_shadow_stack syscall Richard Henderson
2025-08-14 12:57 ` [PATCH v3 78/85] target/arm: Enable GCSPR_EL0 for read in user-mode Richard Henderson
2025-08-14 12:57 ` [PATCH v3 79/85] linux-user/aarch64: Inject SIGSEGV for GCS faults Richard Henderson
2025-08-14 12:57 ` [PATCH v3 80/85] linux-user/aarch64: Generate GCS signal records Richard Henderson
2025-08-14 12:57 ` [PATCH v3 81/85] linux-user: Change exported get_elf_hwcap to abi_ulong Richard Henderson
2025-08-14 12:57 ` [PATCH v3 82/85] linux-user/aarch64: Enable GCS in HWCAP Richard Henderson
2025-08-14 12:57 ` [PATCH v3 83/85] tests/tcg/aarch64: Add gcsstr Richard Henderson
2025-08-14 12:57 ` [PATCH v3 84/85] tests/tcg/aarch64: Add gcspushm Richard Henderson
2025-08-14 12:57 ` [PATCH v3 85/85] tests/tcg/aarch64: Add gcsss Richard Henderson
2025-08-29 23:14 ` [PATCH v3 00/85] target/arm: Implement FEAT_GCS Thiago Jung Bauermann
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=20250814125752.164107-51-richard.henderson@linaro.org \
--to=richard.henderson@linaro.org \
--cc=pierrick.bouvier@linaro.org \
--cc=qemu-arm@nongnu.org \
--cc=qemu-devel@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).