Chromium Code Reviews| Index: src/arm/full-codegen-arm.cc |
| diff --git a/src/arm/full-codegen-arm.cc b/src/arm/full-codegen-arm.cc |
| index c57c78559803c81e51137a32876688dff0ceebc0..fbea793efd6fbd962027b418074c40f236fb2b68 100644 |
| --- a/src/arm/full-codegen-arm.cc |
| +++ b/src/arm/full-codegen-arm.cc |
| @@ -168,9 +168,21 @@ void FullCodeGenerator::Generate() { |
| // Generators allocate locals, if any, in context slots. |
| ASSERT(!info->function()->is_generator() || locals_count == 0); |
| if (locals_count > 0) { |
| - __ LoadRoot(ip, Heap::kUndefinedValueRootIndex); |
| - for (int i = 0; i < locals_count; i++) { |
| + // Emit a loop to initialize stack cells for locals when optimizing for |
| + // size. Otherwise, unroll the loop for maximum performance. |
| + if (FLAG_optimize_for_size && locals_count > 4) { |
| + Label loop; |
| + __ mov(r2, Operand(locals_count)); |
| + __ LoadRoot(ip, Heap::kUndefinedValueRootIndex); |
|
vincent.belliard.fr
2013/10/30 08:45:02
The two LoadRoot can be factorized before the if.
Benedikt Meurer
2013/10/30 08:46:53
Hm, no, I think the mov(r2, Operand(locals_count))
vincent.belliard.fr
2013/10/30 08:53:56
We can use an other register to load undefined (fo
|
| + __ bind(&loop); |
| + __ sub(r2, r2, Operand(1), SetCC); |
| __ push(ip); |
| + __ b(&loop, ne); |
| + } else { |
| + __ LoadRoot(ip, Heap::kUndefinedValueRootIndex); |
| + for (int i = 0; i < locals_count; i++) { |
| + __ push(ip); |
| + } |
| } |
| } |
| } |