[BACK]Return to 78.html CVS log [TXT][DIR] Up to [local] / www

File: [local] / www / 78.html (download) (as text)

Revision 1.64, Wed May 6 17:11:29 2026 UTC (4 weeks, 2 days ago) by tj
Branch: MAIN
CVS Tags: HEAD
Changes since 1.63: +1 -1 lines

"platforms specific" -> "platform-specific"

<!doctype html>
<html lang="en" id="release">
<head>
<meta charset=utf-8>

<title>OpenBSD 7.8</title>
<meta name="description" content="OpenBSD 7.8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" href="openbsd.css">
<link rel="canonical" href="https://www.openbsd.org/78.html">
</head><body>
<h2 id="OpenBSD">
<a href="index.html">
<i>Open</i><b>BSD</b></a>
7.8
</h2>

<table>
<tr>
<td>
<a href="images/Terraodontidae.png">
<img width="200" height="300" src="images/Terraodontidae-s.gif" alt="Terraodontidae"></a>
<td>
Released Oct 22, 2025. (59th OpenBSD release)<br>
Copyright 1997-2025, Theo de Raadt.<br>
<br>
Artwork by Apsephion.
<br>
<ul>
<li>See the information on <a href="ftp.html">the FTP page</a> for
    a list of mirror machines.
<li>Go to the <code class=reldir>pub/OpenBSD/7.8/</code> directory on
    one of the mirror sites.
<li>Have a look at <a href="errata78.html">the 7.8 errata page</a> for a list
    of bugs and workarounds.
<li>See a <a href="plus78.html">detailed log of changes</a> between the
    7.7 and 7.8 releases.
<p>
<li><a href="https://man.openbsd.org/signify.1">signify(1)</a>
    pubkeys for this release:<p>

<table class=signify>
<tr><td>
openbsd-78-base.pub:
<td>
<a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/openbsd-78-base.pub">
RWS3/nvFmk4SWSmt/5QIk9yB4+uoAGoiYvFhVlDQBG3rWENeeIys0LWB</a><tr><td>
openbsd-78-fw.pub:
<td>
RWSFPOE2F7PQul5Fu/3G/JKMmqJD76vKKQh30UrwSslcMcU5/MEBVqTd
<tr><td>
openbsd-78-pkg.pub:
<td>
RWRdSyJORZBFeOu7a8K3nODBr9GrFJlGZUG2j93jDSds8Zc+NLTP8v60
<tr><td>
openbsd-78-syspatch.pub:
<td>
RWRYSW9gIG/XToA9BM+s+ehGgxdWe0+ZShwt85+/dFXYOZFRUi4uqhiR
</table>
</ul>
<p>
All applicable copyrights and credits are in the src.tar.gz,
sys.tar.gz, xenocara.tar.gz, ports.tar.gz files, or in the
files fetched via <code>ports.tar.gz</code>.
</table>

<hr>

<section id="new">
<h3>What's New</h3>
<p>
This is a partial list of new features and systems included in OpenBSD 7.8.
For a comprehensive list, see the <a href="plus78.html">changelog</a> leading to 7.8.
<p>
<ul>

<li>Platform-specific improvements:
  <ul>
  <li><a href="arm64.html">arm64</a>:
    <ul>
    <li>Added support for Raspberry Pi 5 (with console on serial port).
    <li>Implement <a href="https://man.openbsd.org/acpicpu.4">acpicpu(4)</a> for arm64.
    <li>On Apple variants, enter DDB when exuart detects a BREAK.
    <li>On arm64 and riscv64, avoid multiple threads of a process
	continuously faulting on a single page when <a
	href="https://man.openbsd.org/pmap_enter.9">pmap_enter(9)</a> is asked
	to enter a mapping that already exists.
    <li>Make apm and <code>hw.cpuspeed</code> work on Snapdragon X Elite
	machines.
    </ul>
  <li><a href="amd64.html">amd64</a>:
    <ul>
    <li>Fix processing of GPIO events for pin numbers less than 256 with
	an _EVT method. Fixes power button on various ThinkPads with AMD CPUs.
    </ul>
  <li>Other <a href="plat.html">architectures</a>:
    <ul>
    <li>Added a sparc64-specific _raw flavour to the softintr routines for
	those drivers that need to be able to schedule soft interrupts at
	actual hardware levels.
    </ul>

  <li>More platform specific changes can be found in the <a href="#hardware_support">hardware support</a> section below.
  </ul>

<li>Various kernel improvements:
  <ul>
  <li>Set an upper limit on the value of
	<a href="https://man.openbsd.org/sysctl.2#KERN_SEMINFO_SEMOPM~2">
	sysctl(2) kern.seminfo.semopm</a> to avoid a possible kernel panic.
  <li>On arm64, avoid decoding instructions when ELR isn't pointing
	into the kernel part of the virtual address space and use fault()
	instead of panic() to provide better error reports.
  <li>Inherit <code>PS_NOBTCFI</code> at
        <a href="https://man.openbsd.org/fork.2">fork(2)</a>
        so forked children do not get killed by BTCFI safeguards.
  <li>Inherit <code>PS_PROFILE</code> at
        <a href="https://man.openbsd.org/fork.2">fork(2)</a>.
	This lets child processes
	disable/reenable profiling when they deemed appropriate.
  <li>Implement the POSIX-2024 close-on-fork flag, but modified to be
	reset on exec as preserving it across exec is not necessary for its
	original purpose and has security and usability concerns.
  <li>Improve handling of lock nesting by <a
	href="https://man.openbsd.org/witness.4">witness(4)</a>.
  <li>Add MI high-level software interrupt dispatcher, providing a
	common subsystem for the high-level allocation, scheduling, and
	dispatching of soft interrupts.
  <li>Remove the functionality of the <code>fs.posix.setuid</code> sysctl.
  <li>Use a FIFO queue for passing dead threads to the reaper,
	reducing latency with large numbers of CPUs and jobs.
  <li>Skip filesystem mount time update in BOOT kernels to enable
	crude timekeeping across reboots without RTC and NTP.
  <li>Move the kernel to using nanoseconds for the sleep time argument
	instead of ticks. Userland functions don't change but precision is no
	longer lost converting nanoseconds into ticks.
  <li>Show SEV or SEV-ES guest mode in dmesg when running with AMD SEV.
  <li>Support the GHCB protocol for IO and MMIO with SEV-ES.
	This makes OpenBSD work with SEV-ES on kvm/qemu in 1-vCPU VMs
  <li>Add <a href="https://man.openbsd.org/psp.4">psp(4)</a> <a
	href="https://man.openbsd.org/ioctl.2">ioctl(2)</a> to encrypt and
	measure state for AMD SEV-ES.
  <li>Add <a
	href="https://man.openbsd.org/cpu_xcall.9">cpu_xcall(9)</a>, an API
	for CPU xcalls (crosscalls), allowing dispatching of code to run on
	the specified CPU from an interrupt context.
  <li>Add <a href="https://man.openbsd.org/dt.4">dt(4)</a> trace points
	to <a href="https://man.openbsd.org/rwlock.9">rwlock(9)</a>.
  <li>Teach <a href="https://man.openbsd.org/btrace.8">btrace(8)</a>
	how to resolve addresses in callstacks to symbols.
  <li>Improve the documentation of <a
	href="https://man.openbsd.org/dt.4">dt(4)</a> and <a
	href="https://man.openbsd.org/btrace.8">btrace(8)</a>
  <li>Improve compatibility of the FUSE filesystem with
	the Linux libfuse implementation.
  <li>Make it possible to run the upper part of the fault handler in parallel.
  <li>Improve mtx_enter() for machines with a huge number of CPUs.
  </ul>

