From nobody Wed Nov 12 01:49:21 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=gmail.com ARC-Seal: i=1; a=rsa-sha256; t=1567306614; cv=none; d=zoho.com; s=zohoarc; b=C/ayBp8lFOJ6jnITMdXMAaaT3xYrrcKElg4QbCa0kl+ZDGR3Du2Ik+E3Zuf8PLAUpzZNUaXNXYxTD39Zc3tfPRFxmuhtUxq+fzSznLGJJNc0xLgn/q8+K4D0TGjoB9ZX9tb1sLWWOKNvbzxxXECPQyweKC0ozycor/wcVqPS1jA= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zoho.com; s=zohoarc; t=1567306614; h=Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:Message-ID:References:Sender:Subject:To:ARC-Authentication-Results; bh=3gPXuF8DTtQY+sieWCstJKIb4KmsuKA2RH20YnVdJmE=; b=H2/LbEBWLUKQw9VqEShoWHsWZHz7Vdu/CnM+Zna+b+NXB+CHx8b6kC+DA1Y/tZguEW6fyll+3AIIw9X91JVAOGwXL0wKU3vkJJ7ydxwysca/4+SIKm5EPLU7x3SAdAgXmLHUz5m9b1XkF2FIJPvkT/qo8/xv3ztG8ZGikYx5omg= ARC-Authentication-Results: i=1; mx.zoho.com; dkim=fail; spf=pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail header.from= (p=none dis=none) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1567306614204407.14625586686225; Sat, 31 Aug 2019 19:56:54 -0700 (PDT) Received: from localhost ([::1]:47196 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1i4G2r-0001Qs-Jk for importer@patchew.org; Sat, 31 Aug 2019 22:56:49 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:47688) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1i4Fzg-0007cG-1p for qemu-devel@nongnu.org; Sat, 31 Aug 2019 22:53:34 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1i4Fzd-0006P5-Tp for qemu-devel@nongnu.org; Sat, 31 Aug 2019 22:53:31 -0400 Received: from mail-pl1-x641.google.com ([2607:f8b0:4864:20::641]:39637) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1i4Fzd-0006No-MW; Sat, 31 Aug 2019 22:53:29 -0400 Received: by mail-pl1-x641.google.com with SMTP id az1so4092938plb.6; Sat, 31 Aug 2019 19:53:29 -0700 (PDT) Received: from localhost.localdomain (unknown-224-80.windriver.com. [147.11.224.80]) by smtp.gmail.com with ESMTPSA id p10sm11453307pff.132.2019.08.31.19.53.27 (version=TLS1 cipher=AES128-SHA bits=128/128); Sat, 31 Aug 2019 19:53:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:in-reply-to:references; bh=3gPXuF8DTtQY+sieWCstJKIb4KmsuKA2RH20YnVdJmE=; b=ZbCwuk/1oFpTu+FqSK4gy3tcPxLsaBWCgTZz0biNzaFdRZst9ZSrdapBijAnRbX9Eg XVotTpogSIatg+ak96OUP2YFhWHzVT89csJviJpJMMFSpUKzGEoP90DD9MFZ+4keDd4d 0o5vlZGhLYZTg0vwNyVLS4GK460X1nkyiX+kpabVwCfhXR16VoXOmy7v24iXDShWCPo7 wqKKW4Qj+kD7UL7iINuCG98NNylOxVaM1KTwSAZxWVfGAyyrlfhFgV6lqReJMBDQUG31 CDseqAqwYYb/RD+UaLXkhMQjvdH4l5imOnuEkVLLPtjuQD7Ryy5I4lVMuJTJ4P2h6Cwa danw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references; bh=3gPXuF8DTtQY+sieWCstJKIb4KmsuKA2RH20YnVdJmE=; b=i9ij789/H5KMnjBQKLvhiERnfB6FTukYmePxNFyr7Gi/WaKUBWBjIO05rAy1AFc+va +F95sBRXdoblt5oaRlsrYi+y1QoPg1FXtvGvNoEU6Kw+lPi/rUzklH6XYlv+XNii+fgo yQ+V0SiBjJof2UAP05p9BzQXa/nd0XWWnxVcprm3JXUVkPG47ptukEe4Xvo5g1jIzBLk bqWH9hPO30DYMnUrYb82fBZxkgtwUkx0Qo2MBRdIaP4joIS/AJlCW0IRXV6YUzxhGT+R tCOGtqqtuJ6jPHEQFdC41LA4kzA3V7fgnVzY1+HtD10DtSz4GPmAfKiEJaLemFaT0ydO wCVA== X-Gm-Message-State: APjAAAVY52D/UYSnpe5oKui7omlam1JU3bYdmbYrB3dug5PAX5eI62AU zm9SqZ0rDh+3Fx7mF3pz2Ww= X-Google-Smtp-Source: APXvYqx2sz3tgc3OCdNtgVbS5lHJvcB4FagFCVQSHywRq9JQrRWMZDa4mpymSDXZ3gr4CojAXeZ6EA== X-Received: by 2002:a17:902:e407:: with SMTP id ci7mr23873370plb.326.1567306408654; Sat, 31 Aug 2019 19:53:28 -0700 (PDT) From: Bin Meng To: Alistair Francis , Palmer Dabbelt , qemu-devel@nongnu.org, qemu-riscv@nongnu.org Date: Sat, 31 Aug 2019 19:52:50 -0700 Message-Id: <1567306391-2682-10-git-send-email-bmeng.cn@gmail.com> X-Mailer: git-send-email 1.7.1 In-Reply-To: <1567306391-2682-1-git-send-email-bmeng.cn@gmail.com> References: <1567306391-2682-1-git-send-email-bmeng.cn@gmail.com> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2607:f8b0:4864:20::641 Subject: [Qemu-devel] [PATCH v7 09/30] riscv: sifive: Rename sifive_prci.{c, h} to sifive_e_prci.{c, h} X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Current SiFive PRCI model only works with sifive_e machine, as it only emulates registers or PRCI block in the FE310 SoC. Rename the file name to make it clear that it is for sifive_e. This also prefix "sifive_e"/"SIFIVE_E" for all macros, variables and functions. Signed-off-by: Bin Meng Reviewed-by: Chih-Min Chao Reviewed-by: Alistair Francis --- Changes in v7: None Changes in v6: None Changes in v5: None Changes in v4: - prefix all macros/variables/functions with SIFIVE_E/sifive_e in the sifive_e_prci driver Changes in v3: None Changes in v2: None hw/riscv/Makefile.objs | 2 +- hw/riscv/sifive_e.c | 4 +- hw/riscv/{sifive_prci.c =3D> sifive_e_prci.c} | 79 ++++++++++++++---------= ------ include/hw/riscv/sifive_e_prci.h | 69 +++++++++++++++++++++++++ include/hw/riscv/sifive_prci.h | 69 ------------------------- 5 files changed, 111 insertions(+), 112 deletions(-) rename hw/riscv/{sifive_prci.c =3D> sifive_e_prci.c} (51%) create mode 100644 include/hw/riscv/sifive_e_prci.h delete mode 100644 include/hw/riscv/sifive_prci.h diff --git a/hw/riscv/Makefile.objs b/hw/riscv/Makefile.objs index eb9d4f9..c859697 100644 --- a/hw/riscv/Makefile.objs +++ b/hw/riscv/Makefile.objs @@ -2,9 +2,9 @@ obj-y +=3D boot.o obj-$(CONFIG_SPIKE) +=3D riscv_htif.o obj-$(CONFIG_HART) +=3D riscv_hart.o obj-$(CONFIG_SIFIVE_E) +=3D sifive_e.o +obj-$(CONFIG_SIFIVE_E) +=3D sifive_e_prci.o obj-$(CONFIG_SIFIVE) +=3D sifive_clint.o obj-$(CONFIG_SIFIVE) +=3D sifive_gpio.o -obj-$(CONFIG_SIFIVE) +=3D sifive_prci.o obj-$(CONFIG_SIFIVE) +=3D sifive_plic.o obj-$(CONFIG_SIFIVE) +=3D sifive_test.o obj-$(CONFIG_SIFIVE_U) +=3D sifive_u.o diff --git a/hw/riscv/sifive_e.c b/hw/riscv/sifive_e.c index 2a499d8..2d67670 100644 --- a/hw/riscv/sifive_e.c +++ b/hw/riscv/sifive_e.c @@ -41,9 +41,9 @@ #include "hw/riscv/riscv_hart.h" #include "hw/riscv/sifive_plic.h" #include "hw/riscv/sifive_clint.h" -#include "hw/riscv/sifive_prci.h" #include "hw/riscv/sifive_uart.h" #include "hw/riscv/sifive_e.h" +#include "hw/riscv/sifive_e_prci.h" #include "hw/riscv/boot.h" #include "chardev/char.h" #include "sysemu/arch_init.h" @@ -174,7 +174,7 @@ static void riscv_sifive_e_soc_realize(DeviceState *dev= , Error **errp) SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE); sifive_mmio_emulate(sys_mem, "riscv.sifive.e.aon", memmap[SIFIVE_E_AON].base, memmap[SIFIVE_E_AON].size); - sifive_prci_create(memmap[SIFIVE_E_PRCI].base); + sifive_e_prci_create(memmap[SIFIVE_E_PRCI].base); =20 /* GPIO */ =20 diff --git a/hw/riscv/sifive_prci.c b/hw/riscv/sifive_e_prci.c similarity index 51% rename from hw/riscv/sifive_prci.c rename to hw/riscv/sifive_e_prci.c index 1957dcd..c514032 100644 --- a/hw/riscv/sifive_prci.c +++ b/hw/riscv/sifive_e_prci.c @@ -1,5 +1,5 @@ /* - * QEMU SiFive PRCI (Power, Reset, Clock, Interrupt) + * QEMU SiFive E PRCI (Power, Reset, Clock, Interrupt) * * Copyright (c) 2017 SiFive, Inc. * @@ -22,19 +22,19 @@ #include "hw/sysbus.h" #include "qemu/log.h" #include "qemu/module.h" -#include "hw/riscv/sifive_prci.h" +#include "hw/riscv/sifive_e_prci.h" =20 -static uint64_t sifive_prci_read(void *opaque, hwaddr addr, unsigned int s= ize) +static uint64_t sifive_e_prci_read(void *opaque, hwaddr addr, unsigned int= size) { - SiFivePRCIState *s =3D opaque; + SiFiveEPRCIState *s =3D opaque; switch (addr) { - case SIFIVE_PRCI_HFROSCCFG: + case SIFIVE_E_PRCI_HFROSCCFG: return s->hfrosccfg; - case SIFIVE_PRCI_HFXOSCCFG: + case SIFIVE_E_PRCI_HFXOSCCFG: return s->hfxosccfg; - case SIFIVE_PRCI_PLLCFG: + case SIFIVE_E_PRCI_PLLCFG: return s->pllcfg; - case SIFIVE_PRCI_PLLOUTDIV: + case SIFIVE_E_PRCI_PLLOUTDIV: return s->plloutdiv; } qemu_log_mask(LOG_GUEST_ERROR, "%s: read: addr=3D0x%x\n", @@ -42,27 +42,27 @@ static uint64_t sifive_prci_read(void *opaque, hwaddr a= ddr, unsigned int size) return 0; } =20 -static void sifive_prci_write(void *opaque, hwaddr addr, - uint64_t val64, unsigned int size) +static void sifive_e_prci_write(void *opaque, hwaddr addr, + uint64_t val64, unsigned int size) { - SiFivePRCIState *s =3D opaque; + SiFiveEPRCIState *s =3D opaque; switch (addr) { - case SIFIVE_PRCI_HFROSCCFG: + case SIFIVE_E_PRCI_HFROSCCFG: s->hfrosccfg =3D (uint32_t) val64; /* OSC stays ready */ - s->hfrosccfg |=3D SIFIVE_PRCI_HFROSCCFG_RDY; + s->hfrosccfg |=3D SIFIVE_E_PRCI_HFROSCCFG_RDY; break; - case SIFIVE_PRCI_HFXOSCCFG: + case SIFIVE_E_PRCI_HFXOSCCFG: s->hfxosccfg =3D (uint32_t) val64; /* OSC stays ready */ - s->hfxosccfg |=3D SIFIVE_PRCI_HFXOSCCFG_RDY; + s->hfxosccfg |=3D SIFIVE_E_PRCI_HFXOSCCFG_RDY; break; - case SIFIVE_PRCI_PLLCFG: + case SIFIVE_E_PRCI_PLLCFG: s->pllcfg =3D (uint32_t) val64; /* PLL stays locked */ - s->pllcfg |=3D SIFIVE_PRCI_PLLCFG_LOCK; + s->pllcfg |=3D SIFIVE_E_PRCI_PLLCFG_LOCK; break; - case SIFIVE_PRCI_PLLOUTDIV: + case SIFIVE_E_PRCI_PLLOUTDIV: s->plloutdiv =3D (uint32_t) val64; break; default: @@ -71,9 +71,9 @@ static void sifive_prci_write(void *opaque, hwaddr addr, } } =20 -static const MemoryRegionOps sifive_prci_ops =3D { - .read =3D sifive_prci_read, - .write =3D sifive_prci_write, +static const MemoryRegionOps sifive_e_prci_ops =3D { + .read =3D sifive_e_prci_read, + .write =3D sifive_e_prci_write, .endianness =3D DEVICE_NATIVE_ENDIAN, .valid =3D { .min_access_size =3D 4, @@ -81,43 +81,42 @@ static const MemoryRegionOps sifive_prci_ops =3D { } }; =20 -static void sifive_prci_init(Object *obj) +static void sifive_e_prci_init(Object *obj) { - SiFivePRCIState *s =3D SIFIVE_PRCI(obj); + SiFiveEPRCIState *s =3D SIFIVE_E_PRCI(obj); =20 - memory_region_init_io(&s->mmio, obj, &sifive_prci_ops, s, - TYPE_SIFIVE_PRCI, 0x8000); + memory_region_init_io(&s->mmio, obj, &sifive_e_prci_ops, s, + TYPE_SIFIVE_E_PRCI, 0x8000); sysbus_init_mmio(SYS_BUS_DEVICE(obj), &s->mmio); =20 - s->hfrosccfg =3D (SIFIVE_PRCI_HFROSCCFG_RDY | SIFIVE_PRCI_HFROSCCFG_EN= ); - s->hfxosccfg =3D (SIFIVE_PRCI_HFROSCCFG_RDY | SIFIVE_PRCI_HFROSCCFG_EN= ); - s->pllcfg =3D (SIFIVE_PRCI_PLLCFG_REFSEL | SIFIVE_PRCI_PLLCFG_BYPASS | - SIFIVE_PRCI_PLLCFG_LOCK); - s->plloutdiv =3D SIFIVE_PRCI_PLLOUTDIV_DIV1; - + s->hfrosccfg =3D (SIFIVE_E_PRCI_HFROSCCFG_RDY | SIFIVE_E_PRCI_HFROSCCF= G_EN); + s->hfxosccfg =3D (SIFIVE_E_PRCI_HFROSCCFG_RDY | SIFIVE_E_PRCI_HFROSCCF= G_EN); + s->pllcfg =3D (SIFIVE_E_PRCI_PLLCFG_REFSEL | SIFIVE_E_PRCI_PLLCFG_BYPA= SS | + SIFIVE_E_PRCI_PLLCFG_LOCK); + s->plloutdiv =3D SIFIVE_E_PRCI_PLLOUTDIV_DIV1; } =20 -static const TypeInfo sifive_prci_info =3D { - .name =3D TYPE_SIFIVE_PRCI, +static const TypeInfo sifive_e_prci_info =3D { + .name =3D TYPE_SIFIVE_E_PRCI, .parent =3D TYPE_SYS_BUS_DEVICE, - .instance_size =3D sizeof(SiFivePRCIState), - .instance_init =3D sifive_prci_init, + .instance_size =3D sizeof(SiFiveEPRCIState), + .instance_init =3D sifive_e_prci_init, }; =20 -static void sifive_prci_register_types(void) +static void sifive_e_prci_register_types(void) { - type_register_static(&sifive_prci_info); + type_register_static(&sifive_e_prci_info); } =20 -type_init(sifive_prci_register_types) +type_init(sifive_e_prci_register_types) =20 =20 /* * Create PRCI device. */ -DeviceState *sifive_prci_create(hwaddr addr) +DeviceState *sifive_e_prci_create(hwaddr addr) { - DeviceState *dev =3D qdev_create(NULL, TYPE_SIFIVE_PRCI); + DeviceState *dev =3D qdev_create(NULL, TYPE_SIFIVE_E_PRCI); qdev_init_nofail(dev); sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, addr); return dev; diff --git a/include/hw/riscv/sifive_e_prci.h b/include/hw/riscv/sifive_e_p= rci.h new file mode 100644 index 0000000..c4b76aa --- /dev/null +++ b/include/hw/riscv/sifive_e_prci.h @@ -0,0 +1,69 @@ +/* + * QEMU SiFive E PRCI (Power, Reset, Clock, Interrupt) interface + * + * Copyright (c) 2017 SiFive, Inc. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms and conditions of the GNU General Public License, + * version 2 or later, as published by the Free Software Foundation. + * + * This program is distributed in the hope it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License f= or + * more details. + * + * You should have received a copy of the GNU General Public License along= with + * this program. If not, see . + */ + +#ifndef HW_SIFIVE_E_PRCI_H +#define HW_SIFIVE_E_PRCI_H + +enum { + SIFIVE_E_PRCI_HFROSCCFG =3D 0x0, + SIFIVE_E_PRCI_HFXOSCCFG =3D 0x4, + SIFIVE_E_PRCI_PLLCFG =3D 0x8, + SIFIVE_E_PRCI_PLLOUTDIV =3D 0xC +}; + +enum { + SIFIVE_E_PRCI_HFROSCCFG_RDY =3D (1 << 31), + SIFIVE_E_PRCI_HFROSCCFG_EN =3D (1 << 30) +}; + +enum { + SIFIVE_E_PRCI_HFXOSCCFG_RDY =3D (1 << 31), + SIFIVE_E_PRCI_HFXOSCCFG_EN =3D (1 << 30) +}; + +enum { + SIFIVE_E_PRCI_PLLCFG_PLLSEL =3D (1 << 16), + SIFIVE_E_PRCI_PLLCFG_REFSEL =3D (1 << 17), + SIFIVE_E_PRCI_PLLCFG_BYPASS =3D (1 << 18), + SIFIVE_E_PRCI_PLLCFG_LOCK =3D (1 << 31) +}; + +enum { + SIFIVE_E_PRCI_PLLOUTDIV_DIV1 =3D (1 << 8) +}; + +#define TYPE_SIFIVE_E_PRCI "riscv.sifive.e.prci" + +#define SIFIVE_E_PRCI(obj) \ + OBJECT_CHECK(SiFiveEPRCIState, (obj), TYPE_SIFIVE_E_PRCI) + +typedef struct SiFiveEPRCIState { + /*< private >*/ + SysBusDevice parent_obj; + + /*< public >*/ + MemoryRegion mmio; + uint32_t hfrosccfg; + uint32_t hfxosccfg; + uint32_t pllcfg; + uint32_t plloutdiv; +} SiFiveEPRCIState; + +DeviceState *sifive_e_prci_create(hwaddr addr); + +#endif diff --git a/include/hw/riscv/sifive_prci.h b/include/hw/riscv/sifive_prci.h deleted file mode 100644 index bd51c4a..0000000 --- a/include/hw/riscv/sifive_prci.h +++ /dev/null @@ -1,69 +0,0 @@ -/* - * QEMU SiFive PRCI (Power, Reset, Clock, Interrupt) interface - * - * Copyright (c) 2017 SiFive, Inc. - * - * This program is free software; you can redistribute it and/or modify it - * under the terms and conditions of the GNU General Public License, - * version 2 or later, as published by the Free Software Foundation. - * - * This program is distributed in the hope it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License f= or - * more details. - * - * You should have received a copy of the GNU General Public License along= with - * this program. If not, see . - */ - -#ifndef HW_SIFIVE_PRCI_H -#define HW_SIFIVE_PRCI_H - -enum { - SIFIVE_PRCI_HFROSCCFG =3D 0x0, - SIFIVE_PRCI_HFXOSCCFG =3D 0x4, - SIFIVE_PRCI_PLLCFG =3D 0x8, - SIFIVE_PRCI_PLLOUTDIV =3D 0xC -}; - -enum { - SIFIVE_PRCI_HFROSCCFG_RDY =3D (1 << 31), - SIFIVE_PRCI_HFROSCCFG_EN =3D (1 << 30) -}; - -enum { - SIFIVE_PRCI_HFXOSCCFG_RDY =3D (1 << 31), - SIFIVE_PRCI_HFXOSCCFG_EN =3D (1 << 30) -}; - -enum { - SIFIVE_PRCI_PLLCFG_PLLSEL =3D (1 << 16), - SIFIVE_PRCI_PLLCFG_REFSEL =3D (1 << 17), - SIFIVE_PRCI_PLLCFG_BYPASS =3D (1 << 18), - SIFIVE_PRCI_PLLCFG_LOCK =3D (1 << 31) -}; - -enum { - SIFIVE_PRCI_PLLOUTDIV_DIV1 =3D (1 << 8) -}; - -#define TYPE_SIFIVE_PRCI "riscv.sifive.prci" - -#define SIFIVE_PRCI(obj) \ - OBJECT_CHECK(SiFivePRCIState, (obj), TYPE_SIFIVE_PRCI) - -typedef struct SiFivePRCIState { - /*< private >*/ - SysBusDevice parent_obj; - - /*< public >*/ - MemoryRegion mmio; - uint32_t hfrosccfg; - uint32_t hfxosccfg; - uint32_t pllcfg; - uint32_t plloutdiv; -} SiFivePRCIState; - -DeviceState *sifive_prci_create(hwaddr addr); - -#endif --=20 2.7.4