OSDN Git Service

android-x86/art.git
10 years agoFix wrong handling of Generic JNI not finding native method.
Andreas Gampe [Fri, 4 Apr 2014 23:20:13 +0000 (16:20 -0700)]
Fix wrong handling of Generic JNI not finding native method.

Code did not properly call JNIMethodEnd, such that locks etc
where not correctly handled.

Add a test case to jni_compiler_test.

Change-Id: If2d5c628517d65a56dd6bb5c4cabdff77c7664a1

10 years agoMerge "Fix using kArm instead of kThumb2."
Mathieu Chartier [Fri, 4 Apr 2014 23:16:12 +0000 (23:16 +0000)]
Merge "Fix using kArm instead of kThumb2."

10 years agoFix using kArm instead of kThumb2.
Mathieu Chartier [Fri, 4 Apr 2014 23:10:05 +0000 (16:10 -0700)]
Fix using kArm instead of kThumb2.

Change-Id: I0f3bf93b38d910bc57d017693675829b6a39bc18

10 years agoMerge "art_quick_lock_object uses registers incorrectly"
Ian Rogers [Fri, 4 Apr 2014 22:29:04 +0000 (22:29 +0000)]
Merge "art_quick_lock_object uses registers incorrectly"

10 years agoMerge "ARM: enable optimisation for easy multiply, add modulus pattern."
Ian Rogers [Fri, 4 Apr 2014 22:13:22 +0000 (22:13 +0000)]
Merge "ARM: enable optimisation for easy multiply, add modulus pattern."

10 years agoMerge "Check the machine type of an ELF file when loading."
Andreas Gampe [Fri, 4 Apr 2014 22:08:03 +0000 (22:08 +0000)]
Merge "Check the machine type of an ELF file when loading."

10 years agoCheck the machine type of an ELF file when loading.
Andreas Gampe [Fri, 4 Apr 2014 00:50:24 +0000 (17:50 -0700)]
Check the machine type of an ELF file when loading.

This ensures that we reject wrong target ELF files,
and should result in a recompile for the right
target.

Change-Id: I898dddc4f2bb9b1607a7436083d0ba7619b6007b

10 years agoMerge "Improve invalid root dumping."
Mathieu Chartier [Fri, 4 Apr 2014 18:37:41 +0000 (18:37 +0000)]
Merge "Improve invalid root dumping."

10 years agoImprove invalid root dumping.
Mathieu Chartier [Fri, 4 Apr 2014 18:09:41 +0000 (11:09 -0700)]
Improve invalid root dumping.

The invalid root dumping now attempts to print the root type.

Change-Id: Ie821296d569f34909ba6e2705f5c347cd2143a3a

10 years agoMerge "Disable use of R4 as a promotable register"
Dave Allison [Fri, 4 Apr 2014 17:25:33 +0000 (17:25 +0000)]
Merge "Disable use of R4 as a promotable register"

10 years agoMerge "Inlining synthetic accessors."
Vladimir Marko [Fri, 4 Apr 2014 17:19:02 +0000 (17:19 +0000)]
Merge "Inlining synthetic accessors."

10 years agoMerge "Inlining setters that return one of their arguments."
Vladimir Marko [Fri, 4 Apr 2014 16:42:17 +0000 (16:42 +0000)]
Merge "Inlining setters that return one of their arguments."

10 years agoInlining synthetic accessors.
Vladimir Marko [Wed, 2 Apr 2014 14:24:05 +0000 (15:24 +0100)]
Inlining synthetic accessors.

Bug: 11549140
Change-Id: Ie0034a6840b1beaa3df92f26bf9d315119c81e34

10 years agoInlining setters that return one of their arguments.
Vladimir Marko [Fri, 4 Apr 2014 13:52:53 +0000 (14:52 +0100)]
Inlining setters that return one of their arguments.

Useful for builder classes and synthetic setters. The latter
are not inlined yet since they are static methods, i.e. they
don't use "this" as the object for IPUT.

Change-Id: I946cf570195be83ecec5fb32851bcaefad45f8a5

10 years agoMerge "Re-enable DEX-to-DEX compilation path"
Sebastien Hertz [Fri, 4 Apr 2014 15:07:26 +0000 (15:07 +0000)]
Merge "Re-enable DEX-to-DEX compilation path"

