mirror of
https://github.com/qemu/qemu.git
synced 2024-11-26 21:33:40 +08:00
usb: fix unbounded stack warning for xhci_dma_write_u32s
All the callers for xhci_dma_write_u32s() are using mostly 5 * uint32_t in len. To avoid unbound stack warning for the function, make it statically allocated, and assert when it's not big enough in the future. Signed-off-by: Peter Xu <peterx@redhat.com> Message-id: 1457661106-9569-1-git-send-email-peterx@redhat.com Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
0ab6d12ffd
commit
182b391e79
@ -698,11 +698,13 @@ static inline void xhci_dma_write_u32s(XHCIState *xhci, dma_addr_t addr,
|
||||
uint32_t *buf, size_t len)
|
||||
{
|
||||
int i;
|
||||
uint32_t tmp[len / sizeof(uint32_t)];
|
||||
uint32_t tmp[5];
|
||||
uint32_t n = len / sizeof(uint32_t);
|
||||
|
||||
assert((len % sizeof(uint32_t)) == 0);
|
||||
assert(n <= ARRAY_SIZE(tmp));
|
||||
|
||||
for (i = 0; i < (len / sizeof(uint32_t)); i++) {
|
||||
for (i = 0; i < n; i++) {
|
||||
tmp[i] = cpu_to_le32(buf[i]);
|
||||
}
|
||||
pci_dma_write(PCI_DEVICE(xhci), addr, tmp, len);
|
||||
|
Loading…
Reference in New Issue
Block a user