From: kernel test robot <lkp@intel.com>
To: kbuild@lists.01.org
Subject: Re: [PATCH] mac80211: keep non-zero sequence counter of injected frames
Date: Fri, 03 Jul 2020 00:17:06 +0800 [thread overview]
Message-ID: <202007030045.DWWmobk6%lkp@intel.com> (raw)
[-- Attachment #1: Type: text/plain, Size: 7192 bytes --]
CC: kbuild-all(a)lists.01.org
In-Reply-To: <20200628220512.28535ebc@mathy-work.localhost>
References: <20200628220512.28535ebc@mathy-work.localhost>
TO: Mathy Vanhoef <Mathy.Vanhoef@kuleuven.be>
TO: Johannes Berg <johannes@sipsolutions.net>
TO: linux-wireless(a)vger.kernel.org
CC: mathy.vanhoef(a)nyu.edu
Hi Mathy,
Thank you for the patch! Perhaps something to improve:
[auto build test WARNING on mac80211-next/master]
[also build test WARNING on mac80211/master v5.8-rc3 next-20200702]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use as documented in
https://git-scm.com/docs/git-format-patch]
url: https://github.com/0day-ci/linux/commits/Mathy-Vanhoef/mac80211-keep-non-zero-sequence-counter-of-injected-frames/20200629-021517
base: https://git.kernel.org/pub/scm/linux/kernel/git/jberg/mac80211-next.git master
:::::: branch date: 4 days ago
:::::: commit date: 4 days ago
config: arm-randconfig-m031-20200701 (attached as .config)
compiler: arm-linux-gnueabi-gcc (GCC) 9.3.0
If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp@intel.com>
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
New smatch warnings:
net/mac80211/tx.c:816 ieee80211_tx_h_sequence() warn: compare has higher precedence than mask
net/mac80211/tx.c:816 ieee80211_tx_h_sequence() warn: add some parenthesis here?
Old smatch warnings:
net/mac80211/tx.c:1831 invoke_tx_handlers_late() warn: variable dereferenced before check 'tx->skb' (see line 1809)
net/mac80211/tx.c:3426 ieee80211_xmit_fast_finish() error: we previously assumed 'key' could be null (see line 3394)
# https://github.com/0day-ci/linux/commit/f452608b92bbd4fff530a8f234d4e909287d249c
git remote add linux-review https://github.com/0day-ci/linux
git remote update linux-review
git checkout f452608b92bbd4fff530a8f234d4e909287d249c
vim +816 net/mac80211/tx.c
ba8c3d6f16a1f9 Felix Fietkau 2015-03-27 802
f591fa5dbbbeae Johannes Berg 2008-07-10 803 static ieee80211_tx_result debug_noinline
f591fa5dbbbeae Johannes Berg 2008-07-10 804 ieee80211_tx_h_sequence(struct ieee80211_tx_data *tx)
f591fa5dbbbeae Johannes Berg 2008-07-10 805 {
f591fa5dbbbeae Johannes Berg 2008-07-10 806 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb);
f591fa5dbbbeae Johannes Berg 2008-07-10 807 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data;
f591fa5dbbbeae Johannes Berg 2008-07-10 808 int tid;
f591fa5dbbbeae Johannes Berg 2008-07-10 809
25d834e16294c8 Johannes Berg 2008-09-12 810 /*
f452608b92bbd4 Mathy Vanhoef 2020-06-28 811 * Packet injection may want to control the sequence number.
f452608b92bbd4 Mathy Vanhoef 2020-06-28 812 * Do not assign one ourselves, and do not ask the driver to,
f452608b92bbd4 Mathy Vanhoef 2020-06-28 813 * if there is no matching interface or if the injected frame
f452608b92bbd4 Mathy Vanhoef 2020-06-28 814 * was already assigned a non-zero sequence number.
25d834e16294c8 Johannes Berg 2008-09-12 815 */
f452608b92bbd4 Mathy Vanhoef 2020-06-28 @816 if (unlikely(info->control.vif->type == NL80211_IFTYPE_MONITOR ||
f452608b92bbd4 Mathy Vanhoef 2020-06-28 817 (info->flags & IEEE80211_TX_CTL_INJECTED != 0 &&
f452608b92bbd4 Mathy Vanhoef 2020-06-28 818 hdr->seq_ctrl != 0)))
25d834e16294c8 Johannes Berg 2008-09-12 819 return TX_CONTINUE;
25d834e16294c8 Johannes Berg 2008-09-12 820
f591fa5dbbbeae Johannes Berg 2008-07-10 821 if (unlikely(ieee80211_is_ctl(hdr->frame_control)))
f591fa5dbbbeae Johannes Berg 2008-07-10 822 return TX_CONTINUE;
f591fa5dbbbeae Johannes Berg 2008-07-10 823
f591fa5dbbbeae Johannes Berg 2008-07-10 824 if (ieee80211_hdrlen(hdr->frame_control) < 24)
f591fa5dbbbeae Johannes Berg 2008-07-10 825 return TX_CONTINUE;
f591fa5dbbbeae Johannes Berg 2008-07-10 826
49a59543eb5a5d Johannes Berg 2011-09-29 827 if (ieee80211_is_qos_nullfunc(hdr->frame_control))
49a59543eb5a5d Johannes Berg 2011-09-29 828 return TX_CONTINUE;
49a59543eb5a5d Johannes Berg 2011-09-29 829
94778280fabdb6 Johannes Berg 2008-10-10 830 /*
94778280fabdb6 Johannes Berg 2008-10-10 831 * Anything but QoS data that has a sequence number field
94778280fabdb6 Johannes Berg 2008-10-10 832 * (is long enough) gets a sequence number from the global
c4c205f3cd17b5 Bob Copeland 2013-08-23 833 * counter. QoS data frames with a multicast destination
c4c205f3cd17b5 Bob Copeland 2013-08-23 834 * also use the global counter (802.11-2012 9.3.2.10).
94778280fabdb6 Johannes Berg 2008-10-10 835 */
c4c205f3cd17b5 Bob Copeland 2013-08-23 836 if (!ieee80211_is_data_qos(hdr->frame_control) ||
c4c205f3cd17b5 Bob Copeland 2013-08-23 837 is_multicast_ether_addr(hdr->addr1)) {
b9771d41aee7aa Johannes Berg 2018-05-28 838 if (tx->flags & IEEE80211_TX_NO_SEQNO)
b9771d41aee7aa Johannes Berg 2018-05-28 839 return TX_CONTINUE;
94778280fabdb6 Johannes Berg 2008-10-10 840 /* driver should assign sequence number */
f591fa5dbbbeae Johannes Berg 2008-07-10 841 info->flags |= IEEE80211_TX_CTL_ASSIGN_SEQ;
94778280fabdb6 Johannes Berg 2008-10-10 842 /* for pure STA mode without beacons, we can do it */
94778280fabdb6 Johannes Berg 2008-10-10 843 hdr->seq_ctrl = cpu_to_le16(tx->sdata->sequence_number);
94778280fabdb6 Johannes Berg 2008-10-10 844 tx->sdata->sequence_number += 0x10;
79c892b85027d5 Johannes Berg 2014-11-21 845 if (tx->sta)
e5a9f8d04660da Johannes Berg 2015-10-16 846 tx->sta->tx_stats.msdu[IEEE80211_NUM_TIDS]++;
f591fa5dbbbeae Johannes Berg 2008-07-10 847 return TX_CONTINUE;
f591fa5dbbbeae Johannes Berg 2008-07-10 848 }
f591fa5dbbbeae Johannes Berg 2008-07-10 849
f591fa5dbbbeae Johannes Berg 2008-07-10 850 /*
f591fa5dbbbeae Johannes Berg 2008-07-10 851 * This should be true for injected/management frames only, for
f591fa5dbbbeae Johannes Berg 2008-07-10 852 * management frames we have set the IEEE80211_TX_CTL_ASSIGN_SEQ
f591fa5dbbbeae Johannes Berg 2008-07-10 853 * above since they are not QoS-data frames.
f591fa5dbbbeae Johannes Berg 2008-07-10 854 */
f591fa5dbbbeae Johannes Berg 2008-07-10 855 if (!tx->sta)
f591fa5dbbbeae Johannes Berg 2008-07-10 856 return TX_CONTINUE;
f591fa5dbbbeae Johannes Berg 2008-07-10 857
f591fa5dbbbeae Johannes Berg 2008-07-10 858 /* include per-STA, per-TID sequence counter */
a1f2ba04cc9241 Sara Sharon 2018-02-19 859 tid = ieee80211_get_tid(hdr);
e5a9f8d04660da Johannes Berg 2015-10-16 860 tx->sta->tx_stats.msdu[tid]++;
f591fa5dbbbeae Johannes Berg 2008-07-10 861
ba8c3d6f16a1f9 Felix Fietkau 2015-03-27 862 hdr->seq_ctrl = ieee80211_tx_next_seq(tx->sta, tid);
f591fa5dbbbeae Johannes Berg 2008-07-10 863
f591fa5dbbbeae Johannes Berg 2008-07-10 864 return TX_CONTINUE;
f591fa5dbbbeae Johannes Berg 2008-07-10 865 }
f591fa5dbbbeae Johannes Berg 2008-07-10 866
---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all(a)lists.01.org
[-- Attachment #2: config.gz --]
[-- Type: application/gzip, Size: 27196 bytes --]
next reply other threads:[~2020-07-02 16:17 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-02 16:17 kernel test robot [this message]
-- strict thread matches above, loose matches on Subject: below --
2020-06-28 18:05 [PATCH] mac80211: keep non-zero sequence counter of injected frames Mathy Vanhoef
2020-06-28 18:59 ` Johannes Berg
2020-07-01 7:32 ` Mathy Vanhoef
2020-06-29 9:38 ` kernel test robot
2020-06-29 9:38 ` kernel test robot
2020-06-29 11:19 ` kernel test robot
2020-06-29 11:19 ` kernel test robot
2020-06-29 12:30 ` kernel test robot
2020-06-29 12:30 ` kernel test robot
2020-07-07 13:45 ` Dan Carpenter
2020-07-07 13:45 ` Dan Carpenter
2020-07-07 13:45 ` Dan Carpenter
2020-07-07 13:55 ` Mathy Vanhoef
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=202007030045.DWWmobk6%lkp@intel.com \
--to=lkp@intel.com \
--cc=kbuild@lists.01.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.