FreeBSD/src bebe2fesecure ssh.mk

openssh: Request the OpenSSL 1.1 API

Upstream OpenSSH commit f51423bda ("request 1.1x API compatibility for
OpenSSL >=3.x") requests OPENSSL_API_COMPAT version 0x10100000L (OpenSSL
1.1.0), in order to avoid warnings about deprecated functions.

Do the same here, to avoid getting those warnings.

Reviewed by:    emaste
Approved by:    emaste (mentor)
MFC after:      1 week
Differential Revision:  https://reviews.freebsd.org/D49517

(cherry picked from commit d4f438357e90ee1cb12819d092913fdbce813626)
DeltaFile
+2-0secure/ssh.mk
+2-01 files

FreeBSD/src b847e40sys/dev/mii mcommphy.c miidevs

Revert "mccomphy: add support for YT8531"

The new code makes use of FDT/OFW types and interfaces, and obviously
fails to build on amd64. Revert to fix.

Pointy-hat-to: mhorne

This reverts commit e69623451ea62d2c3c76e0d0e775aa3f7317f2eb.
DeltaFile
+25-233sys/dev/mii/mcommphy.c
+0-2sys/dev/mii/miidevs
+25-2352 files

FreeBSD/src 0a91888sys/arm64/apple apple_pinctrl.c, sys/conf files.arm64

arm64: add a GPIO driver for Apple Silicon

This is a ported version of OpenBSD's work, modulo interrupt
functionality.  We won't need GPIO interrupts until we start to get
closer to audio support, and the existing version is sufficient for,
e.g., pcie.

Reviewed by:    andrew
Differential Revision:  https://reviews.freebsd.org/D49630
DeltaFile
+469-0sys/arm64/apple/apple_pinctrl.c
+1-0sys/conf/files.arm64
+470-02 files

FreeBSD/src d0b59c4sys/kern vfs_syscalls.c

kern_mkdirat(): unconditionally provide the out label

Needed for the MAC-less kernel configs.

Fixes:  2ec2ba7e232dd126df0617194fd07be78c7a2ab9
Sponsored by:   The FreeBSD Foundation
DeltaFile
+0-2sys/kern/vfs_syscalls.c
+0-21 files

FreeBSD/src 6441407sys/sys vnode.h

vnode.h: Delete VA_NAMEDATTR_TYPE

Commit 2ec2ba7e232d added a new va_vaflags called VA_NAMEDATTR_TYPE.
This is not needed, since a new flag will be committed by D49651
when it is committed.

This patch reverts the definition of this flag value.

Discussed with: kib
DeltaFile
+3-4sys/sys/vnode.h
+3-41 files

FreeBSD/src 2ec2ba7sys/kern vfs_syscalls.c vfs_vnops.c, sys/sys vnode.h namei.h

vfs: Add VFS/syscall support for Solaris style extended attributes

Some systems, such as Solaris, represent extended attributes as
a set of files in a directory associated with a file object.  This
allows extended attributes to be acquired/modified via regular
file system operations, such as read(2), write(2), lseek(2) and
ftruncate(2).

Since ZFS already has the capability to do this, this patch allows
system calls (and the NFSv4 client/server) such access to extended
attributes.
This permits handling of large extended attributes and allows the NFSv4
server to provide the service to NFSv4 clients that want it, such as
Windows, MacOS and Solaris.

The top level syscall change is a new open(2)/openat(2) flag I called
O_NAMEDATTR that allows the named attribute directory or any attribute
within that directory to be open'd.


    [17 lines not shown]
DeltaFile
+42-0sys/kern/vfs_syscalls.c
+38-1sys/kern/vfs_vnops.c
+6-3sys/sys/vnode.h
+5-1sys/kern/vfs_cache.c
+3-2sys/sys/namei.h
+3-1sys/sys/mount.h
+97-85 files not shown
+102-811 files

