From: John Snow <jsnow@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: kwolf@redhat.com, qemu-devel@nongnu.org, stefanha@redhat.com,
mst@redhat.com
Subject: Re: [Qemu-devel] [PATCH 4/6] ide: Update ide_drive_get to be HBA agnostic
Date: Wed, 24 Sep 2014 12:49:54 -0400 [thread overview]
Message-ID: <5422F632.1080401@redhat.com> (raw)
In-Reply-To: <87egv1ozlt.fsf@blackfin.pond.sub.org>
On 09/24/2014 10:35 AM, Markus Armbruster wrote:
> John Snow <jsnow@redhat.com> writes:
>
>> Instead of duplicating the logic for the if_ide
>> (bus,unit) mappings, rely on the blockdev layer
>> for managing those mappings for us, and use the
>> drive_get_by_index call instead.
>>
>> This allows ide_drive_get to work for AHCI HBAs
>> as well, and can be used in the Q35 initialization.
>>
>> Signed-off-by: John Snow <jsnow@redhat.com>
>> ---
>> hw/ide/core.c | 12 +++++++-----
>> 1 file changed, 7 insertions(+), 5 deletions(-)
>>
>> diff --git a/hw/ide/core.c b/hw/ide/core.c
>> index 6fba056..1e43d50 100644
>> --- a/hw/ide/core.c
>> +++ b/hw/ide/core.c
>> @@ -2551,13 +2551,15 @@ const VMStateDescription vmstate_ide_bus = {
>> void ide_drive_get(DriveInfo **hd, int max_bus)
>> {
>> int i;
>> + int max_devs = if_get_max_devs(IF_IDE) * max_bus;
>
> Okay, here you need if_get_max_devs(). Suggest to move its introduction
> from PATCH 2 to this one. Hmm, I guess we better change its name to
> start with drive_.
>
>> + int buses = drive_get_max_bus(IF_IDE) + 1;
>>
>> - if (drive_get_max_bus(IF_IDE) >= max_bus) {
>> - fprintf(stderr, "qemu: too many IDE bus: %d\n", max_bus);
>> - exit(1);
>> + if (buses > max_bus) {
>> + fprintf(stderr, "Warning: Too many IDE buses defined (%d > %d)\n",
>> + buses, max_bus);
>
> New! Error message now English!
>
> Since you touch it, you could use error_report(). Not important, as
> doesn't make much of a difference in this case.
>
>> }
>>
>> - for(i = 0; i < max_bus * MAX_IDE_DEVS; i++) {
>> - hd[i] = drive_get(IF_IDE, i / MAX_IDE_DEVS, i % MAX_IDE_DEVS);
>> + for (i = 0; i < max_devs; i++) {
>> + hd[i] = drive_get_by_index(IF_IDE, i);
>> }
>> }
>
> Maybe parameter max_bus should be replaced by the number of slots in
> hd[]. What do you think?
>
This is your only recommendation I haven't implemented yet for V2. I
think this makes sense from a mechanical perspective because it would be
nice to have the hard guarantee of not running over the array boundary
instead of relying on the numbers in different places to be consistent.
The only reason I didn't do this is because I didn't want to touch calls
to drive_get in 10 boards.
On the other hand, if the numbers are out of alignment and we run over
the end of the array here, it's a board property not aligning with how
the board init function works -- Not really a runtime issue, and
something we can avoid relatively easily.
However, this could be a problem if we decide NOT to make the
units-per-bus property constant across all Q35 types, for example, if we
don't also then update how we generate this HD array.
(If Q35 1.6 does not use this property, we'll have 12 max devices
implied, which is clearly wrong and why I advocate instating this
property backwards for all versions.)
I think I am inclined to leave it as-is for now provided we agree that
creating this property for all versions makes sense. If we wish to add
the ability to have different numbers of units-per-bus properties per
version, then the ide drive pickup code on all boards will have to get
smarter.
Thoughts?
next prev parent reply other threads:[~2014-09-24 17:46 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-09-23 16:47 [Qemu-devel] [PATCH 0/6] Q35: Implement -cdrom/-hda sugar John Snow
2014-09-23 16:48 ` [Qemu-devel] [PATCH 1/6] blockdev: Orphaned drive search John Snow
2014-09-24 14:06 ` Markus Armbruster
2014-09-24 22:36 ` John Snow
2014-09-23 16:48 ` [Qemu-devel] [PATCH 2/6] blockdev: Allow overriding if_max_dev property John Snow
2014-09-24 14:10 ` Markus Armbruster
2014-09-23 16:48 ` [Qemu-devel] [PATCH 3/6] pc/vl: Add units-per-default-bus property John Snow
2014-09-24 14:25 ` Markus Armbruster
2014-09-23 16:48 ` [Qemu-devel] [PATCH 4/6] ide: Update ide_drive_get to be HBA agnostic John Snow
2014-09-24 14:35 ` Markus Armbruster
2014-09-24 16:49 ` John Snow [this message]
2014-09-25 6:13 ` Markus Armbruster
2014-09-26 16:34 ` John Snow
2014-09-27 8:41 ` Markus Armbruster
2014-09-23 16:48 ` [Qemu-devel] [PATCH 5/6] qtest/bios-tables: Correct Q35 command line John Snow
2014-09-23 16:48 ` [Qemu-devel] [PATCH 6/6] q35/ahci: Pick up -cdrom and -hda options John Snow
2014-09-24 15:08 ` Markus Armbruster
2014-09-24 15:30 ` Markus Armbruster
2014-09-24 15:32 ` [Qemu-devel] [PATCH 0/6] Q35: Implement -cdrom/-hda sugar Markus Armbruster
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=5422F632.1080401@redhat.com \
--to=jsnow@redhat.com \
--cc=armbru@redhat.com \
--cc=kwolf@redhat.com \
--cc=mst@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@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).