On Sat, 28 Nov 2009 05:20:31 pm Amit Shah wrote:
> From: Rusty Russell <[email protected]>
>
> Now we can use an allocation function to remove our global console variable.
>
> Signed-off-by: Rusty Russell <[email protected]>
> Signed-off-by: Amit Shah <[email protected]>
> ---
> drivers/char/virtio_console.c | 70 +++++++++++++++++++++++++++-------------
> 1 files changed, 47 insertions(+), 23 deletions(-)
>
> diff --git a/drivers/char/virtio_console.c b/drivers/char/virtio_console.c
> index c133bf6..98a5249 100644
> --- a/drivers/char/virtio_console.c
> +++ b/drivers/char/virtio_console.c
> @@ -32,6 +32,18 @@
> * across multiple devices and multiple ports per device.
> */
> struct ports_driver_data {
> + /*
> + * This is used to keep track of the number of hvc consoles
> + * spawned by this driver. This number is given as the first
> + * argument to hvc_alloc(). To correctly map an initial
> + * console spawned via hvc_instantiate to the console being
> + * hooked up via hvc_alloc, we need to pass the same vtermno.
> + *
> + * We also just assume the first console being initialised was
> + * the first one that got used as the initial console.
> + */
> + unsigned int next_vtermno;
Let's just make this a global?
> +static struct port *__devinit add_port(u32 vtermno)
> +{
> + struct port *port;
> +
> + port = kzalloc(sizeof *port, GFP_KERNEL);
> + if (!port)
> + return NULL;
> +
> + port->used_len = port->offset = 0;
> + port->inbuf = kmalloc(PAGE_SIZE, GFP_KERNEL);
> + if (!port->inbuf) {
> + kfree(port);
> + return NULL;
> + }
> + port->hvc = NULL;
> + port->vtermno = vtermno;
> + return port;
> +}
Rename this to add_console_port(), and split off the core part which
does ->port setup into "int setup_port(struct port *)" for later re-use?
> +static void free_port(struct port *port)
> +{
> + kfree(port->inbuf);
> + kfree(port);
> +}
Similarly, free_console_port/free_port?
> + err = -ENOMEM;
> + port = add_port(pdrvdata.next_vtermno);
> + if (!port)
> + goto fail;
I realize other coders do this pre-init, and it saves a line, but it also
means that you don't get a warning about err being uninitialized if it doesn't
get set correctly later on.
So I prefer:
port = add...
if (!port) {
err = -ENOMEM;
goto fail;
}
Thanks,
Rusty.
_______________________________________________
Virtualization mailing list
[email protected]
https://lists.linux-foundation.org/mailman/listinfo/virtualization