Commit f46b8378 by Sandeep Kumar Singh Committed by Jayant Sonar

Added offset bits of MOVA/Sz assembly instruction for memory access

From-SVN: r188600
parent 5921cd19
......@@ -70,7 +70,7 @@ for s in QI HI; do
(plus:$d (zero_extend:$d $operand)
(match_operand:$d 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/b.l @(%o2,$src),%S0"
"mova/b.l @(%o2%C2,$src),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -114,7 +114,7 @@ EOF
(const_int $amount))
(match_operand:$d 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/$opsize.l @(%o2,$src),%S0"
"mova/$opsize.l @(%o2%C2,$src),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -143,7 +143,7 @@ EOF
(const_int $amount))
(match_operand:$d 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/$opsize.l @(%o2,$src),%S0"
"mova/$opsize.l @(%o2%C2,$src),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -184,7 +184,7 @@ EOF
(const_int $mask))
(match_operand:$d 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/$opsize.l @(%o2,$src),%S0"
"mova/$opsize.l @(%o2%C2,$src),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......
......@@ -1446,6 +1446,12 @@ h8300_print_operand (FILE *file, rtx x, int code)
switch (code)
{
case 'C':
if (h8300_constant_length (x) == 2)
fprintf (file, ":16");
else
fprintf (file, ":32");
return;
case 'E':
switch (GET_CODE (x))
{
......
......@@ -23,7 +23,7 @@
(const_int 2))
(match_operand:QI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -33,7 +33,7 @@
(const_int 1))
(match_operand:QI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -43,7 +43,7 @@
(const_int 4))
(match_operand:QI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -53,7 +53,7 @@
(const_int 2))
(match_operand:QI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -62,7 +62,7 @@
(plus:HI (zero_extend:HI (match_operand:QI 1 "h8300_dst_operand" "0,rQ"))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/b.l @(%o2,%X1.b),%S0"
"mova/b.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -81,7 +81,7 @@
(const_int 2))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -102,7 +102,7 @@
(const_int 510))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -123,7 +123,7 @@
(const_int 510))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -142,7 +142,7 @@
(const_int 1))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -163,7 +163,7 @@
(const_int 510))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -184,7 +184,7 @@
(const_int 510))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -203,7 +203,7 @@
(const_int 4))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -224,7 +224,7 @@
(const_int 1020))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -245,7 +245,7 @@
(const_int 1020))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -264,7 +264,7 @@
(const_int 2))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -285,7 +285,7 @@
(const_int 1020))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -306,7 +306,7 @@
(const_int 1020))
(match_operand:HI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -315,7 +315,7 @@
(plus:SI (zero_extend:SI (match_operand:QI 1 "h8300_dst_operand" "0,rQ"))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/b.l @(%o2,%X1.b),%S0"
"mova/b.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -334,7 +334,7 @@
(const_int 2))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -355,7 +355,7 @@
(const_int 510))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -376,7 +376,7 @@
(const_int 510))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -395,7 +395,7 @@
(const_int 1))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -416,7 +416,7 @@
(const_int 510))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -437,7 +437,7 @@
(const_int 510))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%X1.b),%S0"
"mova/w.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -456,7 +456,7 @@
(const_int 4))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -477,7 +477,7 @@
(const_int 1020))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -498,7 +498,7 @@
(const_int 1020))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -517,7 +517,7 @@
(const_int 2))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -538,7 +538,7 @@
(const_int 1020))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -559,7 +559,7 @@
(const_int 1020))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%X1.b),%S0"
"mova/l.l @(%o2%C2,%X1.b),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -569,7 +569,7 @@
(const_int 2))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -579,7 +579,7 @@
(const_int 1))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -589,7 +589,7 @@
(const_int 4))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -599,7 +599,7 @@
(const_int 2))
(match_operand:HI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -608,7 +608,7 @@
(plus:SI (zero_extend:SI (match_operand:HI 1 "h8300_dst_operand" "0,rQ"))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/b.l @(%o2,%T1.w),%S0"
"mova/b.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -627,7 +627,7 @@
(const_int 2))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -648,7 +648,7 @@
(const_int 131070))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -669,7 +669,7 @@
(const_int 131070))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -688,7 +688,7 @@
(const_int 1))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -709,7 +709,7 @@
(const_int 131070))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -730,7 +730,7 @@
(const_int 131070))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/w.l @(%o2,%T1.w),%S0"
"mova/w.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -749,7 +749,7 @@
(const_int 4))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -770,7 +770,7 @@
(const_int 262140))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -791,7 +791,7 @@
(const_int 262140))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -810,7 +810,7 @@
(const_int 2))
(match_operand:SI 2 "immediate_operand" "i,i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -831,7 +831,7 @@
(const_int 262140))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
......@@ -852,7 +852,7 @@
(const_int 262140))
(match_operand:SI 2 "immediate_operand" "i")))]
"TARGET_H8300SX"
"mova/l.l @(%o2,%T1.w),%S0"
"mova/l.l @(%o2%C2,%T1.w),%S0"
[(set_attr "length_table" "mova")
(set_attr "cc" "none")])
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment