This patch introduces x86_64 (64-bit) support to the payload, building upon the existing x86 (32-bit) architecture. Files necessary for 64-bit compilation are now guarded by the `CONFIG_LP_ARCH_X86_64` Kconfig option. BUG=b:242829490 TEST=Able to verify all valid combinations between coreboot and payload with this patch. Payload Entry Point Behavior with below code. +----------------+--------------------+----------------------------+ | LP_ARCH_X86_64 | Payload Entry Mode | Description | +----------------+--------------------+----------------------------+ | No | 32-bit | Direct protected mode init | +----------------+--------------------+----------------------------+ | Yes | 32-bit | Protected to long mode | +----------------+--------------------+----------------------------+ | Yes | 64-bit | Long mode initialization | +----------------+--------------------+----------------------------+ Change-Id: I69fda47bedf1a14807b1515c4aed6e3a1d5b8585 Signed-off-by: Subrata Banik <subratabanik@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/81968 Reviewed-by: Julius Werner <jwerner@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
		
			
				
	
	
		
			221 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			221 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
#!/bin/sh
 | 
						|
##
 | 
						|
## Copyright (C) 2008 Advanced Micro Devices, Inc.
 | 
						|
##
 | 
						|
## Redistribution and use in source and binary forms, with or without
 | 
						|
## modification, are permitted provided that the following conditions
 | 
						|
## are met:
 | 
						|
## 1. Redistributions of source code must retain the above copyright
 | 
						|
##    notice, this list of conditions and the following disclaimer.
 | 
						|
## 2. Redistributions in binary form must reproduce the above copyright
 | 
						|
##    notice, this list of conditions and the following disclaimer in the
 | 
						|
##    documentation and/or other materials provided with the distribution.
 | 
						|
## 3. The name of the author may not be used to endorse or promote products
 | 
						|
##    derived from this software without specific prior written permission.
 | 
						|
##
 | 
						|
## THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
 | 
						|
## ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
						|
## IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | 
						|
## ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
 | 
						|
## FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | 
						|
## DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 | 
						|
## OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
						|
## HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 | 
						|
## LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 | 
						|
## OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 | 
						|
## SUCH DAMAGE.
 | 
						|
 | 
						|
# GCC wrapper for libpayload
 | 
						|
if [ "${V}" = "1" ]; then
 | 
						|
	DEBUGME=1
 | 
						|
else
 | 
						|
	DEBUGME=0
 | 
						|
fi
 | 
						|
 | 
						|
if [ $DEBUGME -eq 1 ]; then
 | 
						|
	echo "CC = $CC"
 | 
						|
fi
 | 
						|
 | 
						|
# let's not recurse.
 | 
						|
# This is a hack, I know, but it makes sure that really simple user errors
 | 
						|
# don't fork-bomb your machine.
 | 
						|
if [ -n "$CC" ]; then
 | 
						|
b=`basename "$CC"`
 | 
						|
if [ "$b" = "lpgcc" ]; then
 | 
						|
CC=""
 | 
						|
fi
 | 
						|
fi
 | 
						|
 | 
						|
if [ "$CC" != "" ]; then
 | 
						|
DEFAULT_CC=$CC
 | 
						|
else
 | 
						|
DEFAULT_CC=gcc
 | 
						|
fi
 | 
						|
 | 
						|
BASE=`dirname $0`
 | 
						|
 | 
						|
# This will set the _LIBDIR and _INCDIR variables used below
 | 
						|
. $BASE/lp.functions
 | 
						|
 | 
						|
if [ $_LIBDIR != $_OBJ ]; then
 | 
						|
	_DOTCONFIG=$BASE/../libpayload.config
 | 
						|
	_XCOMPILE=$BASE/../libpayload.xcompile
 | 
						|
else
 | 
						|
	_DOTCONFIG=$_OBJ/libpayload.config
 | 
						|
	_XCOMPILE=$_OBJ/xcompile
 | 
						|
fi
 | 
						|
 | 
						|
# include libpayload config
 | 
						|
if [ -f $_DOTCONFIG ]; then
 | 
						|
	. $_DOTCONFIG
 | 
						|
else
 | 
						|
	echo "Can't find config"
 | 
						|
	exit 1
 | 
						|
fi
 | 
						|
 | 
						|
