aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorColin Cross <ccross@android.com>2017-04-07 17:07:49 -0700
committerColin Cross <ccross@android.com>2017-04-07 17:08:44 -0700
commit705b1ebf36002a7ffb8fb957480e30b67836625e (patch)
tree2df01c38cfe3f1df29a3c6a4586669ed3af787eb
parent9e84fb4b5c54ee5e97a044026dab39c7c1a452b2 (diff)
downloadsmali-705b1ebf36002a7ffb8fb957480e30b67836625e.tar.gz
Support dex version 38 in smali
Smali is used by cts-api-coverage. Test: m -j ANDROID_COMPILE_WITH_JACK=false continuous_instrumentation_tests_api_coverage Change-Id: I4b02caa9d4b6370497faeb4ab142b297865c5234
-rw-r--r--dexlib2/src/main/java/org/jf/dexlib2/dexbacked/raw/HeaderItem.java12
1 files changed, 8 insertions, 4 deletions
diff --git a/dexlib2/src/main/java/org/jf/dexlib2/dexbacked/raw/HeaderItem.java b/dexlib2/src/main/java/org/jf/dexlib2/dexbacked/raw/HeaderItem.java
index 531ff461..2f3af4c3 100644
--- a/dexlib2/src/main/java/org/jf/dexlib2/dexbacked/raw/HeaderItem.java
+++ b/dexlib2/src/main/java/org/jf/dexlib2/dexbacked/raw/HeaderItem.java
@@ -45,11 +45,12 @@ public class HeaderItem {
/**
* The magic numbers for dex files.
*
- * They are: "dex\n035\0" and "dex\n037\0".
+ * They are: "dex\n035\0", "dex\n037\0", and "dex\n038\0".
*/
public static final byte[][] MAGIC_VALUES= new byte[][] {
new byte[]{0x64, 0x65, 0x78, 0x0a, 0x30, 0x33, 0x35, 0x00},
- new byte[]{0x64, 0x65, 0x78, 0x0a, 0x30, 0x33, 0x37, 0x00}};
+ new byte[]{0x64, 0x65, 0x78, 0x0a, 0x30, 0x33, 0x37, 0x00},
+ new byte[]{0x64, 0x65, 0x78, 0x0a, 0x30, 0x33, 0x38, 0x00}};
public static final int LITTLE_ENDIAN_TAG = 0x12345678;
public static final int BIG_ENDIAN_TAG = 0x78563412;
@@ -239,9 +240,12 @@ public class HeaderItem {
if (api < 24) {
// Prior to Android N we only support dex version 035.
return HeaderItem.MAGIC_VALUES[0];
- } else {
+ } else if (api < 26) {
// On android N and later we support dex version 037.
return HeaderItem.MAGIC_VALUES[1];
+ } else {
+ // On android O and later we support dex version 038.
+ return HeaderItem.MAGIC_VALUES[2];
}
}
@@ -261,7 +265,7 @@ public class HeaderItem {
}
}
if (matches) {
- return i==0?35:37;
+ return i==0?35:(i==1?37:38);
}
}
return 0;