forked from sonic011gamer/Mu-Samsung
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build_uefi.sh
executable file
·129 lines (112 loc) · 4.76 KB
/
build_uefi.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#!/bin/bash
# Function to display Help Message
function _help(){
echo "Usage: ./build_uefi.sh -d <Codename> [-t <Tool Chain> -a <ARCH Type> -r <Build Mode> -m <RAM Size>]"
echo
echo "Build Project Mu UEFI for Samsung Exynos Platforms."
echo
echo "Options:"
echo " --device <Codename>, -d <Codename>: Build a Device."
echo " --release <Build Mode>, -r <Build Mode>: Release mode for building, 'RELEASE' is the default or use 'DEBUG' alternatively."
echo " --tool-chain <Tool Chain>, -t <Tool Chain>: Define wich Tool Chain to use, 'CLANG38' is default."
echo " --help, -h: Shows this Help."
echo " --memory <RAM Size>, -m <RAM Size>: Define how much Memory your Device has."
echo " --arch <ARCH Type>, -a <ARCH Type>: Define Wich ARCH Type to use for Target Device."
echo
echo "MainPage: https://github.com/sonic011gamer/Mu-Samsung"
exit 1
}
# Functions to display the Message Type (Error or Warning)
function _error(){ echo -e "\033[1;31m${@}\033[0m" >&2;exit 1; }
function _warn(){ echo -e "\033[0;33m${@}\033[0m" >&2; }
# Set Default Defines
TARGET_BUILD_MODE="RELEASE"
MULTIPLE_RAM_SIZE="FALSE"
MULTIPLE_ARCH_TYPE="FALSE"
TOOL_CHAIN_TAG="CLANG38"
# Check if any args were given
OPTS="$(getopt -o d:hfbcACDO:r:t:m:a: -l device:,help,release:,tool-chain:,memory:,arch: -n 'build_uefi.sh' -- "$@")"||exit 1
eval set -- "${OPTS}"
while true
do case "${1}" in
-d|--device) TARGET_DEVICE="${2}";shift 2;;
-h|--help) _help 0;shift;;
-r|--release) TARGET_BUILD_MODE="${2}";shift 2;;
-t|--tool-chain) TOOL_CHAIN_TAG="${2}";shift 2;;
-m|--memory) TARGET_RAM_SIZE="${2}";shift 2;;
-a|--arch) TARGET_ARCH_TYPE="${2}";shift 2;;
--) shift;break;;
*) _help 1;;
esac
done
# If no Device arg is present, Display the Help Message
if [ -z ${TARGET_DEVICE} ]
then _help
fi
# Set Release Type of UEFI
case "${TARGET_BUILD_MODE}" in
RELEASE) _TARGET_BUILD_MODE=RELEASE;;
*) _TARGET_BUILD_MODE=DEBUG;;
esac
# Include Device Config if it exists
if [ -f "configs/${TARGET_DEVICE}.conf" ]
then source "configs/${TARGET_DEVICE}.conf"
else _error "\nDevice configuration not found!\nCheck if your .conf File is in the 'configs' Folder\n"
fi
# Check for ARCH Configs and Parameters
if [ -z ${TARGET_ARCH_TYPE} ]
then TARGET_ARCH_TYPE=${DEFAULT_ARCH_TYPE}
else
if [ ${MULTIPLE_ARCH_TYPE} == FALSE ]
then TARGET_ARCH_TYPE=${DEFAULT_ARCH_TYPE}
fi
fi
# Correct ARCH Parameter
case "${TARGET_ARCH_TYPE}" in
AARCH64) _TARGET_ARCH_TYPE=AARCH64;;
*) _TARGET_ARCH_TYPE=ARM;;
esac
# Check if Device has more that one Static RAM Size
if [ -z ${TARGET_RAM_SIZE} ]; then
if [ ${MULTIPLE_RAM_SIZE} == TRUE ]
then _warn "\nThe Device you chose has more than one RAM Size!\nUse -m or --memory to define how much RAM your Device has.\n" && exit 0
fi
fi
# Delete Output Files if present
rm -r Conf &> /dev/null
rm ./BootShim/${_TARGET_ARCH_TYPE}/BootShim.bin &> /dev/null
rm ./BootShim/${_TARGET_ARCH_TYPE}/BootShim.elf &> /dev/null
rm ./ImageResources/bootpayload.bin &> /dev/null
rm Mu-${TARGET_DEVICE}.img &> /dev/null
# Compile BootShim
cd BootShim/${_TARGET_ARCH_TYPE}
make UEFI_BASE=${TARGET_FD_BASE} UEFI_SIZE=${TARGET_FD_SIZE}||_error "\nFailed to Compile BootShim!\n"
cd ../..
if [ ${_TARGET_ARCH_TYPE} == ARM ]; then
# Apply Project Mu Patches
cp ./MuPatches/Compile.patch ./Mu_Basecore/
cd Mu_Basecore
git apply Compile.patch
cd ..
fi
# Start the Real Build of the UEFI
stuart_setup -c "Platforms/${TARGET_DEVICE_VENDOR}/${TARGET_DEVICE}Pkg/PlatformBuild.py" "TOOL_CHAIN_TAG=${TOOL_CHAIN_TAG}"||_error "\nFailed to Setup UEFI Env!\n"
stuart_update -c "Platforms/${TARGET_DEVICE_VENDOR}/${TARGET_DEVICE}Pkg/PlatformBuild.py" "TOOL_CHAIN_TAG=${TOOL_CHAIN_TAG}"||_error "\nFailed to Update UEFI Env!\n"
stuart_build -c "Platforms/${TARGET_DEVICE_VENDOR}/${TARGET_DEVICE}Pkg/PlatformBuild.py" "TOOL_CHAIN_TAG=${TOOL_CHAIN_TAG}" "TARGET=${_TARGET_BUILD_MODE}" "RAM_SIZE=${TARGET_RAM_SIZE}" "FD_BASE=${TARGET_FD_BASE}" "FD_SIZE=${TARGET_FD_SIZE}" "FD_BLOCKS=${TARGET_FD_BLOCKS}" "TARGET_ARCH=${_TARGET_ARCH_TYPE}"||_error "\nFailed to Compile UEFI!\n"
# Execute Device Specific Boot Image Creation
if [ -f "configs/${TARGET_DEVICE}.sh" ]
then source configs/${TARGET_DEVICE}.sh
else _warn "\nImage Creation Script of ${TARGET_DEVICE} has not been Found!\nNo Boot Image Was Generated.\n"
fi
if [[ ${STATUS} != "STABLE" ]]; then
if [[ ${STATUS} == "UNSTABLE" ]];
then _warn "\n${TARGET_DEVICE} is marked as Unstable.\nThings are expected to be broken.\n"
elif [[ ${STATUS} == "LIMITED" ]];
then _warn "\n${TARGET_DEVICE} is marked as Limited.\nIt's stable but does not have much functionality\n"
fi
fi
git fetch &> /dev/null
UPDATE_CHECK=$(git status)
if [[ ${UPDATE_CHECK} == *"git pull"* ]];
then _warn "\nYou are using an old Version of Mu-Samsung.\nThis Image may be unstable.\n"
fi