qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH] pcnet: Add link state support


From: Anthony Liguori
Subject: Re: [Qemu-devel] [PATCH] pcnet: Add link state support
Date: Tue, 01 Nov 2011 17:20:22 -0500
User-agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.2.21) Gecko/20110831 Lightning/1.0b2 Thunderbird/3.1.13

On 10/07/2011 05:27 AM, Jan Kiszka wrote:
Update lnkst on link state changes so that guests can obtain this
information via reading back the LED output pin. Works for Linux but
not for guests that depend on the missing PHY.

Signed-off-by: Jan Kiszka<address@hidden>

Applied.  Thanks.

Regards,

Anthony Liguori

---
  hw/lance.c     |    1 +
  hw/pcnet-pci.c |    1 +
  hw/pcnet.c     |    7 +++++++
  hw/pcnet.h     |    1 +
  4 files changed, 10 insertions(+), 0 deletions(-)

diff --git a/hw/lance.c b/hw/lance.c
index d83e7f5..93d5fda 100644
--- a/hw/lance.c
+++ b/hw/lance.c
@@ -97,6 +97,7 @@ static NetClientInfo net_lance_info = {
      .size = sizeof(NICState),
      .can_receive = pcnet_can_receive,
      .receive = pcnet_receive,
+    .link_status_changed = pcnet_set_link_status,
      .cleanup = lance_cleanup,
  };

diff --git a/hw/pcnet-pci.c b/hw/pcnet-pci.c
index cab1116..548bb50 100644
--- a/hw/pcnet-pci.c
+++ b/hw/pcnet-pci.c
@@ -287,6 +287,7 @@ static NetClientInfo net_pci_pcnet_info = {
      .size = sizeof(NICState),
      .can_receive = pcnet_can_receive,
      .receive = pcnet_receive,
+    .link_status_changed = pcnet_set_link_status,
      .cleanup = pci_pcnet_cleanup,
  };

diff --git a/hw/pcnet.c b/hw/pcnet.c
index add3ec2..cba253b 100644
--- a/hw/pcnet.c
+++ b/hw/pcnet.c
@@ -1197,6 +1197,13 @@ ssize_t pcnet_receive(VLANClientState *nc, const uint8_t 
*buf, size_t size_)
      return size_;
  }

+void pcnet_set_link_status(VLANClientState *nc)
+{
+    PCNetState *d = DO_UPCAST(NICState, nc, nc)->opaque;
+
+    d->lnkst = nc->link_down ? 0 : 0x40;
+}
+
  static void pcnet_transmit(PCNetState *s)
  {
      target_phys_addr_t xmit_cxda = 0;
diff --git a/hw/pcnet.h b/hw/pcnet.h
index 52cc52e..edc81c9 100644
--- a/hw/pcnet.h
+++ b/hw/pcnet.h
@@ -58,6 +58,7 @@ uint32_t pcnet_ioport_readl(void *opaque, uint32_t addr);
  uint32_t pcnet_bcr_readw(PCNetState *s, uint32_t rap);
  int pcnet_can_receive(VLANClientState *nc);
  ssize_t pcnet_receive(VLANClientState *nc, const uint8_t *buf, size_t size_);
+void pcnet_set_link_status(VLANClientState *nc);
  void pcnet_common_cleanup(PCNetState *d);
  int pcnet_common_init(DeviceState *dev, PCNetState *s, NetClientInfo *info);
  extern const VMStateDescription vmstate_pcnet;




reply via email to

[Prev in Thread] Current Thread [Next in Thread]