From: jamal <hadi@cyberus.ca>
To: Andrew Morton <akpm@linux-foundation.org>
Cc: netdev@vger.kernel.org, bugzilla-daemon@bugzilla.kernel.org,
bugme-daemon@bugzilla.kernel.org, reinaldoc@gmail.com
Subject: Re: [Bugme-new] [Bug 15379] New: u32 classifier port range calculation error
Date: Wed, 24 Feb 2010 22:24:17 -0500 [thread overview]
Message-ID: <1267068257.3973.865.camel@bigi> (raw)
In-Reply-To: <20100224145220.da5ec0b0.akpm@linux-foundation.org>
This is expected.
An incoming packet is masked with 0x1FE0 at offset 20 and the
value is compared to 6880. If they match, success.
So between 1-10000, you essentially have some starting at 6880.
And then at a large number prolly around port 15000, you have
a few more. and the pattern repeats etc.
cheers,
jamal
On Wed, 2010-02-24 at 14:52 -0800, Andrew Morton wrote:
> (switched to email. Please respond via emailed reply-to-all, not via the
> bugzilla web interface).
>
> On Tue, 23 Feb 2010 20:56:09 GMT bugzilla-daemon@bugzilla.kernel.org wrote:
>
> > http://bugzilla.kernel.org/show_bug.cgi?id=15379
> >
> > Summary: u32 classifier port range calculation error
> > Product: Networking
> > Version: 2.5
> > Kernel Version: All (2.6.32 tested)
> > Platform: All
> > OS/Version: Linux
> > Tree: Mainline
> > Status: NEW
> > Severity: normal
> > Priority: P1
> > Component: Other
> > AssignedTo: acme@ghostprotocols.net
> > ReportedBy: reinaldoc@gmail.com
> > Regression: No
> >
> >
> > U32 classifier have a problem on mask calculation of IP port range value.
> >
> > To reproduce the problem:
> >
> > ##### MASK CALCULATION FOR PORT RANGE 6880->6911
> >
> > echo "obase=16;(2^13)-32" | bc
> > 1FE0
> >
> > Example:
> >
> > ###### TC SAMPLE RULES
> > tc qdisc del dev eth0 root >/dev/null 2>&1
> >
> > tc qdisc add dev eth0 root handle 1: htb default 1100
> > tc class add dev eth0 root classid 1:1000 htb rate 1000Mbit ceil 1000Mbit
> > tc class add dev eth0 classid 1:1100 parent 1:1000 htb prio 0 rate 999Mbit
> > ceil 999Mbit
> > tc class add dev eth0 classid 1:1200 parent 1:1000 htb prio 0 rate 1Mbit
> > ceil 1Mbit
> >
> > tc filter add dev eth0 protocol ip prio 1 parent 1: u32 flowid 1:1200 match ip
> > dport 6880 0x1FE0
> >
> > ###### STATS CLEAN ** success 0
> > tc -s filter show dev eth0
> > filter parent 1: protocol ip pref 1 u32
> > filter parent 1: protocol ip pref 1 u32 fh 800: ht divisor 1
> > filter parent 1: protocol ip pref 1 u32 fh 800::800 order 2048 key ht 800 bkt 0
> > flowid 1:1200 (rule hit 116 success 0)
> > match 00001ae0/00001fe0 at 20 (success 0 )
> >
> > ###### SENDING PACKETS I
> > # nmap example.ufpa.br -p 1-10000
> >
> > ###### STATS I ** success 32 (OK)
> > # tc -s filter show dev eth0
> > filter parent 1: protocol ip pref 1 u32
> > filter parent 1: protocol ip pref 1 u32 fh 800: ht divisor 1
> > filter parent 1: protocol ip pref 1 u32 fh 800::800 order 2048 key ht 800 bkt 0
> > flowid 1:1200 (rule hit 12676 success 32)
> > match 00001ae0/00001fe0 at 20 (success 32 )
> >
> > ###### SENDING PACKETS II
> > # nmap example.ufpa.br -p 10000-20000
> >
> > ###### STATS II ** success 64 (ERROR) - should not match
> >
> > # tc -s filter show dev eth0
> > filter parent 1: protocol ip pref 1 u32
> > filter parent 1: protocol ip pref 1 u32 fh 800: ht divisor 1
> > filter parent 1: protocol ip pref 1 u32 fh 800::800 order 2048 key ht 800 bkt 0
> > flowid 1:1200 (rule hit 25172 success 64)
> > match 00001ae0/00001fe0 at 20 (success 64 )
> >
> > ###### SENDING PACKETS III
> > # nmap example.ufpa.br -p 20000-30000
> >
> > ###### STATS III ** success 96 (ERROR) - should not match
> >
> > # tc -s filter show dev eth0
> > filter parent 1: protocol ip pref 1 u32
> > filter parent 1: protocol ip pref 1 u32 fh 800: ht divisor 1
> > filter parent 1: protocol ip pref 1 u32 fh 800::800 order 2048 key ht 800 bkt 0
> > flowid 1:1200 (rule hit 43131 success 96)
> > match 00001ae0/00001fe0 at 20 (success 96 )
> >
> > ### End
>
> --
> To unsubscribe from this list: send the line "unsubscribe netdev" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2010-02-25 3:24 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <bug-15379-10286@http.bugzilla.kernel.org/>
2010-02-24 22:52 ` [Bugme-new] [Bug 15379] New: u32 classifier port range calculation error Andrew Morton
2010-02-25 3:24 ` jamal [this message]
2010-02-25 11:25 ` Reinaldo de Carvalho
2010-02-25 13:24 ` jamal
2010-02-25 19:11 ` Reinaldo de Carvalho
2010-02-25 21:47 ` jamal
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=1267068257.3973.865.camel@bigi \
--to=hadi@cyberus.ca \
--cc=akpm@linux-foundation.org \
--cc=bugme-daemon@bugzilla.kernel.org \
--cc=bugzilla-daemon@bugzilla.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=reinaldoc@gmail.com \
/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