diff options
Diffstat (limited to 'meta/classes')
-rw-r--r-- | meta/classes/bootimg.bbclass | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/meta/classes/bootimg.bbclass b/meta/classes/bootimg.bbclass index 4abe00e944..605edc911e 100644 --- a/meta/classes/bootimg.bbclass +++ b/meta/classes/bootimg.bbclass | |||
@@ -136,19 +136,30 @@ build_iso() { | |||
136 | mkisofs_compress_opts="-r" | 136 | mkisofs_compress_opts="-r" |
137 | fi | 137 | fi |
138 | 138 | ||
139 | # Check the size of ${ISODIR}/rootfs.img, use mkisofs -iso-level 3 | ||
140 | # when it exceeds 3.8GB, the specification is 4G - 1 bytes, we need | ||
141 | # leave a few space for other files. | ||
142 | mkisofs_iso_level="" | ||
143 | rootfs_img_size=`stat -c '%s' ${ISODIR}/rootfs.img` | ||
144 | # 4080218931 = 3.8 * 1024 * 1024 * 1024 | ||
145 | if [ $rootfs_img_size -gt 4080218931 ]; then | ||
146 | bbnote "${ISODIR}/rootfs.img execeeds 3.8GB, using '-iso-level 3' for mkisofs" | ||
147 | mkisofs_iso_level="-iso-level 3" | ||
148 | fi | ||
149 | |||
139 | if [ "${PCBIOS}" = "1" ] && [ "${EFI}" != "1" ] ; then | 150 | if [ "${PCBIOS}" = "1" ] && [ "${EFI}" != "1" ] ; then |
140 | # PCBIOS only media | 151 | # PCBIOS only media |
141 | mkisofs -V ${BOOTIMG_VOLUME_ID} \ | 152 | mkisofs -V ${BOOTIMG_VOLUME_ID} \ |
142 | -o ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.iso \ | 153 | -o ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.iso \ |
143 | -b ${ISO_BOOTIMG} -c ${ISO_BOOTCAT} \ | 154 | -b ${ISO_BOOTIMG} -c ${ISO_BOOTCAT} \ |
144 | $mkisofs_compress_opts \ | 155 | $mkisofs_compress_opts \ |
145 | ${MKISOFS_OPTIONS} ${ISODIR} | 156 | ${MKISOFS_OPTIONS} $mkisofs_iso_level ${ISODIR} |
146 | else | 157 | else |
147 | # EFI only OR EFI+PCBIOS | 158 | # EFI only OR EFI+PCBIOS |
148 | mkisofs -A ${BOOTIMG_VOLUME_ID} -V ${BOOTIMG_VOLUME_ID} \ | 159 | mkisofs -A ${BOOTIMG_VOLUME_ID} -V ${BOOTIMG_VOLUME_ID} \ |
149 | -o ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.iso \ | 160 | -o ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.iso \ |
150 | -b ${ISO_BOOTIMG} -c ${ISO_BOOTCAT} \ | 161 | -b ${ISO_BOOTIMG} -c ${ISO_BOOTCAT} \ |
151 | $mkisofs_compress_opts ${MKISOFS_OPTIONS} \ | 162 | $mkisofs_compress_opts ${MKISOFS_OPTIONS} $mkisofs_iso_level \ |
152 | -eltorito-alt-boot -eltorito-platform efi \ | 163 | -eltorito-alt-boot -eltorito-platform efi \ |
153 | -b efi.img -no-emul-boot \ | 164 | -b efi.img -no-emul-boot \ |
154 | ${ISODIR} | 165 | ${ISODIR} |