]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/log
FreeBSD/FreeBSD.git
4 years agoregulator: Add regulator_check_voltage function
manu [Wed, 6 Nov 2019 14:55:24 +0000 (14:55 +0000)]
regulator: Add regulator_check_voltage function

This function will call the regnode_check_voltage method for a given regulator
and check if the desired voltage in reachable by it.
Also adds a default method that check the std_param and which should be enough
for most regulators and add it as the method for axp* rk805 and fixed regulators.

Reviewed by: mmel
MFC after: 1 month
Differential Revision: https://reviews.freebsd.org/D22260

4 years agoIPv6 tests: test case for scapy bpf parsing bug
bz [Wed, 6 Nov 2019 14:43:35 +0000 (14:43 +0000)]
IPv6 tests: test case for scapy bpf parsing bug

PR: 239380
Reported by: lwhsu, CI system
MFC after: 3 weeks
Sponsored by: Netflix

4 years agoipv6 tests: cleanup
bz [Wed, 6 Nov 2019 14:30:56 +0000 (14:30 +0000)]
ipv6 tests:  cleanup

Remove mentions of fragmentation tests from extension header test.
Remove setting an MTU > IF_MAXMTU from the test cases to avoid warnings;
this was only possible in a local research tree.

MFC after: 2 weeks
Sponsored by: Netflix

4 years agozstd: Add an Xlist and document use during import
cem [Wed, 6 Nov 2019 06:50:02 +0000 (06:50 +0000)]
zstd: Add an Xlist and document use during import

No functional change.

4 years agopowerpc/booke: Fix pmap_mapdev_attr() for multi-TLB1 entry mappings
jhibbits [Wed, 6 Nov 2019 04:40:12 +0000 (04:40 +0000)]
powerpc/booke: Fix pmap_mapdev_attr() for multi-TLB1 entry mappings

Also, fix pmap_change_attr() to ignore non-kernel mappings.

* Fix a masking bug in mmu_booke_mapdev_attr() which caused it to align
  mappings to the smallest mapping alignment, instead of the largest.  This
  caused mappings to be potentially pessimally aligned, using more TLB
  entries than necessary.
* Return existing mappings from mmu_booke_mapdev_attr() that span more than
  one TLB1 entry.  The drm-current-kmod drivers map discontiguous segments
  of the GPU, resulting in more than one TLB entry being used to satisfy the
  mapping.
* Ignore non-kernel mappings in mmu_booke_change_attr().  There's a bug in
  the linuxkpi layer that causes it to actually try to change physical
  address mappings, instead of virtual addresses.  amd64 doesn't encounter
  this because it ignores non-kernel mappings.

With this it's possible to use drm-current-kmod on Book-E.

4 years agofileargs_init() sets errno on failure.
markj [Wed, 6 Nov 2019 01:42:30 +0000 (01:42 +0000)]
fileargs_init() sets errno on failure.

Sponsored by: The FreeBSD Foundation

4 years agoSwitch cache zones from early counters to real implementation.
kib [Tue, 5 Nov 2019 21:38:48 +0000 (21:38 +0000)]
Switch cache zones from early counters to real implementation.

Early counter mock can be only used on BSP for amd64, when APs try to
update it that causes random memory corruption.

N.B.  This is a temporary patch to plug the corruption for now, while
a proper solution for handling cache zones in zone_foreach() is being
developed.

In collaboration with: pho
Reviewed by: markj
Sponsored by: The FreeBSD Foundation, Mellanox Technologies

4 years agoloader: clean up the noise around log device
tsoome [Tue, 5 Nov 2019 18:35:13 +0000 (18:35 +0000)]
loader: clean up the noise around log device

We are ignoring log device but we also do want to have clean code.

4 years agoloader: populate nvl with data even when label_txg is 0
tsoome [Tue, 5 Nov 2019 18:07:30 +0000 (18:07 +0000)]
loader: populate nvl with data even when label_txg is 0

We actually do not use that data, at least not now, but we want to
avoid possible surprises.

4 years agoTemporarily disable sys.netinet6.exthdr on i386
lwhsu [Tue, 5 Nov 2019 17:49:15 +0000 (17:49 +0000)]
Temporarily disable sys.netinet6.exthdr on i386

PR: 241493
Sponsored by: The FreeBSD Foundation

4 years agoRemove picobsd(8) via `make delete-old`
ngie [Tue, 5 Nov 2019 17:33:27 +0000 (17:33 +0000)]
Remove picobsd(8) via `make delete-old`

This completes the commit that removed picobsd(8) (r354346).

MFC after: never

4 years agoAdd vfs.zfs.zio.taskq_batch_pct tunable.
mav [Tue, 5 Nov 2019 15:19:05 +0000 (15:19 +0000)]
Add vfs.zfs.zio.taskq_batch_pct tunable.

MFC after: 1 week

4 years agofix up r354333, make zfsproc visible to dtrace, rename to system_proc
avg [Tue, 5 Nov 2019 14:34:59 +0000 (14:34 +0000)]
fix up r354333, make zfsproc visible to dtrace, rename to system_proc

I overlooked the fact that zfsproc is required by dtrace modules that
use illumos compatible taskq KPI.  So, move the symbol definition to
the opensolaris module that provides compatibility support for both ZFS
and DTrace.  Also, rename zfsproc to system_proc to reflect that it is
not specific to ZFS.

Reported by: ae
MFC after: 5 weeks
X-MFC with: ae

4 years agoip6 tests: Add very simplistic extension header tests
bz [Tue, 5 Nov 2019 10:59:33 +0000 (10:59 +0000)]
ip6 tests: Add very simplistic extension header tests

Add a simple test case which can exercise some of the IPv6 extension
header code paths.  At the moment only a small set of extension headers
is implemented and no options to the ones which take them.
Also implements a "bad" case to make sure that error handling works.