<li>Suspend/Hibernate Support:
  <ul>
  <li>Preallocate hibernate work area during boot to fix failures where the needed region can't be late-allocated.
  <li>Implement lid suspend/resume for lids that use a GPIO.
  <li>Implement support for wakeup interrupts in <a
	href="https://man.openbsd.org/amdgpio.4">amdgpio(4)</a>, making it
	possible to resume laptops with AMD CPUs from S0ix suspend.
  <li>Introduce a generic powerbutton_event() function that does
	everything we expect from a power button event in a consistent manner,
	ensuring all drivers now prevent shutdown within the first 10 seconds
	after resume.
  <li>Implement a <code>ddb.suspend</code> sysctl that will force "S0ix"
	suspend and skip suspend of <a
	href="https://man.openbsd.org/inteldrm.4">inteldrm(4)</a> and <a
	href="https://man.openbsd.org/amdgpu.4">amdgpu(4)</a> such that the
	display remains on during suspend.
  <li>Fix dead USB ports after suspend/resume on the ThinkPad Z13.
  <li>Make <a href="https://man.openbsd.org/amdgpu.4">amdgpu(4)</a> S3 suspend more reliable.
  <li>Double the size of the amd64 unhibernate chunk table for machines with large amounts of memory.
  </ul>


<li id="SMP_Improvements">SMP Improvements:
  <ul>
  <li>Up to 8 softnet threads are used to handle network input.
	The number of threads is also limited by the number of CPUs.
  <li>TCP stack is now running in parallel on multiple CPUs.
	Up to 8 threads are used to process TCP traffic.
	Note that each connection can only be handled by one CPU.
        Use multiple streams and a network interface capable of
        multi queue to distribute packets.
  <li>IPv6 fragment reassembly is now running in parallel.
  <li>IPv6 destination option and routing header parsing is now
	running in parallel.
  <li>System calls
	<a href="https://man.openbsd.org/close.2">close(2)</a> and
	<a href="https://man.openbsd.org/listen.2">listen(2)</a>
	run without exclusive net lock.
  </ul>

<li>Direct Rendering Manager and graphics drivers:
  <ul>
  <li>Updated <a href="https://man.openbsd.org/drm.4">drm(4)</a>
      to Linux 6.12.50.
  <li>New <a href="https://man.openbsd.org/qcdrm.4">qcdrm(4)</a>
      driver for Qualcomm Snapdragon DRM subsystem.
  <li>New <a href="https://man.openbsd.org/qcdpc.4">qcdpc(4)</a>
      driver for Qualcomm DisplayPort Controller.
  </ul>

<li>VMM/VMD improvements:
  <ul>
  <li>On AMD processors SEV-ES technology is supported to start
	confidential virtual machines.
	SEV-ES works with the vmm/vmd hypervisor and with OpenBSD
	guests on KVM/qemu.
  <li>Add option for <a href="https://man.openbsd.org/vmd.8">vmd(8)</a>
	to run guests in AMD SEV-ES mode and keyword "seves" for <a
	href="https://man.openbsd.org/vm.conf.5">vm.conf(5)</a> to enable it.
  <li>Allow SEV-ES enabled guests to run on <a
	href="https://man.openbsd.org/vmm.4">vmm(4)</a>/<a
	href="https://man.openbsd.org/vmd.8">vmd(8)</a>.
  <li>Make <a href="https://man.openbsd.org/vmctl.8">vmctl(8)</a> show file path in error messages.
  <li>Sanitize <a href="https://man.openbsd.org/vmd.8">vmd(8)</a>'s interprocess communication.
  <li>Back <a href="https://man.openbsd.org/vmm.4">vmm(4)</a> guest
	memory with UVM aobjs, simplifying how guest memory is represented and
	managed.
  <li>Allow Linux guests to use kvm-clock in <a href="https://man.openbsd.org/vmm.4">vmm(4)</a>.
  <li>Remove <a href="https://man.openbsd.org/vmd.8">vmd(8)</a> send & receive functionality.
  <li>Prevent <a href="https://man.openbsd.org/vmd.8">vmd(8)</a> guests from reading outside pci config space.
  <li>Emulate PKRU XSAVE area and features in <a href="https://man.openbsd.org/vmm.4">vmm(4)</a>.
  <li>Update <a href="https://man.openbsd.org/vmd.8">vmd(8)</a>'s
	emulated Virtio network, block, entropy, and scsi devices
	to support Virtio 1.2 in non-transitional mode.
  </ul>


<li>Various new userland features:
  <ul>
  <li>Switched <a href="https://man.openbsd.org/pkg-config.1">pkg-config(1)</a>
	to the widely used C-based pkgconf 2.4.3 due to major performance issues
	with the unmaintained homegrown Perl script.
  <li>Import IIJ's iwatch as <a href="https://man.openbsd.org/watch.1">watch(1)</a>, a utility to periodically execute a command and display its output.
  <li><a href="https://man.openbsd.org/security.8">security(8)</a>
	creates backups of GPT/MBR.
  <li><a href="https://man.openbsd.org/fdisk.8">fdisk(8)</a>
	<code>-R</code> recovers/creates GPT/MBR from a file.
  <li><a href="https://man.openbsd.org/fdisk.8">fdisk(8)</a>
	interactive editor supports one-line partition addition/modification.
  <li>Add [-w percent] and /etc/apm/warnlow hook to <a href="https://man.openbsd.org/apmd.8">apmd(8)</a>.
  <li>Introduced a new gprof profiling system using <a
	href="https://man.openbsd.org/profil.2">profil(2)</a> system call and
	removed the <a
	href="https://man.openbsd.org/OpenBSD-7.7/monstartup.3">monstartup(3)</a>
	interface.
  <li>Add <a href="https://man.openbsd.org/ibufq_new.3">ibufq(3)</a>
	API to support multithreaded use of ibufs.
  </ul>

<li>More bugfixes and tweaks in userland:
  <ul>
  <li>As usual, many improvements and corrections in documentation were made.
  <li><a href="https://man.openbsd.org/fdisk.8">fdisk(8)</a>
	interactive editor displays verbose information if <code>-v</code>
	was set.
  <li><a href="https://man.openbsd.org/fdisk.8">fdisk(8)</a>
	displays GPT partitions in disk offset order with free areas shown.
  <li><a href="https://man.openbsd.org/fdisk.8">fdisk(8)</a>
	can create GPT partitions with any well formed UUID as the type.
  <li>Only GPT partitions with recognized filesystems are
    included in the default <a href="https://man.openbsd.org/disklabel.5">disklabel(5)</a>.
  <li>Version 0 <a href="https://man.openbsd.org/disklabel.5">disklabel(5)</a>
    no longer supported.
  <li>Fix a crash in <a href="https://man.openbsd.org/vi.1">vi(1)</a> when executing commands.
  <li>Fix <a href="https://man.openbsd.org/vi.1">vi(1)</a> crash with expandtab and running external commands.
  <li>Make <a href="https://man.openbsd.org/vi.1">vi(1)</a> 'p' command paste in the correct place.

  <li>Improve the
	<a href="https://man.openbsd.org/flockfile.3">flockfile(3)</a>
	implementation by switching from external
	locks to per FILE recursive mutexes.
  <li>Do not log OTP secrets in
	<a href="https://man.openbsd.org/login_yubikey.8">login_yubikey(8)</a>.
  <li>Change <a href="https://man.openbsd.org/gmtime.3">gmtime(3)</a>
	to return time in UTC rather than GMT, as
	required by our own manpage, POSIX, C standards, and other OSes.
  <li>Make <a href="https://man.openbsd.org/exit.3">exit(3)</a>,
	<a href="https://man.openbsd.org/fclose.3">fclose(3)</a>,
	<a href="https://man.openbsd.org/fflush.3">fflush(3)</a>, and
	<a href="https://man.openbsd.org/freopen.3">freopen(3)</a> comply with
	POSIX-2008 requirements for setting the underlying file position when
	flushing read-mode streams, and make an
	<a href="https://man.openbsd.org/fseek.3">fseek(3)</a>-after-<a
	href="https://man.openbsd.org/fflush.3">fflush(3)</a> not
	change the underlying file position.
  <li>FILE is now opaque.  Its member representing the file descriptor has been
	widened from type short to int.
  <li>Improve externs for KEYMAPE(), extern in .c files resulted in the use of a wrongly sized
	anonymous struct.
  <li>Make <a href="https://man.openbsd.org/bioctl.8">bioctl(8)</a> properly indicate key disk for RAID 1C.
  <li>Fix sign of <code>%z</code> output in
	<a href="https://man.openbsd.org/zic.8">zic(8)</a>, and add DST offset.
  <li>Add <code>-t</code> and <code>-V</code> options from tzcode2013d to
	<a href="https://man.openbsd.org/zdump.8">zdump(8)</a>.
  <li>Fix an <a href="https://man.openbsd.org/rmdir.1">rmdir(1)</a> bug where "mkdir exampledir; ln -s exampledir examplelink; rmdir examplelink/" didn't remove exampledir like POSIX requires.
  <li>Fix a POSIX-violating
	<a href="https://man.openbsd.org/grep.1">grep(1)</a> bug where
	arguments starting with a hyphen-minus character were misinterpreted
	as options even when appearing behind non-option operands.
  <li>Improve handling of UTF-8 input in
	<a href="https://man.openbsd.org/ksh.1">ksh(1)</a> VI mode
	in several ways.  This work is not yet complete.
  <li>In <a href="https://man.openbsd.org/ksh.1">ksh(1)</a> VI mode, make the
	behaviour of "1P" consistent with the behaviour of "2P" such that
	both back up to the first byte of the last character inserted.
  <li>Make <a href="https://man.openbsd.org/mdoc.7">mdoc(7)</a>
	support the input syntax ".Lb libname [...]" with multiple arguments
	in the SYNOPSIS.
  <li>For better consistency with POSIX and traditional UNIX and BSD
	<a href="https://man.openbsd.org/man.1">man(1)</a>, if the
	<code>-l</code> option is not specified, never interpret "name"
	command line arguments as absolute or relative path names, not
	even for arguments that contain a slash and that do not resolve
	to a manual page name.
  <li>Make <a href="https://man.openbsd.org/sndiod.8">sndiod(8)</a> use
	per-program level controls instead of per-client.
  <li>Stop <a href="https://man.openbsd.org/tar.1">tar(1)</a> from
	exiting silently if the mtime didn't fit in the ustar header when
	writing out the extended headers.
  <li>Fix memleak in <a
	href="https://man.openbsd.org/syslogd.8">syslogd(8)</a> when a client
	aborts a TLS connection, and ensure that <a
	href="https://man.openbsd.org/syslogd.8">syslogd(8)</a> runs TLS
	handshake callback.
  <li>Support for embedded PNG bitmaps in Freetype (often used for fonts
	with colour emoji).
  <li>Backport TearFree page flips for the modesetting driver from X.Org master.

  </ul>

