From: Peter Maydell <peter.maydell@linaro.org>
To: Alistair Francis <alistair.francis@xilinx.com>
Cc: "Edgar Iglesias" <edgar.iglesias@xilinx.com>,
"Peter Crosthwaite" <peter.crosthwaite@xilinx.com>,
eric.auger@linaro.org, "Kim Phillips" <kim.phillips@linaro.org>,
"Markus Armbruster" <armbru@redhat.com>,
"Alexander Graf" <agraf@suse.de>,
"QEMU Developers" <qemu-devel@nongnu.org>,
"Edgar E. Iglesias" <edgar.iglesias@gmail.com>,
"Andreas Färber" <afaerber@suse.de>
Subject: Re: [Qemu-devel] [PATCH v2 0/4] Allow sysbus devices to be attached via commandline
Date: Fri, 11 Apr 2014 08:55:34 +0100 [thread overview]
Message-ID: <CAFEAcA94a=hXmXzeok4sdY7_CYf=YB2JQgQDGOWXFV_VCjWkpw@mail.gmail.com> (raw)
In-Reply-To: <cover.1397197001.git.alistair.francis@xilinx.com>
On 11 April 2014 07:34, Alistair Francis <alistair.francis@xilinx.com> wrote:
> This patch allows sysbus devices to be attached via
> command line arguments.
>
> This can be used to build an entire machine from the command
> line or to just add devices that aren't in the machine_init
> code.
>
> A peripheral can be added with the following syntax:
> -device cadence_uart,addr=0xE0000000,irq=27
>
> A CPU can be added with either of the following:
> -device cpu,model=cortex-a9,type=arm-cpu,reset-cbar=0xF8F00000,midr=0x413 FC090
> -sysbusdev device=cpu,name=microblaze-cp
I don't see how this can possibly be sufficient information
to wire up the CPU properly. How would you specify
where the generic timer outputs go on an A15?
How are you going to handle the private peripheral
mappings? Is the user supposed to provide another
argument for the a9mpcore_priv device?
> RAM or ROM can be attached with this command:
> -device memory,name=zynq.ext_ram,addr=0x00000000,size=0x8000000
How would you use this if you needed to manage
multiple separate address spaces? I'm hoping we can
get rid of address_space_memory at some point
in favour of actually properly modelling when different
CPUs or DMA masters have different views of the world,
so I don't want us to tie ourselves into an incorrect
model by command line back-compat problems.
> Multiple IRQ lines can be used as well as multiple properties:
> -device pl330,addr=0xF8003000,irq=13,irq=14,irq=15,irq=16,irq=17,\
> irq=40,irq=41,irq=42,irq=43,num_chnls=8,num_periph_req=4,num_events=16
This doesn't seem to actually specify anywhere how those
IRQ numbers are supposed to be interpreted. You need
to somehow say "connect this IRQ output line up to
device X's GPIO input line Y" (where X will usually but not
necessarily be an interrupt controller).
Again addr= is assuming a single system wide address
space.
I also think that "allow machine specification by the
command line" is a terrible goal -- certainly we should allow
users the flexibility to put machines together from individual
devices, but we should do that with a reasonably usable
configuration or scripting language (and then we can use
that internally for our own board models). If you try to
specify things using command line argument syntax as
your primary approach then the result is going to end
up with hard-coded shortcuts (like the address space and
which-interrupt-controller problems I mention above) that
you've ended up with to try to make the command line
vaguely comprehensible. But the real comprehensibility
problem is from trying to do it with a single line of text
with highly constrained syntax conventions.
thanks
-- PMM
next prev parent reply other threads:[~2014-04-11 7:56 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-11 6:34 [Qemu-devel] [PATCH v2 0/4] Allow sysbus devices to be attached via commandline Alistair Francis
2014-04-11 6:34 ` [Qemu-devel] [PATCH v2 1/4] qemu-option.c: Add qemu_opt functions that step over arguments Alistair Francis
2014-04-11 6:34 ` [Qemu-devel] [PATCH v2 2/4] qdev-monitor: Implement three functions used to connect devices Alistair Francis
2014-04-11 6:34 ` [Qemu-devel] [PATCH v2 3/4] vl.c: Enable adding devices to the system bus Alistair Francis
2014-04-11 7:45 ` Peter Maydell
2014-04-11 6:35 ` [Qemu-devel] [PATCH v2 4/4] qemu-options.hx: Update the command line documentation for -device Alistair Francis
2014-04-11 9:49 ` Peter Crosthwaite
2014-04-11 6:41 ` [Qemu-devel] [PATCH v2 0/4] Allow sysbus devices to be attached via commandline Alistair Francis
2014-04-11 7:55 ` Peter Maydell [this message]
2014-04-11 9:09 ` Alexander Graf
2014-04-11 9:13 ` Peter Crosthwaite
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='CAFEAcA94a=hXmXzeok4sdY7_CYf=YB2JQgQDGOWXFV_VCjWkpw@mail.gmail.com' \
--to=peter.maydell@linaro.org \
--cc=afaerber@suse.de \
--cc=agraf@suse.de \
--cc=alistair.francis@xilinx.com \
--cc=armbru@redhat.com \
--cc=edgar.iglesias@gmail.com \
--cc=edgar.iglesias@xilinx.com \
--cc=eric.auger@linaro.org \
--cc=kim.phillips@linaro.org \
--cc=peter.crosthwaite@xilinx.com \
--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).