Commit graph

39527 commits

Author SHA1 Message Date
Dimitry Andric
be8e341777 bwi: Fix clang 14 warning about possible unaligned access
On architectures with strict alignment requirements (e.g. arm), clang 14
warns about a packed struct which encloses a non-packed union:

In file included from sys/dev/bwi/bwimac.c:79:
sys/dev/bwi/if_bwivar.h:308:7: error: field iv_val within 'struct bwi_fw_iv' is less aligned than 'union (unnamed union at sys/dev/bwi/if_bwivar.h:305:2)' and is usually due to 'struct bwi_fw_iv' being packed, which can lead to unaligned accesses [-Werror,-Wunaligned-access]
	}			iv_val;
				^

It appears to help if you also add __packed to the inner union (i.e.
iv_val). No change to the layout is intended.

MFC after:	3 days
Differential Revision: https://reviews.freebsd.org/D34196

(cherry picked from commit 09d0a0fbe8)
2022-02-16 21:24:53 +01:00
Alexander Motin
2dfb21cdd4 snd_hda: Add some ATI HDMI codec IDs.
Submitted by:	Dmitry Luhtionov <dmitryluhtionov@gmail.com>
MFC after:	1 week

(cherry picked from commit 98d59d2e0d)
2022-02-15 19:46:12 -05:00
Stefan Grundmann
5fed793a50 vt: fix splash_cpu logos use of vd_drawrect
In the (extremely unlikely) case of vd->vd_height ==
vt_logo_sprite_height the vd_drawrect code would write outside of
frame-buffer memory.

MFC after:	1 week
Reviewed by:	cem
Differential Revision:	https://reviews.freebsd.org/D34220

(cherry picked from commit 06296f77c5)
2022-02-15 19:39:34 -05:00
Ram Kishore Vegesna
2748f68db9 ocs_fc: Fix a possible Null pointer dereference
Fix a possible Null pointer dereference in ocs_hw_get_profile_list_cb()

PR: 261453
Reported by: lwhsu

MFC after: 3 days

(cherry picked from commit 7bf31432fd)
2022-02-14 12:42:55 +05:30
Andrew Turner
9ddf1ab1b9 Fix the spelling of '*/' in the vnic driver
Sponsored by:	The FreeBSD Foundation

(cherry picked from commit c007408c24)
2022-02-13 20:09:34 +01:00
Alexander Motin
376fd49ae3 APEI: Make sure event data fit into the buffer.
There seem to be systems returning some garbage here.  I still don't
know why, but at least I hope this check fix indefinite printf loop.

MFC after:	2 weeks

(cherry picked from commit 3b248a2113)
2022-02-13 13:26:55 -05:00
Ed Maste
a60685ffbc vnic: add TODO list
- non-promisc mode
- multicast filter support

Also drop ARM64TODO comments; this is an issue with this specific
driver, not a general arm64 issue.

PR:		223575
PR:		223573

(cherry picked from commit 941650aae9)
(cherry picked from commit 29e9b487c1)
2022-02-12 14:09:52 -05:00
Kyle Evans
371633ece3 Annotate geom_md with MODULE_VERSION
This was missed in 74d6c131cb where other geom modules were annotated
with MODULE_VERSION.  Again, the problem is the same: we can't detect
that geom_md is loaded into the kernel without it.

This was noticed in release builds on the cluster; mdconfig attempts to
load geom_md because it can't detect it in the kernel, but the cluster
config includes md(4) and does not build the kmod.  This problem would
have been masked on hosts with the kmod built, as the kmod attempts to
register the g_md module and fails.  With this commit, mdconfig would
not even try to load it again.

(cherry picked from commit b9c92d631c)
2022-02-12 10:46:45 -06:00
Hans Petter Selasky
16635c7b21 mlx5en: Make sure the NIC IP addresses are written to firmware on link up.
Fixes e059c120b4 .

PR:		261746
Sponsored by:	NVIDIA Networking