<li id="hardware_support">Improved hardware support and driver bugfixes, including:
  <ul>
  <li>New <a href="https://man.openbsd.org/acpiwmi.4">acpiwmi(4)</a>
      driver for Windows Management Instrumentation.
  <li>New <a href="https://man.openbsd.org/amdpmc.4">amdpmc(4)</a>
      driver for AMD power management controller.
  <li>New bcmmip
      driver for BCM2712 MSI controller.
  <li>New <a href="https://man.openbsd.org/bcmstbgpio.4">bcmstbgpio(4)</a>
      driver for Broadcom Set-top Box GPIO controller.
  <li>New <a href="https://man.openbsd.org/bcmstbintc.4">bcmstbintc(4)</a>
      driver for Broadcom Set-to Box interrupt controller.
  <li>New <a href="https://man.openbsd.org/bcmstbpinctrl.4">bcmstbpinctrl(4)</a>
      driver for Broadcom Set-top Box pin multiplexing.
  <li>New <a href="https://man.openbsd.org/bcmstbrescal.4">bcmstbrescal(4)</a>
      driver for Broadcom Set-top Box reset calibration controller.
  <li>New <a href="https://man.openbsd.org/bcmstbreset.4">bcmstbreset(4)</a>
      driver for Broadcom Set-top Box reset controller.
  <li>New <a href="https://man.openbsd.org/arm64/rpone.4">rpone(4)</a>
      driver for Raspberry Pi RP1 peripheral controller.
  <li>New <a href="https://man.openbsd.org/arm64/rpiclock.4">rpiclock(4)</a>
      driver for Raspberry Pi RP1 clock controller.
  <li>New <a href="https://man.openbsd.org/arm64/rpipwm.4">rpipwm(4)</a>
      driver for Raspberry Pi RP1 PWM controller.
  <li>New <a href="https://man.openbsd.org/arm64/rpirtc.4">rpirtc(4)</a>
      driver for Raspberry Pi real-time clock.
  <li>New <a href="https://man.openbsd.org/iasuskbd.4">iasuskbd(4)</a>
      driver for ASUS I2C HID keyboards.
  <li>Add support for the SDHC controllers found on the Raspberry Pi 5.
  <li>In <a href="https://man.openbsd.org/virtio.4">virtio(4)</a>,
	allow to use memory above 4G on amd64 for virtio rings and
	descriptors.
  
  <li>Add support for H.264 advanced video coding to
	<a href="https://man.openbsd.org/uvideo.4">uvideo(4)</a>.
  <li>Prevent a kernel panic in
	<a href="https://man.openbsd.org/wsdisplay.4">wsdisplay(4)</a>
	when asked to switch VTs during resume.
  <li>Avoid a use-after-free in
	<a href="https://man.openbsd.org/psp.4">psp(4)</a>.
  <li>Do not attach YubiKeys as keyboards anymore in
	<a href="https://man.openbsd.org/ukbd.4">ukbd(4)</a>.
	This disables the OTP functionality, but makes it easier to use
	the FIDO function without the need to configure the YubiKeys
	correctly first.
  <li>Implement support for "vmmc-supply" in
	<a href="https://man.openbsd.org/sdhc.4">sdhc(4)</a>,
	needed to power on the WiFi chip on the Raspberry Pi 5.
  <li>Add RK3528 support to <a href="https://man.openbsd.org/rkpinctrl.4">rkpinctrl(4)</a>.
  <li>Add RK3528 support to <a href="https://man.openbsd.org/rkclock.4">rkclock(4)</a>.
  <li>Add RK3528 support to <a href="https://man.openbsd.org/rkusbphy.4">rkusbphy(4)</a>.
  <li>Fix and add time sensor to <a href="https://man.openbsd.org/pvclock.4">pvclock(4)</a>.

  </ul>

<li>New or improved network hardware support:
  <ul>
  <li>Make the <a href="https://man.openbsd.org/cad.4">cad(4)</a>
	Ethernet interface on the Raspberry Pi 5 work by
	configuring the delays for RGMII PHYs correctly.
  <li>Add support for the Realtek RTL8125D and RTL8127 chips to the <a
	href="https://man.openbsd.org/rge.4">rge(4)</a> driver and update
	microcode for RTL8125B.
  <li>Add a software implementation of TCP Large Receive Offload to <a
	href="https://man.openbsd.org/ixl.4">ixl(4)</a>.
  <li>Intel E810 network devices
        <a href="https://man.openbsd.org/ice.4">ice(4)</a> are
        supported for 100 and 25 GBit in QSFP and SFP variants.
  <li>Add support for the ifconfig
	<a href="https://man.openbsd.org/ifconfig.8#transceiver">transceiver</a>
	command to <a href="https://man.openbsd.org/ice.4">ice(4)</a>.
  <li>Add Rx checksum offload and TSO (TCP Segmentation Offload) support to <a
	href="https://man.openbsd.org/ice.4">ice(4)</a>.
  <li>Enable RSS in <a
	href="https://man.openbsd.org/ice.4">ice(4)</a>, and enable Tx/Rx
	across multiple queues.
  <li>Use SoftLRO in <a href="https://man.openbsd.org/ice.4">ice(4)</a>, but default off.
  <li>Add SoftLRO support to <a href="https://man.openbsd.org/bnxt.4">bnxt(4)</a>.
  <li>Add support for TSO to <a
	href="https://man.openbsd.org/iavf.4">iavf(4)</a>.
  <li>Disable <a href="https://man.openbsd.org/hvn.4">hvn(4)</a> TCP
	checksum offload, broken on newer hyper-v versions.
  <li>Add support for the RTL8157 chipset in <a href="https://man.openbsd.org/ure.4">ure(4)</a>. 


  </ul>

<li>Added or improved wireless network drivers:
  <ul>
  <li>Add 802.11n/HT and roaming support to
        <a href="https://man.openbsd.org/qwx.4">qwx(4)</a>.
  <li>Fix TKIP crypto offload in
        <a href="https://man.openbsd.org/qwx.4">qwx(4)</a>.
  <li>Fix suspend/resume instability caused by
        <a href="https://man.openbsd.org/qwx.4">qwx(4)</a>.
  <li>Make WPA handshakes succeed more reliably with the
      <a href="https://man.openbsd.org/bwfm.4">bwfm(4)</a> driver.
  <li>Unbreak support for a subset of Intel AX210 devices by making
     <a href="https://man.openbsd.org/iwx.4">iwx(4)</a> load the
     correct firmware image for them.

  </ul>

