Index: src/trusted/service_runtime/sel_validate_image.c |
diff --git a/src/trusted/service_runtime/sel_validate_image.c b/src/trusted/service_runtime/sel_validate_image.c |
index cea38a913cd7476ab0c560faa0094313ab3c9ad5..bb7ef26fc8479ee6a31347afe91a3aa7a4d17bb7 100644 |
--- a/src/trusted/service_runtime/sel_validate_image.c |
+++ b/src/trusted/service_runtime/sel_validate_image.c |
@@ -25,10 +25,22 @@ static int NaClValidateStatus(NaClValidationStatus status) { |
} |
} |
+enum NaClSBKind getSBKind(struct NaClApp *nap) { |
+ enum NaClSBKind sb_kind = NACL_SB_DEFAULT; |
+#if NACL_ARCH(NACL_BUILD_ARCH) == NACL_arm |
+ uintptr_t entry = nap->user_entry_pt ? |
+ nap->user_entry_pt : nap->initial_entry_pt; |
+ sb_kind = (entry & 1) ? NACL_SB_ARM_THUMB2 : sb_kind; |
+#else |
+ UNREFERENCED_PARAMETER(nap); |
+#endif |
+ return sb_kind; |
+} |
+ |
int NaClValidateCode(struct NaClApp *nap, uintptr_t guest_addr, |
uint8_t *data, size_t size) { |
NaClValidationStatus status = NaClValidationSucceeded; |
- enum NaClSBKind sb_kind = NACL_SB_DEFAULT; |
+ enum NaClSBKind sb_kind = getSBKind(nap); |
if (nap->validator_stub_out_mode) { |
/* In stub out mode, we do two passes. The second pass acts as a |
sanity check that bad instructions were indeed overwritten with |
@@ -56,14 +68,13 @@ int NaClValidateCode(struct NaClApp *nap, uintptr_t guest_addr, |
int NaClValidateCodeReplacement(struct NaClApp *nap, uintptr_t guest_addr, |
uint8_t *data_old, uint8_t *data_new, |
size_t size) { |
- enum NaClSBKind sb_kind = NACL_SB_DEFAULT; |
+ enum NaClSBKind sb_kind = getSBKind(nap); |
if (nap->validator_stub_out_mode) return LOAD_BAD_FILE; |
if ((guest_addr % nap->bundle_size) != 0 || |
(size % nap->bundle_size) != 0) { |
return LOAD_BAD_FILE; |
} |
- |
return NaClValidateStatus( |
NACL_SUBARCH_NAME(ApplyValidatorCodeReplacement, |
NACL_TARGET_ARCH, |
@@ -74,7 +85,7 @@ int NaClValidateCodeReplacement(struct NaClApp *nap, uintptr_t guest_addr, |
int NaClCopyCode(struct NaClApp *nap, uintptr_t guest_addr, |
uint8_t *data_old, uint8_t *data_new, |
size_t size) { |
- enum NaClSBKind sb_kind = NACL_SB_DEFAULT; |
+ enum NaClSBKind sb_kind = getSBKind(nap); |
return NaClValidateStatus( |
NACL_SUBARCH_NAME(ApplyValidatorCopy, |
NACL_TARGET_ARCH, |