| Submitter | Stefan Hajnoczi |
|---|---|
| Date | March 11, 2013, 9:20 a.m. |
| Message ID | <1362993621-30993-3-git-send-email-stefanha@redhat.com> |
| Download | mbox | patch |
| Permalink | /patch/226504/ |
| State | New |
| Headers | show |
Comments
Patch
diff --git a/exec.c b/exec.c index 46a2830..a9aa703 100644 --- a/exec.c +++ b/exec.c @@ -912,6 +912,8 @@ static ram_addr_t find_ram_offset(ram_addr_t size) RAMBlock *block, *next_block; ram_addr_t offset = RAM_ADDR_MAX, mingap = RAM_ADDR_MAX; + assert(size != 0); /* it would hand out same offset multiple times */ + if (QTAILQ_EMPTY(&ram_list.blocks)) return 0;
find_ram_offset() does not handle size=0 gracefully. It hands out the same RAMBlock offset multiple times, leading to obscure failures later on. Add an assert to warn early if something is incorrectly allocating a zero size RAMBlock. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> --- exec.c | 2 ++ 1 file changed, 2 insertions(+)