OSDN Git Service
Roland Levillain [Wed, 12 Aug 2015 11:50:47 +0000 (11:50 +0000)]
am
6a5037eb: Merge "[optimizing] More x86_64 code improvements"
* commit '
6a5037eb3340e4c981fd7de3ff45167ee5b7fc82':
[optimizing] More x86_64 code improvements
Roland Levillain [Wed, 12 Aug 2015 11:43:20 +0000 (11:43 +0000)]
Merge "[optimizing] More x86_64 code improvements"
Mathieu Chartier [Wed, 12 Aug 2015 03:27:38 +0000 (03:27 +0000)]
am
2b562f40: Merge "Some heap cleanup"
* commit '
2b562f400cf9717f197ae3ae1f9a32c96769ef06':
Some heap cleanup
Mathieu Chartier [Wed, 12 Aug 2015 03:22:25 +0000 (03:22 +0000)]
Merge "Some heap cleanup"
Mathieu Chartier [Wed, 12 Aug 2015 00:35:25 +0000 (17:35 -0700)]
Some heap cleanup
Bug:
19534862
Change-Id: Ia63f489d26ec8813a263ce877bdbbc8c4e8fe5f4
Mathieu Chartier [Wed, 12 Aug 2015 00:19:18 +0000 (00:19 +0000)]
am
8ee8f322: Merge "Add daemon threads to 004-ThreadStress"
* commit '
8ee8f3223bcf1ad5f3ee11d35c7b4105a48847d8':
Add daemon threads to 004-ThreadStress
Mathieu Chartier [Wed, 12 Aug 2015 00:12:18 +0000 (00:12 +0000)]
Merge "Add daemon threads to 004-ThreadStress"
Roland Levillain [Tue, 11 Aug 2015 22:40:46 +0000 (22:40 +0000)]
am
548a3ce2: Merge "[MIPS] Avoid using odd numbered fp registers"
* commit '
548a3ce2625bc1da12034411036e5a94da183696':
[MIPS] Avoid using odd numbered fp registers
Roland Levillain [Tue, 11 Aug 2015 22:34:21 +0000 (22:34 +0000)]
Merge "[MIPS] Avoid using odd numbered fp registers"
Mathieu Chartier [Tue, 11 Aug 2015 21:21:38 +0000 (21:21 +0000)]
am
4500fcbe: Merge "Address some comments"
* commit '
4500fcbe682d666a24c2e8f6e0cb90cfb35d3fa3':
Address some comments
Mathieu Chartier [Tue, 11 Aug 2015 21:13:37 +0000 (21:13 +0000)]
Merge "Address some comments"
Mathieu Chartier [Tue, 11 Aug 2015 20:01:23 +0000 (13:01 -0700)]
Address some comments
Change-Id: I0262304cc720a0e93015955d0a7fb05dfebe213e
Nicolas Geoffray [Tue, 11 Aug 2015 17:50:39 +0000 (17:50 +0000)]
am
ff2ac94e: Merge "Revert "Revert "Pass the verified method to the inlinee DexCompilationUnit."""
* commit '
ff2ac94ebd542c0b3bdb6812a96363ed56df09f0':
Revert "Revert "Pass the verified method to the inlinee DexCompilationUnit.""
Nicolas Geoffray [Tue, 11 Aug 2015 17:42:21 +0000 (17:42 +0000)]
Merge "Revert "Revert "Pass the verified method to the inlinee DexCompilationUnit."""
Mark Mendell [Mon, 25 May 2015 20:02:44 +0000 (16:02 -0400)]
[optimizing] More x86_64 code improvements
Use the constant area some more, use 32-bit immediates in movq
instructions when possible, and other small tweaks.
Remove the commented out code for Math.Abs(float/double) as it would
fail for baseline compiler due to the output being the same as the
input.
Change-Id: Ifa39f1865b94cec2e1c0a99af3066a645e9d3618
Signed-off-by: Mark Mendell <mark.p.mendell@intel.com>
Vladimir Marko [Tue, 11 Aug 2015 14:31:54 +0000 (14:31 +0000)]
am
adbd0e5c: Merge "ART: Fix Quick\'s DCE+GVN"
* commit '
adbd0e5c3a9a9fce4ad49c48d7a4212f3d18cfcc':
ART: Fix Quick's DCE+GVN
Calin Juravle [Tue, 11 Aug 2015 14:31:53 +0000 (14:31 +0000)]
am
423f150e: Merge "ART-Optimizing: Fix the type of HDivZeroCheck"
* commit '
423f150e5c17b5f4cd16259565b61c57f5f19477':
ART-Optimizing: Fix the type of HDivZeroCheck
Vladimir Marko [Tue, 11 Aug 2015 14:28:04 +0000 (14:28 +0000)]
Merge "ART: Fix Quick's DCE+GVN"
Calin Juravle [Tue, 11 Aug 2015 14:25:45 +0000 (14:25 +0000)]
Merge "ART-Optimizing: Fix the type of HDivZeroCheck"
Serguei Katkov [Mon, 10 Aug 2015 06:59:02 +0000 (12:59 +0600)]
ART: Fix Quick's DCE+GVN
DCE_GVN does not take into account the following case:
mov a, b
...
mov c, b
when optimization tries to replace a with c it must ensure that
for all uses of a there is no new definition of c before use.
Otherwise that use will incorrectly substituted with new c instead
of original b.
Bug:
23102860
Change-Id: I48ee0bd4386419b0f9c814c21b3537a392518cd1
Signed-off-by: Serguei Katkov <serguei.i.katkov@intel.com>
Serguei Katkov [Mon, 3 Aug 2015 07:55:33 +0000 (13:55 +0600)]
ART-Optimizing: Fix the type of HDivZeroCheck
HDivZeroCheck is created during the building CFG and at this moment
its type is not known completely. So it sets the type to int or long.
However, later SSA builder can insert the type conversion and type
of input of HDivZeroCheck can become byte or short while the type
of HDivZeroCheck remains the same.
In reality the type of HDivZeroCheck should be always equal to
its input parameter.
To fix this inconsistency we return the type of HDivZeroCheck as its
input type. Code generators are updated accordingly.
Change-Id: I6a5aedc8d479cfc6328704e7ddf252bca830076b
Signed-off-by: Serguei Katkov <serguei.i.katkov@intel.com>
Nicolas Geoffray [Tue, 11 Aug 2015 02:14:38 +0000 (02:14 +0000)]
Revert "Revert "Pass the verified method to the inlinee DexCompilationUnit.""
bug:
22866717
This reverts commit
f25b661b3708c865cdaa0a018372a42881353bea.
Change-Id: I95e8310e6c3d8e6edb736fdefcabf602cce3a4e0
Andreas Gampe [Tue, 11 Aug 2015 01:24:35 +0000 (01:24 +0000)]
am
f24576a7: Merge "ART: Change UnresolvedMergedType merge"
* commit '
f24576a7233ec708d49badb239cd7336c2b0f07e':
ART: Change UnresolvedMergedType merge
Andreas Gampe [Tue, 11 Aug 2015 01:18:15 +0000 (01:18 +0000)]
Merge "ART: Change UnresolvedMergedType merge"
Andreas Gampe [Tue, 11 Aug 2015 00:15:32 +0000 (17:15 -0700)]
ART: Change UnresolvedMergedType merge
Change to use IsUnresolvedTypes.
Bug:
22881413
(cherry picked from commit
168387df8dcbae1b51f124eed84daf8e8de6a974)
Change-Id: Ic27b97b475b28a5bdf994ea5178767e0efb0e752
Man Cao [Mon, 10 Aug 2015 22:51:27 +0000 (15:51 -0700)]
Add daemon threads to 004-ThreadStress
Bug:
19537976
Change-Id: I129e311aa6f7ca4f49d64ec50c0e07857b12b6d8
Andreas Gampe [Mon, 10 Aug 2015 18:55:57 +0000 (18:55 +0000)]
am
32a67404: Merge "ART: Fix reg_type_test"
* commit '
32a67404baa40664e9ace8eac81be0f4704413a5':
ART: Fix reg_type_test
Andreas Gampe [Mon, 10 Aug 2015 18:46:55 +0000 (18:46 +0000)]
Merge "ART: Fix reg_type_test"
Andreas Gampe [Mon, 10 Aug 2015 18:45:24 +0000 (11:45 -0700)]
ART: Fix reg_type_test
Follow-up to
750f7c2827318f6d07620f2ef0321218ea4d8670.
Bug:
22881413
Change-Id: Iaea4cc29ed680710d01532124bc472547ee18bdb
Andreas Gampe [Mon, 10 Aug 2015 18:31:12 +0000 (18:31 +0000)]
am
ebccaad3: Merge "ART: Add complex UnresolvedMergedType test case"
* commit '
ebccaad3ad6bd32f7a37addc5df2381ce988846e':
ART: Add complex UnresolvedMergedType test case
Andreas Gampe [Mon, 10 Aug 2015 18:31:10 +0000 (18:31 +0000)]
am
081da0ad: Merge "ART: Change UnresolvedMergedType internal representation"
* commit '
081da0add911757a48df74e6ae817af1de6e047d':
ART: Change UnresolvedMergedType internal representation
Andreas Gampe [Mon, 10 Aug 2015 18:26:59 +0000 (18:26 +0000)]
Merge "ART: Add complex UnresolvedMergedType test case"
Andreas Gampe [Mon, 10 Aug 2015 18:26:46 +0000 (18:26 +0000)]
Merge "ART: Change UnresolvedMergedType internal representation"
Mathieu Chartier [Mon, 10 Aug 2015 18:22:33 +0000 (18:22 +0000)]
am
4814bbd6: Merge "Do read barriers on native roots in CopyClassVisitor"
* commit '
4814bbd62306dfe07a68cc5def6aad115bebc45f':
Do read barriers on native roots in CopyClassVisitor
Mathieu Chartier [Mon, 10 Aug 2015 18:16:03 +0000 (18:16 +0000)]
Merge "Do read barriers on native roots in CopyClassVisitor"
Mathieu Chartier [Mon, 10 Aug 2015 17:13:02 +0000 (10:13 -0700)]
Do read barriers on native roots in CopyClassVisitor
Fixes a race condition caused by making a copy of a class then
clearing the native root arrays of the original class. If the
original class was gray and the new class was black then the GC
would miss the native roots.
Bug:
22957957
Change-Id: I706110018220af12a2ad0d72eb803f1cfe3580b9
Andreas Gampe [Thu, 6 Aug 2015 18:31:56 +0000 (11:31 -0700)]
ART: Change UnresolvedMergedType internal representation
Use a BitVector instead of the tree representation. This
avoids flattening the components and other instances.
Bug:
22881413
Change-Id: Ibf7cfb54443affeb1753bf114c0f306125391c62
Andreas Gampe [Fri, 7 Aug 2015 15:07:16 +0000 (08:07 -0700)]
ART: Add complex UnresolvedMergedType test case
Add a test case that stresses the verifier. Add dex2oat timeout
to the host prebuild configuration.
Bug:
22881413
Change-Id: Ic4a0d16a4dc69f3d43bac40a560b6e6884df263f
Nicolas Geoffray [Mon, 10 Aug 2015 15:14:50 +0000 (15:14 +0000)]
am
1a5625be: Merge "Fix a bug in the register allocator around pair allocation."
* commit '
1a5625be743a4a84329930ac1c7e96425e24ca8d':
Fix a bug in the register allocator around pair allocation.
Nicolas Geoffray [Mon, 10 Aug 2015 15:07:43 +0000 (15:07 +0000)]
Merge "Fix a bug in the register allocator around pair allocation."
Goran Jakovljevic [Tue, 28 Jul 2015 12:26:12 +0000 (14:26 +0200)]
[MIPS] Avoid using odd numbered fp registers
Don't use odd numbered fp registers for single precision data on
MIPS32r6 (64-bit FPU).
Bug:
23050326
Change-Id: I35cc19df091149773411e2336b01c170929376bc
Nicolas Geoffray [Sat, 8 Aug 2015 01:13:03 +0000 (18:13 -0700)]
Fix a bug in the register allocator around pair allocation.
We may get hints that do not work with the current implementation
of register pairs, which forces the allocation of (low + 1)
for the high register. For example, if the hint is EBX, we will
allocate ESP for the high register.
bug:
23043730
Change-Id: I371ebb0c61568f09d12eb9ab815c0bf0ea02d49b
Andreas Gampe [Sat, 8 Aug 2015 00:28:47 +0000 (00:28 +0000)]
am
77bccdc5: Merge "ART: Clean up unnecessary ArtMethod**"
* commit '
77bccdc5e4f7bb150867c7aecd350efee84367bc':
ART: Clean up unnecessary ArtMethod**
Andreas Gampe [Sat, 8 Aug 2015 00:23:51 +0000 (00:23 +0000)]
Merge "ART: Clean up unnecessary ArtMethod**"
Andreas Gampe [Sat, 8 Aug 2015 00:20:11 +0000 (17:20 -0700)]
ART: Clean up unnecessary ArtMethod**
ArtMethods are no longer Java objects, so the additional indirection
is no longer necessary here.
Change-Id: If76756d875b418b3f6e83f51b3225a158e9ce29b
Andreas Gampe [Sat, 8 Aug 2015 00:20:55 +0000 (00:20 +0000)]
am
fc298560: Merge "ART: Remove TODO in BitVector"
* commit '
fc29856047d90d8f446d73b576c0c18de7a1380f':
ART: Remove TODO in BitVector
Andreas Gampe [Sat, 8 Aug 2015 00:14:42 +0000 (00:14 +0000)]
Merge "ART: Remove TODO in BitVector"
Andreas Gampe [Fri, 7 Aug 2015 15:29:13 +0000 (08:29 -0700)]
ART: Remove TODO in BitVector
Refactor the BitVector constructor: split it up to remove the
possibility to provide contradicting parameters, and add a custom
copying constructor.
Change-Id: Ie943f279baa007db578aea0f2f33fa93311612ee
Mathieu Chartier [Fri, 7 Aug 2015 23:38:50 +0000 (23:38 +0000)]
am
e6b307a8: Merge "Add class table field to class loader"
* commit '
e6b307a833d3a0ba4327004c2a286680e01eae3b':
Add class table field to class loader
Mathieu Chartier [Fri, 7 Aug 2015 23:33:43 +0000 (23:33 +0000)]
Merge "Add class table field to class loader"
Dan Albert [Fri, 7 Aug 2015 23:30:50 +0000 (23:30 +0000)]
am
4b2e98fc: Merge "Fix C++14 bitrot."
* commit '
4b2e98fc8c257a27a95fecbc859fcc617e2fa827':
Fix C++14 bitrot.
Dan Albert [Fri, 7 Aug 2015 23:21:25 +0000 (23:21 +0000)]
Merge "Fix C++14 bitrot."
Dan Albert [Fri, 7 Aug 2015 23:19:01 +0000 (16:19 -0700)]
Fix C++14 bitrot.
Change-Id: I22f7925a87bca45646c563971342a9a1b2090ba6
Mathieu Chartier [Wed, 5 Aug 2015 22:08:12 +0000 (15:08 -0700)]
Add class table field to class loader
Fixes bug with the class table where the comparator would cause read
barriers and break the map strict ordering properties.
Bug:
22957957
Change-Id: I8dbc042db6e22e2172ab4ec58ddf1db0345dcaaa
Nicolas Geoffray [Fri, 7 Aug 2015 16:13:53 +0000 (16:13 +0000)]
am
3ded7766: Merge "Ensure coherency of call kinds for LocationSummary."
* commit '
3ded7766981b3105c7686e0c9d75c378c42fa4a0':
Ensure coherency of call kinds for LocationSummary.
Nicolas Geoffray [Fri, 7 Aug 2015 16:04:33 +0000 (16:04 +0000)]
Merge "Ensure coherency of call kinds for LocationSummary."
Nicolas Geoffray [Fri, 7 Aug 2015 15:36:51 +0000 (15:36 +0000)]
am
a001e3a0: Merge "Revert "Pass the verified method to the inlinee DexCompilationUnit.""
* commit '
a001e3a0200fe137feeaaead3c99026abce914cd':
Revert "Pass the verified method to the inlinee DexCompilationUnit."
Nicolas Geoffray [Fri, 7 Aug 2015 15:31:20 +0000 (15:31 +0000)]
Merge "Revert "Pass the verified method to the inlinee DexCompilationUnit.""
Nicolas Geoffray [Fri, 7 Aug 2015 15:31:10 +0000 (15:31 +0000)]
Revert "Pass the verified method to the inlinee DexCompilationUnit."
Crashes testing libcore on host/x86.
Bug:
22866717
This reverts commit
08624c50f488ecd845e48683e84726ff8c53e6a7.
Change-Id: Ia8f130d9ea32e171e554bd3e10c44f8453111b52
Nicolas Geoffray [Fri, 7 Aug 2015 14:57:50 +0000 (14:57 +0000)]
am
4320ff10: Merge "Pass the verified method to the inlinee DexCompilationUnit."
* commit '
4320ff10bb344140b75e029c6a4d46b070399682':
Pass the verified method to the inlinee DexCompilationUnit.
Nicolas Geoffray [Fri, 7 Aug 2015 14:47:18 +0000 (14:47 +0000)]
Merge "Pass the verified method to the inlinee DexCompilationUnit."
Roland Levillain [Fri, 7 Aug 2015 10:56:54 +0000 (10:56 +0000)]
am
62dee441: Merge "Tighten default inlining settings when using the space filter."
* commit '
62dee441fff15e951c577b9565f87bb5f27c5ffb':
Tighten default inlining settings when using the space filter.
Roland Levillain [Fri, 7 Aug 2015 10:50:06 +0000 (10:50 +0000)]
Merge "Tighten default inlining settings when using the space filter."
Roland Levillain [Fri, 7 Aug 2015 10:38:32 +0000 (11:38 +0100)]
Tighten default inlining settings when using the space filter.
Bug:
21868508
Change-Id: Ic83813a966cef18e59447083926bf033aa587154
Alexandre Rames [Fri, 7 Aug 2015 09:26:17 +0000 (10:26 +0100)]
Ensure coherency of call kinds for LocationSummary.
The coherency is enforced with checks added in the `InvokeRuntime`
helper, that we now also use on x86 and x86_64.
Change-Id: I8cb92b042f25dc3c5fd390e9c61a45b477d081f4
David Brazdil [Fri, 7 Aug 2015 07:31:32 +0000 (07:31 +0000)]
am
33407564: Merge "Introduce arch-specific checker tests."
* commit '
33407564904d2186f536107e1ca8d88f2c760c83':
Introduce arch-specific checker tests.
David Brazdil [Fri, 7 Aug 2015 07:23:23 +0000 (07:23 +0000)]
Merge "Introduce arch-specific checker tests."
Nicolas Geoffray [Fri, 7 Aug 2015 04:10:30 +0000 (21:10 -0700)]
Pass the verified method to the inlinee DexCompilationUnit.
Sharpening and other optimizations in compiler driver rely
on having it there.
Also fixes a warning for the intrinsics code.
bug:
22866717
Change-Id: I6ac4f55e9e77452a4ea9e0d0dd0ad70124a95a55
Calin Juravle [Thu, 6 Aug 2015 17:58:12 +0000 (17:58 +0000)]
am
7fbaa22e: Merge "ART: Fix the simplifier for add/sub"
* commit '
7fbaa22e10979cf17b8c1c0c96bef4919e9d4163':
ART: Fix the simplifier for add/sub
Calin Juravle [Thu, 6 Aug 2015 17:49:55 +0000 (17:49 +0000)]
Merge "ART: Fix the simplifier for add/sub"
Serguei Katkov [Wed, 5 Aug 2015 11:03:30 +0000 (17:03 +0600)]
ART: Fix the simplifier for add/sub
Instruction simplifier for add/sub should not proceed with floats
because that might cause the incorrect behavior with signed zero.
Change-Id: If0c9bf3931bcbf96b0814f8605a86997aea37145
Signed-off-by: Serguei Katkov <serguei.i.katkov@intel.com>
Sebastien Hertz [Thu, 6 Aug 2015 14:52:47 +0000 (14:52 +0000)]
am
a27a67c9: Merge "Fix image loading in interpeter-only mode"
* commit '
a27a67c98e12cd1a90431704a6d7bcbd546667fd':
Fix image loading in interpeter-only mode
Sebastien Hertz [Thu, 6 Aug 2015 14:48:55 +0000 (14:48 +0000)]
am
bc7db535: Merge "Fix DDM reply buffer deallocation"
* commit '
bc7db5356a68cf44d6497f6956e8a97dc9355b80':
Fix DDM reply buffer deallocation
Sebastien Hertz [Thu, 6 Aug 2015 14:46:41 +0000 (14:46 +0000)]
Merge "Fix image loading in interpeter-only mode"
Sebastien Hertz [Thu, 6 Aug 2015 14:43:58 +0000 (14:43 +0000)]
Merge "Fix DDM reply buffer deallocation"
Alexandre Rames [Thu, 6 Aug 2015 13:49:28 +0000 (14:49 +0100)]
Introduce arch-specific checker tests.
- The '.cfg' output is now created on target.
- Arch-specific checker tests can be created by inserting a
suffix. For example:
/// CHECK-START-ARM64: int Main.foo(int) register (after)
/// CHECK-DAG: <<Arg:i\d+>> ParameterValue
Change-Id: I55cdb37f8e806c7ffdde6b676c8f44ac30b59051
Sebastien Hertz [Thu, 6 Aug 2015 10:52:43 +0000 (12:52 +0200)]
Fix image loading in interpeter-only mode
Follow-up https://android-review.googlesource.com/162935. We now need
an ArtMethodVisitor to update entrypoints of methods in the image.
Bug:
22832610
Change-Id: I30ca9c369a73c3372694b446e73afa2e37890a65
Mathieu Chartier [Thu, 6 Aug 2015 12:33:35 +0000 (12:33 +0000)]
am
1f3f766d: Merge "Move ArtFields and ArtMethods to be a length prefixed array"
* commit '
1f3f766d3b365d01f36b85dc19d40f754fa48533':
Move ArtFields and ArtMethods to be a length prefixed array
Sebastien Hertz [Thu, 6 Aug 2015 09:37:02 +0000 (11:37 +0200)]
Fix DDM reply buffer deallocation
Reply buffer is an uint8_t* allocated with new uint8_t[...] so it
must be deallocated with delete[], not free.
Change-Id: Ib5d6387aa63f1e0393113f82602f661bbada4aa2
Mathieu Chartier [Thu, 6 Aug 2015 03:12:39 +0000 (03:12 +0000)]
Merge "Move ArtFields and ArtMethods to be a length prefixed array"
Mathieu Chartier [Thu, 30 Jul 2015 23:20:06 +0000 (16:20 -0700)]
Move ArtFields and ArtMethods to be a length prefixed array
Fixes race conditions between changing method and fields arrays
being seen in the wrong order by the GC.
Bug:
22832610
Change-Id: Ia21d6698f73ba207a6392c3d6b9be2658933073f
Andreas Gampe [Wed, 5 Aug 2015 23:38:50 +0000 (23:38 +0000)]
am
275bc5e5: Merge "ART: Extend ISA features option for (host) run tests"
* commit '
275bc5e5f318ba6ea1bad6c89c2924d1248b7523':
ART: Extend ISA features option for (host) run tests
Andreas Gampe [Wed, 5 Aug 2015 23:06:02 +0000 (23:06 +0000)]
Merge "ART: Extend ISA features option for (host) run tests"
Andreas Gampe [Wed, 5 Aug 2015 16:24:45 +0000 (09:24 -0700)]
ART: Extend ISA features option for (host) run tests
To allow to test advanced intrinsics only available on (fairly)
modern processors, and because our build requirements are still
too low to enable them in the build system, pipe through the
existing make variables to the run-tests to allow to override
the dex2oat autodetection scheme.
Usage (standalone run-test): use the new --instruction-set-features
command line parameter to set the value for dex2oat (in the prebuild
configuration) or as an -Xcompiler-option (for no-prebuild). Note:
this is general and also works for target tests.
Usage (through make): set DEX2OAT_HOST_INSTRUCTION_SET_FEATURES and
2ND_DEX2OAT_HOST_INSTRUCTION_SET_FEATURES to set instruction set
features, as was possible before for the compilation of core files.
This option is now forwarded to host run-tests.
Change-Id: I9d89c82b6a5c8853748e5d1c153dde5d4050757a
Andreas Gampe [Wed, 5 Aug 2015 19:06:54 +0000 (19:06 +0000)]
am
d8406781: Merge "ART: Wire up DexToDexCompiler without extern"
* commit '
d8406781fdb8917ae0c45c1e2194f9a5ab874e78':
ART: Wire up DexToDexCompiler without extern
Andreas Gampe [Wed, 5 Aug 2015 18:59:25 +0000 (18:59 +0000)]
Merge "ART: Wire up DexToDexCompiler without extern"
Andreas Gampe [Thu, 23 Jul 2015 08:19:26 +0000 (01:19 -0700)]
ART: Wire up DexToDexCompiler without extern
The extern declaration actually had the wrong signature, a parameter
was missing, and we never noticed.
Remove the function field and extern. Add a header for the compiler.
Use the header file.
Change-Id: Ia4d4dd86211da6045709a45c7bf8430471d1b62b
Igor Murashkin [Wed, 5 Aug 2015 18:23:03 +0000 (18:23 +0000)]
am
02f0771b: Merge "Revert "cleanup: Replace pointers with out-parameters and fix-up formatting""
* commit '
02f0771bba69edd34b0b112902bb9132ed099c75':
Revert "cleanup: Replace pointers with out-parameters and fix-up formatting"
Igor Murashkin [Wed, 5 Aug 2015 18:18:59 +0000 (18:18 +0000)]
Merge "Revert "cleanup: Replace pointers with out-parameters and fix-up formatting""
Mathieu Chartier [Wed, 5 Aug 2015 18:08:39 +0000 (18:08 +0000)]
am
94800f46: Merge "Address some comments and clean up"
* commit '
94800f46da0aded5152545322ad842f89e8a21d8':
Address some comments and clean up
Mathieu Chartier [Wed, 5 Aug 2015 18:02:53 +0000 (18:02 +0000)]
Merge "Address some comments and clean up"
Mathieu Chartier [Wed, 5 Aug 2015 17:49:05 +0000 (17:49 +0000)]
am
46e0f460: Merge "Fix mod-union logic for native roots"
* commit '
46e0f460aa233a4a0ac161bfafde164357fe2b26':
Fix mod-union logic for native roots
Mathieu Chartier [Wed, 5 Aug 2015 17:42:56 +0000 (17:42 +0000)]
Merge "Fix mod-union logic for native roots"
Mathieu Chartier [Wed, 5 Aug 2015 17:10:07 +0000 (10:10 -0700)]
Fix mod-union logic for native roots
Bug:
22949217
Change-Id: I9e4631870160d5a9412df1eec2a7b79c65668542
Roland Levillain [Wed, 5 Aug 2015 12:57:11 +0000 (12:57 +0000)]
am
13394093: Merge "Have constant folding be more flexible."
* commit '
1339409345cc8b46d64570430ca3197408fda159':
Have constant folding be more flexible.
Roland Levillain [Wed, 5 Aug 2015 12:52:12 +0000 (12:52 +0000)]
Merge "Have constant folding be more flexible."
Roland Levillain [Wed, 5 Aug 2015 10:11:10 +0000 (10:11 +0000)]
am
902ec264: Merge "Add constant folding for long unary operations in opt. compiler."
* commit '
902ec264e1040cbfd783c44809ed10b261bd78ee':
Add constant folding for long unary operations in opt. compiler.
Roland Levillain [Wed, 5 Aug 2015 10:03:46 +0000 (10:03 +0000)]
Merge "Add constant folding for long unary operations in opt. compiler."
Roland Levillain [Wed, 5 Aug 2015 09:21:34 +0000 (10:21 +0100)]
Have constant folding be more flexible.
- Have Evaluate methods take as argument(s) and return value
instances of HConstant (instead of built-in 32- or 64-bit
integer values), to let the evaluated instruction choose
the type of the statically evaluated node; for instance,
art::HEqual::Evaluate shall return a HIntConstant
node (as implementation of a Boolean constant) whatever
the type of its inputs (a pair of HIntConstant or a pair
of HLongConstant).
- Split the evaluation job from the operation logic: the
former is addressed by Evaluate methods, while the latter
is done by a generic Compute method.
- Adress valid BinOp(int, long) and BinOp(long, int) cases.
- Add a constructor to art::HIntConstant to build an integer
constant from a `bool` value.
Change-Id: If84b6fe8406bb94ddb1aa8b02e36628dff526db3
Roland Levillain [Thu, 11 Dec 2014 12:14:33 +0000 (12:14 +0000)]
Add constant folding for long unary operations in opt. compiler.
Add tests to exercise the constant folding of these
instructions.
Also, prevent Java methods from run-tests exercising the
code generation of these instruction from being inlined,
so that they continue to check the generated code (and
not the code produced by the constant folding pass).
Change-Id: I28efca7cdb5142ac2b6d158ba296fb9136d62481