qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 3/4] monitor, console: add QEVENT_SCREEN_DUMP_CO


From: Luiz Capitulino
Subject: Re: [Qemu-devel] [PATCH 3/4] monitor, console: add QEVENT_SCREEN_DUMP_COMPLETE
Date: Tue, 28 Feb 2012 17:01:13 -0300

On Fri, 24 Feb 2012 23:22:04 +0200
Alon Levy <address@hidden> wrote:

> Signed-off-by: Alon Levy <address@hidden>
> ---
>  QMP/qmp-events.txt |   14 ++++++++++++++
>  console.c          |   18 ++++++++++++++++++
>  console.h          |    1 +
>  monitor.c          |    2 ++
>  monitor.h          |    1 +
>  5 files changed, 36 insertions(+), 0 deletions(-)
> 
> diff --git a/QMP/qmp-events.txt b/QMP/qmp-events.txt
> index 9286af5..0d1c9f4 100644
> --- a/QMP/qmp-events.txt
> +++ b/QMP/qmp-events.txt
> @@ -335,3 +335,17 @@ Example:
>                 "len": 10737418240, "offset": 134217728,
>                 "speed": 0 },
>       "timestamp": { "seconds": 1267061043, "microseconds": 959568 } }
> +
> +SCREEN_DUMP_COMPLETE
> +--------------------
> +
> +Emitted when screen-dump-async completes.
> +
> +Data:
> +
> +- "filename": Name of file containing screen dump (json-string)
> +
> +Example:
> +
> +{ "event": "SCREEN_DUMP_COMPLETE",
> +     "data": { "filename": "/tmp/a.ppm" } }

This example is incomplete, a QMP event contains more fields.

> diff --git a/console.c b/console.c
> index 6a463f5..6750538 100644
> --- a/console.c
> +++ b/console.c
> @@ -24,6 +24,8 @@
>  #include "qemu-common.h"
>  #include "console.h"
>  #include "qemu-timer.h"
> +#include "qjson.h"
> +#include "monitor.h"
>  
>  //#define DEBUG_CONSOLE
>  #define DEFAULT_BACKSCROLL 512
> @@ -1707,3 +1709,19 @@ PixelFormat qemu_default_pixelformat(int bpp)
>      }
>      return pf;
>  }
> +
> +void monitor_protocol_screen_dump_complete_event(const char *filename)
> +{
> +    QObject *event_data;
> +    /*
> +     * TODO: Only good for a single user, or a very aware user
> +     * that changes the filename to distinguish between different
> +     * screendumps.

This comment pertains to the event documentation.

> +     * Should include support for different monitors on the same device,
> +     * and for different devices. Got stuck trying to figure a canonical 
> string
> +     * represnetation of a device.
> +     */

I think the above comment is not worth it.

> +    event_data = qobject_from_jsonf("{ 'filename': %s }", filename);
> +    monitor_protocol_event(QEVENT_SCREEN_DUMP_COMPLETE, event_data);
> +    qobject_decref(event_data);
> +}
> diff --git a/console.h b/console.h
> index a95b581..c22803c 100644
> --- a/console.h
> +++ b/console.h
> @@ -353,6 +353,7 @@ void vga_hw_update(void);
>  void vga_hw_invalidate(void);
>  void vga_hw_screen_dump(const char *filename);
>  void vga_hw_text_update(console_ch_t *chardata);
> +void monitor_protocol_screen_dump_complete_event(const char *filename);
>  
>  int is_graphic_console(void);
>  int is_fixedsize_console(void);
> diff --git a/monitor.c b/monitor.c
> index 953e748..1a65c41 100644
> --- a/monitor.c
> +++ b/monitor.c
> @@ -493,6 +493,8 @@ void monitor_protocol_event(MonitorEvent event, QObject 
> *data)
>              break;
>          case QEVENT_WAKEUP:
>              event_name = "WAKEUP";
> +        case QEVENT_SCREEN_DUMP_COMPLETE:
> +            event_name = "SCREEN_DUMP_COMPLETE";
>              break;
>          default:
>              abort();
> diff --git a/monitor.h b/monitor.h
> index 0d49800..227ebf2 100644
> --- a/monitor.h
> +++ b/monitor.h
> @@ -41,6 +41,7 @@ typedef enum MonitorEvent {
>      QEVENT_DEVICE_TRAY_MOVED,
>      QEVENT_SUSPEND,
>      QEVENT_WAKEUP,
> +    QEVENT_SCREEN_DUMP_COMPLETE,
>      QEVENT_MAX,
>  } MonitorEvent;
>  




reply via email to

[Prev in Thread] Current Thread [Next in Thread]