[libdvbpsi-devel] [PATCH] SEGV fixed in dvbpsi_decoder_psi_section_add
Michael Kasch - SmartCast
kasch at smartcast.de
Wed Oct 31 11:11:10 CET 2012
Dear Jean-Paul,
i don't have a test file at the moment, tested it yesterday with live data from some major TV Channels in Germany. Unfortunately I am not in the office today, so i can't provide a capture at the moment. Before the patch i got many valgrind errors and after 0,5 - 3 minutes i got an SEGV. Afterwards it worked fine, without any valgrind errors. In my testing setup its still running since yesterday.
regards,
Michael
________________________________________
Von: jpsaman at gmail.com [jpsaman at gmail.com]" im Auftrag von "Jean-Paul Saman [jpsaman at videolan.org]
Gesendet: Mittwoch, 31. Oktober 2012 09:36
Bis: Michael Kasch - SmartCast
Cc: libdvbpsi-devel at videolan.org
Betreff: Re: [libdvbpsi-devel] [PATCH] SEGV fixed in dvbpsi_decoder_psi_section_add
Michael,
The patch looks good. Do you have a test file for me to try?
On Tue, Oct 30, 2012 at 3:11 PM, Michael Kasch - SmartCast
<kasch at smartcast.de> wrote:
> Dear Jean-Paul,
> i think i found the Problem for the SEGV still occuring.
>
> please find the Patch attached.
>
> Regards,
> Michael
>
> From 6eaca9164219365e4003099df53399f195829c28 Mon Sep 17 00:00:00 2001
> From: Michael Kasch <michael.kasch at gmail.com>
> Date: Tue, 30 Oct 2012 15:00:53 +0100
> Subject: [PATCH] src/dvbpsi.c: fix segmentation fault in
> dvbpsi_decoder_psi_section_add()
>
> When p->i_number == p_section->i_number AND p_prev == NULL, then the
> first element of the list has to be replaced. Since it is the first
> element we have to update the pointer to the list, which is pointing to
> the first element
> ---
> src/dvbpsi.c | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/src/dvbpsi.c b/src/dvbpsi.c
> index d45802e..0555b14 100644
> --- a/src/dvbpsi.c
> +++ b/src/dvbpsi.c
> @@ -272,6 +272,7 @@ bool dvbpsi_decoder_psi_section_add(dvbpsi_decoder_t *p_decoder, dvbpsi_psi_sect
> p->p_next = NULL;
> dvbpsi_DeletePSISections(p);
> p = p_section;
In this case p points to the head of the list ( p =
p_decoder->p_sections), so p = p_section should do the trick.
However I wonder if an compiler optimization causes the crash to happen.
> + p_decoder->p_sections = p;
> b_overwrite = true;
> }
> goto out;
> --
> 1.7.10.4
> _______________________________________________
> libdvbpsi-devel mailing list
> libdvbpsi-devel at videolan.org
> http://mailman.videolan.org/listinfo/libdvbpsi-devel
Kind regards,
Jean-Paul Saman
More information about the libdvbpsi-devel
mailing list