10 years agoRe-enable DEX-to-DEX compilation path
Sebastien Hertz [Fri, 4 Apr 2014 13:59:53 +0000 (15:59 +0200)]
Re-enable DEX-to-DEX compilation path

Bug: 13807032
Change-Id: I6de7adb81a0f955a93257b83db9ad689ebcd90ad

10 years agoMerge "Fix LoadValueWide to not call MarkLive for high reg that is equal to low reg"
Bill Buzbee [Fri, 4 Apr 2014 14:00:12 +0000 (14:00 +0000)]
Merge "Fix LoadValueWide to not call MarkLive for high reg that is equal to low reg"

10 years agoMerge "Clean up special method inlining."
Vladimir Marko [Fri, 4 Apr 2014 13:18:51 +0000 (13:18 +0000)]
Merge "Clean up special method inlining."

10 years agoClean up special method inlining.
Vladimir Marko [Fri, 4 Apr 2014 11:37:07 +0000 (12:37 +0100)]
Clean up special method inlining.

Mark inlined getter/setter INVOKEs as NOP to allow implicit
null checks (SIGSEGV-based) rather than the explicit checks
in GenInvoke().

Avoid inlining wide setter and returning wide argument if
the wide source is not in consecutive dalvik registers in
INVOKE. This is valid dalvik bytecode and we should treat it
correctly even if we're currently unaware of any tools that
would generate such INVOKEs.

Remove bogus MIR_INLINED checks from LVN.

Change-Id: I7e75a832fcf9bd0550e21b1c8b3813c6166197dd

10 years agoMerge "Use target-specific word instead of runtime word."
Nicolas Geoffray [Fri, 4 Apr 2014 10:13:53 +0000 (10:13 +0000)]
Merge "Use target-specific word instead of runtime word."

10 years agoUse target-specific word instead of runtime word.
Nicolas Geoffray [Fri, 4 Apr 2014 09:50:14 +0000 (10:50 +0100)]
Use target-specific word instead of runtime word.

Change-Id: Ia11dc3cc520a1a5c7bd017013e5699af9570ce91

10 years agoMerge "Disassemble Thumb2 shifts and more VFP instructions."
Vladimir Marko [Fri, 4 Apr 2014 09:14:00 +0000 (09:14 +0000)]
Merge "Disassemble Thumb2 shifts and more VFP instructions."

10 years agoMerge "Add support for new-instance and invoke-direct."
Nicolas Geoffray [Fri, 4 Apr 2014 09:07:17 +0000 (09:07 +0000)]
Merge "Add support for new-instance and invoke-direct."

10 years agoMerge "Please clang by making explicit instantiations non-static."
Nicolas Geoffray [Fri, 4 Apr 2014 09:06:06 +0000 (09:06 +0000)]
Merge "Please clang by making explicit instantiations non-static."

10 years agoPlease clang by making explicit instantiations non-static.
Nicolas Geoffray [Fri, 4 Apr 2014 08:55:27 +0000 (09:55 +0100)]
Please clang by making explicit instantiations non-static.

Change-Id: I4112bf62c69b4f28ca369c4bf3c626be43692afd

10 years agoAdd support for new-instance and invoke-direct.
Nicolas Geoffray [Thu, 3 Apr 2014 17:49:58 +0000 (18:49 +0100)]
Add support for new-instance and invoke-direct.

Change-Id: I2daed646904f7711972a7da15d88be7573426932

10 years agoMerge "Explicitly instantiate artInvokeCommon to please analysis tool."
Nicolas Geoffray [Fri, 4 Apr 2014 08:35:57 +0000 (08:35 +0000)]
Merge "Explicitly instantiate artInvokeCommon to please analysis tool."

10 years agoExplicitly instantiate artInvokeCommon to please analysis tool.
Nicolas Geoffray [Fri, 4 Apr 2014 08:26:24 +0000 (09:26 +0100)]
Explicitly instantiate artInvokeCommon to please analysis tool.

Change-Id: I5c078a197c5026e9bd886d0ba1e188054b5ffa75

10 years agoMerge "Insert an empty read barrier call."
Hiroshi Yamauchi [Fri, 4 Apr 2014 04:34:09 +0000 (04:34 +0000)]
Merge "Insert an empty read barrier call."