<li>Installer, upgrade, bootloader, and pkg-tools improvements:
  <ul>
<!-- installboot -->
<!-- sysupgrade -->
<!-- fw_update -->
<!-- installer proper -->
  <li>Add installer preference for disks bigger than 1G as default root disk.
  <li>Stop offering http/nfs for offline installation.
  <li>Prevent installing a corrupted <code>/bsd</code> on relink errors.
<!-- updates/sysmerge -->
<!-- pkg_ -->
  <li>Prevent <a
	href="https://man.openbsd.org/pkg_add.1">pkg_add(1)</a> update from
	advising file removal appropriate only when deleting packages.
  </ul>

<li>Security improvements:
  <ul>
  <li>Permit <a href="https://man.openbsd.org/setsockopt.2">setsockopt(2)</a>
	and <a href="https://man.openbsd.org/getsockopt.2">getsockopt(2)</a>
	<code>IPPROTO_IP</code>/<code>IP_TOS</code> and
	<code>IPPROTO_IPV6</code>/<code>IPV6_TCLASS</code> in
	<a href="https://man.openbsd.org/pledge.2">pledge(2)</a> "stdio".
	Previously these were restricted to "inet".
	However, setting TOS is low risk and this way a
	lot more attack surface from inet can be removed.
  <li>Allow low-risk
	<a href="https://man.openbsd.org/getsockname.2">getsockname(2)</a> and
	<a href="https://man.openbsd.org/getpeername.2">getpeername(2)</a>
	in stdio.
  <li>Pledge <a
	href="https://man.openbsd.org/fc-cache.1">fc-cache(1)</a> and <a
	href="https://man.openbsd.org/mkfontscale.1">mkfontscale(1)</a> and
	change ownership of the fontconfig cache to the
	<code>_fc-cache</code> user to run unprivileged when installing fonts.
  <li>Add <code>IPV6_RECVTCLASS</code> to the authorized
	<a href="https://man.openbsd.org/setsockopt.2">setsockopt(2)</a>
	operations for <code>IPPROTO_IPV6</code> in
	<a href="https://man.openbsd.org/pledge.2">pledge(2)</a>
	fixing recent chromium browser with IPv6.
  <li>Add an MI mechanism for creating an (unmapped) guard page between
	the PCB and the kernel stack and enable on 64-bit architectures with
	4k pages.
  </ul>

<li>New features in the network stack:
  <ul>
  <li>Stop adding interfaces with blackhole and reject routes to the
	egress group, even if a default route points at them.
  <li>Some network drivers allow to use soft LRO for TCP.
	If the hardware does not support to concatenate received
	TCP packets, this can be done at driver level.
	As the upper layers handle less packets, performance
	improves.
	Currently the feature is disabled by default, activate with ifconfig(8)
	<a href="https://man.openbsd.org/ifconfig.8#tcplro">tcplro</a>.
	Software LRO has been implemented for
	<a href="https://man.openbsd.org/bnxt.4">bnxt(4)</a>,
	<a href="https://man.openbsd.org/ice.4">ice(4)</a>,
	<a href="https://man.openbsd.org/ixl.4">ixl(4)</a>.
  <li>New <a href="https://man.openbsd.org/erspan.4">erspan(4)</a>
      driver for ERSPAN Type II tunnel networks.
  </ul>

  <li>Further changes and bugfixes in the network stack:
  <ul>
  <li>For
	<a href="https://man.openbsd.org/divert.4">divert(4)</a>
	protocols
	<a href="https://man.openbsd.org/sysctl.8">sysctl(8)</a>
	knobs have been consolidated.
  <li>ARP and ND6 list use iterators to be MP safe.
        This also avoids a race when timeouts handled multipath
        link layer entries.
  <li>TCP keepalive intervals have been fixed.
  <li>Do not allow negative values for
	<a href="https://man.openbsd.org/sysctl.2">sysctl(2)</a>
	<code>net.inet6.ip6.neighborgcthresh</code>, which would disable
	the limit ND6 entries, and disallow setting negative values for
	<code>net.inet6.ip6.maxdynroutes</code>, which previously allowed
	unlimited redirect routes.
  <li>Fix error handling in IPv6 multicast sysctl.
  <li>Fix refcnt leak in <a href="https://man.openbsd.org/veb.4">veb(4)</a>.
  <li>Use VLAN hardware tagging in <a href="https://man.openbsd.org/veb.4">veb(4)</a>.
  <li>Use VLAN hardware tagging in <a href="https://man.openbsd.org/bridge.4">bridge(4)</a>.
  <li>Use checksum offload in <a href="https://man.openbsd.org/veb.4">veb(4)</a>
	and <a href="https://man.openbsd.org/bridge.4">bridge(4)</a>.
  <li>Unbreak <a href="https://man.openbsd.org/vport.4">vport(4)</a> to
	vport communication on the same <a
	href="https://man.openbsd.org/veb.4">veb(4)</a>.

  <li>Remove <code>net.inet6.ip6.soiikey</code> sysctl.
  <li>Make <a href="https://man.openbsd.org/lo.4">lo(4)</a> attach
	multiple interface queues, allowing local network connections to use
	multiple softnets.
  <li>Allow packets being sent out <a
	href="https://man.openbsd.org/pppoe.4">pppoe(4)</a> interfaces to
	bypass queues and go straight onto the underlying interface.

  </ul>

<li>The following changes were made to the <a
	href="https://man.openbsd.org/pf.4">pf(4)</a> firewall:
  <ul>
  <li>The check whether a TCP RST packet belongs to a connection
        was too strict.
        Now resetting a TCP state also works if there were gaps in
        the sequence number space due to lost packets.
  <li>Repair "least-states" in
	<a href="https://man.openbsd.org/pf.4">pf(4)</a> by decrementing
	the state counter properly when the state is removed.

  </ul>

