-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathcreate-image.sh
executable file
·86 lines (71 loc) · 2.96 KB
/
create-image.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
#! /bin/bash
#
# Author: Badr BADRI © pythops
# License: MIT
#
set -e
BSP=https://developer.nvidia.com/downloads/remetpack-463r32releasev73t210jetson-210linur3273aarch64tbz2
# Check if the user is not root
if [ "x$(whoami)" != "xroot" ]; then
printf "\e[31mThis script requires root privilege\e[0m\n"
exit 1
fi
# Check for env variables
if [ ! $JETSON_ROOTFS_DIR ] || [ ! $JETSON_BUILD_DIR ]; then
printf "\e[31mYou need to set the env variables \$JETSON_ROOTFS_DIR and \$JETSON_BUILD_DIR\e[0m\n"
exit 1
fi
# Check if $JETSON_ROOTFS_DIR if not empty
if [ ! "$(ls -A $JETSON_ROOTFS_DIR)" ]; then
printf "\e[31mNo rootfs found in $JETSON_ROOTFS_DIR\e[0m\n"
exit 1
fi
# Check if board type is specified
if [ ! $JETSON_NANO_BOARD ]; then
printf "\e[31mJetson nano board type must be specified\e[0m\n"
exit 1
fi
printf "\e[32mBuild the image ...\n"
# Create the build dir if it does not exists
mkdir -p $JETSON_BUILD_DIR
# Download L4T
if [ ! "$(ls -A $JETSON_BUILD_DIR)" ]; then
printf "\e[32mDownload L4T... "
wget -qO- $BSP | tar -jxpf - -C $JETSON_BUILD_DIR
printf "[OK]\n"
# Fix nvidia's bugs in various BSP scripts
case "$BSP" in
*32.5*)
# Fix link dereferencing in 32.5 for xavier. Adds "-a" flag to "cp" command.
# Without it nVidia's script fails to copy any symlinks from rootfs into recovery image which crashes the whole image creation process.
sed -i 's/cp -f/cp -af/g' "$JETSON_BUILD_DIR/Linux_for_Tegra/tools/ota_tools/version_upgrade/ota_make_recovery_img_dtb.sh"
;;
*32.6*)
# When preallocating loopback image space for root, nvidia's script uses ((rootfs_size + (rootfs_size /10))
# In case of a 400MiB rootfs, this causes the same script to fail copying rootfs into the root image.
# So we arbitraryly preallocate extra 128MiB ((rootfs_size + 128MiB + (rootfs_size / 10))
sed -i 's/rootfs_size +/rootfs_size + 128 +/g' "$JETSON_BUILD_DIR/Linux_for_Tegra/tools/jetson-disk-image-creator.sh"
;;
esac
fi
case "$JETSON_NANO_BOARD" in
jetson-nano-2gb)
printf "Create image for Jetson nano 2GB board... "
ROOTFS_DIR=$JETSON_ROOTFS_DIR $JETSON_BUILD_DIR/Linux_for_Tegra/tools/jetson-disk-image-creator.sh \
-o jetson.img -b jetson-nano-2gb-devkit
printf "[OK]\n"
;;
jetson-nano)
nano_board_revision=${JETSON_NANO_REVISION:=300}
printf "Creating image for Jetson nano board (%s revision)... " $nano_board_revision
ROOTFS_DIR=$JETSON_ROOTFS_DIR $JETSON_BUILD_DIR/Linux_for_Tegra/tools/jetson-disk-image-creator.sh \
-o jetson.img -b jetson-nano -r $nano_board_revision
printf "[OK]\n"
;;
*)
printf "\e[31mUnknown Jetson nano board type\e[0m\n"
exit 1
;;
esac
printf "\e[32mImage created successfully\n"
printf "Image location ./jetson.img\n"