10 years agoInsert an empty read barrier call.
Hiroshi Yamauchi [Thu, 3 Apr 2014 00:32:54 +0000 (17:32 -0700)]
Insert an empty read barrier call.

Bug: 12687968
Change-Id: Ie1d28658e16e09f6a983cb5c1f0d5b375b7ae069

10 years agoMerge "Fix Object::Clone()'s pre-fence barrier."
Hiroshi Yamauchi [Fri, 4 Apr 2014 02:54:16 +0000 (02:54 +0000)]
Merge "Fix Object::Clone()'s pre-fence barrier."

10 years agoart_quick_lock_object uses registers incorrectly
Serguei Katkov [Thu, 3 Apr 2014 08:17:26 +0000 (15:17 +0700)]
art_quick_lock_object uses registers incorrectly

x86 implementation of art_quick_lock_object uses registers
incorrectly in the case of .Lalready_thin. eax points to object
while it is used as holding the lock word.

The patch fixes this.

Change-Id: Iacf1a40c6570fae78a5504ca3b2f1218631f7a8f
Signed-off-by: Serguei Katkov <serguei.i.katkov@intel.com>
10 years agoMerge "Restore the args in the invoke trampoline slow paths."
Mathieu Chartier [Fri, 4 Apr 2014 00:47:42 +0000 (00:47 +0000)]
Merge "Restore the args in the invoke trampoline slow paths."

10 years agoFix Object::Clone()'s pre-fence barrier.
Hiroshi Yamauchi [Thu, 3 Apr 2014 23:28:10 +0000 (16:28 -0700)]
Fix Object::Clone()'s pre-fence barrier.

Pass in a pre-fence barrier object that sets in the array length
instead of setting it after returning from AllocObject().

Fix another potential bug due to the wrong default pre-fence barrier
parameter value. Since this appears error-prone, removed the default
parameter value and make it an explicit parameter.

Fix another potential moving GC bug due to a lack of a SirtRef.

Bug: 13097759
Change-Id: I466aa0e50f9e1a5dbf20be5a195edee619c7514e

10 years agoRestore the args in the invoke trampoline slow paths.
Mathieu Chartier [Thu, 3 Apr 2014 22:25:30 +0000 (15:25 -0700)]
Restore the args in the invoke trampoline slow paths.

Previously, there were errors caused by not restoring the args for
the slow path in artInvokeInterfaceTrampoline and artInvokeCommon. The
slow path in artInvokeInterfaceTrampoline occurs when you attempt
to do an interface dispatch of a method in another dex file. The slow
path in artInvokeCommon occurs when the method in dex cache is not
already resolved.

Since FindMethodFromCode may resolve a method, it can occasionally
cause thread suspension/GC. If a moving GC occurred at this point it
resulted in this_object being invalid after the trampoline returned
the code pointer. This caused a native crash in one of the money runs
since there was an unbundeled app which did a List.iterator call.

Bug: 12934910
Change-Id: Ib454faad14bef0d7732a6d7f1ca5803472d502a6

10 years agoDisable use of R4 as a promotable register
Dave Allison [Thu, 3 Apr 2014 23:33:48 +0000 (16:33 -0700)]
Disable use of R4 as a promotable register

When we are using implicit suspend checks we can potentially
use r4 as a register into which variables can be promoted.  However
the runtime doesn't save this and thus will corrupt it.  Not good.

This disables the promotion of r4 until we can figure out how
to make the runtime save it properly.

Change-Id: Ib95ce93579e1c364de5ecc8e728f2cb7990da77a

10 years agoFix LoadValueWide to not call MarkLive for high reg that is equal to low reg
Chao-ying Fu [Thu, 3 Apr 2014 22:09:37 +0000 (15:09 -0700)]
Fix LoadValueWide to not call MarkLive for high reg that is equal to low reg

For x86 double FP registers, LoadValueWide should not call MarkLive for
high reg that is equal to low reg.

