Project

General

Profile

Download (13.3 KB) Statistics
| Branch: | Tag: | Revision:
1
#!/bin/sh
2
#
3
# builder_defaults.sh
4
#
5
# Copyright (c) 2004-2015 Electric Sheep Fencing, LLC. All rights reserved.
6
#
7
# Redistribution and use in source and binary forms, with or without
8
# modification, are permitted provided that the following conditions are met:
9
#
10
# 1. Redistributions of source code must retain the above copyright notice,
11
#    this list of conditions and the following disclaimer.
12
#
13
# 2. Redistributions in binary form must reproduce the above copyright
14
#    notice, this list of conditions and the following disclaimer in
15
#    the documentation and/or other materials provided with the
16
#    distribution.
17
#
18
# 3. All advertising materials mentioning features or use of this software
19
#    must display the following acknowledgment:
20
#    "This product includes software developed by the pfSense Project
21
#    for use in the pfSense® software distribution. (http://www.pfsense.org/).
22
#
23
# 4. The names "pfSense" and "pfSense Project" must not be used to
24
#    endorse or promote products derived from this software without
25
#    prior written permission. For written permission, please contact
26
#    coreteam@pfsense.org.
27
#
28
# 5. Products derived from this software may not be called "pfSense"
29
#    nor may "pfSense" appear in their names without prior written
30
#    permission of the Electric Sheep Fencing, LLC.
31
#
32
# 6. Redistributions of any form whatsoever must retain the following
33
#    acknowledgment:
34
#
35
# "This product includes software developed by the pfSense Project
36
# for use in the pfSense software distribution (http://www.pfsense.org/).
37
#
38
# THIS SOFTWARE IS PROVIDED BY THE pfSense PROJECT ``AS IS'' AND ANY
39
# EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
40
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
41
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE pfSense PROJECT OR
42
# ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
43
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
44
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
45
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
46
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
47
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
48
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
49
# OF THE POSSIBILITY OF SUCH DAMAGE.
50
#
51

    
52
###########################################
53
# Product builder configuration file      #
54
# Please don't modify this file, you      #
55
# can put your settings and options       #
56
# in build.conf, which is sourced at the  #
57
# beginning of this file                  #
58
###########################################
59

    
60
if [ -z "${BUILDER_ROOT}" ]; then
61
	echo ">>> ERROR: BUILDER_ROOT must be defined by script that includes builder_defaults.sh"
62
	exit 1
63
fi
64

    
65
if [ ! -d "${BUILDER_ROOT}" ]; then
66
	echo ">>> ERROR: BUILDER_ROOT is invalid"
67
	exit 1
68
fi
69

    
70
export BUILDER_TOOLS=${BUILDER_TOOLS:-"${BUILDER_ROOT}/tools"}
71

    
72
if [ ! -d "${BUILDER_TOOLS}" ]; then
73
	echo ">>> ERROR: BUILDER_TOOLS is invalid"
74
	exit 1
75
fi
76

    
77
BUILD_CONF="${BUILDER_ROOT}/build.conf"
78

    
79
# Ensure file exists
80
if [ -f ${BUILD_CONF} ]; then
81
	. ${BUILD_CONF}
82
fi
83

    
84
# Make sure pkg will not be interactive
85
export ASSUME_ALWAYS_YES=true
86

    
87
# Architecture, supported ARCH values are: 
88
#  Tier 1: i386, AMD64, and PC98
89
#  Tier 2: ARM, PowerPC, ia64, Sparc64 and sun4v
90
#  Tier 3: MIPS and S/390
91
#  Tier 4: None at the moment
92
#  Source: http://www.freebsd.org/doc/en/articles/committers-guide/archs.html
93
export TARGET=${TARGET:-"`uname -m`"}
94
export TARGET_ARCH=${TARGET_ARCH:-${TARGET}}
95
# Set TARGET_ARCH_CONF_DIR
96
if [ "$TARGET_ARCH" = "" ]; then
97
        export TARGET_ARCH=`uname -p`
