]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/log
FreeBSD/FreeBSD.git
5 years agoMFC 341800: Don't report stale signal information in ptrace_lwpinfo.
John Baldwin [Wed, 2 Jan 2019 19:11:49 +0000 (19:11 +0000)]
MFC 341800: Don't report stale signal information in ptrace_lwpinfo.

Once a signal's siginfo was copied to 'td_si' as part of the signal
exchange in issignal(), it was never cleared.  This caused future
thread events that are reported as SIGTRAP events without signal
information to report the stale siginfo in 'td_si'.  For example, if a
debugger created a new process and used SIGSTOP to stop it after
PT_ATTACH, future system call entry / exit events would set PL_FLAG_SI
with the SIGSTOP siginfo in pl_siginfo.  This broke 'catch syscall' in
current versions of gdb as it assumed PL_FLAG_SI with SIGTRAP
indicates a breakpoint or single step trap.

5 years agoMFC r342221:
Mark Johnston [Wed, 2 Jan 2019 16:42:07 +0000 (16:42 +0000)]
MFC r342221:
Implement cpu_halt() for RISC-V.

5 years agoMFC r342223:
Mark Johnston [Wed, 2 Jan 2019 16:41:39 +0000 (16:41 +0000)]
MFC r342223:
Replace uses of sbadaddr with stval.

5 years agoMFC r342093:
Mark Johnston [Wed, 2 Jan 2019 16:40:54 +0000 (16:40 +0000)]
MFC r342093:
Clean up the riscv pmap_bootstrap() implementation.

PR: 231515

5 years agoMFC r342097:
Mark Johnston [Wed, 2 Jan 2019 16:36:46 +0000 (16:36 +0000)]
MFC r342097:
Add a QEMU config for RISC-V.

5 years agoMFC r342099:
Mark Johnston [Wed, 2 Jan 2019 16:34:36 +0000 (16:34 +0000)]
MFC r342099:
Avoid needless TLB invalidations in pmap_remove_pages().

5 years agoMFC r342100:
Mark Johnston [Wed, 2 Jan 2019 16:33:49 +0000 (16:33 +0000)]
MFC r342100:
Add some more checking to the RISC-V page fault handler.

5 years agoMFC r342098:
Mark Johnston [Wed, 2 Jan 2019 16:33:17 +0000 (16:33 +0000)]
MFC r342098:
Assume that pmap_l1() will return a PTE.

5 years agoMFC r342182:
Mark Johnston [Wed, 2 Jan 2019 16:11:02 +0000 (16:11 +0000)]
MFC r342182:
Remove UMS support code from radeonkms.

5 years agoMFC r342596:
Cy Schubert [Wed, 2 Jan 2019 15:13:08 +0000 (15:13 +0000)]
MFC r342596:

Remove duplicate include of sys/mbuf.h.

Reported by: Trond Endrest <Trond.Endrestol@ximalas.info>

5 years agoMFC r341438:
Toomas Soome [Wed, 2 Jan 2019 07:30:27 +0000 (07:30 +0000)]
MFC r341438:
zfs: we can boot from dataset with large_dnode enabled

loader has been supporting large_dnode for some time, no need to block the
feature for boot dataset.

Relnotes: yes

5 years agoMFC r342613: Import tzdata 2018h
Philip Paeps [Tue, 1 Jan 2019 10:04:49 +0000 (10:04 +0000)]
MFC r342613: Import tzdata 2018h
MFC r342644: Import tzdata 2018i

5 years agoMFC r342661: Happy New Year 2019!
Xin LI [Tue, 1 Jan 2019 00:35:26 +0000 (00:35 +0000)]
MFC r342661: Happy New Year 2019!

5 years agoMFC r342594:
Konstantin Belousov [Tue, 1 Jan 2019 00:28:00 +0000 (00:28 +0000)]
MFC r342594:
i386: Fix allocation of the KVA frame for pmap_quick_enter_page().

5 years agoMFC 340460: Convert the number of MSI IRQs on x86 from a constant to a tunable.
John Baldwin [Mon, 31 Dec 2018 22:09:08 +0000 (22:09 +0000)]
MFC 340460: Convert the number of MSI IRQs on x86 from a constant to a tunable.

The number of MSI IRQs still defaults to 512, but it can now be
changed at boot time via the machdep.num_msi_irqs tunable.

Relnotes: yes

5 years agoMFC 340465: Use sbsndptr_adv() instead of sbsndptr() for TOE TLS.
John Baldwin [Mon, 31 Dec 2018 21:55:12 +0000 (21:55 +0000)]
MFC 340465: Use sbsndptr_adv() instead of sbsndptr() for TOE TLS.

For TOE TLS, we just want to advance the send pointer to skip over the
record just sent to the TOE.  The recently added sbsndptr_adv() is
sufficient for that and is cheaper.

5 years agoMFC r342368, r342369
Vincenzo Maffione [Mon, 31 Dec 2018 10:59:30 +0000 (10:59 +0000)]
MFC r342368, r342369

netmap: fix bug in netmap_poll() optimization

