diff options
| -rw-r--r-- | classes/dm-verity-img.bbclass | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/classes/dm-verity-img.bbclass b/classes/dm-verity-img.bbclass index 62c3069..7f79548 100644 --- a/classes/dm-verity-img.bbclass +++ b/classes/dm-verity-img.bbclass | |||
| @@ -177,6 +177,24 @@ CONVERSION_CMD:verity = "verity_setup ${type}" | |||
| 177 | CONVERSION_DEPENDS_verity = "cryptsetup-native" | 177 | CONVERSION_DEPENDS_verity = "cryptsetup-native" |
| 178 | IMAGE_CMD:vhash = "verity_hash" | 178 | IMAGE_CMD:vhash = "verity_hash" |
| 179 | 179 | ||
| 180 | def get_verity_fstypes(d): | ||
| 181 | verity_image = d.getVar('DM_VERITY_IMAGE') | ||
| 182 | verity_type = d.getVar('DM_VERITY_IMAGE_TYPE') | ||
| 183 | verity_hash = d.getVar('DM_VERITY_SEPARATE_HASH') | ||
| 184 | pn = d.getVar('PN') | ||
| 185 | |||
| 186 | fstypes = "" | ||
| 187 | if not pn.endswith(verity_image): | ||
| 188 | return fstypes # This doesn't concern this image | ||
| 189 | |||
| 190 | fstypes = verity_type + ".verity" | ||
| 191 | if verity_hash == "1": | ||
| 192 | fstypes += " vhash" | ||
| 193 | |||
| 194 | return fstypes | ||
| 195 | |||
| 196 | IMAGE_FSTYPES += "${@get_verity_fstypes(d)}" | ||
| 197 | |||
| 180 | python __anonymous() { | 198 | python __anonymous() { |
| 181 | verity_image = d.getVar('DM_VERITY_IMAGE') | 199 | verity_image = d.getVar('DM_VERITY_IMAGE') |
| 182 | verity_type = d.getVar('DM_VERITY_IMAGE_TYPE') | 200 | verity_type = d.getVar('DM_VERITY_IMAGE_TYPE') |
| @@ -188,16 +206,12 @@ python __anonymous() { | |||
| 188 | bb.warn('dm-verity-img class inherited but not used') | 206 | bb.warn('dm-verity-img class inherited but not used') |
| 189 | return | 207 | return |
| 190 | 208 | ||
| 191 | if verity_image != pn: | 209 | if not pn.endswith(verity_image): |
| 192 | return # This doesn't concern this image | 210 | return # This doesn't concern this image |
| 193 | 211 | ||
| 194 | if len(verity_type.split()) != 1: | 212 | if len(verity_type.split()) != 1: |
| 195 | bb.fatal('DM_VERITY_IMAGE_TYPE must contain exactly one type') | 213 | bb.fatal('DM_VERITY_IMAGE_TYPE must contain exactly one type') |
| 196 | 214 | ||
| 197 | d.appendVar('IMAGE_FSTYPES', ' %s.verity' % verity_type) | ||
| 198 | if verity_hash == "1": | ||
| 199 | d.appendVar('IMAGE_FSTYPES', ' vhash') | ||
| 200 | |||
| 201 | # If we're using wic: we'll have to use partition images and not the rootfs | 215 | # If we're using wic: we'll have to use partition images and not the rootfs |
| 202 | # source plugin so add the appropriate dependency. | 216 | # source plugin so add the appropriate dependency. |
| 203 | if 'wic' in image_fstypes: | 217 | if 'wic' in image_fstypes: |