Change-Id: Ie6a59307c9ff93303bd489c15529432cfdeceaa4
Signed-off-by: Chao-ying Fu <chao-ying.fu@intel.com>
10 years agoMerge "Do not output ARM64 assembler debug code."
Andreas Gampe [Thu, 3 Apr 2014 20:46:07 +0000 (20:46 +0000)]
Merge "Do not output ARM64 assembler debug code."

10 years agoMerge "Make frame size dependent on arch-specific constants."
Andreas Gampe [Thu, 3 Apr 2014 20:43:06 +0000 (20:43 +0000)]
Merge "Make frame size dependent on arch-specific constants."

10 years agoMerge "Add OpEndIT() for marking the end of OpIT blocks"
Dave Allison [Thu, 3 Apr 2014 20:41:20 +0000 (20:41 +0000)]
Merge "Add OpEndIT() for marking the end of OpIT blocks"

10 years agoMake frame size dependent on arch-specific constants.
Andreas Gampe [Thu, 3 Apr 2014 20:31:32 +0000 (13:31 -0700)]
Make frame size dependent on arch-specific constants.

Necessary for proper cross-compiling.

Change-Id: I852901ee6ca5121e480b83a8e318bdc9c7d615e8

10 years agoDisassemble Thumb2 shifts and more VFP instructions.
Vladimir Marko [Thu, 3 Apr 2014 16:59:02 +0000 (17:59 +0100)]
Disassemble Thumb2 shifts and more VFP instructions.

Disassemble Thumb2 instructions LSL, LSR, ASR, ROR and VFP
instructions VABS, VADD, VSUB, VMOV, VMUL, VNMUL, VDIV.

Clean up disassembly of VCMP, VCMPE, VNEG and VSQRT. These
could have been erroneously used for other insns (VSQRT for
VMOV was encountered) and one VSQRT branch was unreachable.

Remove duplicate VMOV opcodes from compiler.

Change-Id: I160a1e3e4b6eabb6a5101ce348ffd49c0573257d

10 years agoDo not output ARM64 assembler debug code.
Andreas Gampe [Thu, 3 Apr 2014 20:16:01 +0000 (13:16 -0700)]
Do not output ARM64 assembler debug code.

This breaks the run tests, which are a simple diff against an
expected output. Please do such changes in a local change.

Change-Id: Ib961919600ba79eca1356278bc6c09ca17041c7c

10 years agoAdd OpEndIT() for marking the end of OpIT blocks
Dave Allison [Thu, 3 Apr 2014 00:03:45 +0000 (17:03 -0700)]
Add OpEndIT() for marking the end of OpIT blocks

In ARM we need to prevent code motion to the inside of an
IT block.  This was done using a GenBarrier() to mark the end, but
it wasn't obvious that this is what was happening.  This CL adds
an explicit OpEndIT() that takes the LIR of the OpIT for future
checks.

Bug: 13751744
Change-Id: If41d2adea1f43f11ebb3b72906bd308252ce3d01

10 years agoMerge "Fix off-by-1 error in new SpaceBitmap"
Andreas Gampe [Thu, 3 Apr 2014 17:52:27 +0000 (17:52 +0000)]
Merge "Fix off-by-1 error in new SpaceBitmap"

10 years agoFix off-by-1 error in new SpaceBitmap
Andreas Gampe [Thu, 3 Apr 2014 17:46:42 +0000 (10:46 -0700)]
Fix off-by-1 error in new SpaceBitmap

Do not visit_end in the VisitMarkedRange code.

Change-Id: Iaf02788509b21a102cd1c0e2db3cbd09d0522bfa

10 years agoMerge "Add monitor_enter_object as root."
Mathieu Chartier [Thu, 3 Apr 2014 17:43:40 +0000 (17:43 +0000)]
Merge "Add monitor_enter_object as root."

10 years agoAdd monitor_enter_object as root.
Mathieu Chartier [Thu, 3 Apr 2014 16:57:36 +0000 (09:57 -0700)]
Add monitor_enter_object as root.

The monitor enter object was not a root, this caused issues with
compactions since the object could move and then verify object would
fail.

Bug: 13769139
Change-Id: Ia732376fb9d1de8bf137ef9894cb2bb3241d8bb2

10 years agoARM: enable optimisation for easy multiply, add modulus pattern.
Zheng Xu [Wed, 2 Apr 2014 12:31:31 +0000 (13:31 +0100)]
ARM: enable optimisation for easy multiply, add modulus pattern.

Fix the issue when src/dest registers overlap in easy multiply.

Change-Id: Ie8cc098c29c74fd06c1b67359ef94f2c6b88a71e

10 years agoMerge "Support passing arguments to invoke-static* instructions."
Nicolas Geoffray [Thu, 3 Apr 2014 16:49:25 +0000 (16:49 +0000)]
Merge "Support passing arguments to invoke-static* instructions."

10 years agoSupport passing arguments to invoke-static* instructions.
Nicolas Geoffray [Thu, 3 Apr 2014 09:38:37 +0000 (10:38 +0100)]
Support passing arguments to invoke-static* instructions.

- Stop using the frame pointer for accessing locals.
- Stop emulating a stack when doing code generation. Instead,
  rely on dex register model, where instructions only reference
  registers.

Change-Id: Id51bd7d33ac430cb87a53c9f4b0c864eeb1006f9

10 years agoMerge "art: Handle x86_64 architecture equal to x86"
Bill Buzbee [Thu, 3 Apr 2014 13:29:36 +0000 (13:29 +0000)]
Merge "art: Handle x86_64 architecture equal to x86"

10 years agoMerge "Fix Unsafe.getLong()/putLong() for x86, add test."
Vladimir Marko [Thu, 3 Apr 2014 12:58:51 +0000 (12:58 +0000)]
Merge "Fix Unsafe.getLong()/putLong() for x86, add test."

10 years agoMerge "Runtime::PreZygoteFork returns void, not boolean."
Narayan Kamath [Thu, 3 Apr 2014 12:28:17 +0000 (12:28 +0000)]
Merge "Runtime::PreZygoteFork returns void, not boolean."

10 years agoFix Unsafe.getLong()/putLong() for x86, add test.
Vladimir Marko [Thu, 3 Apr 2014 11:56:06 +0000 (12:56 +0100)]
Fix Unsafe.getLong()/putLong() for x86, add test.

Change-Id: Id6841ae50e1047543c04dcdae30254dd6ce82082

10 years agoMerge "Profile: renamed kThresholdPercent and make it configurable"
Calin Juravle [Thu, 3 Apr 2014 09:01:40 +0000 (09:01 +0000)]
Merge "Profile: renamed kThresholdPercent and make it configurable"

10 years agoMerge "Profile: repurposed kTresholdPercent"
Calin Juravle [Thu, 3 Apr 2014 09:01:20 +0000 (09:01 +0000)]
Merge "Profile: repurposed kTresholdPercent"

10 years agoart: Handle x86_64 architecture equal to x86
Dmitry Petrochenko [Wed, 2 Apr 2014 10:27:59 +0000 (17:27 +0700)]
art: Handle x86_64 architecture equal to x86

This patch forces FE/ME to treat x86_64 as x86 exactly.
The x86_64 logic will be revised later when assembly will be ready.

Change-Id: I4a92477a6eeaa9a11fd710d35c602d8d6f88cbb6
Signed-off-by: Dmitry Petrochenko <dmitry.petrochenko@intel.com>
10 years agoMerge "Use temp register in Unsafe Get/Put intrisics for displaced offset."
Mathieu Chartier [Thu, 3 Apr 2014 02:45:19 +0000 (02:45 +0000)]
Merge "Use temp register in Unsafe Get/Put intrisics for displaced offset."

10 years agoMerge "Make SpaceBitmap cross-compiling tolerant"
Andreas Gampe [Thu, 3 Apr 2014 01:17:54 +0000 (01:17 +0000)]
Merge "Make SpaceBitmap cross-compiling tolerant"

10 years agoUse temp register in Unsafe Get/Put intrisics for displaced offset.
Mathieu Chartier [Thu, 3 Apr 2014 00:09:17 +0000 (17:09 -0700)]
Use temp register in Unsafe Get/Put intrisics for displaced offset.

Previously, the object register would get clobberd by the adding the
offset for wide UnsafeGets and wide UnsafePuts. This resulted in heap
corruption in AtomicLongFieldUpdater.compareAndSet and possibly other
places.

Bug: 13744490
Change-Id: Ic368d930b855c5c57e22060b32b73d0745328ef2

