qemu-devel
[Top][All Lists]
Advanced

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

[Qemu-devel] Re: [PATCH] virtio-serial: Simplify virtio_serial_load()


From: Markus Armbruster
Subject: [Qemu-devel] Re: [PATCH] virtio-serial: Simplify virtio_serial_load()
Date: Sat, 26 Jun 2010 07:54:16 +0200
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/23.1 (gnu/linux)

Did this fall through the cracks?

Markus Armbruster <address@hidden> writes:

> For all i, ports_map[i] is used in and only in the i-th iteration.
> Replace the dynamic array by a scalar variable.
>
> Signed-off-by: Markus Armbruster <address@hidden>
> ---
>  hw/virtio-serial-bus.c |   12 +++---------
>  1 files changed, 3 insertions(+), 9 deletions(-)
>
> diff --git a/hw/virtio-serial-bus.c b/hw/virtio-serial-bus.c
> index 3ce95e8..bcc6d5d 100644
> --- a/hw/virtio-serial-bus.c
> +++ b/hw/virtio-serial-bus.c
> @@ -492,8 +492,7 @@ static int virtio_serial_load(QEMUFile *f, void *opaque, 
> int version_id)
>  {
>      VirtIOSerial *s = opaque;
>      VirtIOSerialPort *port;
> -    size_t ports_map_size;
> -    uint32_t max_nr_ports, nr_active_ports, *ports_map;
> +    uint32_t max_nr_ports, nr_active_ports, ports_map;
>      unsigned int i;
>  
>      if (version_id > 2) {
> @@ -517,22 +516,17 @@ static int virtio_serial_load(QEMUFile *f, void 
> *opaque, int version_id)
>          return -EINVAL;
>      }
>  
> -    ports_map_size = sizeof(uint32_t) * (max_nr_ports + 31) / 32;
> -    ports_map = qemu_malloc(ports_map_size);
> -
>      for (i = 0; i < (max_nr_ports + 31) / 32; i++) {
> -        qemu_get_be32s(f, &ports_map[i]);
> +        qemu_get_be32s(f, &ports_map);
>  
> -        if (ports_map[i] != s->ports_map[i]) {
> +        if (ports_map != s->ports_map[i]) {
>              /*
>               * Ports active on source and destination don't
>               * match. Fail migration.
>               */
> -            qemu_free(ports_map);
>              return -EINVAL;
>          }
>      }
> -    qemu_free(ports_map);
>  
>      qemu_get_be32s(f, &nr_active_ports);



reply via email to

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