The tests were used to test m_pullup() changes to the code paths while
removing the KAME PULLDOWN_TEST cases and related macros.

MFC after: 3 weeks
Sponsored by: Netflix

4 years agofrag6 tests: set end to catch timeout as error
bz [Tue, 5 Nov 2019 10:53:55 +0000 (10:53 +0000)]
frag6 tests: set end to catch timeout as error

There are times when we have to wait for reply packets.  There are
either an ICMPv6 (error) reply or the expiration timeout.
In these cases synchonous ICMPv6 replies should arrive, always,
unless the packet is lost.  Due to errors experienced with the
test software sending an invlaid request on at least i386 (*) these
packets are not generated.  That means we are waiting for a long time
for the replies or even timeout the test case.

Manually set the "End" flag on these test cases as well, so they do
fail rather than timeout as the sniffer timeout happens.  This improves
debugging options, reflects the error properly, and saves time on each
test suit run.

(*) The real cause for that is still to be found (see the referenced PRs)

PR: 241493, 239380
MFC after: 2 weeks
Sponsored by: Netflix

4 years agoo OpenBSD 6.6 and FreeBSD 12.1 releases added.
maxim [Tue, 5 Nov 2019 08:53:40 +0000 (08:53 +0000)]
o OpenBSD 6.6 and FreeBSD 12.1 releases added.

4 years agoif_ixv: disable RSS configuration on 82599 and X540 VFs
avg [Tue, 5 Nov 2019 06:34:20 +0000 (06:34 +0000)]
if_ixv: disable RSS configuration on 82599 and X540 VFs

It is reported that those VFs share their RSS configuration with PF and,
thus, they cannot be configured independently.

Also:
- add missing opt_rss.h to if_ixv.c, otherwise RSS kernel option could
  not be seen
- do not enable IXGBE_FEATURE_RSS on the older VFs
- set flowid / hash type to M_HASHTYPE_NONE or M_HASHTYPE_OPAQUE_HASH
  (based on what the hardware reports) if IXGBE_FEATURE_RSS is not set

Reviewed by: nobody
MFC after: 4 weeks
Sponsored by: Panzura
Differential Revision: https://reviews.freebsd.org/D21705

4 years agoarmv6, armv7: Switch to llvm-libunwind by default
cem [Tue, 5 Nov 2019 03:22:15 +0000 (03:22 +0000)]
armv6, armv7: Switch to llvm-libunwind by default

This could just be ${__TT} == "arm", except armv5 isn't slated for death
until EOY.

arm tinderbox builds.  Let's see what else shakes out.

4 years agoFix llvm-libunwind userspace build on ARM
cem [Tue, 5 Nov 2019 03:20:40 +0000 (03:20 +0000)]
Fix llvm-libunwind userspace build on ARM

GCC's libgcc exports a few ARM-specific symbols for ARM EABI, AEABI, or
EHABI or whatever it's called.  Export the same ones from LLVM-libunwind's
libgcc_s, on ARM.  As part of this, convert libgcc_s from a direct
Version.map to one constructed from component Symbol.map files.  This allows
the ARM-specific Symbol.map to be included only on ARM.

Fix ARM-only oddities in struct name/aliases in LLVM-libunwind to match
non-ARM definitions and ARM-specific expectations in libcxxrt /
libcompiler_rt.

No functional change intended for non-ARM architectures.

This commit does not actually flip the switch for ARM defaults from libgcc
to llvm-libunwind, but makes it possible (to compile, anyway).

4 years agoRemove picobsd build scripts and the remaining tinyware
kevans [Tue, 5 Nov 2019 02:30:41 +0000 (02:30 +0000)]
Remove picobsd build scripts and the remaining tinyware

Postings were sent to -arch@ on 2019/09/13 and 2019/10/01, proposing and
confirming a removal of these scripts on 2019/10/31, due to significant work
needed to bring this into the modern world and nobody having done this work
in the past couple of years. No objections or proposed work was raised in
response to these postings. The tinyware may see a resurrection into a
separate repo for archival purposes if any users of it show interest in
doing so.

MFC after: never

4 years agonet: add ETHER_IS_ZERO macro similar to ETHER_IS_BROADCAST
erj [Tue, 5 Nov 2019 00:12:21 +0000 (00:12 +0000)]
net: add ETHER_IS_ZERO macro similar to ETHER_IS_BROADCAST

Some places in network code may need to verify that an ethernet address
is not the 'zero' address. Provide a standard macro ETHER_IS_ZERO for
this purpose, similar to the ETHER_IS_BROADCAST macro already available.

This patch also removes previous ETHER_IS_ZERO definitions in several
USB ethernet drivers, in favor of this centrally-located macro.

Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Submitted by: Jacob Keller <jacob.e.keller@intel.com>
Reviewed by: erj@
Sponsored by: Intel Corporation
Differential Revision: https://reviews.freebsd.org/D21240

4 years agoiflib: properly release memory allocated for DMA
erj [Mon, 4 Nov 2019 23:06:57 +0000 (23:06 +0000)]
iflib: properly release memory allocated for DMA

DMA memory allocations using the bus_dma.h interface are not properly
released in all cases for both Tx and Rx. This causes ~448 bytes of
M_DEVBUF allocations to be leaked.

First, the DMA maps for Rx are not properly destroyed. A slight attempt
is made in iflib_fl_bufs_free to destroy the maps if we're detaching.
However, this function may not be reliably called during detach. Indeed,
there is a comment "asking" if this should be moved out.

Fix this by moving the bus_dmamap_destroy call into iflib_rx_sds_free,
where we already sync and unload the DMA.

Second, the DMA tag associated with the ifr_ifdi descriptor DMA is not
released properly anywhere. Add a call to iflib_dma_free in
iflib_rx_structures_free.