<li>Routing daemons and other userland network programs saw the following improvements:
<ul>
  <li>Make <a href="https://man.openbsd.org/getaddrinfo.3">getaddrinfo(3)</a>
	convert numeric host addresses for all address families,
	independent of them being listed in /etc/resolv.conf.
  <li>Added <a href="https://man.openbsd.org/lldpd.8">lldpd(8)</a>,
      Link Layer Discovery Protocol (LLDP) daemon, and
      <a href="https://man.openbsd.org/lldp.8">lldp(8)</a> control program.
  <li>Added <a href="https://man.openbsd.org/bpflogd.8">bpflogd(8)</a>,
      Berkeley Packet Filter logging daemon.
  <li>Disallow <a href="https://man.openbsd.org/nc.1">nc(1)</a>
	<code>-T</code> with = when arguments are not key=value pairs.
  <li>Add SOCKS4A support to <a
	href="https://man.openbsd.org/nc.1">nc(1)</a>
	proxy (<code>-X</code>) mode.
  <li>Add ALPN TLS option, so you can specify <code>-T</code> alpn=value
	in <a href="https://man.openbsd.org/nc.1">nc(1)</a>.
  <li>Make <a href="https://man.openbsd.org/iked.8">iked(8)</a> load
	multiple certificates as a certificate chain from a file.
  <li>In <a href="https://man.openbsd.org/relayd.8">relayd(8)</a>
	add tighter checks on inter-process messages.
  <li>Remove the currently useless "status memory" command in
	<a href="https://man.openbsd.org/unwindctl.8">unwindctl(8)</a>.
  <li>Disable aggressive-nsec when "force" is in use in
	<a href="https://man.openbsd.org/unwind.8">unwind(8)</a>.
  <li>Repair the printing of IPv6 route commands with
	<a href="https://man.openbsd.org/netstart.8">netstart(8)</a>
	<code>-n</code>, which was broken in 2022.
  <li>Change <a href="https://man.openbsd.org/dhcpd.8">dhcpd(8)</a> to
	use the rdomain/rtable it was started in.
  <li>Reduce the number of times that
	<a href="https://man.openbsd.org/dhcpleased.8">dhcpleased(8)</a> uses
	<a href="https://man.openbsd.org/if_indextoname.3">if_indextoname(3)</a>
	to translate an interface index to an interface name.
  <li>In <a href="https://man.openbsd.org/dhcp6leased.8">dhcp6leased(8)</a>,
	install reject route for prefix delegation, to
	prevent routing loops in case only parts of the delegated prefix are
	configured on interfaces.
  <li>Introduce a lower bound for the IPv6-Only preferred timelimit in
	<a href="https://man.openbsd.org/dhcpleased.8">dhcpleased(8)</a>.

  <li>Network statistics reporting using <a
	href="https://man.openbsd.org/netstat.1">netstat(1)</a> was changed:
  <ul>
  <li>The output of
	<a href="https://man.openbsd.org/netstat.1">netstat(1)</a>
	for multicast route and divert protocol statistics
	have been improved.
  <li>Export TCP send congestion window for IPv6 also to allow its
	display with <a
	href="https://man.openbsd.org/netstat.1">netstat(1)</a>
	<code>-B</code>.
  <li>Harmonize <a
	href="https://man.openbsd.org/netstat.1">netstat(1)</a> ip4 and ip6
	multicast counter output.
  <li>Provide m_pool_alloc() failures in mbstat, making the count
	visible in <a href="https://man.openbsd.org/netstat.1">netstat(1)</a>
	<code>-m</code>.
  <li>Remove specific divert6 netstat counters, use divert instead.
  </ul>

  <li><a href="https://man.openbsd.org/acme-client.1">acme-client(1)</a> saw several changes:
  <ul>
  <li>Made <a
	href="https://man.openbsd.org/acme-client.1">acme-client(1)</a> handle
	"processing" status by retrying.
  <li>Remove http support from <a
	href="https://man.openbsd.org/acme-client.1">acme-client(1)</a>, using
	https for the API server per RFC 8555.
  <li>Allow port numbers in API URLs, letting <a
	href="https://man.openbsd.org/acme-client.1">acme-client(1)</a> talk
	to Let's Encrypt's pebble server.
  <li>Implement draft-ietf-acme-profiles for <a
	href="https://man.openbsd.org/acme-client.1">acme-client(1)</a>.
  <li>Adapt renewal calculation for shortlived certificates in <a
        href="https://man.openbsd.org/acme-client.1">acme-client(1)</a>.
  </ul>

  <li>In <a href="https://man.openbsd.org/bgpd.8">bgpd(8)</a>:
  <ul>
  <li>In verbose mode log the NOTIFICATION data for UPDATE errors.
  <li>Fix a busy loop error in the pfkey handling.
  <li>Introduce monotime - an internal time API using microsecond resolution.
  <li>Fix accounting of the pending update counter
  <li>Use new ibufq interface instead of handrolling the same.
  <li>Large refactoring of internal APIs to make the code easier to share
      and cleaner.
  </ul>

  <li>In <a href="https://man.openbsd.org/rpki-client.8">rpki-client(8)</a>:
  <ul>
  <li>The parser process now uses parallel threads for object
	validation.  The new <code>-p</code> option can be used
	to adjust the number of threads.
  <li>Support for Canonical Cache Representation has been added.
	<a href="https://datatracker.ietf.org/doc/html/draft-spaghetti-sidrops-rpki-ccr">CCR</a>
	is a new DER-encoded data interchange format to support audit trail
	keeping, validated payload dissemination, and analytics pipelines.
  <li>Certificate parsing and validation has been completely reworked.
	In particular, a more stringent set of compliance checks based on RFC
	6487, RFC 8209, and RFC 8608 is imposed on end entity certificates.
  <li>Filemode is now able to detect most file types without recourse
	to the file name extension.
  <li>Experimental support for P-256 Trust Anchor keys was added.
  <li>Marshalling and unmarshalling of privsep messages was improved.
  <li>In verbose mode, warnings are emitted about uncompressed
	HTTP/RRDP transfers larger than one megabyte. Publication server
	operators are strongly encouraged to offer gzip compressed HTTP
	content-encoding, see draft-ietf-sidrops-publication-server-bcp,
	section 6.3.
  <li>Emit all key identifiers (AKI and SKI) encoded in JSON as bare
	hex strings without colons.
  <li>Fixed numerous minor issues flagged by the Coverity static analyzer.
  </ul>
</ul><!-- Routing daemons and other userland network improvements -->

<li><a href="https://man.openbsd.org/tmux.1">tmux(1)</a> improvements and bug fixes:
  <ul>
  <li>Allow <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> bind -r and -N to change an existing key binding if no command is specified.
  <li>Add more features for boolean expressions in <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> formats.
  <li>Add an option variation-selector-always-wide to instruct <a
	href="https://man.openbsd.org/tmux.1">tmux(1)</a> not to always
	interpret VS16 as a wide character and assume the terminal does
	likewise.
  <li>Add R format modifier to <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> to repeat an argument.
  <li>Add -E to run-shell to forward stderr as well as stdout in <a href="https://man.openbsd.org/tmux.1">tmux(1)</a>.
  <li>Fix several memory leaks.
  <li>Flush scrolling when wrapping so UTF-8 in last position draws correctly.
  <li>Treat Shift-Tab just like the up arrow in completion popup menu.
  <li>Fix PageDown in menus.
  <li>Replace invalid UTF-8 with the placeholder instead of ignoring them.
  <li>Add pane-border-lines value to use spaces for pane borders.
  <li>Add a nicer default second and third status line.
  <li>Add a <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> set-default style attribute which replaces the current default colours and attributes completely.
  <li>Add S: to list <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> sessions with modifiers for sorting.
  <li>Add <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> support for DECRQSS SP q (report cursor style), DECRQM ?12 (report cursor blink state) and DECRQM ?2004, ?1004, ?1006 (report mouse state).
  <li>Introduce <a href="https://man.openbsd.org/tmux.1">tmux(1)</a> new window option: tiled-layout-max-columns, which configures the maximum number of columns in the tiled layout. 



</ul>

