From: Jason Wang <jasowang@redhat.com>
To: arei.gonglei@huawei.com, qemu-devel@nongnu.org
Cc: pbonzini@redhat.com, peter.huangpeng@huawei.com, stefanha@redhat.com
Subject: Re: [Qemu-devel] [PATCH v2 for-2.2 3/4] pcnet: fix Negative array index read
Date: Fri, 21 Nov 2014 09:42:05 +0800 [thread overview]
Message-ID: <546E986D.5000001@redhat.com> (raw)
In-Reply-To: <1416483303-12072-4-git-send-email-arei.gonglei@huawei.com>
On 11/20/2014 07:35 PM, arei.gonglei@huawei.com wrote:
> From: Gonglei <arei.gonglei@huawei.com>
>
> s->xmit_pos maybe assigned to a negative value (-1),
> but in this branch variable s->xmit_pos as an index to
> array s->buffer. Let's add a check for s->xmit_pos.
>
> Signed-off-by: Gonglei <arei.gonglei@huawei.com>
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
> Reviewed-by: Jason Wang <jasowang@redhat.com>
> ---
> hw/net/pcnet.c | 55 ++++++++++++++++++++++++++++++-------------------------
> 1 file changed, 30 insertions(+), 25 deletions(-)
>
> diff --git a/hw/net/pcnet.c b/hw/net/pcnet.c
> index d344c15..f409b92 100644
> --- a/hw/net/pcnet.c
> +++ b/hw/net/pcnet.c
> @@ -1212,7 +1212,7 @@ static void pcnet_transmit(PCNetState *s)
> hwaddr xmit_cxda = 0;
> int count = CSR_XMTRL(s)-1;
> int add_crc = 0;
> -
> + int bcnt;
> s->xmit_pos = -1;
>
> if (!CSR_TXON(s)) {
> @@ -1247,35 +1247,40 @@ static void pcnet_transmit(PCNetState *s)
> s->xmit_pos = -1;
> goto txdone;
> }
> +
> + if (s->xmit_pos < 0) {
> + goto txdone;
> + }
> +
> + bcnt = 4096 - GET_FIELD(tmd.length, TMDL, BCNT);
> + s->phys_mem_read(s->dma_opaque, PHYSADDR(s, tmd.tbadr),
> + s->buffer + s->xmit_pos, bcnt, CSR_BSWP(s));
> + s->xmit_pos += bcnt;
> +
> if (!GET_FIELD(tmd.status, TMDS, ENP)) {
> - int bcnt = 4096 - GET_FIELD(tmd.length, TMDL, BCNT);
> - s->phys_mem_read(s->dma_opaque, PHYSADDR(s, tmd.tbadr),
> - s->buffer + s->xmit_pos, bcnt, CSR_BSWP(s));
> - s->xmit_pos += bcnt;
> - } else if (s->xmit_pos >= 0) {
> - int bcnt = 4096 - GET_FIELD(tmd.length, TMDL, BCNT);
> - s->phys_mem_read(s->dma_opaque, PHYSADDR(s, tmd.tbadr),
> - s->buffer + s->xmit_pos, bcnt, CSR_BSWP(s));
> - s->xmit_pos += bcnt;
> + goto txdone;
> + }
> +
> #ifdef PCNET_DEBUG
> - printf("pcnet_transmit size=%d\n", s->xmit_pos);
> + printf("pcnet_transmit size=%d\n", s->xmit_pos);
> #endif
> - if (CSR_LOOP(s)) {
> - if (BCR_SWSTYLE(s) == 1)
> - add_crc = !GET_FIELD(tmd.status, TMDS, NOFCS);
> - s->looptest = add_crc ? PCNET_LOOPTEST_CRC : PCNET_LOOPTEST_NOCRC;
> - pcnet_receive(qemu_get_queue(s->nic), s->buffer, s->xmit_pos);
> - s->looptest = 0;
> - } else
> - if (s->nic)
> - qemu_send_packet(qemu_get_queue(s->nic), s->buffer,
> - s->xmit_pos);
> -
> - s->csr[0] &= ~0x0008; /* clear TDMD */
> - s->csr[4] |= 0x0004; /* set TXSTRT */
> - s->xmit_pos = -1;
> + if (CSR_LOOP(s)) {
> + if (BCR_SWSTYLE(s) == 1)
> + add_crc = !GET_FIELD(tmd.status, TMDS, NOFCS);
> + s->looptest = add_crc ? PCNET_LOOPTEST_CRC : PCNET_LOOPTEST_NOCRC;
> + pcnet_receive(qemu_get_queue(s->nic), s->buffer, s->xmit_pos);
> + s->looptest = 0;
> + } else {
> + if (s->nic) {
> + qemu_send_packet(qemu_get_queue(s->nic), s->buffer,
> + s->xmit_pos);
> + }
> }
>
> + s->csr[0] &= ~0x0008; /* clear TDMD */
> + s->csr[4] |= 0x0004; /* set TXSTRT */
> + s->xmit_pos = -1;
> +
> txdone:
> SET_FIELD(&tmd.status, TMDS, OWN, 0);
> TMDSTORE(&tmd, PHYSADDR(s,CSR_CXDA(s)));
Reviewed-by: Jason Wang <jasowang@redhat.com>
next prev parent reply other threads:[~2014-11-21 1:42 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-11-20 11:34 [Qemu-devel] [PATCH v2 for-2.2 0/4] net: fix high impact outstanding defects reported by Coverity arei.gonglei
2014-11-20 11:35 ` [Qemu-devel] [PATCH v2 for-2.2 1/4] net/slirp: fix memory leak arei.gonglei
2014-11-20 11:35 ` [Qemu-devel] [PATCH v2 for-2.2 2/4] net/socket: fix Uninitialized scalar variable arei.gonglei
2014-11-20 11:35 ` [Qemu-devel] [PATCH v2 for-2.2 3/4] pcnet: fix Negative array index read arei.gonglei
2014-11-21 1:42 ` Jason Wang [this message]
2014-11-20 11:35 ` [Qemu-devel] [PATCH v2 for-2.2 4/4] rtl8139: fix Pointer to local outside scope arei.gonglei
2014-11-21 1:42 ` Jason Wang
2014-11-20 12:34 ` [Qemu-devel] [PATCH v2 for-2.2 0/4] net: fix high impact outstanding defects reported by Coverity Paolo Bonzini
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=546E986D.5000001@redhat.com \
--to=jasowang@redhat.com \
--cc=arei.gonglei@huawei.com \
--cc=pbonzini@redhat.com \
--cc=peter.huangpeng@huawei.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).