diff options
author | Renato Botelho <renato@netgate.com> | 2017-02-15 08:55:38 -0200 |
---|---|---|
committer | Renato Botelho <renato@netgate.com> | 2017-02-15 08:55:38 -0200 |
commit | ca0f9142e9dea13e25f534866cdd96ff0ba39489 (patch) | |
tree | d5991bb7798d6fcf3523aa6b754b8da2445a43c6 /tools/builder_common.sh | |
parent | 76dfb0be6b2461d749aea386cc81d8297546b20d (diff) | |
download | pfsense-ca0f9142e9dea13e25f534866cdd96ff0ba39489.zip pfsense-ca0f9142e9dea13e25f534866cdd96ff0ba39489.tar.gz |
Make sure OVA_TMP is umounted before start using it
Diffstat (limited to 'tools/builder_common.sh')
-rw-r--r-- | tools/builder_common.sh | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/tools/builder_common.sh b/tools/builder_common.sh index f7abe1d..867520e 100644 --- a/tools/builder_common.sh +++ b/tools/builder_common.sh @@ -283,6 +283,17 @@ create_ova_image() { LOGFILE=${BUILDER_LOGS}/ova.${TARGET}.log if [ -d "${OVA_TMP}" ]; then + local _dev + # XXX Root cause still didn't found but it doesn't umount + # properly on looped builds and then require this extra + # check + while true; do + _dev=$(mount -p ${OVA_TMP} 2>/dev/null | awk '{print $1}') + [ $? -ne 0 -o -z "${_dev}" ] \ + && break + umount -f ${OVA_TMP} + mdconfig -d -u ${_dev#/dev/} + done chflags -R noschg ${OVA_TMP} rm -rf ${OVA_TMP} fi |