if [ "$CONFIG_LP_ARCH_ARM" = "y" ]; then
 | 
						|
  _ARCHDIR=arm
 | 
						|
  _ARCHEXTRA=""
 | 
						|
 | 
						|
fi
 | 
						|
if [ "$CONFIG_LP_ARCH_ARM64" = "y" ]; then
 | 
						|
  _ARCHDIR=arm64
 | 
						|
  _ARCHEXTRA=""
 | 
						|
fi
 | 
						|
if [ "$CONFIG_LP_ARCH_X86" = "y" ]; then
 | 
						|
  _ARCHDIR=x86
 | 
						|
  if [ "$CONFIG_LP_ARCH_X86_32" = "y" ]; then
 | 
						|
    _ARCHEXTRA="-m32 "
 | 
						|
  else
 | 
						|
    _ARCHEXTRA="-m64 "
 | 
						|
  fi
 | 
						|
fi
 | 
						|
if [ "$CONFIG_LP_ARCH_MOCK" = "y" ]; then
 | 
						|
  _ARCHDIR=mock
 | 
						|
  _ARCHEXTRA=""
 | 
						|
fi
 | 
						|
 | 
						|
_ARCHINCDIR=$_INCDIR/$_ARCHDIR
 | 
						|
_ARCHLIBDIR=$_LIBDIR/$_ARCHDIR
 | 
						|
 | 
						|
if [ -f $_LIBDIR/libpayload.ldscript ]; then
 | 
						|
	_LDDIR=$_LIBDIR
 | 
						|
elif [ -f $BASE/../arch/$_ARCHDIR/libpayload.ldscript ]; then
 | 
						|
	_LDDIR=$BASE/../arch/$_ARCHDIR
 | 
						|
fi
 | 
						|
# Host arch should youse default linker script
 | 
						|
if [ "$CONFIG_LP_ARCH_MOCK" = "y" ]; then
 | 
						|
  _LDSCRIPT=""
 | 
						|
else
 | 
						|
  _LDSCRIPT="-Wl,-T,$_LDDIR/libpayload.ldscript"
 | 
						|
fi
 | 
						|
 | 
						|
trygccoption() {
 | 
						|
	$DEFAULT_CC $1 -S -xc /dev/null -o /dev/null &> /dev/null
 | 
						|
	return $?
 | 
						|
}
 | 
						|
 | 
						|
DOLINK=1
 | 
						|
 | 
						|
# This variable will contain the command line that the user wants to
 | 
						|
# pass to gas
 | 
						|
 | 
						|
CMDLINE=
 | 
						|
 | 
						|
# Process various flags that would change our behavior
 | 
						|
 | 
						|
while [ $# -gt 0 ]; do
 | 
						|
	case $1 in
 | 
						|
	    -m32|-fno-stack-protector|-m64)
 | 
						|
		shift
 | 
						|
		continue
 | 
						|
		;;
 | 
						|
	    -c)
 | 
						|
		DOLINK=0
 | 
						|
		;;
 | 
						|
	    -debug-wrapper)
 | 
						|
		DEBUGME=1
 | 
						|
		shift
 | 
						|
		continue
 | 
						|
		;;
 | 
						|
	    -Wl,-T,*)
 | 
						|
		_LDSCRIPT="$1"
 | 
						|
		shift
 | 
						|
		continue
 | 
						|
		;;
 | 
						|
	    *)
 | 
						|
		;;
 | 
						|
	esac
 | 
						|
 | 
						|
	CMDLINE="$CMDLINE $1"
 | 
						|
	shift
 | 
						|
done
 | 
						|
 | 
						|
_CFLAGS="$_ARCHEXTRA -nostdinc -nostdlib -I$_INCDIR -I$_ARCHINCDIR -D__LIBPAYLOAD__=1"
 | 
						|
 | 
						|
