summaryrefslogtreecommitdiffstats
path: root/compiler/utils/arm/assembler_arm32.h
diff options
context:
space:
mode:
authorRoland Levillain <rpl@google.com>2014-11-13 14:11:42 +0000
committerRoland Levillain <rpl@google.com>2014-11-13 17:30:06 +0000
commit51d3fc40637fc73d4156ad617cd451b844cbb75e (patch)
tree21669a66124a23dfc78a8c3f1d8b89415bfb0271 /compiler/utils/arm/assembler_arm32.h
parentd94a0a1d2868baaab49f4d2835bca086d98cf763 (diff)
downloadart-51d3fc40637fc73d4156ad617cd451b844cbb75e.zip
art-51d3fc40637fc73d4156ad617cd451b844cbb75e.tar.gz
art-51d3fc40637fc73d4156ad617cd451b844cbb75e.tar.bz2
Add support for int-to-byte in the optimizing compiler.
- Add support for the int-to-byte Dex instruction in the optimizing compiler. - Implement the ARM and Thumb-2 SBFX instructions. - Generate x86, x86-64 and ARM (but not ARM64) code for char to byte, short to byte and int to byte HTypeConversion nodes. - Add related tests to test/422-type-conversion. Change-Id: Ic8b8911b90d4b5281fad15bcee96bc3ee85dc577
Diffstat (limited to 'compiler/utils/arm/assembler_arm32.h')
-rw-r--r--compiler/utils/arm/assembler_arm32.h2
1 files changed, 2 insertions, 0 deletions
diff --git a/compiler/utils/arm/assembler_arm32.h b/compiler/utils/arm/assembler_arm32.h
index dbabb99..b582e9e 100644
--- a/compiler/utils/arm/assembler_arm32.h
+++ b/compiler/utils/arm/assembler_arm32.h
@@ -96,6 +96,8 @@ class Arm32Assembler FINAL : public ArmAssembler {
void sdiv(Register rd, Register rn, Register rm, Condition cond = AL) OVERRIDE;
void udiv(Register rd, Register rn, Register rm, Condition cond = AL) OVERRIDE;
+ void sbfx(Register rd, Register rn, uint32_t lsb, uint32_t width, Condition cond = AL) OVERRIDE;
+
// Load/store instructions.
void ldr(Register rd, const Address& ad, Condition cond = AL) OVERRIDE;
void str(Register rd, const Address& ad, Condition cond = AL) OVERRIDE;