linux-media.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Ang Way Chuang <wcang79@gmail.com>
To: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: [PATCH] dvb-core: Fix ULE decapsulation bug when less than 4 bytes of ULE SNDU is packed into the remaining bytes of a MPEG2-TS frame
Date: Tue, 24 Nov 2009 09:34:04 +0800	[thread overview]
Message-ID: <51d384e10911231734g744d4f6av8b393d99fee92105@mail.gmail.com> (raw)
In-Reply-To: <51d384e10911230137q7553b8c4x5ba3aca3e8edbc77@mail.gmail.com>

ULE (Unidirectional Lightweight Encapsulation RFC 4326) decapsulation
code has a bug that incorrectly treats ULE SNDU packed into the
remaining 2 or 3 bytes of a MPEG2-TS frame as having invalid pointer
field on the subsequent MPEG2-TS frame.

This patch was generated and tested against v2.6.32-rc8. Similar patch
was applied and tested using 2.6.27 which is similar to the latest
dvb_net.c, except for network device statistical data structure. I
suspect that this bug was introduced in kernel version 2.6.15, but had
not verified it.

Care has been taken not to introduce more bug by fixing this bug, but
please scrutinize the code for I always produces buggy code.

Signed-off-by: Ang Way Chuang <wcang@nav6.org>
---
diff --git a/drivers/media/dvb/dvb-core/dvb_net.c
b/drivers/media/dvb/dvb-core/dvb_net.c
index 0241a7c..7e0db86 100644
--- a/drivers/media/dvb/dvb-core/dvb_net.c
+++ b/drivers/media/dvb/dvb-core/dvb_net.c
@@ -458,8 +458,9 @@ static void dvb_net_ule( struct net_device *dev,
const u8 *buf, size_t buf_len )
                                                      "field: %u.\n",
priv->ts_count, *from_where);

                                               /* Drop partly decoded
SNDU, reset state, resync on PUSI. */
-                                               if (priv->ule_skb) {
-                                                       dev_kfree_skb(
priv->ule_skb );
+                                               if (priv->ule_skb ||
priv->ule_sndu_remain) {
+                                                       if (priv->ule_skb)
+
dev_kfree_skb( priv->ule_skb );
                                                       dev->stats.rx_errors++;

dev->stats.rx_frame_errors++;
                                               }
@@ -533,6 +534,7 @@ static void dvb_net_ule( struct net_device *dev,
const u8 *buf, size_t buf_len )
                               from_where += 2;
                       }

+                       priv->ule_sndu_remain = priv->ule_sndu_len + 2;
                       /*
                        * State of current TS:
                        *   ts_remain (remaining bytes in the current TS cell)
@@ -542,6 +544,7 @@ static void dvb_net_ule( struct net_device *dev,
const u8 *buf, size_t buf_len )
                        */
                       switch (ts_remain) {
                               case 1:
+                                       priv->ule_sndu_remain--;
                                       priv->ule_sndu_type = from_where[0] << 8;
                                       priv->ule_sndu_type_1 = 1; /*
first byte of ule_type is set. */
                                       ts_remain -= 1; from_where += 1;
@@ -555,6 +558,7 @@ static void dvb_net_ule( struct net_device *dev,
const u8 *buf, size_t buf_len )
                               default: /* complete ULE header is
present in current TS. */
                                       /* Extract ULE type field. */
                                       if (priv->ule_sndu_type_1) {
+                                               priv->ule_sndu_type_1 = 0;
                                               priv->ule_sndu_type |=
from_where[0];
                                               from_where += 1; /*
points to payload start. */
                                               ts_remain -= 1;

  reply	other threads:[~2009-11-24  1:33 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-11-23  9:37 [PATCH] dvb-core: Fix ULE decapsulation bug when less than 4 bytes of ULE SNDU is packed into the remaining bytes of a MPEG2-TS frame Ang Way Chuang
2009-11-24  1:34 ` Ang Way Chuang [this message]
2009-11-24  8:00 ` Dan Carpenter
2009-11-24  8:04   ` Ang Way Chuang
2009-11-24  8:07     ` Ang Way Chuang
  -- strict thread matches above, loose matches on Subject: below --
2010-05-27  5:02 Ang Way Chuang
2010-05-27 12:30 ` Jarod Wilson
2010-05-06 14:52 Ang Way Chuang
2009-11-17 10:00 Ang Way Chuang
2009-11-17  9:56 Ang Way Chuang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=51d384e10911231734g744d4f6av8b393d99fee92105@mail.gmail.com \
    --to=wcang79@gmail.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).