FreeBSD/src fd748c7sys/amd64/amd64 trap.c, sys/arm64/arm64 trap.c

efirt: add a tunable to disable printing faults during EFIRT calls

PR:     285797
Reported and tested by:  Bakul Shah <bakul at iitbombay.org>
Reviewed by:    markj
Sponsored by:   The FreeBSD Foundation
MFC after:      1 week
Differential revision:  https://reviews.freebsd.org/D49592
DeltaFile
+11-2sys/amd64/amd64/trap.c
+10-1sys/dev/efidev/efirt.c
+3-0sys/arm64/arm64/trap.c
+24-33 files

FreeBSD/src 80febaarelease/tools ec2.conf

EC2: Set PCIe eject timeout to 0

Since PCIe device detaching is done via API, there is no opportunity
to "press the attention button a second time" and thus the 5 second
timeout mandated by PCIe serves no purpose.

MFC after:      2 weeks
Sponsored by:   Amazon
DeltaFile
+6-0release/tools/ec2.conf
+6-01 files

FreeBSD/src 9be42eesys/dev/pci pci_pci.c

pci: Make PCIe Eject timeout configurable

PCIe mandates a 5 second delay between when the "Attention Button" is
pressed and when the associated device is detached; this is to allow
for the button to be pressed a second time to cancel the ejection.  On
some systems this 5 second delay may not be desireable; so introduce a
hw.pci.pcie_hp_detach_timeout sysctl (which can also be set as a loader
tunable) which specifies the timeout in milliseconds (default 5000).
If set to zero, the device is detached immediately.

Reviewed by:    jhb
MFC after:      2 weeks
Sponsored by:   Amazon
Differential Revision:  https://reviews.freebsd.org/D49585
DeltaFile
+16-5sys/dev/pci/pci_pci.c
+16-51 files

FreeBSD/src cc05f8dshare/man/man4 pci.4

pci.4: Update the information on pci_bar_mmap to match pciio.h

Reviewed by:    kib,markj,ziaee
MFC after:      1 week
Sponsored by:   Chelsio Communications
Differential Revision:  https://reviews.freebsd.org/D49639
DeltaFile
+7-5share/man/man4/pci.4
+7-51 files

FreeBSD/src 61c010ftests/sys/netinet fibs_test.sh

tests/netinet: enable test against kern/189088

This test was created together with the bug, however after fixing commit
9fdbf7eef5c0 it was not enabled.  Also, the test has a mistake: the second
netstat check would fail cause it would see the route remaining from the
first run.  Workaround that by running the second run in a separate pair
of fibs to the first one.
DeltaFile
+4-5tests/sys/netinet/fibs_test.sh
+4-51 files

FreeBSD/src 58164dcsbin/pfctl pfctl.c, tests/sys/netpfil/pf anchor.sh

pfctl: fix recursive printing of NAT rules

pfctl_show_nat() is called recursively to print nat anchors. This passes the
anchor path, but this path was modified by pfctl_show_nat(), leading to issues
printing the anchors.

Make a copy of the path ('npath') before we modify it. Ensure we do this
correctly by sprinking in 'const', and add a test case to verify that we do now
print things correctly.

Reported by:    Thomas Pasqualini <thomas.pasqualini at orange.com>
MFC after:      2 weeks
Sponsored by:   Rubicon Communications, LLC ("Netgate")
DeltaFile
+46-0tests/sys/netpfil/pf/anchor.sh
+17-16sbin/pfctl/pfctl.c
+63-162 files

FreeBSD/src 7feee91tools/build depend-cleanup.sh

depend-cleanup: Handle ctld moving from C to C++

Reviewed by:    asomers
Sponsored by:   Chelsio Communications
Differential Revision:  https://reviews.freebsd.org/D49140
DeltaFile
+9-0tools/build/depend-cleanup.sh
+9-01 files

FreeBSD/src 839d075usr.sbin/ctld ctld.cc ctld.c

ctld: Convert to C++

