diff options
| author | Michael S. Tsirkin <mst@redhat.com> | 2014-04-03 19:52:05 +0300 |
|---|---|---|
| committer | Juan Quintela <quintela@redhat.com> | 2014-05-05 22:15:02 +0200 |
| commit | ead7a57df37d2187813a121308213f41591bd811 (patch) | |
| tree | eb9bb03708905e2906085689c7c1a7f46c0c8ab5 /hw/gpio/zaurus.c | |
| parent | caa881abe0e01f9931125a0977ec33c5343e4aa7 (diff) | |
| download | focaccia-qemu-ead7a57df37d2187813a121308213f41591bd811.tar.gz focaccia-qemu-ead7a57df37d2187813a121308213f41591bd811.zip | |
ssd0323: fix buffer overun on invalid state load
CVE-2013-4538 s->cmd_len used as index in ssd0323_transfer() to store 32-bit field. Possible this field might then be supplied by guest to overwrite a return addr somewhere. Same for row/col fields, which are indicies into framebuffer array. To fix validate after load. Additionally, validate that the row/col_start/end are within bounds; otherwise the guest can provoke an overrun by either setting the _end field so large that the row++ increments just walk off the end of the array, or by setting the _start value to something bogus and then letting the "we hit end of row" logic reset row to row_start. For completeness, validate mode as well. Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Juan Quintela <quintela@redhat.com>
Diffstat (limited to 'hw/gpio/zaurus.c')
0 files changed, 0 insertions, 0 deletions