OPNsense - FreeBSD source
Find a file
Warner Losh f8de2be7d9 cam/da: Call cam_periph_invalidate on ENXIO in dadone
Use cam_periph_invalidate() instead of just setting the PACK_INVALID
flag in the da softc. It's a more appropriate and bigger hammer for this
case. PACK_INVALID is set as part of that, so remove the now-redundant
setting. This also has the side effect of short-circuiting errors for
other I/O still in the drive which is just about to fail (sometimes with
different error codes than what triggered this ENXIO).

The prior practice of just setting the PACK_INVALID flag, however, was
too ephemeral to be effective.. Since daopen would clear PACK_INVALID
after a successful open, we'd have to rediscover the error (which takes
tens of seconds) for every different geom tasting the drive. These two
factors lead to a watchdog before we could get through all the devices
if we had multiple failed drives with this syndrome. By invalidating the
periph, we fail fast enough to reboot enough to start petting the
watchdog. If we disable the watchdog, the tasting eventually completes,
but takes over an hour which is too long. As it is, it takes an extra
minute per failed drive, which is tolerable.

When the PACK_INVALID flag is already set, just flush remaining I/Os
with ENXIO. This bit will be set either when we've called
cam_periph_invalidate() before (so we've just waiting for the I/Os to
complete) or more typically when we've seen an ASC 0x3a, which is the
catch all for 'drive is otherwise OK, we're just missing the media to
get data from'. In the latter case, we do not want to invalidate the
periph since we allow recovery from this with a trip through daopen().

While cam_periph_error's asc/ascq tables have a SSQ_LOST flag for
failing the entire drive, I've opted not to use that. That flag will
also causes all attached drivers, like pass, to detach, which is
undesireable. By not adding that flag, but just invalidating the da
periph driver, we prevent I/Os, but still allow collection of logs from
the device.

We can also simplify the logic w/o bloating the change, so do that too.

Finally, this has been tested on all the removeable/non-removeable disks
I could find, cd players, combo cd/da memory sticks, etc. I've removed
the media while doing I/O on several of them. With these changes, we
handle things corretly in all the cases I tested (except partially
inserted media, which fails chaotically the same as before). The numbre
of devices out there is, however, huge.

