[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v3 5/5] vga: ppm_save(): Return error on failure
From: |
Luiz Capitulino |
Subject: |
Re: [Qemu-devel] [PATCH v3 5/5] vga: ppm_save(): Return error on failure |
Date: |
Fri, 23 Mar 2012 11:27:02 -0300 |
On Sun, 18 Mar 2012 19:29:13 +0100
Alon Levy <address@hidden> wrote:
> From: Luiz Capitulino <address@hidden>
>
> This makes all devices using ppm_save() return an error appropriately
> when the screendump command fails.
>
> Based on a code by Anthony Liguori.
>
> Signed-off-by: Luiz Capitulino <address@hidden>
> Signed-off-by: Alon Levy <address@hidden>
> ---
> hw/blizzard.c | 2 +-
> hw/qxl.c | 2 +-
> hw/vga.c | 8 +++++---
> hw/vga_int.h | 3 ++-
> hw/vmware_vga.c | 2 +-
> 5 files changed, 10 insertions(+), 7 deletions(-)
>
> diff --git a/hw/blizzard.c b/hw/blizzard.c
> index 76df78c..29e5ae6 100644
> --- a/hw/blizzard.c
> +++ b/hw/blizzard.c
> @@ -942,7 +942,7 @@ static void blizzard_screen_dump(void *opaque, const char
> *filename,
> blizzard_update_display(opaque);
> }
> if (s && ds_get_data(s->state))
> - ppm_save(filename, s->state->surface);
> + ppm_save(filename, s->state->surface, errp);
> }
>
> #define DEPTH 8
> diff --git a/hw/qxl.c b/hw/qxl.c
> index 27f27f5..aa68612 100644
> --- a/hw/qxl.c
> +++ b/hw/qxl.c
> @@ -1503,7 +1503,7 @@ static void qxl_hw_screen_dump(void *opaque, const char
> *filename, bool cswitch,
> case QXL_MODE_COMPAT:
> case QXL_MODE_NATIVE:
> qxl_render_update(qxl);
> - ppm_save(filename, qxl->ssd.ds->surface);
> + ppm_save(filename, qxl->ssd.ds->surface, errp);
> break;
> case QXL_MODE_VGA:
> vga->screen_dump(vga, filename, cswitch, errp);
> diff --git a/hw/vga.c b/hw/vga.c
> index 79c5c38..80e6dca 100644
> --- a/hw/vga.c
> +++ b/hw/vga.c
> @@ -2365,7 +2365,7 @@ void vga_init_vbe(VGACommonState *s, MemoryRegion
> *system_memory)
> /********************************************************/
> /* vga screen dump */
>
> -int ppm_save(const char *filename, struct DisplaySurface *ds)
> +int ppm_save(const char *filename, struct DisplaySurface *ds, Error **errp)
> {
> FILE *f;
> uint8_t *d, *d1;
> @@ -2377,8 +2377,10 @@ int ppm_save(const char *filename, struct
> DisplaySurface *ds)
>
> trace_ppm_save(filename, ds);
> f = fopen(filename, "wb");
What I suggested to you was calling qemu_fopen_err() instead of fopen().
> - if (!f)
> + if (!f) {
> + error_set_file_open_failed(errp, filename, errno);
Does this even compile?
Also note that there are device models that don't use ppm_save(), they have to
be converted too.
> return -1;
> + }
> fprintf(f, "P6\n%d %d\n%d\n",
> ds->width, ds->height, 255);
> linebuf = g_malloc(ds->width * 3);
> @@ -2420,5 +2422,5 @@ static void vga_screen_dump(void *opaque, const char
> *filename, bool cswitch,
> vga_invalidate_display(s);
> vga_hw_update();
> }
> - ppm_save(filename, s->ds->surface);
> + ppm_save(filename, s->ds->surface, errp);
> }
> diff --git a/hw/vga_int.h b/hw/vga_int.h
> index 7685b2b..63078ba 100644
> --- a/hw/vga_int.h
> +++ b/hw/vga_int.h
> @@ -24,6 +24,7 @@
>
> #include <hw/hw.h>
> #include "memory.h"
> +#include "error.h"
>
> #define ST01_V_RETRACE 0x08
> #define ST01_DISP_ENABLE 0x01
> @@ -200,7 +201,7 @@ void vga_ioport_write(void *opaque, uint32_t addr,
> uint32_t val);
> uint32_t vga_mem_readb(VGACommonState *s, target_phys_addr_t addr);
> void vga_mem_writeb(VGACommonState *s, target_phys_addr_t addr, uint32_t
> val);
> void vga_invalidate_scanlines(VGACommonState *s, int y1, int y2);
> -int ppm_save(const char *filename, struct DisplaySurface *ds);
> +int ppm_save(const char *filename, struct DisplaySurface *ds, Error **errp);
>
> int vga_ioport_invalid(VGACommonState *s, uint32_t addr);
> void vga_init_vbe(VGACommonState *s, MemoryRegion *address_space);
> diff --git a/hw/vmware_vga.c b/hw/vmware_vga.c
> index 6868778..0769652 100644
> --- a/hw/vmware_vga.c
> +++ b/hw/vmware_vga.c
> @@ -1016,7 +1016,7 @@ static void vmsvga_screen_dump(void *opaque, const char
> *filename, bool cswitch,
> if (s->depth == 32) {
> DisplaySurface *ds = qemu_create_displaysurface_from(s->width,
> s->height, 32, ds_get_linesize(s->vga.ds), s->vga.vram_ptr);
> - ppm_save(filename, ds);
> + ppm_save(filename, ds, errp);
> g_free(ds);
> }
> }
[Qemu-devel] [PATCH v3 1/5] qerror: add error codes for fopen failure, Alon Levy, 2012/03/18
Re: [Qemu-devel] [PATCH v3 1/5] qerror: add error codes for fopen failure, Alon Levy, 2012/03/26
Re: [Qemu-devel] [PATCH v3 1/5] qerror: add error codes for fopen failure, Alon Levy, 2012/03/26
[Qemu-devel] [PATCH v3 3/5] vga_hw_screen_dump: add Error** param, Alon Levy, 2012/03/18
[Qemu-devel] [PATCH v3 4/5] qapi: convert screendump, Alon Levy, 2012/03/18