* [Qemu-devel] [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send
@ 2010-01-24 8:51 Jan Kiszka
2010-01-24 13:59 ` [Qemu-devel] " malc
2010-01-26 22:21 ` [Qemu-devel] " Anthony Liguori
0 siblings, 2 replies; 3+ messages in thread
From: Jan Kiszka @ 2010-01-24 8:51 UTC (permalink / raw)
To: malc; +Cc: Anthony Liguori, qemu-devel
[-- Attachment #1: Type: text/plain, Size: 1440 bytes --]
Commit 930c86820e introduced a regression to eth_send: eth_tx_desc_put
manipulates the host's tx descriptor copy before writing it back, but
two lines down the descriptor is evaluated again, leaving us with an
invalid next address if host and guest endianness differ. So this was
the actual issue commit 2e87c5b937 tried to paper over.
Signed-off-by: Jan Kiszka <jan.kiszka@web.de>
---
hw/musicpal.c | 7 +++----
1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/hw/musicpal.c b/hw/musicpal.c
index e424a7d..b8af15e 100644
--- a/hw/musicpal.c
+++ b/hw/musicpal.c
@@ -238,14 +238,13 @@ static void eth_send(mv88w8618_eth_state *s, int queue_index)
{
uint32_t desc_addr = s->tx_queue[queue_index];
mv88w8618_tx_desc desc;
+ uint32_t next_desc;
uint8_t buf[2048];
int len;
- if (!desc_addr) {
- return;
- }
do {
eth_tx_desc_get(desc_addr, &desc);
+ next_desc = desc.next;
if (desc.cmdstat & MP_ETH_TX_OWN) {
len = desc.bytes;
if (len < 2048) {
@@ -256,7 +255,7 @@ static void eth_send(mv88w8618_eth_state *s, int queue_index)
s->icr |= 1 << (MP_ETH_IRQ_TXLO_BIT - queue_index);
eth_tx_desc_put(desc_addr, &desc);
}
- desc_addr = desc.next;
+ desc_addr = next_desc;
} while (desc_addr != s->tx_queue[queue_index]);
}
--
1.6.0.2
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 257 bytes --]
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [Qemu-devel] Re: [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send
2010-01-24 8:51 [Qemu-devel] [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send Jan Kiszka
@ 2010-01-24 13:59 ` malc
2010-01-26 22:21 ` [Qemu-devel] " Anthony Liguori
1 sibling, 0 replies; 3+ messages in thread
From: malc @ 2010-01-24 13:59 UTC (permalink / raw)
To: Jan Kiszka; +Cc: Anthony Liguori, qemu-devel
On Sun, 24 Jan 2010, Jan Kiszka wrote:
> Commit 930c86820e introduced a regression to eth_send: eth_tx_desc_put
> manipulates the host's tx descriptor copy before writing it back, but
> two lines down the descriptor is evaluated again, leaving us with an
> invalid next address if host and guest endianness differ. So this was
> the actual issue commit 2e87c5b937 tried to paper over.
Applied to master.
[..snip..]
--
mailto:av1474@comtv.ru
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [Qemu-devel] [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send
2010-01-24 8:51 [Qemu-devel] [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send Jan Kiszka
2010-01-24 13:59 ` [Qemu-devel] " malc
@ 2010-01-26 22:21 ` Anthony Liguori
1 sibling, 0 replies; 3+ messages in thread
From: Anthony Liguori @ 2010-01-26 22:21 UTC (permalink / raw)
To: Jan Kiszka; +Cc: Anthony Liguori, qemu-devel
On 01/24/2010 02:51 AM, Jan Kiszka wrote:
> Commit 930c86820e introduced a regression to eth_send: eth_tx_desc_put
> manipulates the host's tx descriptor copy before writing it back, but
> two lines down the descriptor is evaluated again, leaving us with an
> invalid next address if host and guest endianness differ. So this was
> the actual issue commit 2e87c5b937 tried to paper over.
>
> Signed-off-by: Jan Kiszka<jan.kiszka@web.de>
>
Applied to stable. Thanks.
Regards,
Anthony Liguori
> ---
> hw/musicpal.c | 7 +++----
> 1 files changed, 3 insertions(+), 4 deletions(-)
>
> diff --git a/hw/musicpal.c b/hw/musicpal.c
> index e424a7d..b8af15e 100644
> --- a/hw/musicpal.c
> +++ b/hw/musicpal.c
> @@ -238,14 +238,13 @@ static void eth_send(mv88w8618_eth_state *s, int queue_index)
> {
> uint32_t desc_addr = s->tx_queue[queue_index];
> mv88w8618_tx_desc desc;
> + uint32_t next_desc;
> uint8_t buf[2048];
> int len;
>
> - if (!desc_addr) {
> - return;
> - }
> do {
> eth_tx_desc_get(desc_addr,&desc);
> + next_desc = desc.next;
> if (desc.cmdstat& MP_ETH_TX_OWN) {
> len = desc.bytes;
> if (len< 2048) {
> @@ -256,7 +255,7 @@ static void eth_send(mv88w8618_eth_state *s, int queue_index)
> s->icr |= 1<< (MP_ETH_IRQ_TXLO_BIT - queue_index);
> eth_tx_desc_put(desc_addr,&desc);
> }
> - desc_addr = desc.next;
> + desc_addr = next_desc;
> } while (desc_addr != s->tx_queue[queue_index]);
> }
>
>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2010-01-26 22:21 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-01-24 8:51 [Qemu-devel] [PATCH][STABLE] Musicpal: Fix descriptor walk in eth_send Jan Kiszka
2010-01-24 13:59 ` [Qemu-devel] " malc
2010-01-26 22:21 ` [Qemu-devel] " Anthony Liguori
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).