From: Gerhard Wiesinger <lists@wiesinger.com>
To: William Dauchy <wdauchy@gmail.com>
Cc: blauwirbel@gmail.com, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] Re: [PATCH] moving eeprom initialization
Date: Wed, 2 Mar 2011 19:28:10 +0100 (CET) [thread overview]
Message-ID: <alpine.LFD.2.02.1103021924210.1898@bbs.intern> (raw)
In-Reply-To: <AANLkTi=bKKTTL9qurm=Cn6B+ZN5i5GEh0XWsd1=xt+br@mail.gmail.com>
[-- Attachment #1: Type: TEXT/PLAIN, Size: 4305 bytes --]
Hello,
Your patch should be based on fixes for correct EEPROM initialization,
see for details:
http://www.mail-archive.com/qemu-devel@nongnu.org/msg56414.html
Ciao,
Gerhard
--
http://www.wiesinger.com/
On Wed, 2 Mar 2011, William Dauchy wrote:
> On Wed, Mar 2, 2011 at 2:36 PM, William Dauchy <wdauchy@gmail.com> wrote:
>> The initialization should not be only on reset but also when initializing
>> the device.
>> It resolves a bug when hot plugging a pci network device: the mac address
>> was always null.
>> ---
>> hw/pcnet.c | 27 ++++++++++++++-------------
>> hw/rtl8139.c | 24 ++++++++++++------------
>> 2 files changed, 26 insertions(+), 25 deletions(-)
>>
>> diff --git a/hw/pcnet.c b/hw/pcnet.c
>> index db52dc5..4e30e9c 100644
>> --- a/hw/pcnet.c
>> +++ b/hw/pcnet.c
>> @@ -1557,19 +1557,6 @@ uint32_t pcnet_bcr_readw(PCNetState *s, uint32_t rap)
>> void pcnet_h_reset(void *opaque)
>> {
>> PCNetState *s = opaque;
>> - int i;
>> - uint16_t checksum;
>> -
>> - /* Initialize the PROM */
>> -
>> - memcpy(s->prom, s->conf.macaddr.a, 6);
>> - s->prom[12] = s->prom[13] = 0x00;
>> - s->prom[14] = s->prom[15] = 0x57;
>> -
>> - for (i = 0,checksum = 0; i < 16; i++)
>> - checksum += s->prom[i];
>> - *(uint16_t *)&s->prom[12] = cpu_to_le16(checksum);
>> -
>>
>> s->bcr[BCR_MSRDA] = 0x0005;
>> s->bcr[BCR_MSWRA] = 0x0005;
>> @@ -1736,6 +1723,9 @@ void pcnet_common_cleanup(PCNetState *d)
>>
>> int pcnet_common_init(DeviceState *dev, PCNetState *s, NetClientInfo *info)
>> {
>> + int i;
>> + uint16_t checksum;
>> +
>> s->poll_timer = qemu_new_timer(vm_clock, pcnet_poll_timer, s);
>>
>> qemu_macaddr_default_if_unset(&s->conf.macaddr);
>> @@ -1744,5 +1734,16 @@ int pcnet_common_init(DeviceState *dev, PCNetState *s, NetClientInfo *info)
>>
>> add_boot_device_path(s->conf.bootindex, dev, "/ethernet-phy@0");
>>
>> + /* Initialize the PROM */
>> +
>> + memcpy(s->prom, s->conf.macaddr.a, 6);
>> + s->prom[12] = s->prom[13] = 0x00;
>> + s->prom[14] = s->prom[15] = 0x57;
>> +
>> + for (i = 0, checksum = 0; i < 16; i++) {
>> + checksum += s->prom[i];
>> + }
>> + *(uint16_t *)&s->prom[12] = cpu_to_le16(checksum);
>> +
>> return 0;
>> }
>> diff --git a/hw/rtl8139.c b/hw/rtl8139.c
>> index a22530c..8356d5a 100644
>> --- a/hw/rtl8139.c
>> +++ b/hw/rtl8139.c
>> @@ -1189,18 +1189,6 @@ static void rtl8139_reset(DeviceState *d)
>>
>> rtl8139_update_irq(s);
>>
>> - /* prepare eeprom */
>> - s->eeprom.contents[0] = 0x8129;
>> -#if 1
>> - // PCI vendor and device ID should be mirrored here
>> - s->eeprom.contents[1] = PCI_VENDOR_ID_REALTEK;
>> - s->eeprom.contents[2] = PCI_DEVICE_ID_REALTEK_8139;
>> -#endif
>> -
>> - s->eeprom.contents[7] = s->conf.macaddr.a[0] | s->conf.macaddr.a[1] << 8;
>> - s->eeprom.contents[8] = s->conf.macaddr.a[2] | s->conf.macaddr.a[3] << 8;
>> - s->eeprom.contents[9] = s->conf.macaddr.a[4] | s->conf.macaddr.a[5] << 8;
>> -
>> /* mark all status registers as owned by host */
>> for (i = 0; i < 4; ++i)
>> {
>> @@ -3392,6 +3380,18 @@ static int pci_rtl8139_init(PCIDevice *dev)
>>
>> qemu_macaddr_default_if_unset(&s->conf.macaddr);
>>
>> + /* prepare eeprom */
>> + s->eeprom.contents[0] = 0x8129;
>> +#if 1
>> + /* PCI vendor and device ID should be mirrored here */
>> + s->eeprom.contents[1] = PCI_VENDOR_ID_REALTEK;
>> + s->eeprom.contents[2] = PCI_DEVICE_ID_REALTEK_8139;
>> +#endif
>> +
>> + s->eeprom.contents[7] = s->conf.macaddr.a[0] | s->conf.macaddr.a[1] << 8;
>> + s->eeprom.contents[8] = s->conf.macaddr.a[2] | s->conf.macaddr.a[3] << 8;
>> + s->eeprom.contents[9] = s->conf.macaddr.a[4] | s->conf.macaddr.a[5] << 8;
>> +
>> s->nic = qemu_new_nic(&net_rtl8139_info, &s->conf,
>> dev->qdev.info->name, dev->qdev.id, s);
>> qemu_format_nic_info_str(&s->nic->nc, s->conf.macaddr.a);
>> --
>> William
>
> hm I just noticed your correction here
> http://lists.gnu.org/archive/html/qemu-devel/2011-02/msg03232.html ;
> sorry
> Anyway, I tested my version and it works fine.
>
> Regards,
>
> --
> William
>
>
>
next prev parent reply other threads:[~2011-03-02 18:32 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-02-24 14:40 [Qemu-devel] null mac address William Dauchy
2011-02-25 1:32 ` Wen Congyang
2011-02-25 2:55 ` Wen Congyang
2011-02-25 18:15 ` Blue Swirl
2011-02-28 2:09 ` [Qemu-devel] [PATCH v2] move eeprom init from reset function to init function Wen Congyang
2011-03-02 13:36 ` [Qemu-devel] [PATCH] moving eeprom initialization William Dauchy
2011-03-02 15:25 ` [Qemu-devel] " William Dauchy
2011-03-02 18:28 ` Gerhard Wiesinger [this message]
2011-03-02 20:54 ` William Dauchy
2011-03-05 12:15 ` Blue Swirl
2011-03-06 19:23 ` [Qemu-devel] " William Dauchy
2011-03-06 20:38 ` Gerhard Wiesinger
2011-03-06 21:12 ` William Dauchy
2011-03-06 21:27 ` William Dauchy
2011-03-07 2:38 ` [Qemu-devel] " Wen Congyang
2011-03-13 13:33 ` Blue Swirl
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=alpine.LFD.2.02.1103021924210.1898@bbs.intern \
--to=lists@wiesinger.com \
--cc=blauwirbel@gmail.com \
--cc=qemu-devel@nongnu.org \
--cc=wdauchy@gmail.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).