Third, use of NULL as a canary value on the map pointer returned by
bus_dmamap_create is not valid. On some platforms, notably x86, this
value may be NULL. In this case, we fail to properly release the related
resources.

Remove the NULL checks on map values in both iflib_fl_bufs_free and
iflib_txsd_destroy.

With all of these fixes applied, the leaks to M_DEVBUF are squelched,
and iflib drivers now seem to properly cleanup when detaching.

Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Submitted by: Jacob Keller <jacob.e.keller@intel.com>
Reviewed by: erj@, gallatin@
MFC after: 1 week
Sponsored by: Intel Corporation
Differential Revision: https://reviews.freebsd.org/D22203

4 years agonet: prefer ETHER_ADDR_LEN over ETH_ADDR_LEN
erj [Mon, 4 Nov 2019 22:57:36 +0000 (22:57 +0000)]
net: prefer ETHER_ADDR_LEN over ETH_ADDR_LEN

A couple of drivers and one place in if.c use ETH_ADDR_LEN, even though
net/ethernet.h provides an equivalent ETHER_ADDR_LEN definition.

Cleanup all of the locations which refer to ETH_ADDR_LEN to use the
standard ETHER_ADDR_LEN instead.

Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Submitted by: Jacob Keller <jacob.e.keller@intel.com>
Reviewed by: erj@, jpaetzel@
Sponsored by: Intel Corporation
Differential Revision: https://reviews.freebsd.org/D21239

4 years agolibpmc: jevents: handle empty descriptoin
emaste [Mon, 4 Nov 2019 22:52:02 +0000 (22:52 +0000)]
libpmc: jevents: handle empty descriptoin

PR: 241258
Reported by: sigsys @ gmail.com
Obtained from: github.com/andikleen/pmu-tools commit bb3c77ed61
MFC after: 3 days

4 years agoarm64 linuxulator: default to RW stack (no X)
emaste [Mon, 4 Nov 2019 21:23:30 +0000 (21:23 +0000)]
arm64 linuxulator: default to RW stack (no X)

This matches Linux's default arm64 data / stack permissions.

MFC after: 1 week
Sponsored by: The FreeBSD Foundation

4 years agoRemove an outdated assertion.
brooks [Mon, 4 Nov 2019 21:06:06 +0000 (21:06 +0000)]
Remove an outdated assertion.

The exclusive lock assertion became incorrect due to changes in lock
scope in r354155.

Discussed with: jeffr
Sponsored by: DARPA, AFRL

4 years agoMerge commit 97e362607 from llvm git (by Nemanja Ivanovic):
dim [Mon, 4 Nov 2019 19:38:07 +0000 (19:38 +0000)]
Merge commit 97e362607 from llvm git (by Nemanja Ivanovic):

  [PowerPC] Do not emit HW loop if the body contains calls to
  lrint/lround

  These two intrinsics are lowered to calls so should prevent the
  formation of CTR loops. In a subsequent patch, we will handle all
  currently known intrinsics and prevent the formation of HW loops if
  any unknown intrinsics are encountered.

  Differential revision: https://reviews.llvm.org/D68841

This should fix an "invalid CRT loop" assertion when building the
www/node port for powerpc64.

Requested by: Alfredo Dal'Ava JĂșnior <alfredo.junior@eldorado.org.br>
MFC after: 1 month
X-MFC-With: r353358

4 years agoAdd tunable to allow interrupts on hyperthreaded cores
gallatin [Mon, 4 Nov 2019 19:30:19 +0000 (19:30 +0000)]
Add tunable to allow interrupts on hyperthreaded cores

Enabling interrupts on htt cores has benefits to workloads which are primarily
interrupt driven by increasing the logical cores available for interrupt handling.
The tunable is named machdep.hyperthreading_intr_allowed

Reviewed by: kib, jhb
Sponsored by: Netflix
Differential Revision: https://reviews.freebsd.org/D22233

4 years agoIn nd6_timer() enter the network epoch earlier. The defrouter_del() may
glebius [Mon, 4 Nov 2019 17:35:37 +0000 (17:35 +0000)]
In nd6_timer() enter the network epoch earlier.  The defrouter_del() may
call into leaf functions that require epoch.  Since the function is already
run in non-sleepable context, it should be safe to cover it whole with epoch.

Reported by: syzcaller

4 years agoEnable device class group attributes in the LinuxKPI.
hselasky [Mon, 4 Nov 2019 14:19:09 +0000 (14:19 +0000)]
Enable device class group attributes in the LinuxKPI.

Bump the __FreeBSD_version to force recompilation of
external kernel modules due to structure change.

Differential Revision: https://reviews.freebsd.org/D21564
Submitted by: Greg V <greg@unrelenting.technology>
MFC after: 1 week
Sponsored by: Mellanox Technologies

4 years agoDocument contrib updates:
cy [Mon, 4 Nov 2019 13:46:21 +0000 (13:46 +0000)]
Document contrib updates:

r354269:
sqlite3 is updated to sqlite3-3.30.1.

r351397:
WPA is updated from 2.8 to 2.9.

4 years agozfs: enable SPA_PROCESS on the kernel side
avg [Mon, 4 Nov 2019 13:30:37 +0000 (13:30 +0000)]
zfs: enable SPA_PROCESS on the kernel side

The purpose of this change is to group kernelthreads specific to a
particular ZFS pool under a kernel process.  There can be many dozens of
threads per pool.  This change improves observability of those threads.

This change consists of several subchanges:
1. illumos taskq_create_proc can now pass its process parameter to
taskqueue.  Also, use zfsproc instead of NULL for taskq_create.  Caveat:
zfsproc might not be initialized yet.  But in that case it is still NULL,
so not worse than before.

