1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-17 15:27:36 +00:00
Mirror of the FreeBSD src repository https://git.FreeBSD.org/src.git .
Go to file
Dexuan Cui 985455c0cc loader.efi: reduce the size of the staging area if necessary
The loader assumes physical memory in [2MB, 2MB + EFI_STAGING_SIZE)
is Conventional Memory, but actually it may not, e.g. in the case
of Hyper-V Generation-2 VM (i.e. UEFI VM) running on Windows
Server 2012 R2 host, there is a BootServiceData memory block at
the address 47.449MB and the memory is not writable.

Without the patch, the loader will crash in efi_copy_finish():
see PR 211746.

The patch verifies the end of the staging area, and reduces its
size if necessary. This way, the loader will not try to write into
the BootServiceData memory any longer.

Thank Marcel Moolenaar for helping me on this issue!

The patch also allocates the staging area in the first 1GB memory.
See the comment in the patch for this.

PR:		211746
Reviewed by:	marcel, kib, sephe
Approved by:	sephe (mentor)
MFC after:	2 weeks
Sponsored by:	Microsoft
Differential Revision:	https://reviews.freebsd.org/D9686
2017-03-02 07:25:50 +00:00
bin Renumber copyright clause 4 2017-02-28 23:42:47 +00:00
cddl Fix memory leaks in error cases in libdtrace. 2017-02-23 17:56:24 +00:00
contrib Update jemalloc to 4.5.0. 2017-03-02 01:14:48 +00:00
crypto Upgrade to OpenSSH 7.3p1. 2017-03-02 00:11:32 +00:00
etc Remove SVR4 (System V Release 4) binary compatibility support. 2017-02-28 05:14:42 +00:00
gnu Use SRCTOP/OBJTOP and simplify output using :H instead of "../" for directory 2017-02-11 20:12:54 +00:00
include Sort declaration of sem_clockwait_np 2017-02-28 21:47:00 +00:00
kerberos5 Conditionalize adding ${KRB5DIR}/lib/gssapi/krb5/gkrb5_err.et to ETSRCS 2017-01-02 19:03:01 +00:00
lib Expose the sbuf_putbuf() symbol to libsbuf. There are a few other symbols 2017-03-02 01:39:23 +00:00
libexec Renumber copyright clause 4 2017-02-28 23:42:47 +00:00
release Revert prior commit to restore the files mangled by my "fixing" merge 2017-03-01 02:10:40 +00:00
rescue Conditionally compile certain programs into rescue(8) if requested 2017-02-25 03:23:11 +00:00
sbin Update to reflect that SHA-1 has now been broken. 2017-03-02 00:27:21 +00:00
secure Upgrade to OpenSSH 7.3p1. 2017-03-02 00:11:32 +00:00
share Wordsmith mlx4{en,ib}(4) 2017-03-02 06:57:13 +00:00
sys loader.efi: reduce the size of the staging area if necessary 2017-03-02 07:25:50 +00:00
targets Remove pc98 support completely. 2017-01-28 02:22:15 +00:00
tests Add an ATF test for IPv6 SLAAC with multiple fibs 2017-03-01 00:28:04 +00:00
tools Renumber copyright clause 4 2017-02-28 23:42:47 +00:00
usr.bin Revert prior commit to restore the files mangled by my "fixing" merge 2017-03-01 02:10:40 +00:00
usr.sbin Use SRCTOP-relative paths to other directories instead of .CURDIR-relative ones 2017-03-02 05:04:45 +00:00
.arcconfig callsign isn't required anymore 2016-09-29 06:19:45 +00:00
.arclint
COPYRIGHT Bump copyright year. 2016-12-31 12:41:42 +00:00
LOCKS
MAINTAINERS Remove myself from kern_timeout.c yeah! 2016-07-27 20:37:32 +00:00
Makefile Remove pc98 support completely. 2017-01-28 02:22:15 +00:00
Makefile.inc1 Document why cat is a bootstrap tool. 2017-02-21 18:49:30 +00:00
Makefile.libcompat Use cross-NM (XNM) in compat32 build 2017-01-27 03:43:18 +00:00
ObsoleteFiles.inc Don't remove ofwdump.8 on FreeBSD/mips. 2017-02-28 19:32:45 +00:00
README
README.md Remove hard line breaks from README.md 2017-03-01 15:39:58 +00:00
UPDATING add UPDATING entry for r314048, re-work of .zfs code 2017-02-21 17:54:38 +00:00

FreeBSD Source:

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

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

The buildkernel and installkernel targets build and install the kernel and the modules (see below). Please see the top of the Makefile in this directory for more information on the standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process. See build(7), config(8), and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information.

Note: If you want to build and install the kernel with the buildkernel and installkernel targets, you might need to build world before. More information is available in the handbook.

The kernel configuration files reside in the sys/<arch>/conf sub-directory. GENERIC is the default configuration used in release builds. NOTES contains entries and documentation for all possible devices, not just those commonly used.

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.

sys				Kernel sources.

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:

http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html