summaryrefslogtreecommitdiff
path: root/arm/Asmgen.v
diff options
context:
space:
mode:
authorGravatar xleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e>2014-01-02 15:59:11 +0000
committerGravatar xleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e>2014-01-02 15:59:11 +0000
commit29e0c9b2c99a437fc9dfab66e1abdd546a5308d6 (patch)
tree2c3e924125d9b91e5e9b57b87c80f5b5ce9c6710 /arm/Asmgen.v
parentc71e155dbbf34fa17d14e8eee50a019c8ccfd6f5 (diff)
Updated ARM backend wrt new static analyses and optimizations.
NeedOp, Deadcode: must have distinct needs per argument of an operator. This change remains to be propagated to IA32 and PPC. git-svn-id: https://yquem.inria.fr/compcert/svn/compcert/trunk@2399 fca1b0fc-160b-0410-b1d3-a4f43f01ea2e
Diffstat (limited to 'arm/Asmgen.v')
-rw-r--r--arm/Asmgen.v8
1 files changed, 8 insertions, 0 deletions
diff --git a/arm/Asmgen.v b/arm/Asmgen.v
index 3707b7f..b6cb2b3 100644
--- a/arm/Asmgen.v
+++ b/arm/Asmgen.v
@@ -267,6 +267,14 @@ Definition transl_op
| Oaddrstack n, nil =>
do r <- ireg_of res;
OK (addimm r IR13 n k)
+ | Ocast8signed, a1 :: nil =>
+ do r <- ireg_of res; do r1 <- ireg_of a1;
+ OK (Pmov r (SOlslimm r1 (Int.repr 24)) ::
+ Pmov r (SOasrimm r (Int.repr 24)) :: k)
+ | Ocast16signed, a1 :: nil =>
+ do r <- ireg_of res; do r1 <- ireg_of a1;
+ OK (Pmov r (SOlslimm r1 (Int.repr 16)) ::
+ Pmov r (SOasrimm r (Int.repr 16)) :: k)
| Oadd, a1 :: a2 :: nil =>
do r <- ireg_of res; do r1 <- ireg_of a1; do r2 <- ireg_of a2;
OK (Padd r r1 (SOreg r2) :: k)