10 years agoMerge "Add support for -Xverify:none mode."
Jeff Hao [Thu, 3 Apr 2014 00:38:52 +0000 (00:38 +0000)]
Merge "Add support for -Xverify:none mode."

10 years agoAdd support for -Xverify:none mode.
Jeff Hao [Tue, 1 Apr 2014 21:58:49 +0000 (14:58 -0700)]
Add support for -Xverify:none mode.

This mode skips all verification and compilation.
Public bug: https://code.google.com/p/android/issues/detail?id=67664

Change-Id: Idd00ab8e9e46d129c02988b063c41a507e07bf5b

10 years agoMake SpaceBitmap cross-compiling tolerant
Andreas Gampe [Wed, 2 Apr 2014 22:39:58 +0000 (15:39 -0700)]
Make SpaceBitmap cross-compiling tolerant

Change the order of bits in SpaceBitmap to be the intuitive one:
Offset 0 is bit 0, instead of the MSB. Then compiling on 32b for
64b works as expected.

Change-Id: Iee2491eaf06d4b5f8b534b7c980d5719633cb64c

10 years agoMerge "Keep the symbol table in the shared libraries."
Christopher Ferris [Wed, 2 Apr 2014 23:51:59 +0000 (23:51 +0000)]
Merge "Keep the symbol table in the shared libraries."

10 years agoMerge "Pass instruction-set from runtime through to spawned dex2oat."
Ian Rogers [Wed, 2 Apr 2014 23:18:43 +0000 (23:18 +0000)]
Merge "Pass instruction-set from runtime through to spawned dex2oat."

10 years agoPass instruction-set from runtime through to spawned dex2oat.
Ian Rogers [Wed, 2 Apr 2014 21:55:49 +0000 (14:55 -0700)]
Pass instruction-set from runtime through to spawned dex2oat.

Change-Id: I1727af7beb9f710c29124d4d6bc9175e4856f3cc

10 years agoProfile: renamed kThresholdPercent and make it configurable
Calin Juravle [Wed, 2 Apr 2014 18:08:47 +0000 (19:08 +0100)]
Profile: renamed kThresholdPercent and make it configurable

Bug: 12877748
Change-Id: If266f20f77faad4a726ef8df451a0c42f541392f

10 years agoMerge "force dex2oat target executables to be compiled for 32-bit"
Colin Cross [Wed, 2 Apr 2014 20:15:25 +0000 (20:15 +0000)]
Merge "force dex2oat target executables to be compiled for 32-bit"

10 years agoMerge "Add r4 as promotable register if implicit suspend checks"
Dave Allison [Wed, 2 Apr 2014 20:14:58 +0000 (20:14 +0000)]
Merge "Add r4 as promotable register if implicit suspend checks"

10 years agoAdd r4 as promotable register if implicit suspend checks
Dave Allison [Wed, 2 Apr 2014 00:45:18 +0000 (17:45 -0700)]
Add r4 as promotable register if implicit suspend checks

If we are doing implicit suspend checks we should be able
to use r4 as a target for promotion.

Also bump OAT version

Change-Id: Ia27d14ece3b3259dbb74bcf89feaa9da2cda6db8

10 years agoforce dex2oat target executables to be compiled for 32-bit
Colin Cross [Thu, 20 Mar 2014 19:55:13 +0000 (12:55 -0700)]
force dex2oat target executables to be compiled for 32-bit

64-bit dex2oat doesn't support 32-bit targets yet, force dex2oat
target executables to compile 32-bit for now by passing in a
value for LOCAL_MULTILIB to build-art-executable.

Bug: 13764385
Change-Id: I41adba1e64f373e4b61a3c13af2592ed4f7d0b57

10 years agoProfile: repurposed kTresholdPercent
Calin Juravle [Wed, 2 Apr 2014 16:03:08 +0000 (17:03 +0100)]
Profile: repurposed kTresholdPercent

Previously kTresholdPercent was the percentage of samples of the total
that a method must comprise before compiling.

I changed it to mean the threshold for a running total...i.e. compile
all the methods that comprise K% of the samples cumulatively.

