FreeBSD/src ea8f1ff (r342713) — sys/net80211 ieee80211_output.c
MFC r342604: net80211: fix duplicate sequence number bump for non-AMPDU QoS frames. This should be a part of r312972.
Delta | File | |
---|---|---|
+0 | -1 | sys/net80211/ieee80211_output.c |
+0 | -1 | 1 files |
MFC r342604: net80211: fix duplicate sequence number bump for non-AMPDU QoS frames. This should be a part of r312972.
Delta | File | |
---|---|---|
+0 | -1 | sys/net80211/ieee80211_output.c |
+0 | -1 | 1 files |
net80211: fix duplicate sequence number bump for non-AMPDU QoS frames. This should be a part of r312972. MFC after: 4 days
Delta | File | |
---|---|---|
+0 | -1 | sys/net80211/ieee80211_output.c |
+0 | -1 | 1 files |
net80211: wrap protection frame allocation into ieee80211_alloc_prot() Move copy-pasted code for RTS/CTS frame allocation into net80211. While here, add stat / debug message for allocation failures (copied from run(4)) + return error here in bwn(4). Reviewed by: adrian Differential Revision: https://reviews.freebsd.org/D14628
Delta | File | |
---|---|---|
+27 | -53 | sys/dev/bwn/if_bwn.c |
+7 | -29 | sys/dev/usb/wlan/if_run.c |
+11 | -25 | sys/dev/usb/wlan/if_ural.c |
+10 | -25 | sys/dev/ral/rt2661.c |
+10 | -25 | sys/dev/ral/rt2560.c |
+11 | -23 | sys/dev/usb/wlan/if_rum.c |
+76 | -180 | 2 files not shown |
+111 | -180 | 8 files |
Revert MFC of r330463 r330462 r330454 r330452 r330451: These commits have KPI/KBI considerations (or are a result of those that do). I did not properly take into account these concerns when merging to a kbi-stable branch. Requested by: jhb Pointyhat to: eadler
Delta | File | |
---|---|---|
+21 | -70 | sys/net80211/ieee80211_freebsd.h |
+25 | -16 | sys/net80211/ieee80211_input.c |
+2 | -36 | sys/net80211/ieee80211_output.c |
+5 | -11 | sys/dev/iwm/if_iwm.c |
+5 | -8 | sys/dev/otus/if_otus.c |
+3 | -5 | sys/dev/usb/wlan/if_rsu.c |
+61 | -146 | 2 files not shown |
+66 | -149 | 8 files |
MFC r308663: [net80211] announce 11n capabilities in probe requests in IBSS mode. The 802.11-2012 specification notes that a subset of IEs should be present in IBSS probe requests. This is what (initially) allows nodes to discover that other nodes are 11n capable. Notably - HTCAP, but not HTINFO. This isn't everything required to reliably enable 11n between net80211 peers; there's more work to come. Tested: * AR9380, IBSS+11n mode
Delta | File | |
---|---|---|
+36 | -2 | sys/net80211/ieee80211_output.c |
+36 | -2 | 1 files |
Merge ^/head r327341 through r327623.
Delta | File | |
---|---|---|
+0 | -3,076 | sys/mips/rmi/dev/sec/rmilib.c |
+0 | -3,070 | sys/mips/rmi/dev/sec/desc.h |
+0 | -2,565 | sys/mips/rmi/dev/nlge/if_nlge.c |
+0 | -1,613 | sys/mips/idt/if_kr.c |
+1,430 | -0 | sys/i386/i386/npx.c |
+0 | -1,430 | sys/i386/isa/npx.c |
+1,430 | -11,754 | 815 files not shown |
+6,551 | -46,919 | 821 files |
net80211: sanitize input for ieee80211_output() - Add some basic checks for i_fc* bits (ToDS, FromDS, MoreFrag, Protected); those are used / checked across various places in Tx path. - Mark injected 802.11 frame as encapsulated (just as it should be). - Classify 802.11 frame in a proper way (extract ether_type from LLC header for Data frames, use AC_BE queue for others (NoData / Management / Control). - Subtract header length from tx_bytes statistics (so it will correspond to the comment). Was checked with RTL8188EU (AP) + Intel 6205 (STA). Reviewed by: adrian Differential Revision: https://reviews.freebsd.org/D13161
Delta | File | |
---|---|---|
+115 | -28 | sys/net80211/ieee80211_output.c |
+115 | -28 | 1 files |
sys: general adoption of SPDX licensing ID tags. Mainly focus on files that use BSD 2-Clause license, however the tool I was using misidentified many licenses so this was mostly a manual - error prone - task. The Software Package Data Exchange (SPDX) group provides a specification to make it easier for automated tools to detect and summarize well known opensource licenses. We are gradually adopting the specification, noting that the tags are considered only advisory and do not, in any way, superceed or replace the license texts. No functional change intended.
MFH @ r323558.
Delta | File | |
---|---|---|
+148,660 | -148,574 | sys/dev/qlxgbe/ql_fw.c |
+28,149 | -0 | sys/contrib/dev/liquidio/lio_23xx_nic.bin.uu |
+14,241 | -1,432 | sys/dev/bnxt/hsi_struct_def.h |
+11,974 | -0 | sys/dev/cxgbe/firmware/t6fw-1.16.59.0.bin.uu |
+0 | -11,363 | sys/dev/cxgbe/firmware/t6fw-1.16.45.0.bin.uu |
+11,247 | -0 | sys/dev/cxgbe/firmware/t5fw-1.16.59.0.bin.uu |
+214,271 | -161,369 | 960 files not shown |
+277,029 | -213,502 | 966 files |
MFhead at r322957
Delta | File | |
---|---|---|
+39 | -253 | sys/boot/efi/boot1/boot1.c |
+117 | -131 | sys/i386/i386/trap.c |
+133 | -89 | sys/dev/mpr/mpr.c |
+127 | -83 | sys/dev/mps/mps.c |
+98 | -98 | sys/boot/geli/geliboot.c |
+181 | -0 | sys/boot/efi/loader/efi_main.c |
+695 | -654 | 46 files not shown |
+1,077 | -1,040 | 52 files |
net80211: fix a typo (premable -> preamble).
Delta | File | |
---|---|---|
+1 | -1 | sys/net80211/ieee80211_output.c |
+1 | -1 | 1 files |
Merge ^/head r319251 through r319479.
net80211: initialize i_seq for A-MPDU frames. Fragment number field (part of i_seq) is used for AAD calculation; as a result, without this patch every driver without h/w crypto support need to clear it before ieee80211_crypto_encap(). Also fixes rtwn(4) A-MPDU Tx with dev.rtwn.%d.hwcrypto tunable set to 0 (h/w crypto is disabled). Tested with: * Intel 6205, STA mode. * RTL8188EU, STA mode. Differential Revision: https://reviews.freebsd.org/D10753
Delta | File | |
---|---|---|
+6 | -0 | sys/net80211/ieee80211_output.c |
+6 | -0 | 1 files |
Merge ^/head r313896 through r314128.
Delta | File | |
---|---|---|
+30,750 | -0 | sys/contrib/dev/iwm/iwm-7265D-17.fw.uu |
+40 | -8,619 | contrib/openpam/aclocal.m4 |
+8,369 | -0 | contrib/openpam/m4/libtool.m4 |
+3,541 | -2,100 | contrib/openpam/ltmain.sh |
+1,449 | -863 | contrib/openpam/configure |
+700 | -1,234 | sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ctldir.c |
+44,849 | -12,816 | 515 files not shown |
+62,778 | -20,105 | 521 files |
[net80211] teach the probe response routine to add VHT IEs as appropriate.
Delta | File | |
---|---|---|
+9 | -0 | sys/net80211/ieee80211_output.c |
+9 | -0 | 1 files |
Merge ^/head r313301 through r313643.
Delta | File | |
---|---|---|
+53,122 | -0 | sys/contrib/dev/iwm/iwm-8000C-17.fw.uu |
+26,235 | -0 | sys/contrib/dev/iwm/iwm-7265-17.fw.uu |
+23,322 | -0 | sys/contrib/dev/iwm/iwm-7260-17.fw.uu |
+20,409 | -0 | sys/contrib/dev/iwm/iwm-3160-17.fw.uu |
+3,163 | -2,822 | sys/netipsec/key.c |
+0 | -2,946 | secure/usr.bin/bdes/bdes.ps |
+126,251 | -5,768 | 592 files not shown |
+152,402 | -17,405 | 598 files |
[net80211] don't bother doing fragmentation if the driver supports fragmentation offload. Tested: * ath10k, which does its own fragmentation in firmware.
Delta | File | |
---|---|---|
+13 | -5 | sys/net80211/ieee80211_output.c |
+13 | -5 | 1 files |
[net80211] quiet IE handling improvements * on the station side, only call the quiet time IE method if we have a quiet IE - otherwise call the NULL method once, and then don't waste time calling NULL * on the beacon generation side - force a beacon regeneration each time quiet time is enabled/disabled. Without this, enabling/disabling quiet time IE would cause the beacon contents to be corrupted since none of the "move contents around" logic (like for CSA and TIM handling) is implemented. This changes the size of ieee80211_node so it requires a kernel recompile, but no userland recompile. Tested: * AR9380, AP mode, enabling/disabling quiet time IE * AR9380, STA mode, with upcoming driver changes.
Delta | File | |
---|---|---|
+66 | -13 | sys/net80211/ieee80211_output.c |
+40 | -1 | sys/net80211/ieee80211_sta.c |
+5 | -0 | sys/net80211/ieee80211_node.h |
+2 | -1 | sys/net80211/ieee80211_var.h |
+2 | -0 | sys/net80211/ieee80211_proto.h |
+115 | -15 | 5 files |
Merge ^/head r313055 through r313300.
Delta | File | |
---|---|---|
+2,752 | -0 | contrib/byacc/test/btyacc/expr.oxout.tab.c |
+1,958 | -0 | contrib/byacc/test/yacc/expr.oxout.tab.c |
+1,446 | -0 | contrib/byacc/test/expr.oxout.y |
+1,252 | -8 | sys/i386/linux/linux_systrace_args.c |
+1,252 | -8 | sys/amd64/linux32/linux32_systrace_args.c |
+933 | -0 | contrib/libarchive/libarchive/test/test_acl_platform_nfs4.c |
+9,593 | -16 | 290 files not shown |
+18,269 | -3,473 | 296 files |
MFhead at r313243
Delta | File | |
---|---|---|
+0 | -4,387 | sys/pc98/cbus/sio.c |
+2,752 | -0 | contrib/byacc/test/btyacc/expr.oxout.tab.c |
+1,958 | -0 | contrib/byacc/test/yacc/expr.oxout.tab.c |
+871 | -961 | contrib/tcpdump/tcpdump.c |
+1,074 | -707 | contrib/tcpdump/print-802_11.c |
+0 | -1,774 | sys/pc98/pc98/busio.s |
+6,655 | -7,829 | 2,446 files not shown |
+57,027 | -77,686 | 2,452 files |
[net80211] don't update quiet time counter values every probe request. The quiet time counter update is happening each time the IE is added, which also means it happens for each quiet time IE addition to the probe response. Only update the countdown if we request ie (ie, beacon updates.)
Delta | File | |
---|---|---|
+15 | -8 | sys/net80211/ieee80211_output.c |
+15 | -8 | 1 files |
Merge ^/head r312968 through r313054.
Delta | File | |
---|---|---|
+850 | -940 | contrib/tcpdump/tcpdump.c |
+1,074 | -707 | contrib/tcpdump/print-802_11.c |
+543 | -624 | contrib/tcpdump/configure |
+938 | -0 | contrib/tcpdump/util-print.c |
+0 | -890 | contrib/tcpdump/util.c |
+855 | -0 | contrib/tcpdump/print-hncp.c |
+4,260 | -3,161 | 386 files not shown |
+18,856 | -12,170 | 392 files |
[net80211] address seqno allocation for group addressed frames After some digging and looking at packet traces, it looks like the sequence number allocation being done by net80211 doesn't meet 802.11-2012. Specifically, group addressed frames (broadcast, multicast) have sequence numbers allocated from a separate pool, even if they're QoS frames. This patch starts to try and address this, both on transmit and receive. * When receiving, don't throw away multicast frames for now. It's sub-optimal, but until we correctly track group addressed frames via another TID counter, this is the best we can do. * When doing A-MPDU checks, don't include group addressed frames in the sequence number checks. [52 lines not shown]
Delta | File | |
---|---|---|
+46 | -11 | sys/net80211/ieee80211_output.c |
+13 | -0 | sys/net80211/ieee80211_input.h |
+10 | -0 | sys/net80211/ieee80211_ht.c |
+69 | -11 | 3 files |
Merge ^/head r311940 through r312200.
Delta | File | |
---|---|---|
+5,082 | -0 | contrib/netbsd-tests/kernel/t_ptrace_wait.c |
+3,606 | -0 | contrib/netbsd-tests/dev/cgd/t_cgd_aes.c |
+2,341 | -0 | contrib/netbsd-tests/dev/cgd/t_cgd_blowfish.c |
+1,037 | -1,032 | contrib/netbsd-tests/dev/audio/t_pad_output.bz2.uue |
+0 | -1,460 | contrib/netbsd-tests/fs/nfs/nfsservice/rpcbind/rpcb_svc_com.c |
+913 | -0 | contrib/netbsd-tests/dev/cgd/t_cgd_3des.c |
+12,979 | -2,492 | 224 files not shown |
+20,624 | -7,998 | 230 files |
[net80211] Initial VHT node upgrade/downgrade support and initial IE parsing. This is the bulk of the magic to start enabling VHT channel negotiation. It is absolutely, positively not yet even a complete VHT wave-1 implementation. * parse IEs in scan, assoc req/resp, probe req/resp; * break apart the channel upgrade from the HT IE parsing - do it after the VHT IEs are parsed; * (dirty! sigh) add channel width decision making in ieee80211_ht.c htinfo_update_chw(). This is the main bit where negotiated channel promotion through IEs occur. * Shoehorn in VHT node init ,teardown, rate control, etc calls like the HT versions; * Do VHT channel adjustment where appropriate Tested: * monitor mode, ath10k port * STA mode, ath10k port - VHT20, VHT40, VHT80 modes [14 lines not shown]
Delta | File | |
---|---|---|
+246 | -43 | sys/net80211/ieee80211_ht.c |
+153 | -6 | sys/net80211/ieee80211_node.c |
+125 | -1 | sys/net80211/ieee80211_output.c |
+45 | -2 | sys/net80211/ieee80211_sta.c |
+40 | -6 | sys/net80211/ieee80211_scan_sta.c |
+27 | -0 | sys/net80211/ieee80211_hostap.c |
+636 | -58 | 3 files not shown |
+671 | -60 | 9 files |
Merge ^/head r308491 through r308841.
Delta | File | |
---|---|---|
+17,576 | -0 | sys/dev/bnxt/hsi_struct_def.h |
+4,326 | -1,261 | contrib/amd/doc/texinfo.tex |
+2,360 | -0 | sys/dev/bnxt/if_bnxt.c |
+2,021 | -43 | contrib/amd/libamu/xdr_func.c |
+1,791 | -0 | sys/dev/hyperv/pcib/vmbus_pcib.c |
+1,716 | -0 | contrib/amd/fsinfo/null_lex.c |
+29,790 | -1,304 | 737 files not shown |
+59,355 | -8,447 | 743 files |
[net80211] announce 11n capabilities in probe requests in IBSS mode. The 802.11-2012 specification notes that a subset of IEs should be present in IBSS probe requests. This is what (initially) allows nodes to discover that other nodes are 11n capable. Notably - HTCAP, but not HTINFO. This isn't everything required to reliably enable 11n between net80211 peers; there's more work to come. Tested: * AR9380, IBSS+11n mode
Delta | File | |
---|---|---|
+36 | -2 | sys/net80211/ieee80211_output.c |
+36 | -2 | 1 files |
net80211: discard an injected frame if it is smaller than header length. Do not try to pass such frames; a correct frame cannot be smaller than (the corresponding) header size. (for wpi(4) an additional check was added in r289012). PR: 144987
Delta | File | |
---|---|---|
+2 | -2 | sys/net80211/ieee80211_output.c |
+2 | -2 | 1 files |
net80211: fix duplicate packet counter incrementation. Remove 'if_inc_counter(ifp, IFCOUNTER_OPACKETS, 1);' from raw xmit and apbridge path; it will be incremented by ieee80211_tx_complete() after packet transmission. Noticed by: Imre Vadasz <imre at vdsz.com>
Delta | File | |
---|---|---|
+2 | -2 | sys/net80211/ieee80211_hostap.c |
+0 | -1 | sys/net80211/ieee80211_output.c |
+2 | -3 | 2 files |
net80211: replace m_getcl/m_gethdr pair with m_get2 in ieee80211_fragment() - Switch to m_get2() for mbuf allocation instead of manual mbuf size determination. - Reuse MIN() macro for mbuf size selection.
Delta | File | |
---|---|---|
+2 | -10 | sys/net80211/ieee80211_output.c |
+2 | -10 | 1 files |