[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 15/35] target-arm: Drop success/fail return f
From: |
Peter Crosthwaite |
Subject: |
Re: [Qemu-devel] [PATCH v2 15/35] target-arm: Drop success/fail return from cpreg read and write functions |
Date: |
Sun, 9 Feb 2014 13:27:25 +1000 |
On Sat, Feb 1, 2014 at 1:45 AM, Peter Maydell <address@hidden> wrote:
> All cpreg read and write functions now return 0, so we can clean up
> their prototypes:
> * write functions return void
> * read functions return the value rather than taking a pointer
> to write the value to
>
> This is a fairly mechanical change which makes only the bare
> minimum set of changes to the callers of read and write functions.
>
> Signed-off-by: Peter Maydell <address@hidden>
> ---
> hw/arm/pxa2xx.c | 36 +++----
> hw/arm/pxa2xx_pic.c | 11 +-
> target-arm/cpu.c | 6 +-
> target-arm/cpu.h | 23 ++--
> target-arm/helper.c | 288
> ++++++++++++++++++++-----------------------------
> target-arm/op_helper.c | 24 +----
> 6 files changed, 150 insertions(+), 238 deletions(-)
>
> diff --git a/hw/arm/pxa2xx.c b/hw/arm/pxa2xx.c
> index 02b7016..bf9416a 100644
> --- a/hw/arm/pxa2xx.c
> +++ b/hw/arm/pxa2xx.c
> @@ -224,27 +224,24 @@ static const VMStateDescription vmstate_pxa2xx_cm = {
> }
> };
>
> -static int pxa2xx_clkcfg_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pxa2xx_clkcfg_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> - *value = s->clkcfg;
> - return 0;
> + return s->clkcfg;
> }
>
> -static int pxa2xx_clkcfg_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pxa2xx_clkcfg_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> s->clkcfg = value & 0xf;
> if (value & 2) {
> printf("%s: CPU frequency change attempt\n", __func__);
> }
> - return 0;
> }
>
> -static int pxa2xx_pwrmode_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pxa2xx_pwrmode_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> static const char *pwrmode[8] = {
> @@ -310,36 +307,29 @@ static int pxa2xx_pwrmode_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
> printf("%s: machine entered %s mode\n", __func__,
> pwrmode[value & 7]);
> }
> -
> - return 0;
> }
>
> -static int pxa2xx_cppmnc_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pxa2xx_cppmnc_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> - *value = s->pmnc;
> - return 0;
> + return s->pmnc;
> }
>
> -static int pxa2xx_cppmnc_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pxa2xx_cppmnc_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> s->pmnc = value;
> - return 0;
> }
>
> -static int pxa2xx_cpccnt_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pxa2xx_cpccnt_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> PXA2xxState *s = (PXA2xxState *)ri->opaque;
> if (s->pmnc & 1) {
> - *value = qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
> + return qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
> } else {
> - *value = 0;
> + return 0;
> }
> - return 0;
> }
>
> static const ARMCPRegInfo pxa_cp_reginfo[] = {
> diff --git a/hw/arm/pxa2xx_pic.c b/hw/arm/pxa2xx_pic.c
> index 46d337c..345fa4a 100644
> --- a/hw/arm/pxa2xx_pic.c
> +++ b/hw/arm/pxa2xx_pic.c
> @@ -217,20 +217,17 @@ static const int pxa2xx_cp_reg_map[0x10] = {
> [0xa] = ICPR2,
> };
>
> -static int pxa2xx_pic_cp_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pxa2xx_pic_cp_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> int offset = pxa2xx_cp_reg_map[ri->crn];
> - *value = pxa2xx_pic_mem_read(ri->opaque, offset, 4);
> - return 0;
> + return pxa2xx_pic_mem_read(ri->opaque, offset, 4);
> }
>
> -static int pxa2xx_pic_cp_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pxa2xx_pic_cp_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> int offset = pxa2xx_cp_reg_map[ri->crn];
> pxa2xx_pic_mem_write(ri->opaque, offset, value, 4);
> - return 0;
> }
>
> #define REGINFO_FOR_PIC_CP(NAME, CRN) \
> diff --git a/target-arm/cpu.c b/target-arm/cpu.c
> index 3014e86..fe18b65 100644
> --- a/target-arm/cpu.c
> +++ b/target-arm/cpu.c
> @@ -681,14 +681,12 @@ static void cortex_a9_initfn(Object *obj)
> }
>
> #ifndef CONFIG_USER_ONLY
> -static int a15_l2ctlr_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t a15_l2ctlr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> /* Linux wants the number of processors from here.
> * Might as well set the interrupt-controller bit too.
> */
> - *value = ((smp_cpus - 1) << 24) | (1 << 23);
> - return 0;
> + return ((smp_cpus - 1) << 24) | (1 << 23);
> }
> #endif
>
> diff --git a/target-arm/cpu.h b/target-arm/cpu.h
> index 30b1a1c..d1ed423 100644
> --- a/target-arm/cpu.h
> +++ b/target-arm/cpu.h
> @@ -828,11 +828,12 @@ typedef enum CPAccessResult {
> CP_ACCESS_TRAP_UNCATEGORIZED = 2,
> } CPAccessResult;
>
> -/* Access functions for coprocessor registers. These should always succeed.
> */
> -typedef int CPReadFn(CPUARMState *env, const ARMCPRegInfo *opaque,
> - uint64_t *value);
> -typedef int CPWriteFn(CPUARMState *env, const ARMCPRegInfo *opaque,
> - uint64_t value);
> +/* Access functions for coprocessor registers. These cannot fail and
> + * may not raise exceptions.
Is this based on an assumption that the only possible reason for an
exception is access violation? This series quite validly obsoletes the
need for exception-via-return-path, but my understanding is that CP
accessor functions are able to implement any form of side affects. If
an exception is thus generated from the side effects of a CP access
then thats fair game - it just happens via the already existing
mechanisms for generating an exception from helper context. Long story
short, I think you can just drop second sentence from this comment.
> + */
> +typedef uint64_t CPReadFn(CPUARMState *env, const ARMCPRegInfo *opaque);
> +typedef void CPWriteFn(CPUARMState *env, const ARMCPRegInfo *opaque,
> + uint64_t value);
> /* Access permission check functions for coprocessor registers. */
> typedef CPAccessResult CPAccessFn(CPUARMState *env, const ARMCPRegInfo
> *opaque);
> /* Hook function for register reset */
> @@ -907,14 +908,14 @@ struct ARMCPRegInfo {
> /* Function for doing a "raw" read; used when we need to copy
> * coprocessor state to the kernel for KVM or out for
> * migration. This only needs to be provided if there is also a
> - * readfn and it makes an access permission check.
> + * readfn and it has side effects (for instance clear-on-read bits).
> */
> CPReadFn *raw_readfn;
> /* Function for doing a "raw" write; used when we need to copy KVM
> * kernel coprocessor state into userspace, or for inbound
> * migration. This only needs to be provided if there is also a
> - * writefn and it makes an access permission check or masks out
> - * "unwritable" bits or has write-one-to-clear or similar behaviour.
> + * writefn and it masks out "unwritable" bits or has write-one-to-clear
> + * or similar behaviour.
> */
> CPWriteFn *raw_writefn;
> /* Function for resetting the register. If NULL, then reset will be done
> @@ -949,10 +950,10 @@ static inline void define_one_arm_cp_reg(ARMCPU *cpu,
> const ARMCPRegInfo *regs)
> const ARMCPRegInfo *get_arm_cp_reginfo(GHashTable *cpregs, uint32_t
> encoded_cp);
>
> /* CPWriteFn that can be used to implement writes-ignored behaviour */
> -int arm_cp_write_ignore(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value);
> +void arm_cp_write_ignore(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value);
> /* CPReadFn that can be used for read-as-zero behaviour */
> -int arm_cp_read_zero(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> *value);
> +uint64_t arm_cp_read_zero(CPUARMState *env, const ARMCPRegInfo *ri);
>
> /* CPResetFn that does nothing, for use if no reset is required even
> * if fieldoffset is non zero.
> diff --git a/target-arm/helper.c b/target-arm/helper.c
> index 664ac92..10aeccc 100644
> --- a/target-arm/helper.c
> +++ b/target-arm/helper.c
> @@ -107,26 +107,23 @@ static int aarch64_fpu_gdb_set_reg(CPUARMState *env,
> uint8_t *buf, int reg)
> }
> }
>
> -static int raw_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t raw_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> if (cpreg_field_is_64bit(ri)) {
> - *value = CPREG_FIELD64(env, ri);
> + return CPREG_FIELD64(env, ri);
> } else {
> - *value = CPREG_FIELD32(env, ri);
> + return CPREG_FIELD32(env, ri);
> }
> - return 0;
> }
>
> -static int raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> if (cpreg_field_is_64bit(ri)) {
> CPREG_FIELD64(env, ri) = value;
> } else {
> CPREG_FIELD32(env, ri) = value;
> }
> - return 0;
> }
>
> static bool read_raw_cp_reg(CPUARMState *env, const ARMCPRegInfo *ri,
> @@ -138,11 +135,11 @@ static bool read_raw_cp_reg(CPUARMState *env, const
> ARMCPRegInfo *ri,
> if (ri->type & ARM_CP_CONST) {
> *v = ri->resetvalue;
> } else if (ri->raw_readfn) {
> - return (ri->raw_readfn(env, ri, v) == 0);
> + *v = ri->raw_readfn(env, ri);
> } else if (ri->readfn) {
> - return (ri->readfn(env, ri, v) == 0);
> + *v = ri->readfn(env, ri);
> } else {
> - raw_read(env, ri, v);
> + *v = raw_read(env, ri);
> }
> return true;
> }
> @@ -159,9 +156,9 @@ static bool write_raw_cp_reg(CPUARMState *env, const
> ARMCPRegInfo *ri,
> if (ri->type & ARM_CP_CONST) {
> return true;
> } else if (ri->raw_writefn) {
> - return (ri->raw_writefn(env, ri, v) == 0);
> + ri->raw_writefn(env, ri, v);
> } else if (ri->writefn) {
> - return (ri->writefn(env, ri, v) == 0);
> + ri->writefn(env, ri, v);
> } else {
> raw_write(env, ri, v);
> }
> @@ -309,14 +306,13 @@ void init_cpreg_list(ARMCPU *cpu)
> g_list_free(keys);
> }
>
> -static int dacr_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void dacr_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> {
> env->cp15.c3 = value;
> tlb_flush(env, 1); /* Flush TLB as domain not tracked in TLB */
> - return 0;
> }
>
> -static int fcse_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void fcse_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> {
> if (env->cp15.c13_fcse != value) {
> /* Unlike real hardware the qemu TLB uses virtual addresses,
> @@ -325,10 +321,10 @@ static int fcse_write(CPUARMState *env, const
> ARMCPRegInfo *ri, uint64_t value)
> tlb_flush(env, 1);
> env->cp15.c13_fcse = value;
> }
> - return 0;
> }
> -static int contextidr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +
> +static void contextidr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> if (env->cp15.c13_context != value && !arm_feature(env,
> ARM_FEATURE_MPU)) {
> /* For VMSA (when not using the LPAE long descriptor page table
> @@ -338,39 +334,34 @@ static int contextidr_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
> tlb_flush(env, 1);
> }
> env->cp15.c13_context = value;
> - return 0;
> }
>
> -static int tlbiall_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void tlbiall_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Invalidate all (TLBIALL) */
> tlb_flush(env, 1);
> - return 0;
> }
>
> -static int tlbimva_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void tlbimva_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Invalidate single TLB entry by MVA and ASID (TLBIMVA) */
> tlb_flush_page(env, value & TARGET_PAGE_MASK);
> - return 0;
> }
>
> -static int tlbiasid_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void tlbiasid_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Invalidate by ASID (TLBIASID) */
> tlb_flush(env, value == 0);
> - return 0;
> }
>
> -static int tlbimvaa_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void tlbimvaa_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Invalidate single entry by MVA, all ASIDs (TLBIMVAA) */
> tlb_flush_page(env, value & TARGET_PAGE_MASK);
> - return 0;
> }
>
> static const ARMCPRegInfo cp_reginfo[] = {
> @@ -450,14 +441,14 @@ static const ARMCPRegInfo not_v7_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int cpacr_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void cpacr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> if (env->cp15.c1_coproc != value) {
> env->cp15.c1_coproc = value;
> /* ??? Is this safe when called from within a TB? */
> tb_flush(env);
> }
> - return 0;
> }
>
> static const ARMCPRegInfo v6_cp_reginfo[] = {
> @@ -496,89 +487,77 @@ static CPAccessResult pmreg_access(CPUARMState *env,
> const ARMCPRegInfo *ri)
> return CP_ACCESS_OK;
> }
>
> -static int pmcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* only the DP, X, D and E bits are writable */
> env->cp15.c9_pmcr &= ~0x39;
> env->cp15.c9_pmcr |= (value & 0x39);
> - return 0;
> }
>
> -static int pmcntenset_write(CPUARMState *env, const ARMCPRegInfo *ri,
> +static void pmcntenset_write(CPUARMState *env, const ARMCPRegInfo *ri,
> uint64_t value)
> {
> value &= (1 << 31);
> env->cp15.c9_pmcnten |= value;
> - return 0;
> }
>
> -static int pmcntenclr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmcntenclr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> value &= (1 << 31);
> env->cp15.c9_pmcnten &= ~value;
> - return 0;
> }
>
> -static int pmovsr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmovsr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c9_pmovsr &= ~value;
> - return 0;
> }
>
> -static int pmxevtyper_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmxevtyper_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c9_pmxevtyper = value & 0xff;
> - return 0;
> }
>
> -static int pmuserenr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> +static void pmuserenr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> uint64_t value)
> {
> env->cp15.c9_pmuserenr = value & 1;
> - return 0;
> }
>
> -static int pmintenset_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmintenset_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* We have no event counters so only the C bit can be changed */
> value &= (1 << 31);
> env->cp15.c9_pminten |= value;
> - return 0;
> }
>
> -static int pmintenclr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmintenclr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> value &= (1 << 31);
> env->cp15.c9_pminten &= ~value;
> - return 0;
> }
>
> -static int vbar_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void vbar_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c12_vbar = value & ~0x1Ful;
> - return 0;
> }
>
> -static int ccsidr_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t ccsidr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> ARMCPU *cpu = arm_env_get_cpu(env);
> - *value = cpu->ccsidr[env->cp15.c0_cssel];
> - return 0;
> + return cpu->ccsidr[env->cp15.c0_cssel];
> }
>
> -static int csselr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void csselr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c0_cssel = value & 0xf;
> - return 0;
> }
>
> static const ARMCPRegInfo v7_cp_reginfo[] = {
> @@ -675,14 +654,14 @@ static const ARMCPRegInfo v7_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int teecr_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void teecr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> value &= 1;
> env->teecr = value;
> - return 0;
> }
>
> -static CPAccessResultg teehbr_access(CPUARMState *env, const ARMCPRegInfo
> *ri)
> +static CPAccessResult teehbr_access(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> if (arm_current_pl(env) == 0 && (env->teecr & 1)) {
> return CP_ACCESS_TRAP;
> @@ -833,45 +812,40 @@ static void gt_cnt_reset(CPUARMState *env, const
> ARMCPRegInfo *ri)
> timer_del(cpu->gt_timer[timeridx]);
> }
>
> -static int gt_cnt_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t gt_cnt_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = gt_get_countervalue(env);
> - return 0;
> + return gt_get_countervalue(env);
> }
>
> -static int gt_cval_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void gt_cval_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> int timeridx = ri->opc1 & 1;
>
> env->cp15.c14_timer[timeridx].cval = value;
> gt_recalc_timer(arm_env_get_cpu(env), timeridx);
> - return 0;
> }
> -static int gt_tval_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +
> +static uint64_t gt_tval_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> int timeridx = ri->crm & 1;
>
> - *value = (uint32_t)(env->cp15.c14_timer[timeridx].cval -
> - gt_get_countervalue(env));
> - return 0;
> + return (uint32_t)(env->cp15.c14_timer[timeridx].cval -
> + gt_get_countervalue(env));
> }
>
> -static int gt_tval_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void gt_tval_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> int timeridx = ri->crm & 1;
>
> env->cp15.c14_timer[timeridx].cval = gt_get_countervalue(env) +
> + sextract64(value, 0, 32);
> gt_recalc_timer(arm_env_get_cpu(env), timeridx);
> - return 0;
> }
>
> -static int gt_ctl_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void gt_ctl_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> ARMCPU *cpu = arm_env_get_cpu(env);
> int timeridx = ri->crm & 1;
> @@ -888,7 +862,6 @@ static int gt_ctl_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
> qemu_set_irq(cpu->gt_timer_outputs[timeridx],
> (oldval & 4) && (value & 2));
> }
> - return 0;
> }
>
> void arm_gt_ptimer_cb(void *opaque)
> @@ -990,7 +963,7 @@ static const ARMCPRegInfo generic_timer_cp_reginfo[] = {
>
> #endif
>
> -static int par_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void par_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> {
> if (arm_feature(env, ARM_FEATURE_LPAE)) {
> env->cp15.c7_par = value;
> @@ -999,7 +972,6 @@ static int par_write(CPUARMState *env, const ARMCPRegInfo
> *ri, uint64_t value)
> } else {
> env->cp15.c7_par = value & 0xfffff1ff;
> }
> - return 0;
> }
>
> #ifndef CONFIG_USER_ONLY
> @@ -1028,7 +1000,7 @@ static CPAccessResult ats_access(CPUARMState *env,
> const ARMCPRegInfo *ri)
> return CP_ACCESS_OK;
> }
>
> -static int ats_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void ats_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> {
> hwaddr phys_addr;
> target_ulong page_size;
> @@ -1077,7 +1049,6 @@ static int ats_write(CPUARMState *env, const
> ARMCPRegInfo *ri, uint64_t value)
> }
> env->cp15.c7_par_hi = 0;
> }
> - return 0;
> }
> #endif
>
> @@ -1124,32 +1095,26 @@ static uint32_t extended_mpu_ap_bits(uint32_t val)
> return ret;
> }
>
> -static int pmsav5_data_ap_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmsav5_data_ap_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c5_data = extended_mpu_ap_bits(value);
> - return 0;
> }
>
> -static int pmsav5_data_ap_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pmsav5_data_ap_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = simple_mpu_ap_bits(env->cp15.c5_data);
> - return 0;
> + return simple_mpu_ap_bits(env->cp15.c5_data);
> }
>
> -static int pmsav5_insn_ap_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void pmsav5_insn_ap_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c5_insn = extended_mpu_ap_bits(value);
> - return 0;
> }
>
> -static int pmsav5_insn_ap_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t pmsav5_insn_ap_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = simple_mpu_ap_bits(env->cp15.c5_insn);
> - return 0;
> + return simple_mpu_ap_bits(env->cp15.c5_insn);
> }
>
> static const ARMCPRegInfo pmsav5_cp_reginfo[] = {
> @@ -1201,8 +1166,8 @@ static const ARMCPRegInfo pmsav5_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int vmsa_ttbcr_raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void vmsa_ttbcr_raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> int maskshift = extract32(value, 0, 3);
>
> @@ -1219,11 +1184,10 @@ static int vmsa_ttbcr_raw_write(CPUARMState *env,
> const ARMCPRegInfo *ri,
> env->cp15.c2_control = value;
> env->cp15.c2_mask = ~(((uint32_t)0xffffffffu) >> maskshift);
> env->cp15.c2_base_mask = ~((uint32_t)0x3fffu >> maskshift);
> - return 0;
> }
>
> -static int vmsa_ttbcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void vmsa_ttbcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> if (arm_feature(env, ARM_FEATURE_LPAE)) {
> /* With LPAE the TTBCR could result in a change of ASID
> @@ -1231,7 +1195,7 @@ static int vmsa_ttbcr_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
> */
> tlb_flush(env, 1);
> }
> - return vmsa_ttbcr_raw_write(env, ri, value);
> + vmsa_ttbcr_raw_write(env, ri, value);
> }
>
> static void vmsa_ttbcr_reset(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -1264,40 +1228,36 @@ static const ARMCPRegInfo vmsa_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int omap_ticonfig_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void omap_ticonfig_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c15_ticonfig = value & 0xe7;
> /* The OS_TYPE bit in this register changes the reported CPUID! */
> env->cp15.c0_cpuid = (value & (1 << 5)) ?
> ARM_CPUID_TI915T : ARM_CPUID_TI925T;
> - return 0;
> }
>
> -static int omap_threadid_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void omap_threadid_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c15_threadid = value & 0xffff;
> - return 0;
> }
>
> -static int omap_wfi_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void omap_wfi_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Wait-for-interrupt (deprecated) */
> cpu_interrupt(CPU(arm_env_get_cpu(env)), CPU_INTERRUPT_HALT);
> - return 0;
> }
>
> -static int omap_cachemaint_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void omap_cachemaint_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* On OMAP there are registers indicating the max/min index of dcache
> lines
> * containing a dirty line; cache flush operations have to reset these.
> */
> env->cp15.c15_i_max = 0x000;
> env->cp15.c15_i_min = 0xff0;
> - return 0;
> }
>
> static const ARMCPRegInfo omap_cp_reginfo[] = {
> @@ -1339,8 +1299,8 @@ static const ARMCPRegInfo omap_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int xscale_cpar_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void xscale_cpar_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> value &= 0x3fff;
> if (env->cp15.c15_cpar != value) {
> @@ -1348,7 +1308,6 @@ static int xscale_cpar_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
> tb_flush(env);
> env->cp15.c15_cpar = value;
> }
> - return 0;
> }
>
> static const ARMCPRegInfo xscale_cp_reginfo[] = {
> @@ -1428,8 +1387,7 @@ static const ARMCPRegInfo strongarm_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int mpidr_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t mpidr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> CPUState *cs = CPU(arm_env_get_cpu(env));
> uint32_t mpidr = cs->cpu_index;
> @@ -1444,8 +1402,7 @@ static int mpidr_read(CPUARMState *env, const
> ARMCPRegInfo *ri,
> * not currently model any of those cores.
> */
> }
> - *value = mpidr;
> - return 0;
> + return mpidr;
> }
>
> static const ARMCPRegInfo mpidr_cp_reginfo[] = {
> @@ -1454,17 +1411,16 @@ static const ARMCPRegInfo mpidr_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int par64_read(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> *value)
> +static uint64_t par64_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = ((uint64_t)env->cp15.c7_par_hi << 32) | env->cp15.c7_par;
> - return 0;
> + return ((uint64_t)env->cp15.c7_par_hi << 32) | env->cp15.c7_par;
> }
>
> -static int par64_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void par64_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c7_par_hi = value >> 32;
> env->cp15.c7_par = value;
> - return 0;
> }
>
> static void par64_reset(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -1473,27 +1429,24 @@ static void par64_reset(CPUARMState *env, const
> ARMCPRegInfo *ri)
> env->cp15.c7_par = 0;
> }
>
> -static int ttbr064_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t ttbr064_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = ((uint64_t)env->cp15.c2_base0_hi << 32) | env->cp15.c2_base0;
> - return 0;
> + return ((uint64_t)env->cp15.c2_base0_hi << 32) | env->cp15.c2_base0;
> }
>
> -static int ttbr064_raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void ttbr064_raw_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c2_base0_hi = value >> 32;
> env->cp15.c2_base0 = value;
> - return 0;
> }
>
> -static int ttbr064_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void ttbr064_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Writes to the 64 bit format TTBRs may change the ASID */
> tlb_flush(env, 1);
> - return ttbr064_raw_write(env, ri, value);
> + ttbr064_raw_write(env, ri, value);
> }
>
> static void ttbr064_reset(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -1502,19 +1455,16 @@ static void ttbr064_reset(CPUARMState *env, const
> ARMCPRegInfo *ri)
> env->cp15.c2_base0 = 0;
> }
>
> -static int ttbr164_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t ttbr164_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = ((uint64_t)env->cp15.c2_base1_hi << 32) | env->cp15.c2_base1;
> - return 0;
> + return ((uint64_t)env->cp15.c2_base1_hi << 32) | env->cp15.c2_base1;
> }
>
> -static int ttbr164_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void ttbr164_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c2_base1_hi = value >> 32;
> env->cp15.c2_base1 = value;
> - return 0;
> }
>
> static void ttbr164_reset(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -1551,32 +1501,26 @@ static const ARMCPRegInfo lpae_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int aa64_fpcr_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t aa64_fpcr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = vfp_get_fpcr(env);
> - return 0;
> + return vfp_get_fpcr(env);
> }
>
> -static int aa64_fpcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void aa64_fpcr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> vfp_set_fpcr(env, value);
> - return 0;
> }
>
> -static int aa64_fpsr_read(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t *value)
> +static uint64_t aa64_fpsr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> - *value = vfp_get_fpsr(env);
> - return 0;
> + return vfp_get_fpsr(env);
> }
>
> -static int aa64_fpsr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +static void aa64_fpsr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> vfp_set_fpsr(env, value);
> - return 0;
> }
>
> static const ARMCPRegInfo v8_cp_reginfo[] = {
> @@ -1609,13 +1553,13 @@ static const ARMCPRegInfo v8_cp_reginfo[] = {
> REGINFO_SENTINEL
> };
>
> -static int sctlr_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
> +static void sctlr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> env->cp15.c1_sys = value;
> /* ??? Lots of these bits are not implemented. */
> /* This may enable/disable the MMU, so do a TLB flush. */
> tlb_flush(env, 1);
> - return 0;
> }
>
> void register_cp_regs_for_features(ARMCPU *cpu)
> @@ -2193,17 +2137,15 @@ const ARMCPRegInfo *get_arm_cp_reginfo(GHashTable
> *cpregs, uint32_t encoded_cp)
> return g_hash_table_lookup(cpregs, &encoded_cp);
> }
>
> -int arm_cp_write_ignore(CPUARMState *env, const ARMCPRegInfo *ri,
> - uint64_t value)
> +void arm_cp_write_ignore(CPUARMState *env, const ARMCPRegInfo *ri,
> + uint64_t value)
> {
> /* Helper coprocessor write function for write-ignore registers */
> - return 0;
> }
>
> -int arm_cp_read_zero(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> *value)
> +uint64_t arm_cp_read_zero(CPUARMState *env, const ARMCPRegInfo *ri)
> {
> /* Helper coprocessor write function for read-as-zero registers */
> - *value = 0;
> return 0;
> }
>
> diff --git a/target-arm/op_helper.c b/target-arm/op_helper.c
> index 89b0978..0c1b37a 100644
> --- a/target-arm/op_helper.c
> +++ b/target-arm/op_helper.c
> @@ -294,41 +294,25 @@ void HELPER(access_check_cp_reg)(CPUARMState *env, void
> *rip)
> void HELPER(set_cp_reg)(CPUARMState *env, void *rip, uint32_t value)
> {
> const ARMCPRegInfo *ri = rip;
> - int excp = ri->writefn(env, ri, value);
> - if (excp) {
> - raise_exception(env, excp);
> - }
> + ri->writefn(env, ri, value);
> }
>
> uint32_t HELPER(get_cp_reg)(CPUARMState *env, void *rip)
> {
> const ARMCPRegInfo *ri = rip;
> - uint64_t value;
> - int excp = ri->readfn(env, ri, &value);
> - if (excp) {
> - raise_exception(env, excp);
> - }
> - return value;
Should ideally be a blank line here, but ..
> + return ri->readfn(env, ri);
... you could just drop the single use variable completely with:
return ri->readfn(env, (const ARMCPRegInfo *)rip);
> }
>
> void HELPER(set_cp_reg64)(CPUARMState *env, void *rip, uint64_t value)
> {
> const ARMCPRegInfo *ri = rip;
> - int excp = ri->writefn(env, ri, value);
> - if (excp) {
> - raise_exception(env, excp);
> - }
> + ri->writefn(env, ri, value);
Same.
> }
>
> uint64_t HELPER(get_cp_reg64)(CPUARMState *env, void *rip)
> {
> const ARMCPRegInfo *ri = rip;
> - uint64_t value;
> - int excp = ri->readfn(env, ri, &value);
> - if (excp) {
> - raise_exception(env, excp);
> - }
> - return value;
> + return ri->readfn(env, ri);
Same. With fixes,
Reviewed-by: Peter Crosthwaite <address@hidden>
Regards,
Peter
> }
>
> void HELPER(msr_i_pstate)(CPUARMState *env, uint32_t op, uint32_t imm)
> --
> 1.8.5
>
>
- Re: [Qemu-devel] [PATCH v2 15/35] target-arm: Drop success/fail return from cpreg read and write functions,
Peter Crosthwaite <=