2. illumos sys/proc.h: kthread id is stored in t_did field, not t_tid.

3. zfs: enable SPA_PROCESS on the kernel side.  The change is a bit hairy
as newproc() is implemented privately to spa.c.  I couldn't think of a
better way to populate process name than to poke inside the argument for
the process routine.

4. illumos thread_create: allow assigning thread to process other than
zfsproc.

5. zfs: expose spa_proc to other users, assign sync and quiesce threads
to it.

Pool-specific threads created using (relatively new) zthr mechanism are
still assigned to the zfskern process rather than to a respective
zpool-xxx process.  I am going to address this a bit later.

Reviewed by: no one
MFC after: 5 weeks
Relnotes: perhaps
Differential Revision: https://reviews.freebsd.org/D9720

4 years agoloader: show APFS partition type name
tsoome [Mon, 4 Nov 2019 12:20:19 +0000 (12:20 +0000)]
loader: show APFS partition type name

Add small visual aid in lsdev output.

4 years agopatch(1): give /dev/null patches special treatment
kevans [Mon, 4 Nov 2019 03:07:01 +0000 (03:07 +0000)]
patch(1): give /dev/null patches special treatment

We have a bad habit of duplicating contents of files that are sourced from
/dev/null and applied more than once... take the more sane (in most ways)
GNU route and complain if the file exists and offer reversal options.

This still falls short a little bit as selecting "don't reverse, apply
anyway" will still give you duplicated file contents. There's probably other
issues as well, but awareness is the first step to happiness.

MFC after: 2 weeks
Differential Revision: https://reviews.freebsd.org/D21535

4 years ago[ig4] Try to workaround MIPS namespace pollution issue
wulf [Mon, 4 Nov 2019 02:29:58 +0000 (02:29 +0000)]
[ig4] Try to workaround MIPS namespace pollution issue

4 years agopowerpc/pmap: Make use of tlb1_mapin_region in pmap_mapdev_attr()
jhibbits [Mon, 4 Nov 2019 00:35:40 +0000 (00:35 +0000)]
powerpc/pmap: Make use of tlb1_mapin_region in pmap_mapdev_attr()

tlb1_mapin_region() and pmap_mapdev_attr() do roughly the same thing -- map
a chunk of physical address space(memory or MMIO) into virtual, but do it in
differing ways.  Unify the code, settling on pmap_mapdev_attr()'s algorithm,
to simplify and unify the logic.  This fixes a bug with growing the kernel
mappings in mmu_booke_bootstrap(), where part of the mapping was not getting
done, leading to a hang when the unmapped VAs were accessed.

4 years agoMove the struct debug_monitor_state out of _KERNEL.
andrew [Sun, 3 Nov 2019 22:17:49 +0000 (22:17 +0000)]
Move the struct debug_monitor_state out of _KERNEL.

Some userland libraries incude machine/pcb.h and this needs the full
definition of struct debug_monitor_state. To allow this to work move
stuct debug_monitor_state out of the _KERNEL guard.

Sponsored by: DARPA, AFRL

4 years agoloader: allow booting from pool with log device
tsoome [Sun, 3 Nov 2019 21:36:29 +0000 (21:36 +0000)]
loader: allow booting from pool with log device

Apparently people are using log with boot pool, so we can not just
error out there. Still we will need to investigate how to handle
log properly.

4 years agoloader: factor out label and uberblock load from vdev_probe, add MMP checks
tsoome [Sun, 3 Nov 2019 21:19:52 +0000 (21:19 +0000)]
loader: factor out label and uberblock load from vdev_probe, add MMP checks

Clean up the label read.

4 years ago[ig4] Convert ithread interrupt handler to filter based one.
wulf [Sun, 3 Nov 2019 21:17:50 +0000 (21:17 +0000)]
[ig4] Convert ithread interrupt handler to filter based one.

4 years ago[ig4] Enable additional registers support on Appolo Lake controllers
wulf [Sun, 3 Nov 2019 21:17:01 +0000 (21:17 +0000)]
[ig4] Enable additional registers support on Appolo Lake controllers

To be inline with intel-lpss Linux driver

4 years ago[ig4] Add support for CannonLake controllers
wulf [Sun, 3 Nov 2019 21:16:06 +0000 (21:16 +0000)]
[ig4] Add support for CannonLake controllers

They are clocked at 216MHz rate, much higher than previous models.

PR: 240485
Submitted by: Neel Chauhan <neel@neelc.org>

4 years ago[ig4] Add generic resource methods to bus interface
wulf [Sun, 3 Nov 2019 21:15:01 +0000 (21:15 +0000)]
[ig4] Add generic resource methods to bus interface

That allows ig4 children to allocate IRQs

4 years ago[ig4] Minor improvement of write pipelining
wulf [Sun, 3 Nov 2019 21:14:08 +0000 (21:14 +0000)]
[ig4] Minor improvement of write pipelining

With leaving some data queued in the TX FIFO at the end of write cycle.

4 years ago[ig4] wait for bus stop condition after stop command issued
wulf [Sun, 3 Nov 2019 21:12:59 +0000 (21:12 +0000)]
[ig4] wait for bus stop condition after stop command issued

It gives better error detection and ig4 driver's lock coverage
in a pipelined write case

4 years ago[ig4] On SkyLake controllers issue reset on attach unconditionally.
wulf [Sun, 3 Nov 2019 21:10:47 +0000 (21:10 +0000)]
[ig4] On SkyLake controllers issue reset on attach unconditionally.

It is very helpful during debugging of I2C issues.
It is done only for SkyLakes due to lack of testing on other hardware.

4 years ago[ig4] Set STOP condition and flush TX/RX FIFOs on error
wulf [Sun, 3 Nov 2019 21:08:26 +0000 (21:08 +0000)]
[ig4] Set STOP condition and flush TX/RX FIFOs on error

