Re: [PATCH spice-server 2/2] reds: Check we don't register a channel twice in reds_register_channel

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

 



On Tue, Mar 19, 2019 at 01:01:55PM +0000, Frediano Ziglio wrote:
> To avoid possibly regression check it only if extra checks are

"To avoid possible/potential regressions, check it .."

> enabled.
> This allows to check previous "Move channel registration to constructed
> vfunc" commit.
> 
> Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx>
> Acked-by: Snir Sheriber <ssheribe@xxxxxxxxxx>
> ---
>  server/reds.c | 5 +++++
>  1 file changed, 5 insertions(+)
> 
> diff --git a/server/reds.c b/server/reds.c
> index bc043764..f84ab1b8 100644
> --- a/server/reds.c
> +++ b/server/reds.c
> @@ -380,6 +380,11 @@ void stat_remove_counter(SpiceServer *reds, RedStatCounter *counter)
>  void reds_register_channel(RedsState *reds, RedChannel *channel)
>  {
>      spice_assert(reds);
> +    if (spice_extra_checks) {
> +        uint32_t this_type, this_id;
> +        g_object_get(channel, "channel-type", &this_type, "id", &this_id, NULL);
> +        spice_assert(reds_find_channel(reds, this_type, this_id) == NULL);
> +    }

Maybe something like this:

uint32_t this_type, this_id;
g_object_get(channel, "channel-type", &this_type, "id", &this_id, NULL);
if (spice_extra_checks) {
    g_warn_if_fail(reds_find_channel(reds, this_type, this_id) == NULL);
} else
    g_assert(reds_find_channel(reds, this_type, this_id) == NULL);
}

so that we can catch these misuses?

Christophe


>      reds->channels = g_list_prepend(reds->channels, channel);
>      // create new channel in the client if possible
>      main_channel_registered_new_channel(reds->main_channel, channel);
> -- 
> 2.20.1
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel@xxxxxxxxxxxxxxxxxxxxx
> https://lists.freedesktop.org/mailman/listinfo/spice-devel

Attachment: signature.asc
Description: PGP signature

_______________________________________________
Spice-devel mailing list
Spice-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/spice-devel

[Index of Archives]     [Linux Virtualization]     [Linux Virtualization]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]     [Monitors]