The bug was introduced by r339639, although it is present in the upstream
netmap code since 2015. It is due to resetting the want_rx variable to
POLLIN, rather than resetting it to POLLIN|POLLRDNORM.
It only affects select(), which uses POLLRDNORM. poll() is not affected,
because it uses POLLIN.
Also, it only affects FreeBSD, because Linux skips the optimization
implemented by the piece of code where the bug occurs.
To check if txsync can be skipped, it is necessary to look for
unseen TX space. However, this means comparing ring->cur
against ring->tail, rather than ring->head against ring->tail
(like nm_ring_empty() does).

Sponsored by: Sunny Valley Networks

5 years agoMFC r342385:
Cy Schubert [Mon, 31 Dec 2018 03:53:33 +0000 (03:53 +0000)]
MFC r342385:

Remove an empty #if block.

The interesting thing is that looking through Darren's commit logs,
the line containing an extern ppsratecheck() definition was removed
from the v5-1-RELEASE branch but not from HEAD (I have taken his
CVS tree and converted it to GIT). There is a commit adding an
additional #if defined to the empty block. I can only assume that
this was intentional for something later. Looking through HEAD the
extern ppsratecheck() is there. However if we put it back it would
conflict with a static ppsratecheck() definition in fil.c when
building ipftest.

Therefore we remove this empty block.

ppsratecheck() is a function in the FreeBSD kernel. However ipftest
cannot call the ppsratecheck() in the kernel. Therefore one exists in
fil.c for use when building the userland ipftest utility which
approximates the packet filter in userland for testing of ipfilter
rules against packets captured with tcpdump.

5 years agoMFC r342382:
Konstantin Belousov [Sun, 30 Dec 2018 15:22:26 +0000 (15:22 +0000)]
MFC r342382:
nvdimm SPA geom: Update bio fields needed for devstat_end_transaction_bio().

5 years agoMFC r342381:
Konstantin Belousov [Sun, 30 Dec 2018 15:17:57 +0000 (15:17 +0000)]
MFC r342381:
Allocate v_object for the new snapshot vnode.

5 years agoMFC r342380:
Konstantin Belousov [Sun, 30 Dec 2018 15:17:00 +0000 (15:17 +0000)]
MFC r342380:
Properly test for vmio buffer in bnoreuselist().

5 years agoMFC r342151, r342161:
Toomas Soome [Sun, 30 Dec 2018 09:13:38 +0000 (09:13 +0000)]
MFC r342151, r342161:
loader: zfs reader should not probe partitionless disks

First of all, normal setups can not boot such pools as the tools
do not support installing boot programs.

Secondly, for proper pool configuration detection, we need to checks all
four label copies on disk, 2 from front and 2 from the end of the disk,
but zfs label does not contain the size of the disk - so we depend on
firmware to report the correct disk size or use information from the
partition table.

Without partition table, we only can rely on firmware to report and support
disk IO properly.

Relnotes: yes

5 years agoMFC r341329:
Toomas Soome [Sun, 30 Dec 2018 09:05:02 +0000 (09:05 +0000)]
MFC r341329:
loader.efi: fix EFI getchar() for multiple consoles