if controller has not it done for us yet.

Reset controller when transfer abort is failed.

4 years ago[ig4] Improve error detection
wulf [Sun, 3 Nov 2019 21:07:12 +0000 (21:07 +0000)]
[ig4] Improve error detection

Handle error bits of INTR_STAT and TX_ABORT registers.

Move interrupt clearing from interrupt handler to polling loop to get
common execution path with polled mode.

Do not clear interrupts with reading of IG4_REG_CLR_INTR register as
interrupts, triggered during the period from reg_read(IG4_REG_INTR_STAT)
to reg_read(IG4_REG_CLR_INTR) will be missed.
Instead, read each IG4_REG_CLR_* register separately.

4 years ago[ig4] Convert polling loop from status-based to interrupt-based
wulf [Sun, 3 Nov 2019 21:06:06 +0000 (21:06 +0000)]
[ig4] Convert polling loop from status-based to interrupt-based

INTR_STAT register exposes more useful informaton then STA register does
e.g. it exposes error and I2C bus STOP conditions. Make it a main source
of I2C transfer state.

4 years ago[ig4] Use interrupts for waiting for empty TX FIFO
wulf [Sun, 3 Nov 2019 21:04:51 +0000 (21:04 +0000)]
[ig4] Use interrupts for waiting for empty TX FIFO

4 years ago[ig4] Convert last remaining usage of TX_NOTFULL status to TX_EMPTY
wulf [Sun, 3 Nov 2019 21:03:55 +0000 (21:03 +0000)]
[ig4] Convert last remaining usage of TX_NOTFULL status to TX_EMPTY

in ig4iic_read routine. It makes possible interrupt utilization while
waiting for empty space in TX FIFO.

4 years ago[ig4] Rewrite ig4iic_write routine to use TX_EMPTY status flag
wulf [Sun, 3 Nov 2019 21:03:07 +0000 (21:03 +0000)]
[ig4] Rewrite ig4iic_write routine to use TX_EMPTY status flag

rather than TX_NOTFULL. It makes possible interrupt utilization while
waiting for empty space in TX FIFO.

4 years ago[ig4] Remove dead code inherited from DragonflyBSD
wulf [Sun, 3 Nov 2019 21:01:53 +0000 (21:01 +0000)]
[ig4] Remove dead code inherited from DragonflyBSD

4 years ago[ig4] Add suspend/resume support
wulf [Sun, 3 Nov 2019 21:00:55 +0000 (21:00 +0000)]
[ig4] Add suspend/resume support

That is done with re-execution of controller initialization procedure
from resume handler.

PR: 238037

4 years ago[ig4] Implement burst mode for data reads
wulf [Sun, 3 Nov 2019 20:59:04 +0000 (20:59 +0000)]
[ig4] Implement burst mode for data reads

In this mode DATA_CMD register reads and writes are performed in
TX/RX FIFO-sized bursts to increase I2C bus utilization.

That reduces read time from 60us to 30us per byte when read data is fit
in to RX FIFO buffer in FAST speed mode in my setup.

4 years ago[ig4] Set clock registers based on controller model
wulf [Sun, 3 Nov 2019 20:57:59 +0000 (20:57 +0000)]
[ig4] Set clock registers based on controller model

IC clock rates are varied between different controller models so we have
to adjust timing registers in each case individually. Borrow intresting
constants and formulas from Intel specs, i2c-designware and lpss_intel
drivers and apply them to FreeBSD supported controller models.

Implement fetching of timing data via ACPI methods execution if available.

4 years ago[ig4] dump IG4_REG_COMP_PARAM1 and IG4_REG_COMP_VER registers unconditionally
wulf [Sun, 3 Nov 2019 20:56:53 +0000 (20:56 +0000)]
[ig4] dump IG4_REG_COMP_PARAM1 and IG4_REG_COMP_VER registers unconditionally

They appeared to be supported (although undocumented) on SkyLakes+ too.

4 years ago[cyapa] Postpone start of the polling thread until sleep is available
wulf [Sun, 3 Nov 2019 20:55:28 +0000 (20:55 +0000)]
[cyapa] Postpone start of the polling thread until sleep is available

After recent ig4 changes cyapa driver can be attached before timers
initialization is completed. Start polling thread from config_intrhook
to avoid busy loops in that case.

4 years ago[ig4] Do not wait until interrupts are enabled at attach stage
wulf [Sun, 3 Nov 2019 20:54:17 +0000 (20:54 +0000)]
[ig4] Do not wait until interrupts are enabled at attach stage

as the driver is fully functional on a cold boot through utilization of
polled mode.

As a side effect, ig4 children probe and attach methods can be called
earlier in the boot sequence, so now it is up to the child drivers
to wait for a kernel initialization completion if it is required.

4 years ago[ig4] Allow enabling of polled mode from iicbus allocation callback
wulf [Sun, 3 Nov 2019 20:53:13 +0000 (20:53 +0000)]
[ig4] Allow enabling of polled mode from iicbus allocation callback

If controller is allocated with IIC_NOWAIT option ig4 enables polled mode
for a period of allocation that makes possible to start I2C transfers
from the contexts where sleeping is not allowed e.g. from ithreads or
callouts.

4 years ago[ig4] Add support for polled mode
wulf [Sun, 3 Nov 2019 20:51:22 +0000 (20:51 +0000)]
[ig4] Add support for polled mode

Currently ig4 internally depends on it's own interrupts and uses mtx_sleep()
to wait for them. That means it can not be used from any context where
sleeping is disallowed e.g. on cold boot, from DDB/KDB, from other device
driver's interrupt handlers and so on.

This change replaces sleeps with busy loops in cold boot and DDB cases.

