提交 e49f8277 编写于 作者: L Laurent Vivier 提交者: Stefan Hajnoczi

tests: fix qvirtqueue_kick

vq->avail.idx and vq->avail->ring[] are a 16bit values,
so read and write them with readw()/writew() instead of
readl()/writel().

To read/write a 16bit value with a 32bit accessor works fine
on little-endian CPU but not on big endian CPU.

[An equivalent patch for the writew() calls was also sent by
Zhang Shuai <zhangshuai13@huawei.com>.
--Stefan]
Signed-off-by: NLaurent Vivier <lvivier@redhat.com>
Message-id: 1472330054-22607-1-git-send-email-lvivier@redhat.com
Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
上级 049105a3
...@@ -257,16 +257,16 @@ void qvirtqueue_kick(const QVirtioBus *bus, QVirtioDevice *d, QVirtQueue *vq, ...@@ -257,16 +257,16 @@ void qvirtqueue_kick(const QVirtioBus *bus, QVirtioDevice *d, QVirtQueue *vq,
uint32_t free_head) uint32_t free_head)
{ {
/* vq->avail->idx */ /* vq->avail->idx */
uint16_t idx = readl(vq->avail + 2); uint16_t idx = readw(vq->avail + 2);
/* vq->used->flags */ /* vq->used->flags */
uint16_t flags; uint16_t flags;
/* vq->used->avail_event */ /* vq->used->avail_event */
uint16_t avail_event; uint16_t avail_event;
/* vq->avail->ring[idx % vq->size] */ /* vq->avail->ring[idx % vq->size] */
writel(vq->avail + 4 + (2 * (idx % vq->size)), free_head); writew(vq->avail + 4 + (2 * (idx % vq->size)), free_head);
/* vq->avail->idx */ /* vq->avail->idx */
writel(vq->avail + 2, idx + 1); writew(vq->avail + 2, idx + 1);
/* Must read after idx is updated */ /* Must read after idx is updated */
flags = readw(vq->avail); flags = readw(vq->avail);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册