This fix is ported from illumos (issue #9970), the analysis and initial
implementation was done by John Levon.

See also: https://www.illumos.org/issues/9970

Currently, efi_cons_getchar() will wait for a key. While this seems to make
sense, the implementation of getchar() in common/console.c will loop across
getchar() for all consoles without doing ischar() first.

This means that if we've configured multiple consoles, we can't input into
the serial, as getchar() will be sat waiting for input only from efi_console.c

This patch does implement a bit more generic key buffer to support
translation of input keys, and we use generic efi_readkey() to reduce
duplication from calls from getchar() and poll().

Relnotes: yes

5 years agoMFC r341328:
Toomas Soome [Sun, 30 Dec 2018 08:58:31 +0000 (08:58 +0000)]
MFC r341328:
loader: create separate lists for fd, cd and hd, merge bioscd with biosdisk

Create unified block IO implementation in BIOS version, like it is done in UEFI
side. Implement fd, disk and cd device lists, this will split floppy devices
from disks and will allow us to have consistent, predictable device naming
(modulo BIOS issues).

Relnotes: yes
Differential Revision: https://reviews.freebsd.org/D17888

5 years agoMFC: r341231
Toomas Soome [Sun, 30 Dec 2018 08:50:34 +0000 (08:50 +0000)]
MFC: r341231

loader: command_bcache() should print unsigned values

All bcache counters are unsigned.

5 years agoMFC r342547:
Cy Schubert [Sun, 30 Dec 2018 04:42:01 +0000 (04:42 +0000)]
MFC r342547:

Remove another empty #ifdef block. This empty block also exists in
the upstream HEAD.

5 years agoMFC r342377:
Cy Schubert [Sun, 30 Dec 2018 04:37:49 +0000 (04:37 +0000)]
MFC r342377:

Remove NETBSD_PF. NETBSD_PF is a flag that defines whether the pfil(9)
framework is available. pfil(9) has been in FreeBSD since FreeBSD 5
and according to svn log was first committed to HEAD in 2000, therefore
it is safe to say the check is no longer needed in FreeBSD.

pfil(9) first appeared in NetBSD 1.3 (hence the name NETBSD_PF).
Therefore it is safe to say that it is supported by every NetBSD system
today. The framework also exists in illumos.

As ipfilter code is shared and exchanged between FreeBSD and NetBSD, and
at some point in the future illumos too, and as all three platforms have
pfil(9), the redundant NETBSD_PF #defines and #ifdefs are removed.

5 years agoMFC r341279:
Cy Schubert [Sun, 30 Dec 2018 04:31:51 +0000 (04:31 +0000)]
MFC r341279:

Clean up a redundant non-redefinition of IFNAMSIZ. IFNAMSIZ
is defined in net/if.h, therefore the condition is never met and
confusing to those who follow.

5 years agoMFC r342374:
Cy Schubert [Sat, 29 Dec 2018 03:18:16 +0000 (03:18 +0000)]
MFC r342374:

Remove the last vestiges of HP/UX from a FreeBSD-only ipfilter
source file.

5 years agoMFC 340441: Revert r332735 and fix MSI-X to properly fail allocations when full.
John Baldwin [Sat, 29 Dec 2018 01:19:14 +0000 (01:19 +0000)]
MFC 340441: Revert r332735 and fix MSI-X to properly fail allocations when full.

The off-by-one errors in 332735 weren't actual errors and were
preventing the last MSI interrupt source from being used.  Instead,
the issue is that when all MSI interrupt sources were allocated, the
loop in msix_alloc() would terminate with 'msi' still set to non-null.
The only check for 'i' overflowing was in the 'msi' == NULL case, so
msix_alloc() would try to reuse the last MSI interrupt source instead
of failing.

Fix by moving the check for all sources being in use to just after the
loop.

5 years agoMFC r342367: ifconfig.8, lagg.4: fix documentation bug: -use_flowid
Eugene Grosbein [Sat, 29 Dec 2018 00:41:21 +0000 (00:41 +0000)]
MFC r342367: ifconfig.8, lagg.4: fix documentation bug: -use_flowid
needs to be used to force local hash computation and disable usage
of RSS hash provided by driver.

PR: 234242

5 years agoMFC 340304: Use tcp_state_change() in the cxgbe(4) TOE module.
John Baldwin [Sat, 29 Dec 2018 00:30:17 +0000 (00:30 +0000)]
MFC 340304: Use tcp_state_change() in the cxgbe(4) TOE module.

r254889 added tcp_state_change() as a centralized place to log state
changes in TCP connections for DTrace.  r294869 and r296881 took
advantage of this central location to manage per-state counters.
However, TOE sockets were still performing some (but not all) state
change updates via direct assignments to t_state.  This resulted in
state counters underflowing when TOE was in use.  Fix by using
tcp_state_change() when changing a TOE connection's state.

5 years agoAdd an UPDATING entry for r342561.
Rick Macklem [Sat, 29 Dec 2018 00:00:39 +0000 (00:00 +0000)]
Add an UPDATING entry for r342561.

This is a direct commit.

5 years agoMFC r342298:
Andrey V. Elsukov [Fri, 28 Dec 2018 10:09:18 +0000 (10:09 +0000)]
MFC r342298:
  Allow use underscores and dots in service names without escaping.

  PR: 234237

5 years agoMFC r342193: ichwd: add a few assertions about tco_version
Andriy Gapon [Fri, 28 Dec 2018 08:52:50 +0000 (08:52 +0000)]
MFC r342193: ichwd: add a few assertions about tco_version

5 years agoMFC r342073: ichwd: add Sunrise Point-LP ID
Andriy Gapon [Fri, 28 Dec 2018 08:49:51 +0000 (08:49 +0000)]
MFC r342073: ichwd: add Sunrise Point-LP ID

5 years agoMFC r342072: ichwd: add support for clearing No Reboot bit in TCOv4
Andriy Gapon [Fri, 28 Dec 2018 08:47:52 +0000 (08:47 +0000)]
MFC r342072: ichwd: add support for clearing No Reboot bit in TCOv4

5 years agoMFC: r342286
Rick Macklem [Fri, 28 Dec 2018 00:10:31 +0000 (00:10 +0000)]
MFC: r342286
Fix the NFSv4 server to obey vfs.nfsd.nfs_privport.

When the NFSv4 server was coded, I believed that the specification authors
did not want NFSv4 servers to require a client to use a reserved port#.
However, recently it has been noted that the Linux NFSv4 server does support
a check for a reserved port#.
Since both the FreeBSD and Linux NFSv4 clients use a reserved port# by
default, enabling vfs.nfsd.nfs_privport to require a reserved port# for
NFSv4 the same as it does for NFSv2, 3 seems reasonable.
The only case where this could cause a POLA violation is a FreeBSD NFSv4
server with vfs.nfsd.nfs_privport set, but with NFSv4 clients doing mounts
without using a reserved port# (< 1024).

5 years agoMFC r342000:
Kristof Provost [Wed, 26 Dec 2018 12:56:36 +0000 (12:56 +0000)]
MFC r342000:

pf tests: Basic rdr test

5 years agoMFC r341999:
Kristof Provost [Wed, 26 Dec 2018 12:55:35 +0000 (12:55 +0000)]
MFC r341999:

pf tests: NAT exhaustion test

It's been reported that pf doesn't handle running out of available ports
for NAT correctly. It freezes until a state expires and it can find a
free port.
Test for this, by setting up a situation where only two ports are
available for NAT and then attempting to create three connections.

If successful the third connection will fail immediately. In an
incorrect case the connection attempt will freeze, also freezing all
interaction with pf through pfctl and trigger timeout.

PR: 233867

5 years agoMFC r341998:
Kristof Provost [Wed, 26 Dec 2018 12:54:24 +0000 (12:54 +0000)]
MFC r341998:

pf: Fix endless loop on NAT exhaustion with sticky-address

When we try to find a source port in pf_get_sport() it's possible that
all available source ports will be in use. In that case we call
pf_map_addr() to try to find a new source IP to try from. If there are
no more available source IPs pf_map_addr() will return 1 and we stop
trying.

However, if sticky-address is set we'll always return the same IP
address, even if we've already tried that one.
We need to check the supplied address, because if that's the one we'd
set it means pf_get_sport() has already tried it, and we should error
out rather than keep trying.

PR: 233867

5 years agoMFC r342204: cyapa.4, isl.4: cross-reference and document use of chromebook_platform(4)
Andriy Gapon [Wed, 26 Dec 2018 09:21:58 +0000 (09:21 +0000)]
MFC r342204: cyapa.4, isl.4: cross-reference and document use of chromebook_platform(4)

PR: 218632

5 years agoMFC r341681: daprobedone: announce if a disk is write-protected
Andriy Gapon [Wed, 26 Dec 2018 09:16:03 +0000 (09:16 +0000)]
MFC r341681: daprobedone: announce if a disk is write-protected

5 years agoMFC r342349: Fix passing wrong variables to nvlist_destroy() after r333446.
Alexander Motin [Wed, 26 Dec 2018 02:34:18 +0000 (02:34 +0000)]
MFC r342349: Fix passing wrong variables to nvlist_destroy() after r333446.

Reported by: Alexander Fedorov (IT-Grad.ru)

5 years agoMFC r342211:
Andriy Voskoboinyk [Tue, 25 Dec 2018 13:51:21 +0000 (13:51 +0000)]
MFC r342211:
net80211: fix out-of-bounds read in ieee80211_amrr(9)

5 years agoMFC r342185:
Andriy Voskoboinyk [Tue, 25 Dec 2018 13:37:43 +0000 (13:37 +0000)]
MFC r342185:
iwi(4): do not leak node reference when IWI_FLAG_ASSOCIATED flag is set.

5 years agoMFC r341833:
Kristof Provost [Tue, 25 Dec 2018 12:45:46 +0000 (12:45 +0000)]
MFC r341833:

pf: Prevent integer overflow in PF when calculating the adaptive timeout.

Mainly states of established TCP connections would be affected resulting
in immediate state removal once the number of states is bigger than
adaptive.start.  Disabling adaptive timeouts is a workaround to avoid this bug.
Issue found and initial diff by Mathieu Blanc (mathieu.blanc at cea dot fr)

Reported by: Andreas Longwitz <longwitz AT incore.de>
Obtained from: OpenBSD

5 years agoMFC r341835:
Kristof Provost [Tue, 25 Dec 2018 11:08:53 +0000 (11:08 +0000)]
MFC r341835:

pf tests: Use the ATF cleanup infrastructure in the ioctl tests

Use ATF_TC_CLEANUP(), because that means the cleanup code will get
called even if a test fails. Before it would only be executed if every
test within the body succeeded.

Reported by: Marie Helene Kvello-Aune <marieheleneka@gmail.com>

5 years agoMFC r341834:
Kristof Provost [Tue, 25 Dec 2018 11:07:21 +0000 (11:07 +0000)]
MFC r341834:

pf tests: ioctl tests require root rights

Explicitly mark these tests as requiring root rights. We need to be able
to open /dev/pf.

Reported by: Marie Helene Kvello-Aune <marieheleneka@gmail.com>

5 years agoMFC r342302
Vincenzo Maffione [Mon, 24 Dec 2018 14:51:13 +0000 (14:51 +0000)]
MFC r342302

netmap: update nmreplay(8)

Small modifications to the nmreplay man page.
Used igor and mandoc tools to fix warnings and errors.

Reviewed by:    bcr
Differential Revision:  https://reviews.freebsd.org/D18629

5 years agoMFC r342301
Vincenzo Maffione [Mon, 24 Dec 2018 14:49:59 +0000 (14:49 +0000)]
MFC r342301

netmap: nmreplay: import various fixes from upstream (2704a51839906)

Changelist:
    - General reformatting
    - Fix packet duplication in cons(). Whenever cons() reached the
      burst limit it would send all pending packets without advancing
      head. This caused the last injected packet to be sent again in
      the next round.
    - Fix full-speed transmissions after first loop.

5 years agoMFC r342300
Vincenzo Maffione [Mon, 24 Dec 2018 14:48:28 +0000 (14:48 +0000)]
MFC r342300

netmap: move buf_size validation code to its own function

This code validates the netmap buf_size against the interface MTU
and maximum descriptor size, to make sure the values are consistent.
Moving this functionality to its own function is needed because this
function is also called by Linux-specific code.

5 years agoMFC r342299
Vincenzo Maffione [Mon, 24 Dec 2018 14:47:26 +0000 (14:47 +0000)]
MFC r342299

netmap: pipes: make sure both ends use the same number of slots

5 years agoMFC r342280:
Michael Tuexen [Sun, 23 Dec 2018 09:48:36 +0000 (09:48 +0000)]
MFC r342280:

Fix a regression in the TCP handling of received segments.
When receiving TCP segments the stack protects itself by limiting
the resources allocated for a TCP connections. This patch adds
an exception to these limitations for the TCP segement which is the next
expected in-sequence segment. Without this patch, TCP connections
may stall and finally fail in some cases of packet loss.

Reported by: jhb@
Reviewed by: jtl@, rrs@
Sponsored by: Netflix, Inc.
Differential Revision: https://reviews.freebsd.org/D18580

5 years agoMFC r342207:
Mark Johnston [Sat, 22 Dec 2018 19:45:02 +0000 (19:45 +0000)]
MFC r342207:
Fix DDB's "show malloc" after r338899.

5 years agoMFC r342214:
Mark Johnston [Sat, 22 Dec 2018 19:44:06 +0000 (19:44 +0000)]
MFC r342214:
Remove a use of a negative array index from fxp(4).

5 years agoMFC r342141: periodic/weekly/340.noid: do not use sysrc(8) that depends
Eugene Grosbein [Sat, 22 Dec 2018 10:55:40 +0000 (10:55 +0000)]
MFC r342141: periodic/weekly/340.noid: do not use sysrc(8) that depends
on bsdinstall(8) and may be non-functional
for system built WITHOUT_BSDINSTALL. (*)

Also, add a check for jails sharing whole tree with host (path=/)
and do not skip it.

Reported by: Andre.Albsmeier@siemens.com (*)

5 years agoMFC r339746,339751,339794,340866,340939,342042:
Martin Matuska [Fri, 21 Dec 2018 23:32:50 +0000 (23:32 +0000)]
MFC r339746,339751,339794,340866,340939,342042:
Sync libarchive with vendor.

Relevant vendor changes:
  PR #1013: Add missing h_base offset when performing absolute seeks in
            xar decompression
  PR #1023: Support extracting extattrs as non-root on non-user-writeable
            files
  PR #1061: Add support for extraction of RAR v5 archives
  PR #1066: Fix out of bounds read on empty string filename for gnutar, pax
            and v7tar
  PR #1067: Fix temporary file path buffer overflow in tests
  IS #1068: Correctly process and verify integer arguments passed to
            bsdcpio and bsdtar
  PR #1070: Don't default XAR entry atime/mtime to the current time
  PR #1080: Spelling fixes
  PR #1084: RAR5 reader bugfixes
  PR #1091: fix use-after-free in delayed newc link processing
  PR #1092: Fix a few obvious resource leaks and strcpy() misuses
  IS #1096: Support extracting ACLs with in-entry comments (GNU tar)
  PR #1102: RAR5 reader - fix big-endian problems
  PR #1105: Fix various crash, memory corruption and infinite loop conditions

  RAR5 reader: FreeBSD build platform fixes for powerpc(64), mips(64),
               sparc64 and riscv64
  RAR5 reader: more maybe-uninitialized size_t fixes for riscv64
               FreeBSD build

5 years agoMFC r341785
Andrew Rybchenko [Fri, 21 Dec 2018 17:26:22 +0000 (17:26 +0000)]
MFC r341785

sfxge(4): use n Tx queues instead of n + 2 on EF10 HW

On EF10 HW we can avoid sending packets without checksum offload
or with IP-only checksum offload to dedicated queues. Instead, we
can use option descriptors to change offload policy on any queue
during runtime. Thus, we don't need to create two dedicated queues.

Submitted by:   Ivan Malov <Ivan.Malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18390

5 years agoMFC r341784
Andrew Rybchenko [Fri, 21 Dec 2018 17:23:44 +0000 (17:23 +0000)]
MFC r341784

sfxge(4): prepare the number of Tx queues on event queue 0 to become
variable

The number of Tx queues on event queue 0 can depend on the NIC family
type,
and this property will be leveraged by future patches.
This patch prepares the code for this change.

Submitted by:   Ivan Malov <Ivan.Malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18389

5 years agoMFC r341783
Andrew Rybchenko [Fri, 21 Dec 2018 17:22:17 +0000 (17:22 +0000)]
MFC r341783

sfxge(4): report support for Tx checksum op descriptors

FreeBSD driver needs a patch to provide a means for packets
which do not need checksum offload but have flow ID set
to avoid hitting only the first Tx queue (which has been used
for packets not needing checksum offload).

This should be possible on Huntington, Medford or Medford2 chips
since these support toggling checksum offload on any given queue
dynamically by means of pushing option descriptors.

The patch for FreeBSD driver will then need a means to figure out
whether the feature can be used, and testing adapter family might
not be a good solution.

This patch adds a feature bit specifically to indicate support
for checksum option descriptors. The new feature bits may have
more users in future, apart from the mentioned FreeBSD patch.

Submitted by:   Ivan Malov <Ivan.Malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18388

5 years agoMFC r341038
Andrew Rybchenko [Fri, 21 Dec 2018 17:18:33 +0000 (17:18 +0000)]
MFC r341038

sfxge(4): add method to make checksum option descriptors

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18160

5 years agoMFC r340833
Andrew Rybchenko [Fri, 21 Dec 2018 17:12:05 +0000 (17:12 +0000)]
MFC r340833

sfxge(4): support inner checksum offload on transmit

Inner checksum offloads may be used only if firmware supports
these tunnels.

Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18102

5 years agoMFC r340831
Andrew Rybchenko [Fri, 21 Dec 2018 17:10:48 +0000 (17:10 +0000)]
MFC r340831

sfxge(4): make MAC naming consistent with other modules

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18101

5 years agoMFC r341782
Andrew Rybchenko [Fri, 21 Dec 2018 17:02:41 +0000 (17:02 +0000)]
MFC r341782

sfxge(4): populate per-event queue stats in sysctl

In order to find out why the first event queue and corresponding
interrupt is triggered more frequent, it is useful to know which
events go to each event queue.

Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18418

5 years agoMFC r341297
Andrew Rybchenko [Fri, 21 Dec 2018 16:57:59 +0000 (16:57 +0000)]
MFC r341297

sfxge(4): fix out of bounds read when dereferencing sdup

Introduce and use macro to make sure that MCDI buffers allocated
on stack are rounded up properly.

Submitted by:   Gautam Dawar <gdawar at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18259

5 years agoMFC r341327
Andrew Rybchenko [Fri, 21 Dec 2018 16:32:12 +0000 (16:32 +0000)]
MFC r341327

sfxge(4): rollback last seen VLAN TCI if Tx packet is dropped

Early processing of a packet on transmit may change last seen
VLAN TCI in the queue context. If such a packet is eventually
dropped, last seen VLAN TCI must be set to its previous value.

Submitted by:   Ivan Malov <Ivan.Malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18288

5 years agoMFC r341326
Andrew Rybchenko [Fri, 21 Dec 2018 16:31:16 +0000 (16:31 +0000)]
MFC r341326

sfxge(4): ensure EvQ poll stops when abort is requested

If an event handler requested an abort, only the inner loop was
guarenteed to be broken out of - the outer loop could continue
if total == batch.

Fix this by poisoning batch to ensure it is different to total.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18287

5 years agoMFC r341311
Andrew Rybchenko [Fri, 21 Dec 2018 16:30:21 +0000 (16:30 +0000)]
MFC r341311

sfxge(4): make last byte of module information available

Adjust bounds so the interface supports reading
the last available byte of data.

Submitted by:   Richard Houldsworth <rhouldsworth at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18273

5 years agoMFC r341309
Andrew Rybchenko [Fri, 21 Dec 2018 16:29:31 +0000 (16:29 +0000)]
MFC r341309

sfxge(4): fix MAC Tx stats for less or equal to 64 bytes

This statistic should include 64byte and smaller frames.
Fix EF10 calculation to match Siena code.

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18271

5 years agoMFC r341302
Andrew Rybchenko [Fri, 21 Dec 2018 16:28:22 +0000 (16:28 +0000)]
MFC r341302

sfxge(4): fix a typo in unicast filter insertion comment

Submitted by:   Ivan Malov <ivan.malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18264

5 years agoMFC r341301
Andrew Rybchenko [Fri, 21 Dec 2018 16:27:37 +0000 (16:27 +0000)]
MFC r341301

sfxge(4): prevent access to the NIC config before probe

NIC config is initialized during NIC probe.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18263

5 years agoMFC r341295
Andrew Rybchenko [Fri, 21 Dec 2018 16:26:18 +0000 (16:26 +0000)]
MFC r341295

sfxge(4): avoid usage of too big arrays on stack

Found by PreFAST static analysis.

Submitted by:   Martin Harvey <mharvey at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18257

5 years agoMFC r341290
Andrew Rybchenko [Fri, 21 Dec 2018 16:25:25 +0000 (16:25 +0000)]
MFC r341290

sfxge(4): check size of memory to read sensors data to

Size of provided memory should be consistent with specified size.

Submitted by:   Martin Harvey <mharvey at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18252

5 years agoMFC r341215
Andrew Rybchenko [Fri, 21 Dec 2018 16:24:37 +0000 (16:24 +0000)]
MFC r341215

sfxge(4): fix build because of no declaration

Functions declared in mcdi_mon.h are implemented in mcdi_mon.c.
The build fails if compiler options require declaration before
definition.

Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18246

5 years agoMFC r341214
Andrew Rybchenko [Fri, 21 Dec 2018 16:22:12 +0000 (16:22 +0000)]
MFC r341214

sfxge(4): fix SAL annotation for input buffers

Submitted by:   Martin Harvey <mharvey at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18245

5 years agoMFC r341213
Andrew Rybchenko [Fri, 21 Dec 2018 16:21:19 +0000 (16:21 +0000)]
MFC r341213

sfxge(4): fix PreFAST warnings because of unused return

Submitted by:   Martin Harvey <mharvey at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18244

5 years agoMFC r341197
Andrew Rybchenko [Fri, 21 Dec 2018 16:20:13 +0000 (16:20 +0000)]
MFC r341197

sfxge(4): fix comparison always true warning

Loopback type used as bit index has efx_loopback_type_t type
which is enum. clang complains that it is always true when it
is compared with qword (64 bit) bits number boundary.

Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18228

5 years agoMFC r340896
Andrew Rybchenko [Fri, 21 Dec 2018 16:13:48 +0000 (16:13 +0000)]
MFC r340896

sfxge(4): remove Falcon-specific concurrency check

Falcon support has been withdrawn from libefx, however, there is still
an obsolete Falcon-specific assertion that efx_mac_stats_upload()
and efx_port_poll() aren't concurrent. To be consistent with an overall
Falcon support revocation it's desirable to remove it.

Fix debug build invalid assertion failure.

Submitted by:   Ivan Malov <ivan.malov at oktetlabs.ru>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18130

5 years agoMFC r340895
Andrew Rybchenko [Fri, 21 Dec 2018 16:12:59 +0000 (16:12 +0000)]
MFC r340895

sfxge(4): move BIU test code into Siena-specific file

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18129

5 years agoMFC r340894
Andrew Rybchenko [Fri, 21 Dec 2018 16:11:18 +0000 (16:11 +0000)]
MFC r340894

sfxge(4): fix PreFAST static analysis warning (C6001)

Fix warning
"C6001: Using uninitialized memory '*sensor_maskp'"
which could occur when the npages argument to efx_mcdi_sensor_info()
is less than or equal to zero.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18128

5 years agoMFC r340892
Andrew Rybchenko [Fri, 21 Dec 2018 16:10:31 +0000 (16:10 +0000)]
MFC r340892

sfxge(4): remove obsolete check for pre-Siena hardware

The fail4 label was used twice, so it doesn't need removing.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18126

5 years agoMFC r340891
Andrew Rybchenko [Fri, 21 Dec 2018 16:08:49 +0000 (16:08 +0000)]
MFC r340891

sfxge(4): fix warnings from VS2015 C compiler (C4214)

Fix multiple level 4 warnings
"C4214: nonstandard extension used: bit field types other than int";
no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18125

5 years agoMFC r340890
Andrew Rybchenko [Fri, 21 Dec 2018 16:07:13 +0000 (16:07 +0000)]
MFC r340890

sfxge(4): fix warnings from VS2015 C compiler (C4057)

Fix two level 4 warnings
"C4057: 'function': 'const uint8_t *' differs in indirection to
slightly different base types from 'caddr_t'"; no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18124

5 years agoMFC r340889
Andrew Rybchenko [Fri, 21 Dec 2018 16:06:25 +0000 (16:06 +0000)]
MFC r340889

sfxge(4): fix warnings from VS2015 C compiler (C4189)

Fix multiple level 4 warnings
"C4189: 'xxx': local variable is initialized but not referenced";
no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18123

5 years agoMFC r340888
Andrew Rybchenko [Fri, 21 Dec 2018 16:02:29 +0000 (16:02 +0000)]
MFC r340888

sfxge(4): fix warnings from VS2015 C compiler (C4100)

Fix multiple level 4 warnings
"C4100: 'xxx': unreferenced formal parameter"
no functional changes.

The _NOTE(ARGUNUSED(xxx)) annotations are being exposed to the Visual
Studio 2015 C compiler with the following:

  #define _NOTE_ARGUNUSED(...) UNREFERENCED_PARAMETER((__VA_ARGS__));
  #define _NOTE(_annotation)   _NOTE_ ## _annotation

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
MFC after:      1 week
Differential Revision:  https://reviews.freebsd.org/D18122

5 years agoMFC r340887
Andrew Rybchenko [Fri, 21 Dec 2018 15:59:37 +0000 (15:59 +0000)]
MFC r340887

sfxge(4): fix warnings from VS2015 C compiler (C4245)

Fix level 4 warning
"C4245: 'initializing': conversion from 'int' to 'uint32_t',
signed/unsigned mismatch" warning; no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18121

5 years agoMFC r340804
Andrew Rybchenko [Fri, 21 Dec 2018 15:57:38 +0000 (15:57 +0000)]
MFC r340804

sfxge(4): insert filters for encapsulated packets

On Medford, with full-featured firmware running, encapsulated
packets may not be delivered unless filters are inserted for
them, as ordinary filters are not applied to encapsulated
packets. So filters for encapsulated packets need to be
inserted for each class of encapsulated packet. For simplicity,
catch-all filters are always inserted. These may match more
packets than the OS has asked for, but trying to insert more
precise filters increases complexity for little gain.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18074

5 years agoMFC r340803
Andrew Rybchenko [Fri, 21 Dec 2018 15:56:40 +0000 (15:56 +0000)]
MFC r340803

sfxge(4): support filters for encapsulated packets

This supports filters which match all unicast or multicast
inner frames in VXLAN, GENEVE, or NVGRE packets.
(Additional fields to match on can be added easily.)

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18073

5 years agoMFC r340802
Andrew Rybchenko [Fri, 21 Dec 2018 15:55:44 +0000 (15:55 +0000)]
MFC r340802

sfxge(4): use proper MCDI command for encap filters

MC_CMD_FILTER_OP_IN_EXT is needed to set filters for encapsulated
packets.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18072

5 years agoMFC r340801
Andrew Rybchenko [Fri, 21 Dec 2018 15:53:33 +0000 (15:53 +0000)]
MFC r340801

sfxge(4): provide information about supported tunnels

VXLAN/NVGRE (and Geneve) support is available on SFN8xxx with
full-feature firmware variant running.

Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18071

5 years agoMFC r340886
Andrew Rybchenko [Fri, 21 Dec 2018 15:15:07 +0000 (15:15 +0000)]
MFC r340886

sfxge(4): fix warnings from VS2015 C compiler (C4244)

Fix level 4 warning
"C4244: '+=': conversion from 'unsigned int' to 'uint16_t', possible
loss
of data"; no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18120

5 years agoMFC r340885
Andrew Rybchenko [Fri, 21 Dec 2018 15:13:59 +0000 (15:13 +0000)]
MFC r340885

sfxge(4): fix warnings from VS2015 C compiler (C4310)

Fix level 4 warning
"C4310: cast truncates constant value";
no functional changes.

Submitted by:   Andrew Lee <alee at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18119

5 years agoMFC r340884
Andrew Rybchenko [Fri, 21 Dec 2018 15:12:58 +0000 (15:12 +0000)]
MFC r340884

sfxge(4): fix probes in licensing support

EFSYS_PROBE1 takes one typed value (in addition to the probe name),
whereas EFSYS_PROBE has just the probe name.

Which to use is determined by the probe name - "fail1" probes are
expected to include the function result.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18118

5 years agoMFC r340883
Andrew Rybchenko [Fri, 21 Dec 2018 15:11:52 +0000 (15:11 +0000)]
MFC r340883

sfxge(4): fix diagnostics support build without Siena

The compilation failed because __efx_sram_pattern_fns was used in
efx_nic.c, but defined in efx_sram.c which is only needed when
supporting Siena.

To fix it move all the code using __efx_sram_pattern_fns into
Siena-specific files (except for the definition in efx_sram.c itself,
as that file only needs to be included in Siena-supporting builds
anyway).

The functions to test registers and tables are unlikely to apply to any
new hardware and so can be moved into Siena files. Since Huntington
such tests have been implemented in firmware.

Submitted by:   Mark Spender <mspender at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18117

5 years agoMFC r340875
Andrew Rybchenko [Fri, 21 Dec 2018 15:10:07 +0000 (15:10 +0000)]
MFC r340875

sfxge(4): fix build issue with PHY LED control enabled

Fixed build issue with the EFSYS_OPT_PHY_LED_CONTROL for Huntigton and
Medford.

Submitted by:   Vijay Srivastava <vijays at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18110

5 years agoMFC r340814
Andrew Rybchenko [Fri, 21 Dec 2018 15:08:14 +0000 (15:08 +0000)]
MFC r340814

sfxge(4): fix result code in MCDI NVRAM update finish

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18084

5 years agor340796
Andrew Rybchenko [Fri, 21 Dec 2018 15:06:54 +0000 (15:06 +0000)]
r340796

sfxge(4): fix failure path in EF10 Tx queue PIO enable

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18066

5 years agoMFC r340800
Andrew Rybchenko [Fri, 21 Dec 2018 15:05:56 +0000 (15:05 +0000)]
MFC r340800

sfxge(4): let caller know that queue is already flushed

Tx/Rx queue may be already flushed due to Tx/Rx error on the queue or
MC reboot. Caller needs to know that the queue is already flushed to
avoid waiting for flush done event.

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18070

5 years agor340798
Andrew Rybchenko [Fri, 21 Dec 2018 15:05:01 +0000 (15:05 +0000)]
r340798

sfxge(4): fix out of bounds read in VIs allocation

Submitted by:   Andy Moreton <amoreton at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.
Differential Revision:  https://reviews.freebsd.org/D18068