(cherry picked from commit 04f407a3e5)
2022-02-11 11:15:00 +01:00
Hans Petter Selasky
a8727a0b32 rtwn(4): Add new USB ID.
Submitted by:	Wensi <supdrewin@outlook.com>
PR:		261098
Sponsored by:	NVIDIA Networking

(cherry picked from commit 75d20a5e38)
2022-02-10 16:11:07 +01:00
Hans Petter Selasky
3752e6771b uchcom(4): Add new USB ID.
Submitted by:	darius@dons.net.au
PR:		260783
Sponsored by:	NVIDIA Networking

(cherry picked from commit 34bedcee3c)
2022-02-10 16:11:01 +01:00
Hans Petter Selasky
08a56bb43c rtwn(4): Add new USB ID.
Submitted by:	arved@
PR:		260952
Sponsored by:	NVIDIA Networking

(cherry picked from commit 2891a28052)
2022-02-10 16:10:57 +01:00
Hans Petter Selasky
966c36c1b6 usb(4): Ignore port resume failures.
If port resume fails, likely the USB device is detached. Ignore such errors,
because else the USB stack might try forever trying to resume the device,
before it will proceed detaching it.

Sponsored by:	NVIDIA Networking

(cherry picked from commit a88e1a04df)
2022-02-10 16:10:53 +01:00
Mark Johnston
45711ee38a filemon: Reject FILEMON_SET_FD commands when the fd is a kqueue
When FILEMON_SET_FD is used, the filemon handle effectively wraps the
passed file.  In particular, the handle may be inherited by a child
process, or transferred over a unix domain socket, so we must verify
that the backing file permits this.

Reported by:	syzbot+36e6be9e02735fe66ca8@syzkaller.appspotmail.com
Reviewed by:	emaste
Sponsored by:	The FreeBSD Foundation

(cherry picked from commit b84ed4e7f6)
2022-02-10 08:46:24 -05:00
Ed Maste
51f69c0d53 mgb: remove set but not used variables
Sponsored by:	The FreeBSD Foundation

(cherry picked from commit c0aa5f6a32)
2022-02-09 16:22:20 -05:00
Ed Maste
ad3e327247 ce: remove long-obsolete FreeBSD version compatibility
Mechanical change via unifdef.

(cherry picked from commit f9839a42ee)
(cherry picked from commit f48c35fa1e)
2022-02-09 12:39:41 -05:00
Ed Maste
559fb03f96 rsu: add KASSERT to document maximum mbuf size in rsu_tx_start
PR:		254479
Reviewed by:	markj
Sponsored by:	The FreeBSD Foundation

(cherry picked from commit 453d8a7ee2)
2022-02-09 12:28:42 -05:00
Ed Maste
43f704843b hwpmc: drop 0x before %p printf format string
%p already includes the 0x.

Sponsored by:	The FreeBSD Foundation

(cherry picked from commit 2075d00fab)
2022-02-08 15:00:55 -05:00
Ed Maste
94e6d14488 Remove "All Rights Reserved" from FreeBSD Foundation sys/ copyrights
These ones were unambiguous cases where the Foundation was the only
listed copyright holder (in the associated license block).

Sponsored by:	The FreeBSD Foundation

(cherry picked from commit 9feff969a0)
2022-02-08 15:00:55 -05:00
Hans Petter Selasky
7e5b40d818 mlx5core: Set driver version into firmware.
If the driver_version capability bit is enabled, send the driver
version to firmware after the init HCA command, for display purposes.

Example of driver version: "FreeBSD,mlx5_core,14.0.0,3.x-xxx"

Linux commits:
012e50e109fd27ff989492ad74c50ca7ab21e6a1

Sponsored by:	NVIDIA Networking

(cherry picked from commit e6d7ac1d03)
2022-02-08 16:08:54 +01:00
Hans Petter Selasky
5ddb1a584d mlx5en: Implement one RQT object per channel.
These objects will eventually be used to switch TLS RX traffic.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 8e332232a5)
2022-02-08 16:08:54 +01:00
Hans Petter Selasky
823bcb3a13 mlx5: Add raw ethernet local loopback support.
Currently, unicast/multicast loopback raw ethernet (non-RDMA) packets
are sent back to the vport.  A unicast loopback packet is the packet
with destination MAC address the same as the source MAC address.  For
multicast, the destination MAC address is in the vport's multicast
filter list.