mav@ raised concerns about what happens when we have asc/ascq 28/0.  I
see that on boot for one of my cards (that's not autoquirked) and as
preditected in the review, we retry that transaction and we get proper
behavior. To be fair, though, I only ever saw it at startup where it was
a transient. I couldn't get some of my energy saving disks to ever throw
that ASC/ASCQ, even after they spun down, so I've not tested that case.

Sponsored by:		Netflix
Discussed with:		mav@
Differential Revision:	https://reviews.freebsd.org/D48689
2025-02-08 14:31:14 -07:00
.cirrus-ci Cirrus-CI: add some timing info on pkg install failure 2021-08-04 15:02:00 -04:00
.github github: Add new checklist workflow 2025-01-24 15:27:08 -05:00
bin ls: --group-directories requires stat information 2025-01-22 08:29:29 +01:00
cddl libdtrace: Use designators to initialize the opcode array 2025-01-29 00:59:21 +00:00
contrib mdoc.7/MANUAL STRUCTURE: add HARDWARE 2025-02-07 11:47:14 -07:00
crypto Add 'crypto/libecc/' from commit '736d663976d1768533badbf06581481d01fade4c' 2025-01-01 15:11:18 -06:00
etc mtree: Add missing flua/freebsd/sys entry 2025-02-05 19:53:23 +00:00
gnu Remove residual blank line at start of Makefile 2024-07-15 16:43:39 -06:00
include rpc: limited multithread support for svc_nl 2025-02-01 01:00:28 -08:00
kerberos5 Remove residual blank line at start of Makefile 2024-07-15 16:43:39 -06:00
lib libvmmapi: Fix auto-loading of vmm.ko 2025-02-06 16:25:42 +00:00
libexec rc.d/iovctl: Start the iovctl service after kld. 2025-02-07 12:17:32 -08:00
release release: Chase location of pkg repo databases 2025-02-03 16:10:47 -08:00
rescue nvmf: Switch several ioctls to using nvlists 2024-12-30 13:52:21 -05:00
sbin pfctl: Show which limit cannot be set. 2025-02-06 15:00:05 +01:00
secure secure: hook up libecc as libpkgecc 2025-01-01 15:11:22 -06:00
share mtw.4: Fix a couple of nits 2025-02-07 19:50:12 +00:00
stand stand: Use SOURCE_DATE_EPOCH in newvers.sh 2025-02-03 15:58:32 -08:00
sys cam/da: Call cam_periph_invalidate on ENXIO in dadone 2025-02-08 14:31:14 -07:00
targets gvinum(8): Remove userland tool for managing vinum volumes 2025-01-23 11:20:43 -05:00
tests vmm tests: Check for /dev/vmmctl to decide if vmm is initialized 2025-02-08 16:05:37 +00:00
tools tools: Add a small program to demonstrate FIB handling in bind(2) 2025-02-06 16:25:31 +00:00
usr.bin genl: fix printing of a command with zero capabilities 2025-02-04 11:52:35 -08:00
usr.sbin ctladm: Use nvlist instead of home-rolled name-value lists 2025-02-05 14:55:16 -05:00
.arcconfig arcanist: use FreeBSD/git project repository instead of FreeBSD/svn 2022-08-23 14:16:41 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml .cirrus-ci: Update the non-manual GCC build job to GCC 13 2025-01-03 10:44:44 -05:00
.clang-format clang-format: Minor tweaks 2024-04-30 17:33:43 -04:00
.git-blame-ignore-revs git-blame-ignore-revs: list rtld-elf reformatting 2025-01-21 03:57:21 +02:00
.gitattributes Remove SVN related Git attributes 2023-12-26 10:28:28 -07:00
.gitignore Import libecc v0.9.7 2024-12-16 22:18:42 -06:00
.mailmap mailmap: Translate my personal address 2024-06-22 08:57:56 +02:00
CONTRIBUTING.md CONTRIBUTING.md/style: spring cleaning 2024-05-10 15:07:03 -06:00
COPYRIGHT copyright: Happy New Year 2025 2025-01-01 00:04:28 +00:00
LOCKS Update LOCKS for Git 2023-12-26 10:28:25 -07:00
MAINTAINERS man filesystems: fix more xrefs after move to s4 2024-06-27 18:32:05 -06:00
Makefile Import bmake-20250125 2025-01-30 15:38:13 -08:00
Makefile.inc1 mtree: TESTSBASE directory always starts with a / 2025-01-24 23:10:05 +00:00
Makefile.libcompat Remove residual blank line at start of Makefile 2024-07-15 16:43:39 -06:00
Makefile.sys.inc Remove $FreeBSD$: one-line sh pattern 2023-08-16 11:55:03 -06:00
ObsoleteFiles.inc bus_generic_attach.9: Remove manpage for deprecated function 2025-02-05 14:48:16 -05:00
README.md Import libecc v0.9.7 2024-12-16 22:18:42 -06:00
RELNOTES RELNOTES: Add an entry for the new bind_all_fibs tunables 2025-02-06 16:25:42 +00:00
UPDATING Add notes for handling the January 19, 2038 date limit in UFS1 filesystems 2025-02-01 10:59:26 -08:00

FreeBSD Source:

This is the top level of the FreeBSD source directory.

FreeBSD is an operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.

For copyright information, please see the file COPYRIGHT in this directory. Additional copyright information also exists for some sources in this tree - please see the specific source directories for more information.

The Makefile in this directory supports a number of targets for building components (or all) of the FreeBSD source tree. See build(7), config(8), FreeBSD handbook on building userland, and Handbook for kernels for more information, including setting make(1) variables.

For information on the CPU architectures and platforms supported by FreeBSD, see the FreeBSD website's Platforms page.

For official FreeBSD bootable images, see the release page.

Source Roadmap:

Directory Description
bin System/user commands.
cddl Various commands and libraries under the Common Development and Distribution License.
contrib Packages contributed by 3rd parties.
crypto Cryptography stuff (see crypto/README).
etc Template files for /etc.
gnu Commands and libraries under the GNU General Public License (GPL) or Lesser General Public License (LGPL). Please see gnu/COPYING and gnu/COPYING.LIB for more information.
include System include files.
kerberos5 Kerberos5 (Heimdal) package.
lib System libraries.
libexec System daemons.
release Release building Makefile & associated tools.
rescue Build system for statically linked /rescue utilities.
sbin System commands.
secure Cryptographic libraries and commands.
share Shared resources.
stand Boot loader sources.
sys Kernel sources (see sys/README.md).
targets Support for experimental DIRDEPS_BUILD
tests Regression tests which can be run by Kyua. See tests/README for additional information.
tools Utilities for regression testing and miscellaneous tasks.
usr.bin User commands.
usr.sbin System administration commands.

For information on synchronizing your source tree with one or more of the FreeBSD Project's development branches, please see FreeBSD Handbook.