<li>LibreSSL version 4.2.0:
  <ul>
  <li>Portable changes:
    <ul>
      <li>Added explicit OpenBSD/ISC license to build system / scripts.</li>
      <li>Fixed compilation on more CPU targets by removing architecture-specific definitions from header files.</li>
      <li>Fixed builds in deep paths by using relative paths for linking.</li>
      <li>Fixed Windows builds with Clang and CMake.</li>
      <li>Fixed Windows error handling accepting connections with nc.</li>
    </ul>
  <li>Internal improvements:
    <ul>
    <li>Cleaned up code implementing block cipher modes of operation.
	Includes untangling a horrible <code>#ifdef</code> mess and removing a few
	instances of undefined behavior.
    <li>Removed assembly implementations of AES using bit slicing (BS-AES)
	and vector permutation (VP-AES).
    <li>Removed <code>OPENSSL_SMALL_FOOTPRINT</code> and <code>OPENSSL_FIPSAPI</code>.
    <li>Implemented constant time EC field element operations to allow
	elliptic curve operations without bignum arithmetic.
    <li>Implemented an EC method using homogeneous projective coordinates.
	This will allow exception-free elliptic curve arithmetic in
	constant time in future releases.
    <li>Started cleaning up the openssl speed implementation.
    <li>The last <code>SIGILL</code>-based CPU capability detection was removed.
	Instead, capabilities are now detected using a constructor on
	library load, which improves the incomplete coverage by calls
	to <a href="https://man.openbsd.org/OPENSSL_init_crypto.3"
	>OPENSSL_init_crypto(3)</a> on various entry points.
    <li>Rework and simplify AES handling in EVP. In particular, AES-NI
	is now handled in the AES internal code and no longer requires
	the use of <a href="https://man.openbsd.org/evp.3">EVP</a>.
    <li>Added a public API for ML-KEM. This is not yet documented in a
	manpage and may not be in its final form. This will be used to
	support X25519MLKEM768 in libssl.
    </ul>
  <li>Compatibility changes:
    <ul>
    <li>Removed the -msie_hack option from the
	<a href="https://man.openbsd.org/openssl.1">openssl(1)</a>
	<a href="https://man.openbsd.org/openssl.1#ca">ca</a>
	subcommand.
    <li>Removed parameters of the 239-bit prime curves from X9.62, H.5.2:
	prime239v1, prime239v2, prime239v3.
    <li>Increased default MAC salt length used by PKCS12_set_mac(3) to 16 
	per recommendation of NIST SP 800-132.
    <li>Encrypted PKCS#8 key files now use a default password-based key
	derivation function that is acceptable in the present millennium.
    <li>const corrected
	<a href="https://man.openbsd.org/EVP_PKEY_get1_RSA.3"
	>EVP_PKEY_get{0,1}_{DH,DSA,EC_KEY,RSA}(3)</a>.
    <li><a href="https://man.openbsd.org/X509_CRL_verify.3"
	>X509_CRL_verify(3)</a> now checks that the AlgorithmIdentifiers in the
	signature and the tbsCertList are identical.
    <li>Of the old *err() only PEMerr(), RSAerr(), and SSLerr() remain.
    <li>Remove BIO_s_log(),
	<a href="https://man.openbsd.org/OpenBSD-7.7/X509_PKEY_new.3"
	>X509_PKEY_{new,free}(3)</a>,
	<a href="https://man.openbsd.org/OpenBSD-7.7/PEM_X509_INFO_read.3"
	>PEM_X509_INFO_read(3)</a>, and PEM_X509_INFO_write_bio().
    <li>Re-expose the ASN.1 Boolean template items.
    <li>opensslconf.h is now machine-independent.
    </ul>
  <li>New features:
    <ul>
    <li>Allow specifying ALPN in <a href="https://man.openbsd.org/nc.1#T">nc(1)</a>
	via -Talpn="http/1.1,http:/1.0".
    </ul>
  <li>Bug fixes:
    <ul>
    <li>Avoid pointer arithmetic on <code>NULL</code> for memory BIOs.
    <li>Fix leaks and use-after-frees in PKCS7 attribute handling.
    <li>Ensure p and q in RSA private key have a minimum distance of
	2^(bits/2 - 100) as specified in NIST SP 800-56B Revision 2.
    </ul>
  <li>Security fixes:
    <ul>
    <li>Fix out-of-bounds read and write, memory leaks and incorrect
	error check for CMS enveloped data.
    </ul>
  <li>Documentation:
    <ul>
    <li>Rewrote most of the EC documentation from scratch to be at least
	somewhat accurate and intelligible.
    <li>Updated documentation for SMIME_{read,write}* to match reality.
    </ul>
  <li>Testing and proactive security:
    <ul>
    <li>Added a testing framework that will help deduplicating lots of
	ad-hoc code in the regression tests.
    <li>Converted the Wycheproof testing framework to use testvectors_v1.
	This in combination with a few new tests significantly increases
	regress coverage.
    </ul>
  </ul>

<li>OpenSSH 10.2:
  <ul>
  <li>Security fixes:
    <ul>
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
        disallow control characters in usernames passed via the
        commandline or expanded using %-sequences from the configuration
        file, and disallow \0 characters in ssh:// URIs.
        <br>
        If an ssh(1) commandline was constructed using usernames or URIs
        obtained from an untrusted source, and if a ProxyCommand that uses
        the %r expansion was configured, then it may be possible for an
        attacker to inject shell expressions that may be executed when the
        proxy command is started.
        <br>
        We strongly recommend against using untrusted inputs to construct
        ssh(1) commandlines.
        <br>
        This change also relaxes the validity checks in one small way:
        usernames supplied via the configuration file as literals (i.e.
        that have no % expansion characters) are not subject to these
        validity checks. This allows usernames that contain arbitrary
        characters to be used, but only via configuration files. This is
        done on the basis that ssh's configuration is trusted.
        <br>
        This issue was reported by David Leadbeater.
    </ul>
  <li>Potentially incompatible changes:
    <ul>
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
        add a warning when the connection negotiates a non-post
        quantum safe key agreement algorithm.
        <br>
        This warning has been added due to the risk of "store now, decrypt
        later" attacks. More details at the
	<a href="https://openssh.com/pq.html"
	>OpenSSH Post-Quantum Cryptography</a> page.
        <br>
        This warning may be controlled via a new <code>WarnWeakCrypto</code>
        <a href="https://man.openbsd.org/ssh_config">ssh_config(5)</a>
	option, defaulting to on. This option is likely to control
        additional weak crypto warnings in the future.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>,
        <a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
        major changes to handling of DSCP marking/<code>IPQoS</code>
        <br>
        Both the client and the server have changed the default DSCP
        (a.k.a IPQoS) values and the way these values are selected at
        runtime.
        <br>
        Both endpoints now use Expedited Forward (EF) for interactive
        traffic by default. This provides better prioritisation,
        especially on wireless media (cf. RFC 8325). Non-interactive
        traffic now uses the operating system default DSCP marking.
        Both the interactive and non-interactive DSCP values may be
        overridden via the <code>IPQoS</code> keyword in <a
        href="https://man.openbsd.org/ssh_config.5">ssh_config(5)</a> and
        <a href="https://man.openbsd.org/sshd_config.5">sshd_config(5)</a>.
        <br>
        The DSCP value selected may now change over the course of a
        connection. ssh(1) and sshd(8) will automatically select between
        the interactive and non-interactive IPQoS values depending on
        the type of SSH channels open. E.g. if an sftp session is using
        the connection, then the non-interactive value will be used.
        <br>
        This is important now that the default interactive IPQoS is EF
        (Expedited Forwarding), as many networks are configured to allow
        only relatively small amounts of traffic of this class and they will
        aggressively deprioritise the entire connection if this is exceeded.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>,
        <a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
        deprecate support for IPv4 type-of-service (TOS)
        keywords in the IPQoS configuration directive.
        <br>
        Type of Service (ToS) was deprecated in the late nineties and
        replaced with the Differentiated Services architecture. Diffserv
        has significant advantages for operators because this mechanism
        offers more granularity.
        <br>
        OpenSSH switched its default IPQoS from ToS to DSCP values in 2018.
        <br>
        IPQoS configurations with 'lowdelay', 'reliability', or
        'throughput' will be ignored and instead the system default QoS
        settings apply. Additionally, a debug message is logged about the
        deprecation with a suggestion to use DSCP.
      <li><a href="https://man.openbsd.org/ssh-add.1">ssh-add(1)</a>:
        when adding certificates to an agent, set the expiry
        to the certificate expiry time plus a short (5 min) grace period.
        <br>
        This will cause the agent to automatically remove certificates shortly
        after they expire. A new ssh-add(1) <code>-N</code> option
	disables this behaviour.
      <li>All: remove experimental support for XMSS keys. This was never
        enabled by default. We expect to implement a new post-quantum
        signature scheme in the near future.
      <li><a href="https://man.openbsd.org/ssh-agent.1">ssh-agent(1)</a>,
	<a href="https://man.openbsd.org/sshd.8">sshd(8)</a>: move agent
	listener sockets from /tmp to under ~/.ssh/agent
	for both ssh-agent(1) and forwarded sockets in sshd(8).
        <br>
        This ensures processes that have restricted filesystem access
        that includes /tmp do not ambiently have the ability to use keys
        in an agent.
        <br>
        Moving the default directory has the consequence that the OS will
        no longer clean up stale agent sockets, so ssh-agent(1) now gains
        this ability.
        <br>
        To support $HOME on NFS, the socket path includes a truncated hash of
        the hostname. ssh-agent(1) will by default only clean up sockets from
        the same hostname.
        <br>
        ssh-agent(1) gains some new flags: <code>-U</code> suppresses the
	automatic cleanup of stale sockets when it starts.
	<code>-u</code> forces a cleanup without keeping a running agent,
	<code>-uu</code> forces a cleanup that ignores the hostname.
	<code>-T</code> makes ssh-agent(1) put the socket back in /tmp.
    </ul>

  <li>New features:
    <ul>
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>,
	<a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	add <code>SIGINFO</code> handlers to log active channel and
        session information.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	when refusing a certificate for user authentication, log
        enough information to identify the certificate in addition to the
        reason why it was being denied. Makes debugging certificate
        authorisation problems a bit easier.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>,
	<a href="https://man.openbsd.org/ssh-agent.1">ssh-agent(1)</a>:
	support ed25519 keys hosted on PKCS#11 tokens.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
	add a <a href="https://man.openbsd.org/ssh_config.5">ssh_config(5)</a>
	RefuseConnection option that, when encountered while processing
	an active section in a configuration terminates ssh(1) with an
	error message that contains the argument to the option.
        <br>
          This may be useful for expressing reminders or warnings in config
          files, for example:
        <pre>
          Match host foo
              RefuseConnection "foo is deprecated, use splork instead"
        </pre>
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	make the X11 display number check relative to
        X11DisplayOffset. This will allows people to use X11DisplayOffset
        to configure much higher port ranges if they really want, while
        not changing the default behaviour.
      <li>unit tests: the unit test framework now includes some basic
        benchmarking capabilities. Run with "make UNITTEST_BENCHMARK=yes".
    </ul>

  <li>Bugfixes:
    <ul>
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	fix mistracking of MaxStartups process exits in some
        situations. At worst, this could cause all MaxStartups slots to
        fill and sshd(8) to refuse new connections.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
	fix delay on X client startup when ObscureKeystrokeTiming is enabled.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	increase the maximum size of the supported configuration
        from 256KB to 4MB, which ought to be enough for anybody. Fail
        early and visibly when this limit is breached.
      <li><a href="https://man.openbsd.org/sftp.1">sftp(1)</a>:
	during sftp uploads, avoid a condition where a failed
        write could be ignored if a subsequent write succeeded. This is
        unlikely but technically possible because sftp servers are
        allowed to reorder requests.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	avoid a race condition when the sshd-auth process exits
        that could cause a spurious error message to be logged.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	log at level <code>INFO</code> when PerSourcePenalties actually
        blocks access to a source address range. Previously this was
        logged at level <code>VERBOSE</code>, which hid enforcement
	actions under default config settings.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	GssStrictAcceptor was missing from sshd(8) <code>-T</code> output; fix
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	Make the MaxStartups and PerSourceNetBlockSize options
        first-match-wins as advertised.
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
	fix an incorrect return value check in the local forward
        cancellation path that would cause failed cancellations not to be
        logged.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	make "Match !final" not trigger a 2nd pass ssh_config
        parsing pass (unless hostname canonicalisation or a separate
        "Match final" does).
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
	better debug diagnostics when loading keys. Will now list
        key fingerprint and algorithm (not just algorithm number) as well
        as making it explicit which keys didn't load.
      <li>All: fix a number of memory leaks found by LeakSanitizer,
        Coverity and manual inspection.
      <li><a href="https://man.openbsd.org/sshd.8">sshd(8)</a>:
	Output the current name for PermitRootLogin's
        "prohibit-password" in sshd(8) <code>-T</code> instead of its
	deprecated alias "without-password".
      <li><a href="https://man.openbsd.org/ssh.1">ssh(1)</a>:
	make writing known_hosts lines more atomic by writing
        the entire line in one operation and using unbuffered stdio.
        <br>
        Usually writes to this file are serialised on the "Are you sure you
        want to continue connecting?" prompt, but if host key checking is
        disabled and connections were being made with high concurrency
        then interleaved writes might have been possible.
    </ul>
  </ul>