98
fi
99

    
100
# Directory to be used for writing temporary information
101
export SCRATCHDIR=${SCRATCHDIR:-"${BUILDER_ROOT}/tmp"}
102
if [ ! -d ${SCRATCHDIR} ]; then
103
	mkdir -p ${SCRATCHDIR}
104
fi
105

    
106
# Product details
107
export PRODUCT_NAME=${PRODUCT_NAME:-"nonSense"}
108
export PRODUCT_URL=${PRODUCT_URL:-""}
109
export PRODUCT_SRC=${PRODUCT_SRC:-"${BUILDER_ROOT}/src"}
110

    
111
if [ "${PRODUCT_NAME}" = "pfSense" -a "${BUILD_AUTHORIZED_BY_ELECTRIC_SHEEP_FENCING}" != "yes" ]; then
112
	echo ">>>ERROR: According the following license, only Electric Sheep Fencing can build genuine pfSense® software"
113
	echo ""
114
	cat ${BUILDER_ROOT}/license.txt
115
	exit 1
116
fi
117

    
118
if [ -z "${PRODUCT_VERSION}" ]; then
119
	if [ ! -f ${PRODUCT_SRC}/etc/version ]; then
120
		echo ">>> ERROR: PRODUCT_VERSION is not defined and ${PRODUCT_SRC}/etc/version was not found"
121
		print_error_pfS
122
	fi
123

    
124
	export PRODUCT_VERSION=$(head -n 1 ${PRODUCT_SRC}/etc/version)
125
fi
126

    
127
# Product repository tag to build
128
_cur_git_repo_branch_or_tag=$(git -C ${BUILDER_ROOT} rev-parse --abbrev-ref HEAD)
129
if [ "${_cur_git_repo_branch_or_tag}" = "HEAD" ]; then
130
	# We are on a tag, lets find out its name
131
	export GIT_REPO_BRANCH_OR_TAG=$(git -C ${BUILDER_ROOT} describe --tags)
132
else
133
	export GIT_REPO_BRANCH_OR_TAG="${_cur_git_repo_branch_or_tag}"
134
fi
135

    
136
GIT_REPO_BASE=$(git -C ${BUILDER_ROOT} config --get remote.origin.url | sed 's,/[^/]*,,')
137

    
138
# This is used for using svn for retrieving src
139
export FREEBSD_REPO_BASE=${FREEBSD_REPO_BASE:-"${GIT_REPO_BASE}/freebsd-src.git"}
140
export FREEBSD_BRANCH=${FREEBSD_BRANCH:-"devel"}
141
export FREEBSD_PARENT_BRANCH=${FREEBSD_PARENT_BRANCH:-"stable/10"}
142
export FREEBSD_SRC_DIR=${FREEBSD_SRC_DIR:-"${SCRATCHDIR}/FreeBSD-src"}
143

    
144
if [ "${TARGET}" = "i386" ]; then
145
	export BUILD_KERNELS=${BUILD_KERNELS:-"${PRODUCT_NAME} ${PRODUCT_NAME}_wrap ${PRODUCT_NAME}_wrap_vga"}
146
else
147
	export BUILD_KERNELS=${BUILD_KERNELS:-"${PRODUCT_NAME}"}
