changeset 1094:fa20521cbb13

Change faulty offset for asm in Cache.d (ie. change "-20(%rbp)+4)" to "4+-20(%rbp)")
author Kelly Wilson <wilsonk cpsc.ucalgary.ca>
date Wed, 11 Mar 2009 00:08:45 -0400
parents cb868105a6b5
children d6bd818212de
files gen/asm-x86-32.h
diffstat 1 files changed, 11 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/gen/asm-x86-32.h	Tue Mar 10 22:02:11 2009 -0600
+++ b/gen/asm-x86-32.h	Wed Mar 11 00:08:45 2009 -0400
@@ -2055,6 +2055,17 @@
                         }
 
                         use_star = opTakesLabel();//opInfo->takesLabel();
+
+                        if ( operand->segmentPrefix != Reg_Invalid || operand->constDisplacement )
+                        {
+                            insnTemplate->printf ( "%d", operand->constDisplacement );
+                            if ( operand->symbolDisplacement.dim )
+                                insnTemplate->writebyte ( '+' );
+                            //addOperand(fmt, Arg_Integer, newIntExp(operand->constDisplacement), asmcode);
+                            if ( opInfo->operands[i] & Opr_Dest )
+                                asmcode->clobbersMemory = 1;
+                        }
+
                         if ( operand->segmentPrefix != Reg_Invalid )
                         {
                             writeReg ( operand->segmentPrefix );
@@ -2174,15 +2185,6 @@
                         }
                         if ( use_star )
                             insnTemplate->writebyte ( '*' );
-                        if ( operand->segmentPrefix != Reg_Invalid || operand->constDisplacement )
-                        {
-                            if ( operand->symbolDisplacement.dim )
-                                insnTemplate->writebyte ( '+' );
-                            //addOperand(fmt, Arg_Integer, newIntExp(operand->constDisplacement), asmcode);
-                            insnTemplate->printf ( "%d", operand->constDisplacement );
-                            if ( opInfo->operands[i] & Opr_Dest )
-                                asmcode->clobbersMemory = 1;
-                        }
                         if ( operand->baseReg != Reg_Invalid || operand->indexReg != Reg_Invalid )
                         {
                             insnTemplate->writebyte ( '(' );