OPNsense - FreeBSD source
Find a file
Mitchell Horne 0a40193a6e busdma: fix page miscount for small segment sizes
For small segments (< PAGE_SIZE) there is a mismatch between how
required bounce pages are counted in _bus_dmamap_count_pages() and
bounce_bus_dmamap_load_buffer().

This problem has been observed on the RISC-V VisionFive v2 SoC (and
earlier revisions of the hardware) which has memory physically addressed
above 4GB. This requires some bouncing for the dwmmc driver, which has
has a maximum segment size of 2048 bytes. When attempting to load a
page-aligned 4-page buffer that requires bouncing, we can end up
counting 4 bounce pages for an 8-segment transfer. These pages will be
incorrectly configured to cover only the first half of the transfer (4 x
2048 bytes).

Fix the immediate issue by adding the maxsegsz check to
_bus_dmamap_count_pages(); this is what _bus_dmamap_count_phys() does
already. The result is that we will inefficiently allocate a separate
bounce page for each segment (8 pages for the example above), but the
transfer will proceed in its entirety.

The more complete fix is to address the shortcomings in how small
segments are assigned to bounce pages, so that we opportunistically
batch multiple segments to a page whenever they fit (e.g. two 2048 bytes
segments per 4096 page). This will be addressed more holistically in the
future. For now this change will prevent the (silent) incomplete
transfers that have been observed.

PR:		273694
Reported by:	Jari Sihvola <jsihv@gmx.com>
Sponsored by:	The FreeBSD Foundation
Differential Revision:	https://reviews.freebsd.org/D34118

(cherry picked from commit b134c10d65)
2024-04-18 15:09:02 -03:00
.cirrus-ci Cirrus-CI: add some timing info on pkg install failure 2021-08-04 15:02:00 -04:00
.github .github: Switch to v4 of actions/checkout 2024-04-08 11:03:05 -07:00
bin ln: Improve link(1) variant of ln(1). 2024-04-08 12:10:41 +02:00
cddl dtrace: allow NULL interface pointer for ifinfo_t translator 2024-04-17 15:45:40 +02:00
contrib tcpdump: cope with incorrect packet lengths 2024-04-18 15:35:52 +02:00
crypto ssh: Update to OpenSSH 9.7p1 2024-03-25 18:31:44 -04:00
etc dtrace: Add the 'oformat' libdtrace option 2024-04-15 10:05:13 -04:00
gnu Remove $FreeBSD$: one-line sh pattern 2023-08-16 11:55:03 -06:00
include posix_spawn(3): add POSIX_SPAWN_DISABLE_ASLR_NP 2024-03-11 02:25:58 +02:00
kerberos5 kerberos5: Mitigate the possibility of using an old libcrypto 2024-01-22 07:49:05 -08:00
lib libsecureboot do not report expected unverified files 2024-04-16 13:54:22 -06:00
libexec nuageinit: add basic support for cloudinit. 2024-04-11 13:52:52 +02:00
release release: Build dvd image before staging pkgs 2024-04-16 22:43:27 -07:00
rescue zfs: merge openzfs/zfs@32949f256 (zfs-2.2-release) into stable/14 2023-09-03 09:15:24 +02:00
sbin bsdlabel: emit deprecation notice when run 2024-04-18 10:05:01 -04:00
secure ossl: Move arm_arch.h to a common subdirectory 2024-03-29 09:53:05 -04:00
share sound: Implement asynchronous device detach 2024-04-18 14:39:31 +02:00
stand stand: Install gptboot.efi(8) 2024-04-16 13:54:30 -06:00
sys busdma: fix page miscount for small segment sizes 2024-04-18 15:09:02 -03:00
targets loader: add target for dirdeps build 2024-04-15 20:32:03 -06:00
tests ptrace tests: Fix a signed/unsigned integer comparison 2024-04-15 10:05:13 -04:00
tools loader: Add new option WITH_LOADER_BIOS_TEXTONLY 2024-04-16 13:54:25 -06:00
usr.bin dirdeps: Add missing dependency files 2024-04-15 20:32:03 -06:00
usr.sbin mergemaster: postpone removal to FreeBSD 15 2024-04-18 10:05:01 -04:00
.arcconfig arcanist: use FreeBSD/git project repository instead of FreeBSD/svn 2022-08-23 14:16:41 +00:00
.arclint
.cirrus.yml Cirrus-CI: Add manual Clang 18 jobs 2024-04-02 09:56:28 -04:00
.clang-format Remove $FreeBSD$: one-line sh pattern 2023-08-16 11:55:03 -06:00
.git-blame-ignore-revs git-blame-ignore-revs: OptionalObsoleteFiles.inc sorting commits 2023-12-02 00:56:40 +00:00
.gitattributes
.gitignore .gitignore: Ignore LSP generated .cache 2023-03-07 10:04:18 -05:00
CONTRIBUTING.md CONTRIBUTING.md: fix typo from commmit to commit 2024-03-22 09:30:30 -04:00
COPYRIGHT Happy New Year 2023! 2023-01-01 13:44:43 +08:00
LOCKS Remove $FreeBSD$: one-line bare tag 2023-08-16 11:55:20 -06:00
MAINTAINERS Remove $FreeBSD$: one-line bare tag 2023-08-16 11:55:20 -06:00
Makefile build: Order kernel-toolchain and buildkernel targets 2024-03-29 09:53:48 -04:00
Makefile.inc1 dtrace: Add the 'oformat' libdtrace option 2024-04-15 10:05:13 -04:00
Makefile.libcompat build{libcompat}: Pass UNIVERSE_TOOLCHAIN_PATH to the _lc_build-tools submake 2023-08-21 21:00:45 -07:00
Makefile.sys.inc Remove $FreeBSD$: one-line sh pattern 2023-08-16 11:55:03 -06:00
ObsoleteFiles.inc caroot: routine update 2024-02-13 13:14:51 -06:00
README.md README.md: link to the list of supported platforms 2022-11-01 12:20:55 -03:00
RELNOTES RELNOTES: document usbconfig(8) changes 2024-03-27 09:26:30 +01:00
UPDATING stand/lua: always allow overriding with local config files 2024-04-16 13:54:21 -06: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.

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.