148
fi
149

    
150
# Leave this alone.
151
export SRC_CONF=${SRC_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_src.conf"}
152
export MAKE_CONF=${MAKE_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_make.conf"}
153

    
154
# Extra tools to be added to ITOOLS
155
export EXTRA_TOOLS=${EXTRA_TOOLS:-"uuencode uudecode ex"}
156

    
157
# Path to kernel files being built
158
export KERNEL_BUILD_PATH=${KERNEL_BUILD_PATH:-"${SCRATCHDIR}/kernels"}
159

    
160
# Do not touch builder /usr/obj
161
export MAKEOBJDIRPREFIX=${MAKEOBJDIRPREFIX:-"${SCRATCHDIR}/obj"}
162

    
163
# Controls how many concurrent make processes are run for each stage
164
_CPUS=""
165
if [ -z "${NO_MAKEJ}" ]; then
166
	_CPUS=$(expr $(sysctl -n kern.smp.cpus) '*' 2)
167
	if [ -n "${_CPUS}" ]; then
168
		_CPUS="-j${_CPUS}"
169
	fi
170
fi
171

    
172
export MAKEJ_WORLD=${MAKEJ_WORLD:-"${_CPUS}"}
173
export MAKEJ_KERNEL=${MAKEJ_KERNEL:-"${_CPUS}"}
174

    
175
if [ "${TARGET}" = "i386" ]; then
176
	export MODULES_OVERRIDE=${MODULES_OVERRIDE:-"i2c ipmi ndis ipfw ipdivert dummynet fdescfs opensolaris zfs glxsb if_stf coretemp amdtemp hwpmc"}
177
else
178
	export MODULES_OVERRIDE=${MODULES_OVERRIDE:-"i2c ipmi ndis ipfw ipdivert dummynet fdescfs opensolaris zfs glxsb if_stf coretemp amdtemp aesni sfxge hwpmc"}
179
fi
180

    
181
# Area that the final image will appear in
182
export IMAGES_FINAL_DIR=${IMAGES_FINAL_DIR:-"${SCRATCHDIR}/${PRODUCT_NAME}/"}
183

    
184
export BUILDER_LOGS=${BUILDER_LOGS:-"${BUILDER_ROOT}/logs"}
185
if [ ! -d ${BUILDER_LOGS} ]; then
186
	mkdir -p ${BUILDER_LOGS}
187
fi
188

    
189
# This is where files will be staged
190
export STAGE_CHROOT_DIR=${STAGE_CHROOT_DIR:-"${SCRATCHDIR}/stage-dir"}
191

    
192
# Directory that will clone to in order to create
193
# iso staging area.
194
export FINAL_CHROOT_DIR=${FINAL_CHROOT_DIR:-"${SCRATCHDIR}/final-dir"}
195

    
196
# 400M is not enough for amd64
197
export MEMORYDISK_SIZE=${MEMORYDISK_SIZE:-"768M"}
198

    
199
# OVF/vmdk parms
200
# Name of ovf file included inside OVA archive
201
export OVFTEMPLATE=${OVFTEMPLATE:-"${BUILDER_TOOLS}/templates/ovf/${PRODUCT_NAME}.ovf"}
202
# / partition to be used by mkimg
203
export OVFUFS=${OVFUFS:-"${PRODUCT_NAME}-disk1.ufs"}
204
# Raw disk to be converted to vmdk
205
export OVFRAW=${OVFRAW:-"${PRODUCT_NAME}-disk1.raw"}
206
# On disk name of VMDK file included in OVA
207
export OVFVMDK=${OVFVMDK:-"${PRODUCT_NAME}-disk1.vmdk"}
208
# 8 gigabyte on disk VMDK size
209
export VMDK_DISK_CAPACITY_IN_GB=${VMDK_DISK_CAPACITY_IN_GB:-"8"}
210
# first partition size (freebsd-ufs)
211
export OVA_FIRST_PART_SIZE_IN_GB=${OVA_FIRST_PART_SIZE_IN_GB:-"6"}
212
# swap partition size (freebsd-swap)
213
export OVA_SWAP_PART_SIZE_IN_GB=${OVA_SWAP_PART_SIZE_IN_GB:-"2"}
214
# Calculate real swap size, removing 128 blocks (65536 bytes) beggining/loader
215
export OVA_SWAP_PART_SIZE=$((${OVA_SWAP_PART_SIZE_IN_GB}*1024*1024*1024-65536))
216
# Temporary place to save files
217
export OVA_TMP=${OVA_TMP:-"${SCRATCHDIR}/ova_tmp"}
218
# end of OVF
219

    
220
# Number of code images on media (1 or 2)
221
export NANO_IMAGES=2
222
# 0 -> Leave second image all zeroes so it compresses better.
223
# 1 -> Initialize second image with a copy of the first
224
export NANO_INIT_IMG2=1
225
export NANO_NEWFS="-b 4096 -f 512 -i 8192 -O1"
226
export FLASH_SIZE=${FLASH_SIZE:-"1g"}
227
# Size of code file system in 512 bytes sectors
228
# If zero, size will be as large as possible.
229
export NANO_CODESIZE=0
230
# Size of data file system in 512 bytes sectors
231
# If zero: no partition configured.
232
# If negative: max size possible
233
export NANO_DATASIZE=0
234
# Size of Product /conf partition  # 102400 = 50 megabytes.
235
export NANO_CONFSIZE=102400
236
# packet is OK for 90% of embedded
237
export NANO_BOOT0CFG="-o packet -s 1 -m 3"
238

    
239
# NOTE: Date string is used for creating file names of images
240
#       The file is used for sharing the same value with build_snapshots.sh
241
export DATESTRINGFILE=${DATESTRINGFILE:-"$SCRATCHDIR/version.snapshots"}
242
if [ -z "${DATESTRING}" ]; then
243
	if [ -f "${DATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
244
		export DATESTRING=$(cat $DATESTRINGFILE)
245
	else
246
		export DATESTRING=$(date "+%Y%m%d-%H%M")
247
	fi
248
fi
249
echo "$DATESTRING" > $DATESTRINGFILE
250

    
251
# NOTE: Date string is placed on the final image etc folder to help detect new updates
252
#       The file is used for sharing the same value with build_snapshots.sh
253
export BUILTDATESTRINGFILE=${BUILTDATESTRINGFILE:-"$SCRATCHDIR/version.buildtime"}
254
if [ -z "${BUILTDATESTRING}" ]; then
255
	if [ -f "${BUILTDATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
256
		export BUILTDATESTRING=$(cat $BUILTDATESTRINGFILE)
257
	else
258
		export BUILTDATESTRING=$(date "+%a %b %d %T %Z %Y")
259
	fi
260
fi
261
echo "$BUILTDATESTRING" > $BUILTDATESTRINGFILE
262

    
263
# Poudriere
264
export ZFS_TANK=${ZFS_TANK:-"tank"}
265
export ZFS_ROOT=${ZFS_ROOT:-"/poudriere"}
266
export POUDRIERE_PORTS_NAME=${POUDRIERE_PORTS_NAME:-"${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}"}
267

    
268
export POUDRIERE_BULK=${POUDRIERE_BULK:-"${BUILDER_TOOLS}/conf/pfPorts/poudriere_bulk"}
269
export POUDRIERE_PORTS_GIT_URL=${POUDRIERE_PORTS_GIT_URL:-"${GIT_REPO_BASE}/freebsd-ports.git"}
270
export POUDRIERE_PORTS_GIT_BRANCH=${POUDRIERE_PORTS_GIT_BRANCH:-"devel"}
271

    
272
# Host to rsync pkg repos from poudriere
273
export PKG_RSYNC_USERNAME=${PKG_RSYNC_USERNAME:-"wwwsync"}
274
export PKG_RSYNC_SSH_PORT=${PKG_RSYNC_SSH_PORT:-"22"}
275
export PKG_RSYNC_DESTDIR=${PKG_RSYNC_DESTDIR:-"/usr/local/www/beta/packages"}
276
export PKG_REPO_SERVER=${PKG_REPO_SERVER:-"pkg+http://beta.pfsense.org/packages"}
277
export PKG_REPO_CONF_BRANCH=${PKG_REPO_CONF_BRANCH:-"${GIT_REPO_BRANCH_OR_TAG}"}
278

    
279
unset _IS_RELEASE
280
unset CORE_PKG_DATESTRING
281
export TIMESTAMP_SUFFIX="-${DATESTRING}"
282
# pkg doesn't like - as version separator, use . instead
283
export PKG_DATESTRING=$(echo "${DATESTRING}" | sed 's,-,.,g')
284
case "${PRODUCT_VERSION##*-}" in
285
	RELEASE)
286
		export _IS_RELEASE=yes
287
		unset TIMESTAMP_SUFFIX
288
		;;
289
	ALPHA|DEVELOPMENT)
290
		export CORE_PKG_DATESTRING=".a.${PKG_DATESTRING}"
291
		;;
292
	BETA*)
293
		export CORE_PKG_DATESTRING=".b.${PKG_DATESTRING}"
294
		;;
295
	RC*)
