FreeBSD src
Go to file
Roger Pau Monné b6d85a5f51 stand/multiboot: adjust the protocol between loader and kernel
There's a currently ad-hoc protocol to hand off the FreeBSD kernel
payload between the loader and the kernel itself when Xen is in the
middle of the picture. Such protocol wasn't very resilient to changes
to the loader itself, because it relied on moving metadata around to
package it using a certain layout. This has proven to be fragile, so
replace it with a more robust version.

The new protocol requires using a xen_header structure that will be
used to pass data between the FreeBSD loader and the FreeBSD kernel
when booting in dom0 mode. At the moment the only data conveyed is the
offset of the start of the module metadata relative to the start of the
module itself.

This is a slightly disruptive change since it also requires a change
to the kernel which is contained in this patch. In order to update
with this change the kernel must be updated before updating the
loader, as described in the handbook. Note this is only required when
booting a FreeBSD/Xen dom0. This change doesn't affect the normal
FreeBSD boot protocol.

This fixes booting FreeBSD/Xen in dom0 mode after
3630506b9d.

Sponsored by:		Citrix Systems R&D
MFC after:		3 days
Reviewed by:		tsoome
Differential Revision:	https://reviews.freebsd.org/D28411
2021-01-29 15:23:26 +01:00
.github/workflows GitHub actions: unbreak macOS build 2021-01-08 15:36:38 +01:00
bin cp: fix indentation 2021-01-27 12:18:45 +01:00
cddl build: remove LIBPTHREAD/LIBTHR build options 2021-01-22 12:33:27 -06:00
contrib Un-XFAIL two tests with Clang > 10 2021-01-28 17:24:24 +00:00
crypto OpenSSL: Support for kernel TLS offload (KTLS) 2021-01-28 10:24:13 -08:00
etc BSD.usr.dist: remove aout 2021-01-07 19:14:01 -05:00
gnu gnu: remove gnugrep and libgnuregex 2020-12-25 15:16:33 -06:00
include Fix make includes path to nvpair.h 2021-01-19 21:23:25 +00:00
kerberos5 kerberos5: Silence compiler warnings 2021-01-27 17:48:47 +00:00
lib Avoid double output in fenv_test 2021-01-29 09:29:27 +00:00
libexec rc.d/auditd: set pidfile 2021-01-28 17:24:24 +00:00
release release: ROCKPRO64: Remove the quirk that disable the big cores 2021-01-27 23:31:18 +01:00
rescue ping: add a ping6 hard link for backwards compatibility 2020-11-26 18:33:04 +00:00
sbin sbin/sysctl: Fix CTLFLAG_SKIP for adjacent nodes 2021-01-27 14:27:46 -05:00
secure OpenSSL: Regenerate manual pages. 2021-01-28 10:24:24 -08:00
share hsctrl: Fix manpage typo 2021-01-29 00:40:01 +03:00
stand stand/multiboot: adjust the protocol between loader and kernel 2021-01-29 15:23:26 +01:00
sys stand/multiboot: adjust the protocol between loader and kernel 2021-01-29 15:23:26 +01:00
targets ndis(4): remove as previous announced 2021-01-25 21:45:03 +00:00
tests tests/sys/audit: fix timeout calculation 2021-01-28 17:24:24 +00:00
tools OpenSSL: Support for kernel TLS offload (KTLS) 2021-01-28 10:24:13 -08:00
usr.bin du: tests: use dollar-single quotes where appropriate 2021-01-28 21:02:58 -06:00
usr.sbin Now that the portsnap buildbox is generating the raw bits for INDEX-14, 2021-01-28 23:26:14 -08:00
.arcconfig arcconfig: add callsign again 2020-11-23 04:39:29 +00:00
.arclint
.cirrus.yml CI: switch to qemu42 package 2020-10-29 02:02:30 +00:00
.clang-format clang-format: Avoid breaking after the opening paren of function definitions 2020-10-28 11:54:00 +00:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore gitignore: expand list of ignored files 2021-01-14 17:03:57 +01:00
COPYRIGHT copyrights: Happy New Year 2021 2020-12-31 10:29:44 -05:00
LOCKS
MAINTAINERS Add a pointer to csprng@ for the CSPRNG driver. This is enforced anyway by 2020-09-01 08:02:12 +00:00
Makefile Rename NO_WERROR -> MK_WERROR=no 2021-01-07 09:31:03 +00:00
Makefile.inc1 build: remove LIBPTHREAD/LIBTHR build options 2021-01-22 12:33:27 -06:00
Makefile.libcompat libcompat: remove redundant path for ncurses 2021-01-07 15:14:52 +01:00
Makefile.sys.inc
ObsoleteFiles.inc ndis(4): remove as previous announced 2021-01-25 21:45:03 +00:00
README Mark the repository has been converted to Git 2020-12-23 12:27:27 +08:00
README.md Mark the repository has been converted to Git 2020-12-23 12:27:27 +08:00
RELNOTES Bump CURRENT to 14.0 2021-01-21 19:10:07 -05:00
UPDATING Bump __FreeBSD_version for multiple LinuxKPI updates conflicting 2021-01-28 16:37:28 +00:00

FreeBSD Source:

This is the top level of the FreeBSD source directory. This file was last revised on: FreeBSD

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), https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html, and https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information, including setting make(1) variables.

Source Roadmap:

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		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* 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.

sys/<arch>/conf Kernel configuration files. GENERIC is the configuration
		used in release builds. NOTES contains documentation of
		all possible entries.

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:

https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/current-stable.html