Moreover, the local loopback is not needed if there is one or none
user space context.

After this patch, the raw ethernet unicast and multicast local
loopback are disabled by default. When there is more than one user
space context, the local loopback is enabled.

Note that when local loopback is disabled, raw ethernet packets are
not looped back to the vport and are forwarded to the next routing
level (eswitch, or multihost switch, or out to the wire depending on
the configuration).

Linux commits:
c85023e153e3824661d07307138fdeff41f6d86a
8978cc921fc7fad3f4d6f91f1da01352aeeeff25

Sponsored by:	NVIDIA Networking

(cherry picked from commit ea00d7e8ca)
2022-02-08 16:08:54 +01:00
Hans Petter Selasky
7fb8dd15fa mlx5: Implement mlx5_nic_vport_update_local_lb()
Sponsored by:	NVIDIA Networking

(cherry picked from commit c1b76119cb)
2022-02-08 16:08:54 +01:00
Hans Petter Selasky
952d47e5cc mlx5en: Create TIRs before flowtables.
Because flowtables may redirect traffic to TIRs.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 5381f93647)
2022-02-08 16:08:54 +01:00
Hans Petter Selasky
0c4de0f986 mlx5en: Create flowtables in correct order.
Because it affects how the flow tables may re-direct traffic.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 001106f807)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
26b0e75d64 mlx5: Implement flow steering helper functions for TCP sockets.
This change adds convenience functions to setup a flow steering rule based on
a TCP socket. The helper function gets all the address information from the
socket and returns a steering rule, to be used with HW TLS RX offload.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 2c0ade806a)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
513a6d84e9 mlx5: Implement offloads flowtable namespace.
This namespace will be used for TCP offloads, like hardware decryption
of TLS TCP data.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 0ee1b09eaa)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
f42aaf43d3 mlx5en: Create and destroy all flow tables and rules when the network interface attaches and detaches.
Previously flow steering tables and rules were only created and destroyed
at link up and down events, respectivly. Due to new requirements for adding
TLS RX flow tables and rules, the main flow steering table must always be
available as there are permanent redirections from the TLS RX flow table
to the vlan flow table.

Sponsored by:	NVIDIA Networking

(cherry picked from commit e059c120b4)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
e441376f45 mlx5en: Add race protection for SQ remap
Add a refcount for posted WQEs to avoid a race between
post WQE and FW command flows.

Sponsored by:	NVIDIA Networking

(cherry picked from commit a8e715d21b)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
75312cafe7 mlx5en: Properly account for no-checksum on tunneled packets.
Sponsored by:	NVIDIA Networking

(cherry picked from commit aabca1034c)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
428331a8bf mlx5en: Force all packets through the indirection table.
All packets must go through the indirection table, RQT,
because it is not possible to modify the RQN of the TIR
for direct dispatchment after it is created, typically
when the link goes up and down.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 06c2bd1872)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
c7ec839e30 mlx5/mlx5en: Add SQ remap support
Add support to map an SQ to a specific schedule queue using a
special WQE as performance enhancement.

SQ remap operation is handled by a privileged internal queue, IQ,
and the mapping is enabled from one rate to another.

The transition from paced to non-paced should however always go
through FW.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 266c81aae3)
2022-02-08 16:08:53 +01:00
Hans Petter Selasky
57b86395fe mlx5: Properly define the reg_umr_sq networking offload capability bit.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 1c407d0494)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
95854550de mlx5en: Only delete installed VxLAN rules.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 9680b1ba71)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
2c8132accd mlx5en: Fix inverted logical assignment.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 6176a5e338)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
e53c3826c0 mlx5en: Implement support for internal queues, IQ.
Internal send queues are regular sendqueues which are reserved for WQE commands
towards the hardware and firmware. These queues typically carry resync
information for ongoing TLS RX connections and when changing schedule queues
for rate limited connections.