4 years ago[ig4] disable controller before initialization of clock counters
wulf [Sun, 3 Nov 2019 20:50:06 +0000 (20:50 +0000)]
[ig4] disable controller before initialization of clock counters

It is required by controller specifications.

4 years ago[ig4] Stop I2C controller after checking that it's kind of functional.
wulf [Sun, 3 Nov 2019 20:49:04 +0000 (20:49 +0000)]
[ig4] Stop I2C controller after checking that it's kind of functional.

Obtained from: DragonfliBSD (0b3eedb)

4 years ago[ig4] We actually need to set the Rx threshold register one smaller.
wulf [Sun, 3 Nov 2019 20:47:49 +0000 (20:47 +0000)]
[ig4] We actually need to set the Rx threshold register one smaller.

Setting the IG4_REG_RX_TL register to 1 was actually generating an
interrupt after 2 bytes were available in the Rx fifo. We need to set the
register to 0 to get an interrupt for 1 byte already.

Obtained from: DragonflyBSD (02f0bf2)

4 years ago[ig4] Ignore stray interrupts
wulf [Sun, 3 Nov 2019 20:46:20 +0000 (20:46 +0000)]
[ig4] Ignore stray interrupts

4 years ago[ig4] Reduce scope of io_lock
wulf [Sun, 3 Nov 2019 20:45:25 +0000 (20:45 +0000)]
[ig4] Reduce scope of io_lock

Now io_lock is used as condition variable to synchronize active process with
the interrupt handler. It is not used for tasks other than waiting for
interrupt and passing parameters to and from it's handler.

4 years ago[ig4] Do not wait for interrupts in set_controller() routine
wulf [Sun, 3 Nov 2019 20:44:16 +0000 (20:44 +0000)]
[ig4] Do not wait for interrupts in set_controller() routine

Specs shows no dedicated interrupt firing on disable of the controller.

Remove io lock acquisitions around set_controller() calls as they are
not needed anymore.

4 years ago[ig4] Drop driver's internal RX FIFO
wulf [Sun, 3 Nov 2019 20:43:02 +0000 (20:43 +0000)]
[ig4] Drop driver's internal RX FIFO

There is no need to read all controller's RX FIFO data to clear RX_FULL
bit in interrupt handler as interrupts are masked permanently since
previous commit.

4 years ago[ig4] Only enable interrupts when we want them. Otherwise keep mask at 0.
wulf [Sun, 3 Nov 2019 20:42:04 +0000 (20:42 +0000)]
[ig4] Only enable interrupts when we want them. Otherwise keep mask at 0.

This avoids possible interrupt storms, depending on the state of the I2C
controller before the driver attached.

During attaching this clears the interrupt mask.

Revert r338215 as this change makes it no-op.

Obtained from: DragonflyBSD (d7c8555)

4 years ago[ig4] Handle controller startup errors
wulf [Sun, 3 Nov 2019 20:40:55 +0000 (20:40 +0000)]
[ig4] Handle controller startup errors

Fail the attach on controller startup errors.  For some reason the
dell xps 13 says there's I2C controller, but the controller appears
to be permanente disabled and will refuse to enable.

Obtained from: DragonflyBSD (509820b)

4 years ago[ig4] Give common name to PCI and ACPI device drivers
wulf [Sun, 3 Nov 2019 20:39:46 +0000 (20:39 +0000)]
[ig4] Give common name to PCI and ACPI device drivers

They share common device driver code with different bus attachments

This commit starts a bunch of changes which have following properties:

Reviewed by: imp (previous version)
MFC after: 1 month
Differential Revision: https://reviews.freebsd.org/D22016

4 years agoTake arm.arm (armv5) out of universe
cem [Sun, 3 Nov 2019 19:36:34 +0000 (19:36 +0000)]
Take arm.arm (armv5) out of universe

It's on the chopping block in two months, the CI tinderbox doesn't bother with
it anymore either, and buildworld fails today due to an issue linking clang.
It's not worth investigating and it just eats up CPU cycles running universe
builds.

4 years agoarmv6: Switch to LLD by default
cem [Sun, 3 Nov 2019 19:33:49 +0000 (19:33 +0000)]
armv6: Switch to LLD by default

This could just be ${__TT} == "arm", except armv5 isn't slated for death until
EOY.

arm tinderbox builds.  Let's see what else shakes out.

4 years agobhyve: add backend rx backpressure to virtio-net
vmaffione [Sun, 3 Nov 2019 19:02:32 +0000 (19:02 +0000)]
bhyve: add backend rx backpressure to virtio-net

If a VM is flooded with more ingress packets than the guest OS
can handle, the current virtio-net code will keep reading those
packets and drop most of them as no space is available in the
receive queue. This is an undesirable receive livelock, which
is a waste of CPU and memory resources and potentially opens to
DoS attacks.
With this change, virtio-net uses the new netbe_rx_disable()
function to disable ingress operation in the backend while the
guest is short on RX buffers. Once the guest makes more buffers
available to the RX virtqueue, ingress operation is enabled again
by calling netbe_rx_enable().

Reviewed by: bryanv, jhb
MFC after: 2 weeks
Differential Revision: https://reviews.freebsd.org/D20987

4 years agobhyve: fix mistake introduced by r352841
vmaffione [Sun, 3 Nov 2019 18:53:42 +0000 (18:53 +0000)]
bhyve: fix mistake introduced by r352841

MFC after: 1 week
Differential Revision: https://reviews.freebsd.org/D20973

4 years agoUtilize ASIDs to reduce both the direct and indirect costs of context
alc [Sun, 3 Nov 2019 17:45:30 +0000 (17:45 +0000)]
Utilize ASIDs to reduce both the direct and indirect costs of context
switching.  The indirect costs being unnecessary TLB misses that are
incurred when ASIDs are not used.  In fact, currently, when we perform a
context switch on one processor, we issue a broadcast TLB invalidation that
flushes the TLB contents on every processor.