296
		export CORE_PKG_DATESTRING=".r.${PKG_DATESTRING}"
297
		;;
298
	*)
299
		echo ">>> ERROR: Invalid PRODUCT_VERSION format ${PRODUCT_VERSION}"
300
		exit 1
301
esac
302

    
303
# Define base package version, based on date for snaps
304
export CORE_PKG_VERSION="${PRODUCT_VERSION%%-*}${CORE_PKG_DATESTRING}"
305
export CORE_PKG_PATH=${CORE_PKG_PATH:-"${SCRATCHDIR}/${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}_${TARGET}_${TARGET_ARCH}-core"}
306
export CORE_PKG_TMP=${CORE_PKG_TMP:-"${SCRATCHDIR}/core_pkg_tmp"}
307

    
308
# Package overlay. This gives people a chance to build product
309
# installable image that already contains certain extra packages.
310
#
311
# Needs to contain comma separated package names. Of course
312
# package names must be valid. Using non existent
313
# package name would yield an error.
314
#
315
#export custom_package_list=""
316

    
317
# General builder output filenames
318
export UPDATESDIR=${UPDATESDIR:-"${IMAGES_FINAL_DIR}/updates"}
319
export ISOPATH=${ISOPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}-LiveCD-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.iso"}
320
export MEMSTICKPATH=${MEMSTICKPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}-memstick-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
321
export MEMSTICKSERIALPATH=${MEMSTICKSERIALPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}-memstick-serial-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
322
export MEMSTICKADIPATH=${MEMSTICKADIPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}-memstick-ADI-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
323
export OVAPATH=${OVAPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.ova"}
324

    
325
# set full-update update filename
326
export UPDATES_TARBALL_FILENAME=${UPDATES_TARBALL_FILENAME:-"${UPDATESDIR}/${PRODUCT_NAME}-Full-Update-${PRODUCT_VERSION}-${TARGET}${TIMESTAMP_SUFFIX}.tgz"}
327

    
328
# Rsync data to send snapshots
329
export RSYNCUSER=${RSYNCUSER:-"snapshots"}
330
export RSYNCPATH=${RSYNCPATH:-"/usr/local/www/snapshots/${TARGET}/${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}"}
331
export RSYNCLOGS=${RSYNCLOGS:-"/usr/local/www/snapshots/logs/${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}/${TARGET}"}
332
export RSYNCKBYTELIMIT=${RSYNCKBYTELIMIT:-"248000"}
333

    
334
# staging area used on snapshots build
335
STAGINGAREA=${STAGINGAREA:-"${SCRATCHDIR}/staging"}
336
mkdir -p ${STAGINGAREA}
337

    
338
export SNAPSHOTSLOGFILE=${SNAPSHOTSLOGFILE:-"${SCRATCHDIR}/snapshots-build.log"}
339
export SNAPSHOTSLASTUPDATE=${SNAPSHOTSLASTUPDATE:-"${SCRATCHDIR}/snapshots-lastupdate.log"}
(3-3/3)