qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Antony Pavlov <antonynpavlov@gmail.com>
To: Thomas Huth <thuth@redhat.com>
Cc: Michael Clark <mjc@sifive.com>, Stefan O'Rear <sorear2@gmail.com>,
	Sagar Karandikar <sagark@eecs.berkeley.edu>,
	Bastian Koppelmann <kbastian@mail.uni-paderborn.de>,
	Palmer Dabbelt <palmer@sifive.com>,
	qemu-devel@nongnu.org, RISC-V Patches <patches@groups.riscv.org>,
	Eric Blake <eblake@redhat.com>
Subject: Re: [Qemu-devel] [PATCH v8 19/23] SiFive RISC-V UART Device
Date: Tue, 10 Apr 2018 11:04:17 +0300	[thread overview]
Message-ID: <20180410110417.554bc8911fb2e2f0a3d99b2d@gmail.com> (raw)
In-Reply-To: <949f3787-7899-73ba-6c80-d3c20af68fda@redhat.com>

On Tue, 10 Apr 2018 08:17:32 +0200
Thomas Huth <thuth@redhat.com> wrote:

> On 10.04.2018 05:21, Antony Pavlov wrote:
> > On Sat,  3 Mar 2018 02:51:47 +1300
> > Michael Clark <mjc@sifive.com> wrote:
> > 
> >> QEMU model of the UART on the SiFive E300 and U500 series SOCs.
> >> BBL supports the SiFive UART for early console access via the SBI
> >> (Supervisor Binary Interface) and the linux kernel SBI console.
> >>
> >> The SiFive UART implements the pre qom legacy interface consistent
> >> with the 16550a UART in 'hw/char/serial.c'.
> >>
> >> Acked-by: Richard Henderson <richard.henderson@linaro.org>
> >> Signed-off-by: Stefan O'Rear <sorear2@gmail.com>
> >> Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
> >> Signed-off-by: Michael Clark <mjc@sifive.com>
> >> ---
> >>  hw/riscv/sifive_uart.c         | 176 +++++++++++++++++++++++++++++++++++++++++
> >>  include/hw/riscv/sifive_uart.h |  71 +++++++++++++++++
> >>  2 files changed, 247 insertions(+)
> >>  create mode 100644 hw/riscv/sifive_uart.c
> >>  create mode 100644 include/hw/riscv/sifive_uart.h
> >>
> >> diff --git a/hw/riscv/sifive_uart.c b/hw/riscv/sifive_uart.c
> >> new file mode 100644
> >> index 0000000..b0c3798
> >> --- /dev/null
> >> +++ b/hw/riscv/sifive_uart.c
> >> @@ -0,0 +1,176 @@
> >> +/*
> >> + * QEMU model of the UART on the SiFive E300 and U500 series SOCs.
> >> + *
> >> + * Copyright (c) 2016 Stefan O'Rear
> >> + *
> >> + * 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 for
> >> + * more details.
> >> + *
> >> + * You should have received a copy of the GNU General Public License along with
> >> + * this program.  If not, see <http://www.gnu.org/licenses/>.
> >> + */
> >> +
> >> +#include "qemu/osdep.h"
> >> +#include "qapi/error.h"
> >> +#include "hw/sysbus.h"
> >> +#include "chardev/char.h"
> >> +#include "chardev/char-fe.h"
> >> +#include "target/riscv/cpu.h"
> >> +#include "hw/riscv/sifive_uart.h"
> >>
> >> +/*
> >> + * Not yet implemented:
> >> + *
> >> + * Transmit FIFO using "qemu/fifo8.h"
> >> + * SIFIVE_UART_IE_TXWM interrupts
> >> + * SIFIVE_UART_IE_RXWM interrupts must honor fifo watermark
> >> + * Rx FIFO watermark interrupt trigger threshold
> >> + * Tx FIFO watermark interrupt trigger threshold.
> >> + */
> >> +
> >> +static void update_irq(SiFiveUARTState *s)
> >> +{
> >> +    int cond = 0;
> >> +    if ((s->ie & SIFIVE_UART_IE_RXWM) && s->rx_fifo_len) {
> >> +        cond = 1;
> >> +    }
> >> +    if (cond) {
> >> +        qemu_irq_raise(s->irq);
> >> +    } else {
> >> +        qemu_irq_lower(s->irq);
> >> +    }
> >> +}
> >> +
> >> +static uint64_t
> >> +uart_read(void *opaque, hwaddr addr, unsigned int size)
> >> +{
> >> +    SiFiveUARTState *s = opaque;
> >> +    unsigned char r;
> >> +    switch (addr) {
> >> +    case SIFIVE_UART_RXFIFO:
> >> +        if (s->rx_fifo_len) {
> >> +            r = s->rx_fifo[0];
> >> +            memmove(s->rx_fifo, s->rx_fifo + 1, s->rx_fifo_len - 1);
> >> +            s->rx_fifo_len--;
> >> +            qemu_chr_fe_accept_input(&s->chr);
> >> +            update_irq(s);
> >> +            return r;
> >> +        }
> >> +        return 0x80000000;
> >> +
> >> +    case SIFIVE_UART_TXFIFO:
> >> +        return 0; /* Should check tx fifo */
> >> +    case SIFIVE_UART_IE:
> >> +        return s->ie;
> >> +    case SIFIVE_UART_IP:
> >> +        return s->rx_fifo_len ? SIFIVE_UART_IP_RXWM : 0;
> >> +    case SIFIVE_UART_TXCTRL:
> >> +        return s->txctrl;
> >> +    case SIFIVE_UART_RXCTRL:
> >> +        return s->rxctrl;
> >> +    case SIFIVE_UART_DIV:
> >> +        return s->div;
> >> +    }
> >> +
> >> +    hw_error("%s: bad read: addr=0x%x\n",
> >> +        __func__, (int)addr);
> >> +    return 0;
> >> +}
> >> +
> >> +static void
> >> +uart_write(void *opaque, hwaddr addr,
> >> +           uint64_t val64, unsigned int size)
> >> +{
> >> +    SiFiveUARTState *s = opaque;
> >> +    uint32_t value = val64;
> >> +    unsigned char ch = value;
> >> +
> >> +    switch (addr) {
> >> +    case SIFIVE_UART_TXFIFO:
> >> +        qemu_chr_fe_write(&s->chr, &ch, 1);
> >> +        return;
> >> +    case SIFIVE_UART_IE:
> >> +        s->ie = val64;
> >> +        update_irq(s);
> >> +        return;
> >> +    case SIFIVE_UART_TXCTRL:
> >> +        s->txctrl = val64;
> >> +        return;
> >> +    case SIFIVE_UART_RXCTRL:
> >> +        s->rxctrl = val64;
> >> +        return;
> >> +    case SIFIVE_UART_DIV:
> >> +        s->div = val64;
> >> +        return;
> >> +    }
> >> +    hw_error("%s: bad write: addr=0x%x v=0x%x\n",
> >> +        __func__, (int)addr, (int)value);
> >> +}
> >> +
> >> +static const MemoryRegionOps uart_ops = {
> >> +    .read = uart_read,
> >> +    .write = uart_write,
> >> +    .endianness = DEVICE_NATIVE_ENDIAN,
> >> +    .valid = {
> >> +        .min_access_size = 4,
> >> +        .max_access_size = 4
> >> +    }
> >> +};
> >> +
> >> +static void uart_rx(void *opaque, const uint8_t *buf, int size)
> >> +{
> >> +    SiFiveUARTState *s = opaque;
> >> +
> >> +    /* Got a byte.  */
> >> +    if (s->rx_fifo_len >= sizeof(s->rx_fifo)) {
> >> +        printf("WARNING: UART dropped char.\n");
> >> +        return;
> >> +    }
> >> +    s->rx_fifo[s->rx_fifo_len++] = *buf;
> >> +
> >> +    update_irq(s);
> >> +}
> >> +
> >> +static int uart_can_rx(void *opaque)
> >> +{
> >> +    SiFiveUARTState *s = opaque;
> >> +
> >> +    return s->rx_fifo_len < sizeof(s->rx_fifo);
> >> +}
> >> +
> >> +static void uart_event(void *opaque, int event)
> >> +{
> >> +}
> >> +
> >> +static int uart_be_change(void *opaque)
> >> +{
> >> +    SiFiveUARTState *s = opaque;
> >> +
> >> +    qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, uart_event,
> >> +        uart_be_change, s, NULL, true);
> >> +
> >> +    return 0;
> >> +}
> >> +
> >> +/*
> >> + * Create UART device.
> >> + */
> >> +SiFiveUARTState *sifive_uart_create(MemoryRegion *address_space, hwaddr base,
> >> +    Chardev *chr, qemu_irq irq)
> >> +{
> >> +    SiFiveUARTState *s = g_malloc0(sizeof(SiFiveUARTState));
> >> +    s->irq = irq;
> >> +    qemu_chr_fe_init(&s->chr, chr, &error_abort);
> >> +    qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, uart_event,
> >> +        uart_be_change, s, NULL, true);
> >> +    memory_region_init_io(&s->mmio, NULL, &uart_ops, s,
> >> +                          TYPE_SIFIVE_UART, SIFIVE_UART_MAX);
> >> +    memory_region_add_subregion(address_space, base, &s->mmio);
> >> +    return s;
> >> +}
> >> diff --git a/include/hw/riscv/sifive_uart.h b/include/hw/riscv/sifive_uart.h
> >> new file mode 100644
> >> index 0000000..504f18a
> >> --- /dev/null
> >> +++ b/include/hw/riscv/sifive_uart.h
> >> @@ -0,0 +1,71 @@
> >> +/*
> >> + * SiFive UART interface
> >> + *
> >> + * Copyright (c) 2016 Stefan O'Rear
> >> + * 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 for
> >> + * more details.
> >> + *
> >> + * You should have received a copy of the GNU General Public License along with
> >> + * this program.  If not, see <http://www.gnu.org/licenses/>.
> >> + */
> >> +
> >> +#ifndef HW_SIFIVE_UART_H
> >> +#define HW_SIFIVE_UART_H
> >> +
> >> +enum {
> >> +    SIFIVE_UART_TXFIFO        = 0,
> >> +    SIFIVE_UART_RXFIFO        = 4,
> >> +    SIFIVE_UART_TXCTRL        = 8,
> >> +    SIFIVE_UART_TXMARK        = 10,
> >> +    SIFIVE_UART_RXCTRL        = 12,
> >> +    SIFIVE_UART_RXMARK        = 14,
> >> +    SIFIVE_UART_IE            = 16,
> >> +    SIFIVE_UART_IP            = 20,
> >> +    SIFIVE_UART_DIV           = 24,
> >> +    SIFIVE_UART_MAX           = 32
> >> +};
> >> +
> >> +enum {
> >> +    SIFIVE_UART_IE_TXWM       = 1, /* Transmit watermark interrupt enable */
> >> +    SIFIVE_UART_IE_RXWM       = 2  /* Receive watermark interrupt enable */
> >> +};
> >> +
> >> +enum {
> >> +    SIFIVE_UART_IP_TXWM       = 1, /* Transmit watermark interrupt pending */
> >> +    SIFIVE_UART_IP_RXWM       = 2  /* Receive watermark interrupt pending */
> >> +};
> >> +
> >> +#define TYPE_SIFIVE_UART "riscv.sifive.uart"
> >> +
> >> +#define SIFIVE_UART(obj) \
> >> +    OBJECT_CHECK(SiFiveUARTState, (obj), TYPE_SIFIVE_UART)
> >> +
> >> +typedef struct SiFiveUARTState {
> >> +    /*< private >*/
> >> +    SysBusDevice parent_obj;
> > 
> > 
> > You use SysBusDevive in this header file but there is no 'include "hw/sysbus.h"' in the header file itself.
> > 
> > Please see my comment https://github.com/riscv/riscv-qemu/pull/130#issuecomment-379640538
> > 
> > 
> >> +    /*< public >*/
> >> +    qemu_irq irq;
> >> +    MemoryRegion mmio;
> >> +    CharBackend chr;
> > 
> > Just the same thing. CharBackend is defined in "chardev/char-fe.h" please include it.
> 
> Honestly, I rather prefer to *not* add more includes to header files
> than we already have. We already have got lots of "touch this header and
> you have to recompile almost the whole QEMU" conditions, so to avoid
> that this situation gets worse, we should rather avoid including headers
> from headers if it is not necessary. Thus if the current sources build
> fine, no need to change anything here. Just my 0.02 €.

Adding ONLY NECESSARY header files inclusions to header file __can't produce__
additional recompile efforts.
Moreover this can decrease number of include directives in c-files.

I __rebased__ my RISC-V board in my out-of tree qemu branch (https://github.com/miet-riscv-workgroup/riscv-qemu/tree/20180409.erizo). I faced with problem: I have to track dependencies of
header files from include/hw/riscv/ which I use.

So your "not-add-more-includes-to-header-files" approach has an disadvantage:
if a header file required header list changes, each c-file that includes that header file
must be edited to update the #include statement list.

RISC-V is a very promising architecture. It is possible that we will have many RISC-V-related
c-files in the future in qemu. It will be very painful to change these c-files on every RISC-V header
files requirements change.

To Eric Blake:
I have added you to CC because of your comment in the conversation https://patchwork.kernel.org/patch/10147099/

-- 
Best regards,
  Antony Pavlov

  reply	other threads:[~2018-04-10  7:48 UTC|newest]

Thread overview: 70+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-03-02 13:51 [Qemu-devel] [PATCH v8 00/23] RISC-V QEMU Port Submission Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 01/23] RISC-V Maintainers Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 02/23] RISC-V ELF Machine Definition Michael Clark
2018-03-09 13:05   ` Philippe Mathieu-Daudé
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 03/23] RISC-V CPU Core Definition Michael Clark
2018-03-03  2:23   ` Michael Clark
2018-03-03  2:34     ` Michael Clark
2018-03-05  9:44   ` Igor Mammedov
2018-03-05 22:24     ` Michael Clark
2018-03-06  8:58       ` Igor Mammedov
2018-03-06 10:41         ` Igor Mammedov
2018-03-07  3:23         ` Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 04/23] RISC-V Disassembler Michael Clark
2018-04-27 12:26   ` Peter Maydell
2018-04-29 23:27     ` Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 05/23] RISC-V CPU Helpers Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 06/23] RISC-V FPU Support Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 07/23] RISC-V GDB Stub Michael Clark
2018-03-09 12:46   ` Philippe Mathieu-Daudé
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 08/23] RISC-V TCG Code Generation Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 09/23] RISC-V Physical Memory Protection Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 10/23] RISC-V Linux User Emulation Michael Clark
2018-04-04 12:44   ` Laurent Vivier
2018-04-08 20:59     ` Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 11/23] Add symbol table callback interface to load_elf Michael Clark
2018-03-09 11:34   ` Philippe Mathieu-Daudé
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 12/23] RISC-V HTIF Console Michael Clark
2018-03-09 11:52   ` Philippe Mathieu-Daudé
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 13/23] RISC-V HART Array Michael Clark
2018-03-09 12:52   ` Philippe Mathieu-Daudé
2018-03-09 13:48     ` Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 14/23] SiFive RISC-V CLINT Block Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 15/23] SiFive RISC-V PLIC Block Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 16/23] RISC-V Spike Machines Michael Clark
2018-03-09  4:50   ` Michael Clark
2018-05-14 16:49   ` Peter Maydell
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 17/23] SiFive RISC-V Test Finisher Michael Clark
2018-03-09 11:57   ` Philippe Mathieu-Daudé
2018-03-10  3:01     ` Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 18/23] RISC-V VirtIO Machine Michael Clark
2018-04-27 14:17   ` Peter Maydell
2018-04-30  0:18     ` Michael Clark
2018-04-30  7:49       ` Peter Maydell
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 19/23] SiFive RISC-V UART Device Michael Clark
2018-03-09 12:39   ` Philippe Mathieu-Daudé
2018-03-10  3:02     ` Michael Clark
2018-03-10  9:40       ` Mark Cave-Ayland
2018-03-11 11:43         ` Bastian Koppelmann
2018-03-16 18:30           ` Michael Clark
2018-03-16 18:36             ` Michael Clark
2018-03-16 20:46               ` Bastian Koppelmann
2018-04-10  3:21   ` Antony Pavlov
2018-04-10  6:17     ` Thomas Huth
2018-04-10  8:04       ` Antony Pavlov [this message]
2018-04-11 21:12         ` Michael Clark
2018-04-11 22:25         ` Eric Blake
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 20/23] SiFive RISC-V PRCI Block Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 21/23] SiFive Freedom E Series RISC-V Machine Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 22/23] SiFive Freedom U " Michael Clark
2018-03-02 13:51 ` [Qemu-devel] [PATCH v8 23/23] RISC-V Build Infrastructure Michael Clark
2018-03-02 14:33   ` Eric Blake
2018-03-03  2:37     ` Michael Clark
2018-03-05 15:59       ` Eric Blake
2018-03-09 13:03   ` Philippe Mathieu-Daudé
2018-03-02 14:17 ` [Qemu-devel] [PATCH v8 00/23] RISC-V QEMU Port Submission no-reply
2018-03-05  8:41 ` Richard W.M. Jones
2018-03-05 10:02   ` Alex Bennée
2018-03-09 15:07   ` Michael Clark
2018-03-09 16:43   ` Peter Maydell
2018-03-09 18:27     ` Richard W.M. Jones

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=20180410110417.554bc8911fb2e2f0a3d99b2d@gmail.com \
    --to=antonynpavlov@gmail.com \
    --cc=eblake@redhat.com \
    --cc=kbastian@mail.uni-paderborn.de \
    --cc=mjc@sifive.com \
    --cc=palmer@sifive.com \
    --cc=patches@groups.riscv.org \
    --cc=qemu-devel@nongnu.org \
    --cc=sagark@eecs.berkeley.edu \
    --cc=sorear2@gmail.com \
    --cc=thuth@redhat.com \
    /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).