Mark all user-space ("ttbr0") page table entries with the non-global flag so
that they are cached in the TLB under their ASID.

Correct an error in pmap_pinit0().  The pointer to the root of the page
table was being initialized to the root of the kernel-space page table
rather than a user-space page table.  However, the root of the page table
that was being cached in process 0's md_l0addr field correctly pointed to a
user-space page table.  As long as ASIDs weren't being used, this was
harmless, except that it led to some unnecessary page table switches in
pmap_switch().  Specifically, other kernel processes besides process 0 would
have their md_l0addr field set to the root of the kernel-space page table,
and so pmap_switch() would actually change page tables when switching
between process 0 and other kernel processes.

Implement a workaround for Cavium erratum 27456 affecting ThunderX machines.
(I would like to thank andrew@ for providing the code to detect the affected
machines.)

Address integer overflow in the definition of TCR_ASID_16.

Setup TCR according to the PARange and ASIDBits fields from
ID_AA64MMFR0_EL1.  Previously, TCR_ASID_16 was unconditionally set.

Modify build_l1_block_pagetable so that lower attributes, such as ATTR_nG,
can be specified as a parameter.

Eliminate some unused code.

Earlier versions were tested to varying degrees by: andrew, emaste, markj

MFC after: 3 weeks
Differential Revision: https://reviews.freebsd.org/D21922

4 years agoAdd support for setting hardware breakpoints from ptrace on arm64.
andrew [Sun, 3 Nov 2019 15:42:08 +0000 (15:42 +0000)]
Add support for setting hardware breakpoints from ptrace on arm64.

Implement get/fill_dbregs on arm64. This is used by ptrace with the
PT_GETDBREGS and PT_SETDBREGS requests. It allows userspace to set hardware
breakpoints.

The struct dbreg is based on Linux to ease adding hardware breakpoint
support to debuggers.

Reviewed by: jhb
Sponsored by: DARPA, AFRL
Differential Revision: https://reviews.freebsd.org/D22195

4 years agoloader: zfs.c is missing malloc checks, fix it
tsoome [Sun, 3 Nov 2019 14:36:16 +0000 (14:36 +0000)]
loader: zfs.c is missing malloc checks, fix it

malloc() can return NULL, we need to check the return value.

4 years agoloader: we do not support booting from pool with log device
tsoome [Sun, 3 Nov 2019 13:25:47 +0000 (13:25 +0000)]
loader: we do not support booting from pool with log device

If pool has log device, stop there and tell about it.

4 years agoloader: should check malloc in zfs_dev_open
tsoome [Sun, 3 Nov 2019 13:03:47 +0000 (13:03 +0000)]
loader: should check malloc in zfs_dev_open

malloc can return NULL.

4 years agoamd64: Store %cr3 into pcpu saved_ucr3 on double fault.
kib [Sun, 3 Nov 2019 11:52:50 +0000 (11:52 +0000)]
amd64: Store %cr3 into pcpu saved_ucr3 on double fault.

Tested by: pho
Sponsored by: The FreeBSD Foundation
MFC after: 1 week

4 years agoamd64 ddb: Add printing of kernel/user and saved user %cr3 values from pcpu.
kib [Sun, 3 Nov 2019 11:51:53 +0000 (11:51 +0000)]
amd64 ddb: Add printing of kernel/user and saved user %cr3 values from pcpu.

Tested by: pho
Sponsored by: The FreeBSD Foundation
MFC after: 1 week

4 years agoloader: calculate physical vdev psize from asize
tsoome [Sun, 3 Nov 2019 11:09:06 +0000 (11:09 +0000)]
loader: calculate physical vdev psize from asize

Since physical device asize is calculated from psize and the asize is stored
in pool label, we can use asize to set the value of psize, which is used to
calculate the location of the pool labels.

MFC after: 1 week

4 years agoloader: userboot/test should accept more than one disk
tsoome [Sun, 3 Nov 2019 09:14:29 +0000 (09:14 +0000)]
loader: userboot/test should accept more than one disk

allow to specify multiple -d options, test -d disk1 -d disk2 ..

4 years agoDowngrade the firmware images imported in r354201.
markj [Sun, 3 Nov 2019 03:23:27 +0000 (03:23 +0000)]
Downgrade the firmware images imported in r354201.

Version 43 requires further modifications to iwm(4), and this was not
caught in some initial testing.  Version 34 works and is the version
available on Intel's web site.

MFC with: r354201
Sponsored by: The FreeBSD Foundation

4 years agopowerpc: Add display of raw instruction values to x/I in ddb.
bdragon [Sun, 3 Nov 2019 02:18:45 +0000 (02:18 +0000)]
powerpc: Add display of raw instruction values to x/I in ddb.

The "alternate format" character 'I' previously had the same behavior as
the "display as an instruction" character 'i'. With this change, it will now
prefix each disassembled instruction with the raw hex value.

As PowerPC instructions are always 32 bits and always aligned, and there are
no alternate modes that would affect instruction decoding or display, this
seemed to me to be the obvious interpretation of "alternate format".

Approved by: jhibbits (mentor)
Differential Revision: https://reviews.freebsd.org/D22223

4 years agopowerpc: Fix incorrect disassembly of the cntlzw instruction in ddb.
bdragon [Sun, 3 Nov 2019 01:52:50 +0000 (01:52 +0000)]
powerpc: Fix incorrect disassembly of the cntlzw instruction in ddb.

Noticed while comparing disassembly between ddb and objdump.

Approved by: jhibbits (mentor)
Differential Revision: https://reviews.freebsd.org/D22121

4 years agoMFV r354257:
cy [Sun, 3 Nov 2019 01:25:46 +0000 (01:25 +0000)]
MFV r354257:

Update sqlite3-3.29.0 (3290000) --> sqlite3-3.30.1 (3300100)

MFC after: 1 month

4 years agoRemove lock from CTL camsim frontend.
mav [Sun, 3 Nov 2019 00:13:23 +0000 (00:13 +0000)]
Remove lock from CTL camsim frontend.

CAM does not need a SIM lock for quite a while, and CTL never needed it.

MFC after: 2 weeks

4 years agor354264 did mix up the directory path
tsoome [Sat, 2 Nov 2019 21:52:45 +0000 (21:52 +0000)]
r354264 did mix up the directory path

The correct path is sys/cddl/contrib/opensolaris/common/lz4, not
sys/cddl/contrib/opensolaris/lz4

Reported by: Michael Butler

4 years agoAdd support for building Book-E kernels with clang/lld.
bdragon [Sat, 2 Nov 2019 21:15:56 +0000 (21:15 +0000)]
Add support for building Book-E kernels with clang/lld.

This involved several changes:

* Since lld does not like text relocations, replace SMP boot page text relocs
in booke/locore.S with position-independent math, and track the virtual base
in the SMP boot page header.

* As some SPRs are interpreted differently on clang due to the way it handles
platform-specific SPRs, switch m*dear and m*esr mnemonics out for regular
m*spr. Add both forms of SPR_DEAR to spr.h so the correct encoding is selected.

* Change some hardcoded 32 bit things in the boot page to be pointer-sized, and
fix alignment.

* Fix 64-bit build of booke/pmap.c when enabling pmap debugging.

Additionally, I took the opportunity to document how the SMP boot page works.

Approved by: jhibbits (mentor)
Differential Revision: https://reviews.freebsd.org/D21999

4 years agor354253 did miss the fact that libzpool is built as fake kernel
tsoome [Sat, 2 Nov 2019 21:02:54 +0000 (21:02 +0000)]
r354253 did miss the fact that libzpool is built as fake kernel

We build libzpool as kernel like, use _FAKE_KERNEL check to include
kernel api in libzpool.

4 years agor354253 did miss the updates to sys/conf/files and sys/conf/kern.pre.mk
tsoome [Sat, 2 Nov 2019 20:46:45 +0000 (20:46 +0000)]
r354253 did miss the updates to sys/conf/files and sys/conf/kern.pre.mk

Reported by: Brandon Bergren

4 years agoRISC-V: Remove EARLY_AP_STARTUP from GENERIC
mhorne [Sat, 2 Nov 2019 19:33:02 +0000 (19:33 +0000)]
RISC-V: Remove EARLY_AP_STARTUP from GENERIC

This option is causing boot to fail for the Hifive Unleashed and older
versions of QEMU (3.1.1). Remove it from the GENERIC config for now.

Reported by: br
MFC after: 1 week

4 years agoAdd __isnan()/__isnanf() aliases for compatibility with glibc and CUDA
dim [Sat, 2 Nov 2019 16:59:53 +0000 (16:59 +0000)]
Add __isnan()/__isnanf() aliases for compatibility with glibc and CUDA

Even though clang comes with a number of internal CUDA wrapper headers,
compiling sample CUDA programs will result in errors similar to:

In file included from <built-in>:1:
In file included from /usr/lib/clang/9.0.0/include/__clang_cuda_runtime_wrapper.h:204:
/usr/home/arr/cuda/var/cuda-repo-10-0-local-10.0.130-410.48/usr/local/cuda-10.0//include/crt/math_functions.hpp:2910:7: error: no matching function for call to '__isnan'
  if (__isnan(a)) {
      ^~~~~~~
/usr/lib/clang/9.0.0/include/__clang_cuda_device_functions.h:460:16: note: candidate function not viable: call to __device__ function from __host__ function
__DEVICE__ int __isnan(double __a) { return __nv_isnand(__a); }
               ^

CUDA expects __isnan() and __isnanf() declarations to be available,
which are glibc specific extensions, equivalent to the regular isnan()
and isnanf().

To provide these, define __isnan() and __isnanf() as aliases of the
already existing static inline functions __inline_isnan() and
__inline_isnanf() from math.h.

Reported by: arrowd
PR: 241550
MFC after: 1 week

4 years agor354253 did miss lz4.c from sys/cddl/boot/zfs.
tsoome [Sat, 2 Nov 2019 15:08:19 +0000 (15:08 +0000)]
r354253 did miss lz4.c from sys/cddl/boot/zfs.

4 years agoRemove duplicate lz4 implementations
tsoome [Sat, 2 Nov 2019 12:28:04 +0000 (12:28 +0000)]
Remove duplicate lz4 implementations

Port illumos change: https://www.illumos.org/issues/11667

Move lz4.c out of zfs tree to opensolaris/common/lz4, adjust it to be
usable from kernel/stand/userland builds, so we can use just one single
source. Add lz4.h to declare lz4_compress() and lz4_decompress().

MFC after: 1 month
Differential Revision: https://reviews.freebsd.org/D22037

4 years agoloader: libi386/comconsole.c cstyle cleanup
tsoome [Sat, 2 Nov 2019 10:53:23 +0000 (10:53 +0000)]
loader: libi386/comconsole.c cstyle cleanup

Only cstyle, no functional changes.

4 years agoIf /usr/obj is a symlink, cpio(1) needs persuation to DTRT.
phk [Sat, 2 Nov 2019 10:15:34 +0000 (10:15 +0000)]
If /usr/obj is a symlink, cpio(1) needs persuation to DTRT.

4 years agoMention that ports/net-mgmt/libsmi is required
phk [Sat, 2 Nov 2019 10:14:15 +0000 (10:14 +0000)]
Mention that ports/net-mgmt/libsmi is required