(in the process fixed ProfileData#percent doc and changed its name)

Bug: 12877748
Change-Id: Ib0e18e525a16c11b189afc3d840c09183ac629de

10 years agoMerge "Avoid debug check violation in thread registration."
Ian Rogers [Wed, 2 Apr 2014 15:49:42 +0000 (15:49 +0000)]
Merge "Avoid debug check violation in thread registration."

10 years agoAvoid debug check violation in thread registration.
Ian Rogers [Wed, 2 Apr 2014 15:34:36 +0000 (08:34 -0700)]
Avoid debug check violation in thread registration.

Bug: 13757855
Change-Id: Ied83a7fc43e2b9a89a8b99aa4f74069ef8a369b1

10 years agoMerge "Fixed total method count in profile file parsing."
Calin Juravle [Wed, 2 Apr 2014 15:17:21 +0000 (15:17 +0000)]
Merge "Fixed total method count in profile file parsing."

10 years agoFixed total method count in profile file parsing.
Calin Juravle [Wed, 2 Apr 2014 14:41:43 +0000 (15:41 +0100)]
Fixed total method count in profile file parsing.

Change-Id: Iae38b3ca296378d17f054ac330301035ec684084

10 years agoRuntime::PreZygoteFork returns void, not boolean.
Narayan Kamath [Wed, 2 Apr 2014 11:54:23 +0000 (12:54 +0100)]
Runtime::PreZygoteFork returns void, not boolean.

This method aborts on failure (as it should) and unconditionally
returns true, so making it return void simplifies callers.

Change-Id: Iae39bd327f20311579ece47efa8afd1be7defce9

10 years agoMerge "Include <sys/resource.h> for rlimit."
Narayan Kamath [Wed, 2 Apr 2014 11:15:38 +0000 (11:15 +0000)]
Merge "Include <sys/resource.h> for rlimit."

10 years agoInclude <sys/resource.h> for rlimit.
Narayan Kamath [Wed, 2 Apr 2014 11:06:02 +0000 (12:06 +0100)]
Include <sys/resource.h> for rlimit.

Change-Id: I0e487f8191e284052d8b82eb942d723147d780a1

10 years agoMerge "Update missed DEX2OAT -> DEX2OATD changes."
Nicolas Geoffray [Wed, 2 Apr 2014 10:34:54 +0000 (10:34 +0000)]
Merge "Update missed DEX2OAT -> DEX2OATD changes."

10 years agoUpdate missed DEX2OAT -> DEX2OATD changes.
Nicolas Geoffray [Wed, 2 Apr 2014 10:33:28 +0000 (11:33 +0100)]
Update missed DEX2OAT -> DEX2OATD changes.

Change-Id: I9556ac9ce30fe057e8b278858303e25c547e86ba

10 years agoMerge "Move most zygote related code to frameworks/base."
Narayan Kamath [Wed, 2 Apr 2014 10:29:49 +0000 (10:29 +0000)]
Merge "Move most zygote related code to frameworks/base."

10 years agoMerge "Use debug version of DEX2OAT explicitly."
Nicolas Geoffray [Wed, 2 Apr 2014 08:53:01 +0000 (08:53 +0000)]
Merge "Use debug version of DEX2OAT explicitly."

10 years agoUse debug version of DEX2OAT explicitly.
Nicolas Geoffray [Wed, 26 Mar 2014 10:56:24 +0000 (10:56 +0000)]
Use debug version of DEX2OAT explicitly.

Change-Id: I57b4c8caedcc6bfbeaa541d8171f8b5b3069c584

10 years agoMerge "Fix ClassHelper::GetDirectInterface for proxy class"
Sebastien Hertz [Wed, 2 Apr 2014 07:48:31 +0000 (07:48 +0000)]
Merge "Fix ClassHelper::GetDirectInterface for proxy class"

10 years agoMerge "Cleanup transaction support"
Sebastien Hertz [Wed, 2 Apr 2014 07:45:51 +0000 (07:45 +0000)]
Merge "Cleanup transaction support"

10 years agoCleanup transaction support
Sebastien Hertz [Fri, 21 Feb 2014 14:46:30 +0000 (15:46 +0100)]
Cleanup transaction support

Updates Thread::CreateInternalStackTrace to support both transactional and
non-transactional modes using template.

Generalizes non-transactional mode for invariant fields (which are set only
once).

Removes ArrayLog::VisitRoots as we never create Array logs of ObjectArray. As
ObjectArray elements are set using Object::SetFieldObject, they are already
recorded in the object logs: the object is the array itself and the offset
corresponds to the element index in this array. And also checks we never log
ObjectArray in array logs.

Fixes location of thrown exception when calling native method during class
initialization.

Change-Id: Idbc368d3b8292b85ff40bc8a7c559e085477bf89

10 years agoKeep the symbol table in the shared libraries.
Christopher Ferris [Tue, 1 Apr 2014 19:29:09 +0000 (12:29 -0700)]
Keep the symbol table in the shared libraries.

In order to allow the unwinder code to have meaningful names for
art functions, leave the symbol table.

Here are the size increases:

Platform    Size Increase
--------    -------------
arm         ~631K
arm64       ~631K
mips        ~424K
x86         ~565K
x86_64      ~565K

Bug: 12958251
Change-Id: Ib8bf11bef648f8296f4d6544f7b2af0d7f969ad8

10 years agoMerge "Use TEST_ART_RUN_TESTS consistently"
Brian Carlstrom [Wed, 2 Apr 2014 03:18:59 +0000 (03:18 +0000)]
Merge "Use TEST_ART_RUN_TESTS consistently"

10 years agoUse TEST_ART_RUN_TESTS consistently
Brian Carlstrom [Wed, 2 Apr 2014 01:09:33 +0000 (18:09 -0700)]
Use TEST_ART_RUN_TESTS consistently

Change-Id: I0242702886d53a39f2604e209a0763ff82278e1c

10 years agoMerge "Add GenBarrier() calls to terminate all IT blocks."
Dave Allison [Tue, 1 Apr 2014 23:44:59 +0000 (23:44 +0000)]
Merge "Add GenBarrier() calls to terminate all IT blocks."

10 years agoAdd GenBarrier() calls to terminate all IT blocks.
Dave Allison [Tue, 1 Apr 2014 22:14:46 +0000 (15:14 -0700)]
Add GenBarrier() calls to terminate all IT blocks.

This is needed to prevent things like load hoisting from putting
instructions inside the IT block.

Bug: 13749123
Change-Id: I98a010453b163ac20a90f626144f798fc06e65a9

10 years agoMerge "Fix ThreadStress, unify ANR lock descriptions."
Ian Rogers [Tue, 1 Apr 2014 22:46:11 +0000 (22:46 +0000)]
Merge "Fix ThreadStress, unify ANR lock descriptions."

10 years agoMerge "Fix Thread offsets for ARM64 assembly"
Andreas Gampe [Tue, 1 Apr 2014 22:44:36 +0000 (22:44 +0000)]
Merge "Fix Thread offsets for ARM64 assembly"

10 years agoMerge "Fix running with DlMalloc instead of RosAlloc."
Mathieu Chartier [Tue, 1 Apr 2014 22:37:45 +0000 (22:37 +0000)]
Merge "Fix running with DlMalloc instead of RosAlloc."

10 years agoFix ThreadStress, unify ANR lock descriptions.
Ian Rogers [Tue, 1 Apr 2014 22:33:03 +0000 (15:33 -0700)]
Fix ThreadStress, unify ANR lock descriptions.

Bug: 13323656
Change-Id: I902825a847af9aa570ed79701409298e3532bebf

10 years agoFix running with DlMalloc instead of RosAlloc.
Mathieu Chartier [Tue, 1 Apr 2014 22:01:46 +0000 (15:01 -0700)]
Fix running with DlMalloc instead of RosAlloc.

Bug: 13748830
Bug: 13744490

Change-Id: Ieec97cf58ebf9864a40ee85aae582cdcf3f27c0c

10 years agoFix Thread offsets for ARM64 assembly
Andreas Gampe [Tue, 1 Apr 2014 21:18:21 +0000 (14:18 -0700)]
Fix Thread offsets for ARM64 assembly

Change-Id: I8d0516091b5a865f415e1446425203785e607f8a

10 years agoMerge "Build changes to build multilib tests"
Andreas Gampe [Tue, 1 Apr 2014 21:13:05 +0000 (21:13 +0000)]
Merge "Build changes to build multilib tests"