[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property
From: |
Anup Patel |
Subject: |
Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property |
Date: |
Mon, 4 Jul 2022 08:20:02 +0530 |
On Mon, Jul 4, 2022 at 2:59 AM Stafford Horne <shorne@gmail.com> wrote:
>
> Add an endianness property to allow configuring the RTC as either
> native, little or big endian.
>
> Cc: Laurent Vivier <lvivier@redhat.com>
> Signed-off-by: Stafford Horne <shorne@gmail.com>
Looks good to me.
Reviewed-by: Anup Patel <anup@brainfault.org>
Regards,
Anup
> ---
> hw/rtc/goldfish_rtc.c | 46 ++++++++++++++++++++++++++++-------
> include/hw/rtc/goldfish_rtc.h | 2 ++
> 2 files changed, 39 insertions(+), 9 deletions(-)
>
> diff --git a/hw/rtc/goldfish_rtc.c b/hw/rtc/goldfish_rtc.c
> index 35e493be31..24f6587086 100644
> --- a/hw/rtc/goldfish_rtc.c
> +++ b/hw/rtc/goldfish_rtc.c
> @@ -216,14 +216,34 @@ static int goldfish_rtc_post_load(void *opaque, int
> version_id)
> return 0;
> }
>
> -static const MemoryRegionOps goldfish_rtc_ops = {
> - .read = goldfish_rtc_read,
> - .write = goldfish_rtc_write,
> - .endianness = DEVICE_NATIVE_ENDIAN,
> - .valid = {
> - .min_access_size = 4,
> - .max_access_size = 4
> - }
> +static const MemoryRegionOps goldfish_rtc_ops[3] = {
> + [DEVICE_NATIVE_ENDIAN] = {
> + .read = goldfish_rtc_read,
> + .write = goldfish_rtc_write,
> + .endianness = DEVICE_NATIVE_ENDIAN,
> + .valid = {
> + .min_access_size = 4,
> + .max_access_size = 4
> + }
> + },
> + [DEVICE_LITTLE_ENDIAN] = {
> + .read = goldfish_rtc_read,
> + .write = goldfish_rtc_write,
> + .endianness = DEVICE_LITTLE_ENDIAN,
> + .valid = {
> + .min_access_size = 4,
> + .max_access_size = 4
> + }
> + },
> + [DEVICE_BIG_ENDIAN] = {
> + .read = goldfish_rtc_read,
> + .write = goldfish_rtc_write,
> + .endianness = DEVICE_BIG_ENDIAN,
> + .valid = {
> + .min_access_size = 4,
> + .max_access_size = 4
> + }
> + },
> };
>
> static const VMStateDescription goldfish_rtc_vmstate = {
> @@ -265,7 +285,8 @@ static void goldfish_rtc_realize(DeviceState *d, Error
> **errp)
> SysBusDevice *dev = SYS_BUS_DEVICE(d);
> GoldfishRTCState *s = GOLDFISH_RTC(d);
>
> - memory_region_init_io(&s->iomem, OBJECT(s), &goldfish_rtc_ops, s,
> + memory_region_init_io(&s->iomem, OBJECT(s),
> + &goldfish_rtc_ops[s->endianness], s,
> "goldfish_rtc", 0x24);
> sysbus_init_mmio(dev, &s->iomem);
>
> @@ -274,10 +295,17 @@ static void goldfish_rtc_realize(DeviceState *d, Error
> **errp)
> s->timer = timer_new_ns(rtc_clock, goldfish_rtc_interrupt, s);
> }
>
> +static Property goldfish_rtc_properties[] = {
> + DEFINE_PROP_UINT8("endianness", GoldfishRTCState, endianness,
> + DEVICE_NATIVE_ENDIAN),
> + DEFINE_PROP_END_OF_LIST(),
> +};
> +
> static void goldfish_rtc_class_init(ObjectClass *klass, void *data)
> {
> DeviceClass *dc = DEVICE_CLASS(klass);
>
> + device_class_set_props(dc, goldfish_rtc_properties);
> dc->realize = goldfish_rtc_realize;
> dc->reset = goldfish_rtc_reset;
> dc->vmsd = &goldfish_rtc_vmstate;
> diff --git a/include/hw/rtc/goldfish_rtc.h b/include/hw/rtc/goldfish_rtc.h
> index 79ca7daf5d..8e1aeb85e3 100644
> --- a/include/hw/rtc/goldfish_rtc.h
> +++ b/include/hw/rtc/goldfish_rtc.h
> @@ -42,6 +42,8 @@ struct GoldfishRTCState {
> uint32_t irq_pending;
> uint32_t irq_enabled;
> uint32_t time_high;
> +
> + uint8_t endianness;
> };
>
> #endif
> --
> 2.36.1
>
>
- [PATCH v2 00/11] OpenRISC Virtual Machine, Stafford Horne, 2022/07/03
- [PATCH v2 02/11] target/openrisc: Fix memory reading in debugger, Stafford Horne, 2022/07/03
- [PATCH v2 01/11] hw/openrisc: Split re-usable boot time apis out to boot.c, Stafford Horne, 2022/07/03
- [PATCH v2 03/11] goldfish_rtc: Add endianness property, Stafford Horne, 2022/07/03
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property,
Anup Patel <=
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Richard Henderson, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Laurent Vivier, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Richard Henderson, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Laurent Vivier, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Stafford Horne, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Jason A. Donenfeld, 2022/07/04
- Re: [PATCH v2 03/11] goldfish_rtc: Add endianness property, Stafford Horne, 2022/07/04
[PATCH v2 04/11] hw/openrisc: Add the OpenRISC virtual machine, Stafford Horne, 2022/07/03
[PATCH v2 05/11] hw/openrisc: Add PCI bus support to virt, Stafford Horne, 2022/07/03
[PATCH v2 06/11] hw/openrisc: Initialize timer time at startup, Stafford Horne, 2022/07/03