if [ $_LIBDIR = $_OBJ ]; then
 | 
						|
    _CFLAGS="$_CFLAGS -I$_OBJ"
 | 
						|
 | 
						|
    if [ "$CONFIG_LP_PDCURSES" = y ]; then
 | 
						|
	_CFLAGS="$_CFLAGS -I$BASE/../curses/PDCurses -I$BASE/../curses/pdcurses-backend"
 | 
						|
	_CFLAGS="$_CFLAGS -I$BASE/../curses/form -I$BASE/../curses/menu"
 | 
						|
    fi
 | 
						|
 | 
						|
    if [ "$CONFIG_LP_TINYCURSES" = y ]; then
 | 
						|
	_CFLAGS="$_CFLAGS -I$BASE/../curses"
 | 
						|
    fi
 | 
						|
 | 
						|
    _CFLAGS="$_CFLAGS -include $BASE/../../../src/commonlib/bsd/include/commonlib/bsd/compiler.h"
 | 
						|
    _CFLAGS="$_CFLAGS -I$BASE/../../../src/commonlib/bsd/include"
 | 
						|
    if [ "$CONFIG_LP_GPL" = y ]; then
 | 
						|
    _CFLAGS="$_CFLAGS -I$BASE/../../../src/commonlib/include"
 | 
						|
    fi
 | 
						|
    _CFLAGS="$_CFLAGS -I$BASE/../../../3rdparty/vboot/firmware/include"
 | 
						|
else
 | 
						|
    _CFLAGS="$_CFLAGS -include $BASE/../include/commonlib/bsd/compiler.h"
 | 
						|
    _CFLAGS="$_CFLAGS -I$_VBOOTINCDIR"
 | 
						|
fi
 | 
						|
 | 
						|
# Check for the -fno-stack-protector silliness
 | 
						|
 | 
						|
trygccoption -fno-stack-protector
 | 
						|
[ $? -eq 0 ] && _CFLAGS="$_CFLAGS -fno-stack-protector"
 | 
						|
 | 
						|
_CFLAGS="$_CFLAGS -include $BASE/../include/kconfig.h"
 | 
						|
_CFLAGS="$_CFLAGS -I`$DEFAULT_CC $_ARCHEXTRA -print-search-dirs | head -n 1 | cut -d' ' -f2`include"
 | 
						|
 | 
						|
if [ "$CONFIG_LP_VBOOT_LIB" = y ]; then
 | 
						|
	if [ "$CONFIG_LP_VBOOT_TPM2_MODE" = y ]; then
 | 
						|
		_CFLAGS="$_CFLAGS -DTPM2_MODE"
 | 
						|
	else
 | 
						|
		_CFLAGS="$_CFLAGS -DTPM1_MODE"
 | 
						|
	fi
 | 
						|
fi
 | 
						|
 | 
						|
_LDFLAGS="-L$_LIBDIR $_LDSCRIPT -static -Wl,--gc-sections"
 | 
						|
 | 
						|
if [ $DOLINK -eq 0 ]; then
 | 
						|
    if [ $DEBUGME -eq 1 ]; then
 | 
						|
	echo "$DEFAULT_CC $CMDLINE $_CFLAGS"
 | 
						|
    fi
 | 
						|
 | 
						|
    $DEFAULT_CC $CMDLINE $_CFLAGS
 | 
						|
else
 | 
						|
    _LIBGCC=`$DEFAULT_CC $_ARCHEXTRA -print-libgcc-file-name`
 | 
						|
 | 
						|
    if [ "$CONFIG_LP_ARM64_A53_ERRATUM_843419" = y ] &&
 | 
						|
       grep -q fix-cortex-a53-843419 $_XCOMPILE; then
 | 
						|
            _LDFLAGS="$_LDFLAGS -Wl,--fix-cortex-a53-843419"
 | 
						|
    fi
 | 
						|
 | 
						|
    _LDFLAGS="$_LDFLAGS -Wl,--defsym=CONFIG_LP_BASE_ADDRESS=$CONFIG_LP_BASE_ADDRESS"
 | 
						|
    _LDFLAGS="$_LDFLAGS -Wl,--defsym=CONFIG_LP_HEAP_SIZE=$CONFIG_LP_HEAP_SIZE"
 | 
						|
    _LDFLAGS="$_LDFLAGS -Wl,--defsym=CONFIG_LP_STACK_SIZE=$CONFIG_LP_STACK_SIZE"
 | 
						|
 | 
						|
    if [ $DEBUGME -eq 1 ]; then
 | 
						|
	echo "$DEFAULT_CC $_LDFLAGS $CMDLINE $_CFLAGS -lpayload $_LIBGCC"
 | 
						|
    fi
 | 
						|
 | 
						|
    $DEFAULT_CC $_LDFLAGS $CMDLINE $_CFLAGS -lpayload -xnone $_LIBGCC
 | 
						|
fi
 |