 Chromium Code Reviews
 Chromium Code Reviews Issue 23890007:
  ARM: Improve SeqStringSetChar implementation.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
    
  
    Issue 23890007:
  ARM: Improve SeqStringSetChar implementation.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge| Index: src/arm/lithium-codegen-arm.cc | 
| diff --git a/src/arm/lithium-codegen-arm.cc b/src/arm/lithium-codegen-arm.cc | 
| index bc34cfafe08e08b3075ff8ae2b377c2393223255..6bcb5c937f6cd5dfb48c6b1f729851d66ce6bc3d 100644 | 
| --- a/src/arm/lithium-codegen-arm.cc | 
| +++ b/src/arm/lithium-codegen-arm.cc | 
| @@ -1960,32 +1960,42 @@ void LCodeGen::DoDateField(LDateField* instr) { | 
| void LCodeGen::DoSeqStringSetChar(LSeqStringSetChar* instr) { | 
| Register string = ToRegister(instr->string()); | 
| - Register index = ToRegister(instr->index()); | 
| + LOperand* index_op = instr->index(); | 
| Register value = ToRegister(instr->value()); | 
| + Register scratch = scratch0(); | 
| String::Encoding encoding = instr->encoding(); | 
| if (FLAG_debug_code) { | 
| - __ ldr(ip, FieldMemOperand(string, HeapObject::kMapOffset)); | 
| - __ ldrb(ip, FieldMemOperand(ip, Map::kInstanceTypeOffset)); | 
| + __ ldr(scratch, FieldMemOperand(string, HeapObject::kMapOffset)); | 
| + __ ldrb(scratch, FieldMemOperand(scratch, Map::kInstanceTypeOffset)); | 
| - __ and_(ip, ip, Operand(kStringRepresentationMask | kStringEncodingMask)); | 
| + __ and_(scratch, scratch, | 
| + Operand(kStringRepresentationMask | kStringEncodingMask)); | 
| static const uint32_t one_byte_seq_type = kSeqStringTag | kOneByteStringTag; | 
| static const uint32_t two_byte_seq_type = kSeqStringTag | kTwoByteStringTag; | 
| - __ cmp(ip, Operand(encoding == String::ONE_BYTE_ENCODING | 
| - ? one_byte_seq_type : two_byte_seq_type)); | 
| + __ cmp(scratch, Operand(encoding == String::ONE_BYTE_ENCODING | 
| + ? one_byte_seq_type : two_byte_seq_type)); | 
| __ Check(eq, kUnexpectedStringType); | 
| } | 
| - __ add(ip, | 
| - string, | 
| - Operand(SeqString::kHeaderSize - kHeapObjectTag)); | 
| - if (encoding == String::ONE_BYTE_ENCODING) { | 
| - __ strb(value, MemOperand(ip, index)); | 
| + if (index_op->IsConstantOperand()) { | 
| + int constant_index = ToInteger32(LConstantOperand::cast(index_op)); | 
| + if (encoding == String::ONE_BYTE_ENCODING) { | 
| + __ strb(value, | 
| + FieldMemOperand(string, SeqString::kHeaderSize + constant_index)); | 
| 
Benedikt Meurer
2013/09/09 06:05:31
Is that safe for arbitrary constant_index'es?
 
vincent.belliard.fr
2013/09/09 08:29:55
As long as you don't use ip, it's safe (and you sh
 | 
| + } else { | 
| + __ strh(value, | 
| + FieldMemOperand(string, SeqString::kHeaderSize + constant_index * 2)); | 
| + } | 
| } else { | 
| - // MemOperand with ip as the base register is not allowed for strh, so | 
| - // we do the address calculation explicitly. | 
| - __ add(ip, ip, Operand(index, LSL, 1)); | 
| - __ strh(value, MemOperand(ip)); | 
| + Register index = ToRegister(index_op); | 
| + if (encoding == String::ONE_BYTE_ENCODING) { | 
| + __ add(scratch, string, Operand(index)); | 
| + __ strb(value, FieldMemOperand(scratch, SeqString::kHeaderSize)); | 
| + } else { | 
| + __ add(scratch, string, Operand(index, LSL, 1)); | 
| + __ strh(value, FieldMemOperand(scratch, SeqString::kHeaderSize)); | 
| + } | 
| } | 
| } |