Mercurial > projects > ldc
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 ( '(' );