This is the minimal set of changes need to compile as C++ so git can
handle the rename correctly.

Reviewed by:    asomers
Sponsored by:   Chelsio Communications
Differential Revision:  https://reviews.freebsd.org/D49139
DeltaFile
+2,662-0usr.sbin/ctld/ctld.cc
+0-2,659usr.sbin/ctld/ctld.c
+0-1,265usr.sbin/ctld/kernel.c
+1,265-0usr.sbin/ctld/kernel.cc
+1,124-0usr.sbin/ctld/uclparse.cc
+0-1,124usr.sbin/ctld/uclparse.c
+5,051-5,04810 files not shown
+7,467-7,46016 files

FreeBSD/src 4800095sys/cam/ctl ctl_ioctl.h

ctl_ioctl.h: Do not use enums for bit fields of flags

C++ does not permit treating enum values as individual bits used with
the bitwise operators.  For types that are a mask of flags, switch the
typedef to an unsigned int and use preprocessor macros for flag
constants.

Reviewed by:    imp, asomers
Sponsored by:   Chelsio Communications
Differential Revision:  https://reviews.freebsd.org/D49138
DeltaFile
+52-52sys/cam/ctl/ctl_ioctl.h
+52-521 files

FreeBSD/src e94d3f6lib/libiscsiutil libiscsiutil.h

libiscsiutil: Fix header to work with C++

Reviewed by:    asomers
Sponsored by:   Chelsio Communications
Differential Revision:  https://reviews.freebsd.org/D49137
DeltaFile
+4-0lib/libiscsiutil/libiscsiutil.h
+4-01 files

FreeBSD/src cd92dd2sys/dev/eqos if_eqos_starfive.c if_eqos.c, sys/riscv/conf std.starfive

eqos: Add StarFive JH7110 variant

Found on the VisionFive v2 SBC, and similar.

Reviewed by:    mhorne
Tested by:      mhorne
Discussed with: sos
Differential Revision:  https://reviews.freebsd.org/D45600
DeltaFile
+219-0sys/dev/eqos/if_eqos_starfive.c
+27-6sys/dev/eqos/if_eqos.c
+7-0sys/dev/eqos/if_eqos_var.h
+4-0sys/riscv/starfive/files.starfive
+2-0sys/riscv/conf/std.starfive
+1-0sys/dev/eqos/if_eqos_reg.h
+260-66 files

FreeBSD/src e696234sys/dev/mii mcommphy.c miidevs

mccomphy: add support for YT8531

Reviewed by:    mhorne
Tested by:      mhorne
MFC after:      2 weeks
Differential Revision:  https://reviews.freebsd.org/D45600
DeltaFile
+234-26sys/dev/mii/mcommphy.c
+2-0sys/dev/mii/miidevs
+236-262 files

FreeBSD/src f01d26dshare/man/man4 mac_do.4, sys/security/mac_do mac_do.c

MAC/do: Rules: <from> and <to> parts now to be separated by '>'

Previously, we would accept only ':' as the separator, which makes
parsing of the rule specification harder for humans, especially those
people that are used to UNIX systems where ':' is used as the separator
in PATH.  With ':', the <from> and <to> parts can look like two
different elements that are unrelated, especially to these eyes.

Change parse_single_rule() so that '>' is also accepted as a separator
between <from> and <to>, and promote it as the one to use.  During
a transition period, we will still allow the use of ':' for backwards
compatibility.

The manual page update comes from separate revision D49628.  ':' has
been completely removed from it on purpose.

Reviewed by:    bapt, manpages (ziaee)
MFC after:      5 days
Sponsored by:   The FreeBSD Foundation
Differential Revision:  https://reviews.freebsd.org/D49627
DeltaFile
+17-17share/man/man4/mac_do.4
+6-5sys/security/mac_do/mac_do.c
+23-222 files

FreeBSD/src 03c12d0sys/security/mac_do mac_do.c

MAC/do: parse_single_rule(): Fix herald comment's first line

No functional change.

MFC after:      5 days
Sponsored by:   The FreeBSD Foundation
DeltaFile
+1-1sys/security/mac_do/mac_do.c
+1-11 files

FreeBSD/src ce9c467tests/sys/kern ktrace_test.c

ktrace tests: don't use INADDR_ANY as a destination for sendto(2)

The INADDR_ANY is a broadcast address, and with recent changes its use as
destination for UDP sendto(2) was disallowed unless SO_BROADCAST is set.
Use just a localhost address for a successful sendto(2).

While here convert a couple checks that happen in the parent to use normal
ATF_REQUIRE() instead of CHILD_REQUIRE().

PR:                     285851
Fixes:                  3b281d1421a78b588c5fc4182009ce62d8823d95
DeltaFile
+4-5tests/sys/kern/ktrace_test.c
+4-51 files

FreeBSD/src e85aaedsys/sys sysctl.h

Correct CTLTYPE of SYSCTL_SBINTIME_MSEC etc

These should be CTLTYPE_S64, not CTLTYPE_INT, since they handle 64-bit
values.

Reviewed by:    imp
Fixes:  003ffd57fee1 ("Add sysctl_usec_to_sbintime [...]")
MFC after:      2 weeks
Sponsored by:   Amazon
Differential Revision:  https://reviews.freebsd.org/D49584
DeltaFile
+4-4sys/sys/sysctl.h
+4-41 files

FreeBSD/src 0ae0226cddl/contrib/opensolaris/lib/libdtrace/common dt_subr.c dt_consume.c

libdtrace: Fix an off-by-one in CPU ID handling

The illumos-specific _SC_CPUID_MAX is the largest CPU ID in the system.  This
was mapped to _SC_NPROCESSORS_CONF, which is the total number of CPUs recognized
by the kernel.  If CPU IDs are contiguous, as is the case on amd64 and arm64,
this value is one greater than the maximum ID.   As a result, when consuming
per-CPU dtrace buffers, libdtrace tries to fetch from a non-existent CPU.  This
is mostly harmless in practice, but still wrong.

As we don't have a sysconf value for the maximum CPU ID, add a wrapper which
fetches it using the kern.smp.maxid sysctl.

MFC after:      2 weeks
Sponsored by:   Innovate UK
Differential Revision:  https://reviews.freebsd.org/D49243

(cherry picked from commit 9a30c8d347bf9aaa89277b6e5a275f737be8edce)
DeltaFile
+14-0cddl/contrib/opensolaris/lib/libdtrace/common/dt_subr.c
+4-4cddl/contrib/opensolaris/lib/libdtrace/common/dt_consume.c
+4-2cddl/contrib/opensolaris/lib/libdtrace/common/dt_aggregate.c
+0-5cddl/contrib/opensolaris/lib/libdtrace/common/dtrace.h
+1-0cddl/contrib/opensolaris/lib/libdtrace/common/dt_impl.h
+23-115 files

FreeBSD/src 294cda7sys/cddl/dev/dtrace/aarch64 dtrace_subr.c

dtrace/arm64: Fix dtrace_gethrtime()

This routine returns a monotonic count of the number of nanoseconds elapsed
since the previous call.  On arm64 it uses the generic system timer.  The
implementation multiplies the counter value by 10**9 then divides by the counter
frequency, but this multiplication can overflow.  This can result in trace
records with non-monotonic timestamps, which breaks libdtrace's temporal
ordering algorithm.

An easy fix is to reverse the order of operations, since the counter frequency
will in general be smaller than 10**9.  (In fact, it's mandated to be 1Ghz in
ARMv9, which makes life simple.)  However, this can give a fair bit of error.
Adopt the calculation used on amd64, with tweaks to handle frequencies as low as
1MHz: the ARM generic timer documentation suggests that ARMv8 timers are
typically in the 1MHz-50MHz range, which is true on arm64 systems that I have
access to.