<li>Ports and packages:
  <p>Many pre-built packages for each architecture:
  <!-- number of FTP packages minus SHA256, SHA256.sig, index.txt -->
  <ul style="column-count: 3">
    <li>aarch64:    12506
    <li>amd64:      12651
    <li>arm:        8903
    <li>i386:       10457
    <li>mips64:     8484
    <li>powerpc:    10073
    <li>powerpc64:  9698
    <li>riscv64:    10593
    <li>sparc64:    9088
  </ul>

  <p>Some highlights:
  <ul style="column-count: 3"><!-- checked 2025-10-XX -->
    <li>Asterisk 16.30.1, 18.26.4, 20.15.2 and 22.5.2
    <li>Audacity 3.7.5
    <li>CMake 3.31.8
    <li>Chromium 141.0.7390.54
    <li>Emacs 30.2
    <li>FFmpeg 6.1.3
    <li>GCC 8.4.0 and 11.2.0
    <li>GHC 9.8.3
    <li>GNOME 48
    <li>Go 1.25.1
    <li>JDK 8u462, 11.0.28, 17.0.16, 21.0.8 and 25.0.0
    <li>KDE Applications 25.08.1
    <li>KDE Frameworks 6.18.0
    <li>KDE Plasma 6.4.5
    <li>Krita 5.2.13
    <li>LLVM/Clang 19.1.7, 20.1.8 and 21.1.2
    <li>LibreOffice 25.8.1.1
    <li>Lua 5.1.5, 5.2.4, 5.3.6 and 5.4.7
    <li>MariaDB 11.4.7
    <li>Mono 6.12.0.199
    <li>Mozilla Firefox 143.0.3 and ESR 140.3.1
    <li>Mozilla Thunderbird 143.3.1
    <li>Mutt 2.2.15 and NeoMutt 20250905
    <li>Node.js 22.20.0
    <li>OCaml 4.14.2
    <li>OpenLDAP 2.6.10
    <li>PHP 8.2.29, 8.3.26 and 8.4.13
    <li>Postfix 3.5.25 and 3.10.1
    <li>PostgreSQL 17.6
    <li>Python 2.7.18 and 3.12.11
    <li>Qt 5.15.16 (+ kde patches) and 6.8.3
    <li>R 4.5.1
    <li>Ruby 3.2.9, 3.3.9 and 3.4.6
    <li>Rust 1.90.0
    <li>SQLite 3.50.4
    <li>Shotcut 25.08.16
    <li>Sudo 1.9.17p2
    <li>Suricata 7.0.7
    <li>Tcl/Tk 8.5.19 and 8.6.16
    <li>TeX Live 2025
    <li>Vim 9.1.1706 and Neovim 0.11.4
    <li>Xfce 4.20.0
  </ul>
  <p>

<li>As usual, steady improvements in manual pages and other documentation.

<li>The system includes the following major components from outside suppliers:
  <ul><!-- updated 2025-10-09 -->
    <li>Xenocara (based on X.Org 7.7 with xserver 21.1.18 + patches,
        freetype 2.13.3, fontconfig 2.15.0, Mesa 25.0.7, xterm 399,
        xkeyboard-config 2.20, fonttosfnt 1.2.4 and more)
    <li>LLVM/Clang 19.1.7 (+ patches)
    <li>GCC 4.2.1 (+ patches) and 3.3.6 (+ patches)
    <li>Perl 5.40.1 (+ patches)
    <li>pkgconf 2.4.3
    <li>NSD 4.13.0
    <li>Unbound 1.24.0
    <li>Ncurses 6.4
    <li>Binutils 2.17 (+ patches)
    <li>GDB 6.3 (+ patches)
    <li>Awk 20250116
    <li>Expat 2.7.3
    <li>zlib 1.3.1 (+ patches)
  </ul>
</ul>
</section>

<hr>

<section id="install">
<h3>How to install</h3>
<p>
Please refer to the following files on the mirror site for
extensive details on how to install OpenBSD 7.8 on your machine:

<ul>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/alpha/INSTALL.alpha">
	.../OpenBSD/7.8/alpha/INSTALL.alpha</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/amd64/INSTALL.amd64">
	.../OpenBSD/7.8/amd64/INSTALL.amd64</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/arm64/INSTALL.arm64">
	.../OpenBSD/7.8/arm64/INSTALL.arm64</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/armv7/INSTALL.armv7">
	.../OpenBSD/7.8/armv7/INSTALL.armv7</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/hppa/INSTALL.hppa">
	.../OpenBSD/7.8/hppa/INSTALL.hppa</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/i386/INSTALL.i386">
	.../OpenBSD/7.8/i386/INSTALL.i386</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/landisk/INSTALL.landisk">
	.../OpenBSD/7.8/landisk/INSTALL.landisk</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/loongson/INSTALL.loongson">
	.../OpenBSD/7.8/loongson/INSTALL.loongson</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/luna88k/INSTALL.luna88k">
	.../OpenBSD/7.8/luna88k/INSTALL.luna88k</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/macppc/INSTALL.macppc">
	.../OpenBSD/7.8/macppc/INSTALL.macppc</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/octeon/INSTALL.octeon">
	.../OpenBSD/7.8/octeon/INSTALL.octeon</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/powerpc64/INSTALL.powerpc64">
	.../OpenBSD/7.8/powerpc64/INSTALL.powerpc64</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/riscv64/INSTALL.riscv64">
	.../OpenBSD/7.8/riscv64/INSTALL.riscv64</a>