The internal queue, IQ, code is more or less a stripped down copy
of the existing SQ managing code with exception of:

1) An optional single segment memory buffer which can be read or
   written as a whole by the hardware, may be provided.
2) An optional completion callback for all transmit operations, may
   be provided.
3) Does not support mbufs.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 694263572f)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
4deb6e4fab mlx5en: Implement helper functions to open and close TLS TIR context.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 21228c67ab)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
9aca511703 mlx5en: Share DEK objects with TLS RX.
The TLS RX support also needs to be able to allocate DEK objects.
Share the available objects 1:1.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 75767cb889)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
b5b957a8db mlx5en: Add missing TLS structure prototype.
Sponsored by:	NVIDIA Networking

(cherry picked from commit fad4b7d1f2)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
b324932190 mlx5en: Remove unused hardware TLS field.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 3a1bf85503)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
3954e5380a mlx5en: Make the receive packet indirection table, RQT, static instead of dynamic.
Allocate the RQT once, pointing all initial entries to the drop RQN.
When opening the channels simplify modify the RQT, directing all traffic
to the new RQNs. Similarly when closing the channels point all RQT entries
back to the so-called drop RQN.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 33a6a7a72a)
2022-02-08 16:08:52 +01:00
Hans Petter Selasky
0c8b126da5 mlx5en: Set CQN in RQ parameters for drop RQ.
Else creating the drop RQ fails.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 7800af352a)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
e2c02a4920 mlx5en: Set channel pointer for drop receive queue.
A valid channel pointer is needed to get the priv pointer during init.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 03567b0dfa)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
e5b00e9b64 mlx5en: Print error code when opening drop RQ fails.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 4e40e984da)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
62283a6345 mlx5en: Implement dummy receive queue, RQ, for dropping packets.
What is a drop RQ and why is it needed?

The RSS indirection table, also called the RQT, selects the
destination RQ based on the receive queue number, RQN. The RQT is
frequently referred to by flow steering rules to distribute traffic
among multiple RQs. The problem is that the RQs cannot be destroyed
before the RQT referring them is destroyed too. Further, TLS RX
rules may still be referring to the RQT even if the link went
down. Because there is no magic RQN for dropping packets, we create
a dummy RQ, also called drop RQ, which sole purpose is to drop all
received packets. When the link goes down this RQN is filled in all
RQT entries, of the main RQT, so the real RQs which are about to be
destroyed can be released and the TLS RX rules can be sustained.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 27b778ae55)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
7dedd4ba03 mlx5en: Make the hw_lro parameter read only tunable.
This prevents the so-called TIR context from changing during runtime.

Sponsored by:	NVIDIA Networking

(cherry picked from commit a60f953424)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
ecf32f2daa mlx5: Remove support for FreeBSD 10 and older.
Sponsored by:	NVIDIA Networking

(cherry picked from commit 788e9e7478)
2022-02-08 16:08:51 +01:00
Hans Petter Selasky
3be2f639a8 mlx5en: Patch to inhibit transmit doorbell writes during packet reception.
During packet reception the network stack frequently transmit data in
response to TCP window updates. To reduce the number of transmit doorbells
needed, inhibit all transmit doorbells designated for the same channel until
after the reception of packets for the given channel is completed.

While at it slightly refactor the mlx5e_tx_notify_hw() function:

1) The doorbell information is always stored into sq->doorbell.d64 .
No need to pass a separate pointer to this variable.

2) Move checks for skipping doorbell writes inside this function.

Sponsored by:	NVIDIA Networking

(cherry picked from commit 2d5e5a0d75)
2022-02-08 16:08:51 +01:00
Konstantin Belousov
19371d5334 mlx5ib: idiomatic use of preprocessor, in particular paths
(cherry picked from commit 028130b8e4)
2022-02-08 08:42:07 +02:00
Konstantin Belousov
0330cf6769 mlx5ib: normalize use of the opt_*.h files
(cherry picked from commit 7060097908)
2022-02-08 08:42:07 +02:00