diff options
author | Stefan Agner <stefan.agner@toradex.com> | 2018-10-12 15:38:32 +0200 |
---|---|---|
committer | Stefan Agner <stefan.agner@toradex.com> | 2018-10-12 15:51:47 +0200 |
commit | 412cfd9a1f139fd56ca66d312c7df22aafd02e48 (patch) | |
tree | d25e3b5af25c2617ee1da4f8944b76e6c9d67939 /classes | |
parent | 227bd6d5b806bb15e4dc3f286f07f9cb563d228c (diff) | |
download | meta-updater-412cfd9a1f139fd56ca66d312c7df22aafd02e48.tar.gz |
image_types_ota: simplify image creation
Almost all code in create_ota is either tar or ext4 specific. Move
the code directly into the respective IMAGE_CMD_ functions. This
gets rid of unnecessary work for the tar image and simplifies code.
Signed-off-by: Stefan Agner <stefan.agner@toradex.com>
Diffstat (limited to 'classes')
-rw-r--r-- | classes/image_types_ota.bbclass | 43 |
1 files changed, 15 insertions, 28 deletions
diff --git a/classes/image_types_ota.bbclass b/classes/image_types_ota.bbclass index 8b363cc..929d092 100644 --- a/classes/image_types_ota.bbclass +++ b/classes/image_types_ota.bbclass | |||
@@ -122,48 +122,35 @@ fakeroot do_otasetup () { | |||
122 | rm -rf ${HOME_TMP} | 122 | rm -rf ${HOME_TMP} |
123 | } | 123 | } |
124 | 124 | ||
125 | ## Specific image creation | 125 | IMAGE_CMD_ota-ext4 () { |
126 | create_ota () { | ||
127 | FS_TYPE=${1} | ||
128 | # Calculate image type | 126 | # Calculate image type |
129 | OTA_ROOTFS_SIZE=$(calculate_size `du -ks $OTA_SYSROOT | cut -f 1` "${IMAGE_OVERHEAD_FACTOR}" "${IMAGE_ROOTFS_SIZE}" "${IMAGE_ROOTFS_MAXSIZE}" `expr ${IMAGE_ROOTFS_EXTRA_SPACE}` "${IMAGE_ROOTFS_ALIGNMENT}") | 127 | OTA_ROOTFS_SIZE=$(calculate_size `du -ks $OTA_SYSROOT | cut -f 1` "${IMAGE_OVERHEAD_FACTOR}" "${IMAGE_ROOTFS_SIZE}" "${IMAGE_ROOTFS_MAXSIZE}" `expr ${IMAGE_ROOTFS_EXTRA_SPACE}` "${IMAGE_ROOTFS_ALIGNMENT}") |
130 | 128 | ||
131 | if [ $OTA_ROOTFS_SIZE -lt 0 ]; then | 129 | if [ $OTA_ROOTFS_SIZE -lt 0 ]; then |
132 | exit -1 | 130 | bbfatal "create_ota failed to calculate OTA rootfs size!" |
133 | fi | 131 | fi |
132 | |||
134 | eval local COUNT=\"0\" | 133 | eval local COUNT=\"0\" |
135 | eval local MIN_COUNT=\"60\" | 134 | eval local MIN_COUNT=\"60\" |
136 | if [ $OTA_ROOTFS_SIZE -lt $MIN_COUNT ]; then | 135 | if [ $OTA_ROOTFS_SIZE -lt $MIN_COUNT ]; then |
137 | eval COUNT=\"$MIN_COUNT\" | 136 | eval COUNT=\"$MIN_COUNT\" |
138 | fi | 137 | fi |
139 | 138 | ||
140 | # create image | 139 | rm -rf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg |
141 | if [ "${FS_TYPE}" = "ext4" ]; then | 140 | sync |
142 | rm -rf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg | 141 | dd if=/dev/zero of=${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg seek=${OTA_ROOTFS_SIZE} count=$COUNT bs=1024 |
143 | sync | 142 | mkfs.ext4 -O ^64bit ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg -L otaroot -d ${OTA_SYSROOT} |
144 | dd if=/dev/zero of=${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg seek=${OTA_ROOTFS_SIZE} count=$COUNT bs=1024 | 143 | rm -f ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg |
145 | mkfs.ext4 -O ^64bit ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg -L otaroot -d ${OTA_SYSROOT} | 144 | ln -s ${IMAGE_NAME}.otaimg ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg |
146 | rm -f ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg | ||
147 | ln -s ${IMAGE_NAME}.otaimg ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg | ||
148 | elif [ "${FS_TYPE}" = "tar" ]; then | ||
149 | rm -rf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg.tar | ||
150 | tar -cf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg.tar -C ${OTA_SYSROOT} . | ||
151 | rm -f ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar | ||
152 | ln -s ${IMAGE_NAME}.otaimg.tar ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar | ||
153 | # To fit in with the rest of yocto's image utils, we create a rootfs.ota-tar in the deploy dir | ||
154 | cp ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar ${IMGDEPLOYDIR}/${IMAGE_NAME}.rootfs.ota-tar | ||
155 | else | ||
156 | rm -rf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg* | ||
157 | bbfatal "create_ota Function called with unknown or unspecified FS_TYPE of ${FS_TYPE}. Failing!" | ||
158 | fi | ||
159 | } | ||
160 | |||
161 | IMAGE_CMD_ota-ext4 () { | ||
162 | create_ota "ext4" | ||
163 | } | 145 | } |
164 | 146 | ||
165 | IMAGE_CMD_ota-tar () { | 147 | IMAGE_CMD_ota-tar () { |
166 | create_ota "tar" | 148 | rm -rf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg.tar |
149 | tar -cf ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg.tar -C ${OTA_SYSROOT} . | ||
150 | rm -f ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar | ||
151 | ln -s ${IMAGE_NAME}.otaimg.tar ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar | ||
152 | # To fit in with the rest of yocto's image utils, we create a rootfs.ota-tar in the deploy dir | ||
153 | cp ${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.otaimg.tar ${IMGDEPLOYDIR}/${IMAGE_NAME}.rootfs.ota-tar | ||
167 | } | 154 | } |
168 | 155 | ||
169 | do_otasetup[doc] = "Sets up the base ota rootfs used for subsequent image generation" | 156 | do_otasetup[doc] = "Sets up the base ota rootfs used for subsequent image generation" |