<li><a href="https://ftp.openbsd.org/pub/OpenBSD/7.8/sparc64/INSTALL.sparc64">
	.../OpenBSD/7.8/sparc64/INSTALL.sparc64</a>
</ul>
</section>

<hr>

<section id="quickinstall">
<p>
Quick installer information for people familiar with OpenBSD, and the use of
the "<a href="https://man.openbsd.org/disklabel.8">disklabel</a> -E" command.
If you are at all confused when installing OpenBSD, read the relevant
INSTALL.* file as listed above!

<h3>OpenBSD/alpha:</h3>

<p>
If your machine can boot from CD, you can write <i>install78.iso</i> or
<i>cd78.iso</i> to a CD and boot from it.
Refer to INSTALL.alpha for more details.

<h3>OpenBSD/amd64:</h3>

<p>
If your machine can boot from CD, you can write <i>install78.iso</i> or
<i>cd78.iso</i> to a CD and boot from it.
You may need to adjust your BIOS options first.

<p>
If your machine can boot from USB, you can write <i>install78.img</i> or
<i>miniroot78.img</i> to a USB stick and boot from it.

<p>
If you can't boot from a CD, floppy disk, or USB,
you can install across the network using PXE as described in the included
INSTALL.amd64 document.

<p>
If you are planning to dual boot OpenBSD with another OS, you will need to
read INSTALL.amd64.

<h3>OpenBSD/arm64:</h3>

<p>
Depending on your hardware, you can write <i>install78.iso</i>
or <i>cd78.iso</i> to a CD and boot from it, or write a system specific
miniroot to an SD card and boot from it after connecting to the serial
console.  Refer to INSTALL.armv64 for more details.

<h3>OpenBSD/armv7:</h3>

<p>
Write a system specific miniroot to an SD card and boot from it after connecting
to the serial console.  Refer to INSTALL.armv7 for more details.

<h3>OpenBSD/hppa:</h3>

<p>
Boot over the network by following the instructions in INSTALL.hppa or the
<a href="hppa.html#install">hppa platform page</a>.

<h3>OpenBSD/i386:</h3>

<p>
If your machine can boot from CD, you can write <i>install78.iso</i> or
<i>cd78.iso</i> to a CD and boot from it.
You may need to adjust your BIOS options first.

<p>
If your machine can boot from USB, you can write <i>install78.img</i> or
<i>miniroot78.img</i> to a USB stick and boot from it.

<p>
If you can't boot from a CD, floppy disk, or USB,
you can install across the network using PXE as described in
the included INSTALL.i386 document.

<p>
If you are planning on dual booting OpenBSD with another OS, you will need to
read INSTALL.i386.

<h3>OpenBSD/landisk:</h3>

<p>
Write <i>miniroot78.img</i> to the start of the CF
or disk, and boot normally.

<h3>OpenBSD/loongson:</h3>

<p>
Write <i>miniroot78.img</i> to a USB stick and boot bsd.rd from it
or boot bsd.rd via tftp.
Refer to the instructions in INSTALL.loongson for more details.

<h3>OpenBSD/luna88k:</h3>

<p>
Copy 'boot' and 'bsd.rd' to a Mach or UniOS partition, and boot the bootloader
from the PROM, and then bsd.rd from the bootloader.
Refer to the instructions in INSTALL.luna88k for more details.

<h3>OpenBSD/macppc:</h3>

<p>
Burn the <i>install78.iso</i> image from a mirror site to a CDROM,
and power on your machine while holding down the <i>C</i> key until
the display turns on and shows <i>OpenBSD/macppc boot</i>.

<p>
Alternatively, at the Open Firmware prompt, enter <i>boot cd:,ofwboot
/7.8/macppc/bsd.rd</i>

<h3>OpenBSD/octeon:</h3>

<p>
After connecting a serial port, boot bsd.rd over the network via DHCP/tftp.
Refer to the instructions in INSTALL.octeon for more details.

<h3>OpenBSD/powerpc64:</h3>

<p>
To install, write <i>install78.img</i> or <i>miniroot78.img</i> to a
USB stick, plug it into the machine and choose the <i>OpenBSD
install</i> menu item in Petitboot.
Refer to the instructions in INSTALL.powerpc64 for more details.

<h3>OpenBSD/riscv64:</h3>

<p>
To install, write <i>install78.img</i> or <i>miniroot78.img</i> to a
USB stick, and boot with that drive plugged in.
Make sure you also have the microSD card plugged in that shipped with the
HiFive Unmatched board.
Refer to the instructions in INSTALL.riscv64 for more details.

<h3>OpenBSD/sparc64:</h3>

<p>
Burn the image from a mirror site to a CDROM, boot from it, and type
<i>boot cdrom</i>.

<p>
If this doesn't work, or if you don't have a CDROM drive, you can write
<i>floppy78.img</i> or <i>floppyB78.img</i>
(depending on your machine) to a floppy and boot it with <i>boot
floppy</i>. Refer to INSTALL.sparc64 for details.

<p>
Make sure you use a properly formatted floppy with NO BAD BLOCKS or your install
will most likely fail.

<p>
You can also write <i>miniroot78.img</i> to the swap partition on
the disk and boot with <i>boot disk:b</i>.

<p>
If nothing works, you can boot over the network as described in INSTALL.sparc64.
</section>

<hr>

<section id="upgrade">
<h3>How to upgrade</h3>
<p>
If you already have an OpenBSD 7.7 system, and do not want to reinstall,
upgrade instructions and advice can be found in the
<a href="faq/upgrade78.html">Upgrade Guide</a>.
</section>

<hr>

<section id="sourcecode">
<h3>Notes about the source code</h3>
<p>
<code>src.tar.gz</code> contains a source archive starting at <code>/usr/src</code>.
This file contains everything you need except for the kernel sources,
which are in a separate archive.
To extract:
<blockquote><pre>
# <kbd>mkdir -p /usr/src</kbd>
# <kbd>cd /usr/src</kbd>
# <kbd>tar xvfz /tmp/src.tar.gz</kbd>
</pre></blockquote>
<p>
<code>sys.tar.gz</code> contains a source archive starting at <code>/usr/src/sys</code>.
This file contains all the kernel sources you need to rebuild kernels.
To extract:
<blockquote><pre>
# <kbd>mkdir -p /usr/src/sys</kbd>
# <kbd>cd /usr/src</kbd>
# <kbd>tar xvfz /tmp/sys.tar.gz</kbd>
</pre></blockquote>
<p>
Both of these trees are a regular CVS checkout.  Using these trees it
is possible to get a head-start on using the anoncvs servers as
described <a href="anoncvs.html">here</a>.
Using these files
results in a much faster initial CVS update than you could expect from
a fresh checkout of the full OpenBSD source tree.
</section>

<hr>

<section id="ports">
<h3>Ports Tree</h3>
<p>
A ports tree archive is also provided.  To extract:
<blockquote><pre>
# <kbd>cd /usr</kbd>
# <kbd>tar xvfz /tmp/ports.tar.gz</kbd>
</pre></blockquote>
<p>
Go read the <a href="faq/ports/index.html">ports</a> page
if you know nothing about ports
at this point.  This text is not a manual of how to use ports.
Rather, it is a set of notes meant to kickstart the user on the
OpenBSD ports system.
<p>
The <i>ports/</i> directory represents a CVS checkout of our ports.
As with our complete source tree, our ports tree is available via
<a href="anoncvs.html">AnonCVS</a>.
So, in order to keep up to date with the -stable branch, you must make
the <i>ports/</i> tree available on a read-write medium and update the tree
with a command like:
<blockquote><pre>
# <kbd>cd /usr/ports</kbd>
# <kbd>cvs -d anoncvs@server.openbsd.org:/cvs update -Pd -rOPENBSD_7_8</kbd>
</pre></blockquote>
<p>
[Of course, you must replace the server name here with a nearby anoncvs
server.]
<p>
Note that most ports are available as packages on our mirrors. Updated
ports for the 7.8 release will be made available if problems arise.
<p>
If you're interested in seeing a port added, would like to help out, or just
would like to know more, the mailing list
<a href="mail.html">ports@openbsd.org</a> is a good place to know.
</section>
</body>
</html>