MFC after:      2 weeks
Sponsored by:   Innovate UK

    [3 lines not shown]
DeltaFile
+31-2sys/cddl/dev/dtrace/aarch64/dtrace_subr.c
+31-21 files

FreeBSD/src 1cbe878cddl/contrib/opensolaris/lib/libdtrace/common dt_pq.c

libdtrace: Fix an off-by-one in the priority queue implementation

The zero'th index in the array is unused, so a priority queue of N elements
needs N+1 array slots.  Fix the allocation.

Also fix the assertion in dt_pq_insert(): the assertion needs to be checked
after incrementing the count of items in the priority queue, otherwise it can
miss an overflow.

Reported by:    CHERI
MFC after:      2 weeks
Sponsored by:   Innovate UK
Differential Revision:  https://reviews.freebsd.org/D49242

(cherry picked from commit 7ee1bdd094d376fdc547e8ca33e472f1d37a7d79)
DeltaFile
+3-3cddl/contrib/opensolaris/lib/libdtrace/common/dt_pq.c
+3-31 files

FreeBSD/src c10fd9alib/libc/tests/net/getaddrinfo getaddrinfo.c

tests: Require allow_network_access for tests needing name resolution

Tests that require working name resolution or network access now mandate that
the kuya variable allow_network_access be set.

PR:             285826
Reported by:    ngie
Reviewed by:    igoro
Approved by:    lwhsu
Sponsored by:   Netflix
Differential Revision:  https://reviews.freebsd.org/D49633
DeltaFile
+11-2lib/libc/tests/net/getaddrinfo/getaddrinfo.c
+11-21 files

FreeBSD/src fe92788contrib/expat Changes, contrib/expat/fuzz xml_lpm_fuzzer.cpp xml_lpm_fuzzer.proto

contrib/expat: import expat 2.7.1

Changes: https://github.com/libexpat/libexpat/blob/R_2_7_1/expat/Changes
         https://github.com/libexpat/libexpat/blob/R_2_7_0/expat/Changes

Security:       CVE-2024-8176
MFC after:      3 days
DeltaFile
+428-158contrib/expat/lib/xmlparse.c
+464-0contrib/expat/fuzz/xml_lpm_fuzzer.cpp
+322-9contrib/expat/tests/basic_tests.c
+205-44contrib/expat/tests/misc_tests.c
+121-2contrib/expat/Changes
+58-0contrib/expat/fuzz/xml_lpm_fuzzer.proto
+1,598-21322 files not shown
+1,780-26528 files

FreeBSD/src f8cd0c8tests/sys/netipsec/tunnel empty.sh

tests: fix test for NULL encription

After 04207850a9b9 it is required that key length is not zero.
Add some key to avoid error.

Reported by:    markj

(cherry picked from commit b6708045590712930c533e916e3d6fdfe48ec5ba)
DeltaFile
+2-2tests/sys/netipsec/tunnel/empty.sh
+2-21 files

FreeBSD/src 5b6d576tests/sys/netipsec/tunnel empty.sh

tests: fix test for NULL encription

After 04207850a9b9 it is required that key length is not zero.
Add some key to avoid error.

Reported by:    markj

(cherry picked from commit b6708045590712930c533e916e3d6fdfe48ec5ba)
DeltaFile
+2-2tests/sys/netipsec/tunnel/empty.sh
+2-21 files

FreeBSD/src b09cf48. Changes, fuzz xml_lpm_fuzzer.cpp xml_lpm_fuzzer.proto

Vendor import of expat 2.7.1
DeltaFile
+428-158lib/xmlparse.c
+464-0fuzz/xml_lpm_fuzzer.cpp
+322-9tests/basic_tests.c
+205-44tests/misc_tests.c
+121-2Changes
+58-0fuzz/xml_lpm_fuzzer.proto
+1,598-21322 files not shown
+1,780-26528 files