diff options
| author | 2014-02-26 10:38:23 +0700 | |
|---|---|---|
| committer | 2014-02-26 16:46:13 +0700 | |
| commit | c17ebe866beb50eb6da1e6a47555cb4731467f3b (patch) | |
| tree | 704a456285312482394cb15e02dbfaa23e386f0f /compiler/llvm/compiler_llvm.h | |
| parent | ef2cc5a9c6e508a3e8b24d04ca35f7422f27e112 (diff) | |
Incorrect result of the "mul-long by 1" operation
ART handles "mul-long by 1" as a special case and try to alloc a new pair
of regs through the EvalLocWide method and then put there the multiplicand
through the StoreValueWide method. But in case when both multiplicand and
multiplier are constants, it will not place correct values in a new reg pair
and result of calculations will be incorrect. The new solution uses the
only StoreValueWide method.
Change-Id: I3d6947737c92c5a12f2840003b17a427e31d288f
Signed-off-by: Alexei Zavjalov <alexei.zavjalov@intel.com>
Diffstat (limited to 'compiler/llvm/compiler_llvm.h')
0 files changed, 0 insertions, 0 deletions