OSDN Git Service

android-x86/dalvik.git
13 years agoam 789fb059: am bc02ca96: Merge "Fixed bug in OP_GOTO_32.S, added support for additio...
Jean-Baptiste Queru [Tue, 12 Oct 2010 01:58:09 +0000 (18:58 -0700)]
am 789fb059: am bc02ca96: Merge "Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow"

Merge commit '789fb0592cb6ea7ac573bd81ea8fb0a8bb5e103f'

* commit '789fb0592cb6ea7ac573bd81ea8fb0a8bb5e103f':
  Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow

13 years agoam c7fb06ef: am 5276cccb: Verify method invocation type.
Andy McFadden [Mon, 11 Oct 2010 19:37:06 +0000 (12:37 -0700)]
am c7fb06ef: am 5276cccb: Verify method invocation type.

Merge commit 'c7fb06efb576b7ff0295dd70c8beaeea11918645'

* commit 'c7fb06efb576b7ff0295dd70c8beaeea11918645':
  Verify method invocation type.

13 years agoam 22156b4d: am 9be25d09: Clarify the invoke-* opcodes.
Dan Bornstein [Mon, 11 Oct 2010 18:36:14 +0000 (11:36 -0700)]
am 22156b4d: am 9be25d09: Clarify the invoke-* opcodes.

Merge commit '22156b4d43d06446a0bb4d2c887c23bedabb3a96'

* commit '22156b4d43d06446a0bb4d2c887c23bedabb3a96':
  Clarify the invoke-* opcodes.

13 years agoam bc02ca96: Merge "Fixed bug in OP_GOTO_32.S, added support for additional parameter...
Jean-Baptiste Queru [Mon, 11 Oct 2010 01:49:31 +0000 (18:49 -0700)]
am bc02ca96: Merge "Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow"

Merge commit 'bc02ca96c5cd3b45939809ed43ae2e7f2e4fb5b9' into gingerbread-plus-aosp

* commit 'bc02ca96c5cd3b45939809ed43ae2e7f2e4fb5b9':
  Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow

13 years agoMerge "Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandl...
Jean-Baptiste Queru [Mon, 11 Oct 2010 01:34:16 +0000 (18:34 -0700)]
Merge "Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow"

13 years agoam 5276cccb: Verify method invocation type.
Andy McFadden [Sun, 10 Oct 2010 21:12:00 +0000 (14:12 -0700)]
am 5276cccb: Verify method invocation type.

Merge commit '5276cccb15b6ce0133c8107ff9ff013b4a176ef7' into gingerbread-plus-aosp

* commit '5276cccb15b6ce0133c8107ff9ff013b4a176ef7':
  Verify method invocation type.

13 years agoVerify method invocation type.
Andy McFadden [Sun, 10 Oct 2010 19:59:11 +0000 (12:59 -0700)]
Verify method invocation type.

Dalvik provides five different ways to invoke a method (virtual, super,
direct, static, interface).  Using a virtual invoke instruction to call
a direct method will not produce the desired results.

This adds a test to the verifier that ensures the method targeted by
an invocation instruction is of an appropriate kind.

Bug 3082885.

(cherry-pick from dalvik-dev)

Change-Id: I3237cbefc7314f0b9d7557fc0bfd2b548ea30938

13 years agoam 9be25d09: Clarify the invoke-* opcodes.
Dan Bornstein [Sun, 10 Oct 2010 20:20:02 +0000 (13:20 -0700)]
am 9be25d09: Clarify the invoke-* opcodes.

Merge commit '9be25d09d24b3d6d0dd1a41c1c09471af4827687' into gingerbread-plus-aosp

* commit '9be25d09d24b3d6d0dd1a41c1c09471af4827687':
  Clarify the invoke-* opcodes.

13 years agoClarify the invoke-* opcodes.
Dan Bornstein [Sun, 10 Oct 2010 19:29:07 +0000 (12:29 -0700)]
Clarify the invoke-* opcodes.

In particular, make it a little more explicit what kinds of methods
are acceptable for each variant.

Change-Id: Icd9dad876c2d10c23462b4d85ccaa9441d7f2c04

13 years agoMerge "Use DMB ST for store fence."
Andy McFadden [Fri, 1 Oct 2010 22:22:35 +0000 (15:22 -0700)]
Merge "Use DMB ST for store fence."

13 years agoam 5163f62f: am 7d3f633d: Merge "Include static fields when dumping class objects...
Carl Shapiro [Fri, 1 Oct 2010 19:59:39 +0000 (12:59 -0700)]
am 5163f62f: am 7d3f633d: Merge "Include static fields when dumping class objects." into gingerbread

Merge commit '5163f62f7048c4b651a425b4b7a3a1b0fb227eb6'

* commit '5163f62f7048c4b651a425b4b7a3a1b0fb227eb6':
  Include static fields when dumping class objects.

13 years agoam 7d3f633d: Merge "Include static fields when dumping class objects." into gingerbread
Carl Shapiro [Fri, 1 Oct 2010 19:57:44 +0000 (12:57 -0700)]
am 7d3f633d: Merge "Include static fields when dumping class objects." into gingerbread

Merge commit '7d3f633d2c0061e579c57186276c05ddcc275641' into gingerbread-plus-aosp

* commit '7d3f633d2c0061e579c57186276c05ddcc275641':
  Include static fields when dumping class objects.

13 years agoMerge "Include static fields when dumping class objects." into gingerbread
Carl Shapiro [Fri, 1 Oct 2010 19:54:52 +0000 (12:54 -0700)]
Merge "Include static fields when dumping class objects." into gingerbread

13 years agoUse DMB ST for store fence.
Andy McFadden [Fri, 1 Oct 2010 19:31:42 +0000 (12:31 -0700)]
Use DMB ST for store fence.

Change-Id: I4bde544a7c66e30a1756425ec088e53baa2f11a1

13 years agoInclude static fields when dumping class objects.
Carl Shapiro [Fri, 1 Oct 2010 00:20:11 +0000 (17:20 -0700)]
Include static fields when dumping class objects.

Change-Id: I8e7b1d1ef7ca205b489744dcbf0f210c1f2443c4

13 years agoam b11c54c9: am 307aa79a: Merge "Change Runtime.nativeLoad to return the dlerror...
Elliott Hughes [Fri, 1 Oct 2010 17:52:29 +0000 (10:52 -0700)]
am b11c54c9: am 307aa79a: Merge "Change Runtime.nativeLoad to return the dlerror(3) string." into gingerbread

Merge commit 'b11c54c9b7849eaa95423dbbf8433e9f1b20ec32'

* commit 'b11c54c9b7849eaa95423dbbf8433e9f1b20ec32':
  Change Runtime.nativeLoad to return the dlerror(3) string.

13 years agoam 307aa79a: Merge "Change Runtime.nativeLoad to return the dlerror(3) string." into...
Elliott Hughes [Fri, 1 Oct 2010 17:49:02 +0000 (10:49 -0700)]
am 307aa79a: Merge "Change Runtime.nativeLoad to return the dlerror(3) string." into gingerbread

Merge commit '307aa79afc08c50e9ea69aac7bf5128bc75ac7ff' into gingerbread-plus-aosp

* commit '307aa79afc08c50e9ea69aac7bf5128bc75ac7ff':
  Change Runtime.nativeLoad to return the dlerror(3) string.

13 years agoMerge "Change Runtime.nativeLoad to return the dlerror(3) string." into gingerbread
Elliott Hughes [Fri, 1 Oct 2010 17:35:13 +0000 (10:35 -0700)]
Merge "Change Runtime.nativeLoad to return the dlerror(3) string." into gingerbread

13 years agoresolved conflicts for merge of 6d55b332 to master
buzbee [Fri, 1 Oct 2010 06:19:49 +0000 (23:19 -0700)]
resolved conflicts for merge of 6d55b332 to master

Change-Id: I21e35d4cdf2636ae3cd7facd45ad4f5c4ab82e7b

13 years agoam b78c76f8: GC Card marking fix for SPUT_OBJECT - use correct object head
buzbee [Fri, 1 Oct 2010 03:24:45 +0000 (20:24 -0700)]
am b78c76f8: GC Card marking fix for SPUT_OBJECT - use correct object head

Merge commit 'b78c76f88ea42e7a3b295c210ca9ee86e7290043' into gingerbread-plus-aosp

* commit 'b78c76f88ea42e7a3b295c210ca9ee86e7290043':
  GC Card marking fix for SPUT_OBJECT - use correct object head

13 years agoGC Card marking fix for SPUT_OBJECT - use correct object head
buzbee [Fri, 1 Oct 2010 02:08:20 +0000 (19:08 -0700)]
GC Card marking fix for SPUT_OBJECT - use correct object head

Change-Id: I8b84a4f1e1690f5b62de7404ea6ede00317848bb

13 years agoam 33ff9f32: am d8b5f50d: Correct dexopt for uniprocessors.
Andy McFadden [Fri, 1 Oct 2010 01:11:46 +0000 (18:11 -0700)]
am 33ff9f32: am d8b5f50d: Correct dexopt for uniprocessors.

Merge commit '33ff9f32d460a232729a123617ca81b3f67195c6'

* commit '33ff9f32d460a232729a123617ca81b3f67195c6':
  Correct dexopt for uniprocessors.

13 years agoam 2428d518: am f45b6cbe: Be explicit about both uniprocessor and SMP when calling...
Dan Bornstein [Fri, 1 Oct 2010 01:11:15 +0000 (18:11 -0700)]
am 2428d518: am f45b6cbe: Be explicit about both uniprocessor and SMP when calling dexopt.

Merge commit '2428d518efb9b5a62d74f44a267f3a6c18982549'

* commit '2428d518efb9b5a62d74f44a267f3a6c18982549':
  Be explicit about both uniprocessor and SMP when calling dexopt.

13 years agoChange Runtime.nativeLoad to return the dlerror(3) string.
Elliott Hughes [Thu, 30 Sep 2010 22:51:31 +0000 (15:51 -0700)]
Change Runtime.nativeLoad to return the dlerror(3) string.

This has a companion change in libcore:
  https://android-git.corp.google.com/g/71342

Bug: 3044042
Change-Id: I070a80a41ec2f306f5092a641807017f70179451

13 years agoam d8b5f50d: Correct dexopt for uniprocessors.
Andy McFadden [Thu, 30 Sep 2010 22:40:43 +0000 (15:40 -0700)]
am d8b5f50d: Correct dexopt for uniprocessors.

Merge commit 'd8b5f50d0c6c9a0ce157e89df4ee1e8eb8b334c3' into gingerbread-plus-aosp

* commit 'd8b5f50d0c6c9a0ce157e89df4ee1e8eb8b334c3':
  Correct dexopt for uniprocessors.

13 years agoCorrect dexopt for uniprocessors.
Andy McFadden [Thu, 30 Sep 2010 21:02:54 +0000 (14:02 -0700)]
Correct dexopt for uniprocessors.

The SMP flag was defaulting to "true" for dexopt, even on uniprocessors.
With this change the VM now has three choices: dexopt for SMP, dexopt
for uniprocessor, or dexopt for current system.  The last is used for
just-in-time dexopt (used by -eng and -userdebug builds on bootstrap DEX
files) and installd dexopt (used for apps on all builds).

The dexopt used by the build system during -user builds will either be
explicitly SMP or explicitly uniprocessor, since "current system" has
no meaning when you're cross-dexopting.

Also, unified the dexopt control flags into a single enum.

(cherry-pick from dalvik-dev)

Change-Id: Id1d9c548ca8567585a28ef9ee911cc2ac6b116dd

13 years agoam f45b6cbe: Be explicit about both uniprocessor and SMP when calling dexopt.
Dan Bornstein [Thu, 30 Sep 2010 22:11:27 +0000 (15:11 -0700)]
am f45b6cbe: Be explicit about both uniprocessor and SMP when calling dexopt.

Merge commit 'f45b6cbed6ce7cb6a38746b5abe0213263106a71' into gingerbread-plus-aosp

* commit 'f45b6cbed6ce7cb6a38746b5abe0213263106a71':
  Be explicit about both uniprocessor and SMP when calling dexopt.

13 years agoBe explicit about both uniprocessor and SMP when calling dexopt.
Dan Bornstein [Thu, 30 Sep 2010 22:04:34 +0000 (15:04 -0700)]
Be explicit about both uniprocessor and SMP when calling dexopt.

Change-Id: Ic1b68dddf6822773041de6023c594a062e141325

13 years agoam f37569d1: am 1e053438: Merge "After trimming, set the footprint to the number...
Carl Shapiro [Thu, 30 Sep 2010 18:26:04 +0000 (11:26 -0700)]
am f37569d1: am 1e053438: Merge "After trimming, set the footprint to the number of pages in use." into gingerbread

Merge commit 'f37569d1cf3ed24fa37488ceb9bac2a52f45260c'

* commit 'f37569d1cf3ed24fa37488ceb9bac2a52f45260c':
  After trimming, set the footprint to the number of pages in use.

13 years agoam 0cb51973: am d4cdb357: Merge "Update the card table scanning for header-only card...
Carl Shapiro [Thu, 30 Sep 2010 18:24:50 +0000 (11:24 -0700)]
am 0cb51973: am d4cdb357: Merge "Update the card table scanning for header-only card marks." into gingerbread

Merge commit '0cb519734afc574b2ca60d72ced1e9fc46a8f4c9'

* commit '0cb519734afc574b2ca60d72ced1e9fc46a8f4c9':
  Update the card table scanning for header-only card marks.

13 years agoam c315cbf1: am 87f66617: Add --uniprocessor option to dex-preopt.
Dan Bornstein [Thu, 30 Sep 2010 03:35:10 +0000 (20:35 -0700)]
am c315cbf1: am 87f66617: Add --uniprocessor option to dex-preopt.

Merge commit 'c315cbf15411e9b4b1f7a9732f16117eaea7afcb'

* commit 'c315cbf15411e9b4b1f7a9732f16117eaea7afcb':
  Add --uniprocessor option to dex-preopt.

13 years agoam 1e053438: Merge "After trimming, set the footprint to the number of pages in use...
Carl Shapiro [Wed, 29 Sep 2010 21:30:25 +0000 (14:30 -0700)]
am 1e053438: Merge "After trimming, set the footprint to the number of pages in use." into gingerbread

Merge commit '1e053438810dbd8406ec8339b94801195261e849' into gingerbread-plus-aosp

* commit '1e053438810dbd8406ec8339b94801195261e849':
  After trimming, set the footprint to the number of pages in use.

13 years agoMerge "After trimming, set the footprint to the number of pages in use." into gingerbread
Carl Shapiro [Wed, 29 Sep 2010 21:27:50 +0000 (14:27 -0700)]
Merge "After trimming, set the footprint to the number of pages in use." into gingerbread

13 years agoam d4cdb357: Merge "Update the card table scanning for header-only card marks." into...
Carl Shapiro [Wed, 29 Sep 2010 19:40:05 +0000 (12:40 -0700)]
am d4cdb357: Merge "Update the card table scanning for header-only card marks." into gingerbread

Merge commit 'd4cdb3572b489e770d20a6afba0f86563f380825' into gingerbread-plus-aosp

* commit 'd4cdb3572b489e770d20a6afba0f86563f380825':
  Update the card table scanning for header-only card marks.

13 years agoMerge "Update the card table scanning for header-only card marks." into gingerbread
Carl Shapiro [Wed, 29 Sep 2010 19:38:19 +0000 (12:38 -0700)]
Merge "Update the card table scanning for header-only card marks." into gingerbread

13 years agoam 87f66617: Add --uniprocessor option to dex-preopt.
Dan Bornstein [Wed, 29 Sep 2010 17:04:22 +0000 (10:04 -0700)]
am 87f66617: Add --uniprocessor option to dex-preopt.

Merge commit '87f666172f55863d6a50762a1a07a31b67eb48f6' into gingerbread-plus-aosp

* commit '87f666172f55863d6a50762a1a07a31b67eb48f6':
  Add --uniprocessor option to dex-preopt.

13 years agoUpdate the card table scanning for header-only card marks.
Carl Shapiro [Wed, 29 Sep 2010 08:09:11 +0000 (01:09 -0700)]
Update the card table scanning for header-only card marks.

Previously, the card table accessors assumed that objects had either
their header marked or would be marked exactly.  As such, after
reckoning a marked card the scan would back up until it found an
object header and then move forward blackening each object within the
address range of the marked card.

Following a recent change we exclusively mark headers.  The scan only
has to move forward until the end of a card.  This saves scanning time
as dlmalloc's binning may leave large segments of the heap unused.  It
is not uncommon for hundreds of cards to be spanned when backing up to
the first live object below a marked card.

In addition, this change fixes the card table verifier to search the
mark stack for gray objects.  It is permissible for roots to point to
white objects on unmarked cards.  This was incorrectly treated as an
error.

Change-Id: Ia6b6ee2012e381d644b8b3f38b39d746749ea47a

13 years agoAfter trimming, set the footprint to the number of pages in use.
Carl Shapiro [Wed, 29 Sep 2010 03:30:42 +0000 (20:30 -0700)]
After trimming, set the footprint to the number of pages in use.

A trim can decrease the an mspace footprint but it will not decrease
its max footprint.  We need to decrease the max footprint to make any
pages recovered by a trim available to external allocations.

By setting the ideal footprint after a trim we lift any soft limit in
effect and make the mspace footprint and max footprints equal.

Change-Id: Ia6eb99634ce1d732b417a90291b110d1fc46c2e3

13 years agoAdd --uniprocessor option to dex-preopt.
Dan Bornstein [Wed, 29 Sep 2010 01:53:28 +0000 (18:53 -0700)]
Add --uniprocessor option to dex-preopt.

This tells the preoptimizer to target a uniprocessor (unsurprisingly).
By default, it targets SMP, which makes it do more changes than it has
to for a uniprocessor (e.g. editing how non-wide volatile fields are
accessed within bytecode). To be clear, when SMP-optimized code is run
on a uniprocessor, it should still work. We're just aiming to only
make truly necessary changes during optimization.

While I was in the territory, I went ahead and cleaned up some single
vs. double quote hygiene in the file.

Change-Id: Ia45992939a436d0be6db8363c43d430de4acb80b

13 years agoam b3a94965: am 148283d7: Plumb SMP optimization control through to dexopt.
Dan Bornstein [Wed, 29 Sep 2010 01:40:01 +0000 (18:40 -0700)]
am b3a94965: am 148283d7: Plumb SMP optimization control through to dexopt.

Merge commit 'b3a949656a773953a44b148a6cdcba19f1c48e87'

* commit 'b3a949656a773953a44b148a6cdcba19f1c48e87':
  Plumb SMP optimization control through to dexopt.

13 years agoam 148283d7: Plumb SMP optimization control through to dexopt.
Dan Bornstein [Wed, 29 Sep 2010 01:37:39 +0000 (18:37 -0700)]
am 148283d7: Plumb SMP optimization control through to dexopt.

Merge commit '148283d71a7e35b9b506cbb49294b6822719c25e' into gingerbread-plus-aosp

* commit '148283d71a7e35b9b506cbb49294b6822719c25e':
  Plumb SMP optimization control through to dexopt.

13 years agoam 63114829: am de9cdfa9: Fix verification of switch offsets in large methods.
Andy McFadden [Wed, 29 Sep 2010 00:38:21 +0000 (17:38 -0700)]
am 63114829: am de9cdfa9: Fix verification of switch offsets in large methods.

Merge commit '63114829802ecdade4c95fe08a02acec67bd17bd'

* commit '63114829802ecdade4c95fe08a02acec67bd17bd':
  Fix verification of switch offsets in large methods.

13 years agoPlumb SMP optimization control through to dexopt.
Dan Bornstein [Tue, 28 Sep 2010 22:46:54 +0000 (15:46 -0700)]
Plumb SMP optimization control through to dexopt.

Change-Id: I3bfaf6723e7b14d001f9de60cc1c1fd4f8e1ed99

13 years agoresolved conflicts for merge of 2e75e47d to master
buzbee [Tue, 28 Sep 2010 22:22:48 +0000 (15:22 -0700)]
resolved conflicts for merge of 2e75e47d to master

Change-Id: I644b3cd50e3c63b209741c8b818b4c1435ee8218

13 years agoam de9cdfa9: Fix verification of switch offsets in large methods.
Andy McFadden [Tue, 28 Sep 2010 22:15:04 +0000 (15:15 -0700)]
am de9cdfa9: Fix verification of switch offsets in large methods.

Merge commit 'de9cdfa9d6d5fa5c46a0ec0f3f1e8de08a688841' into gingerbread-plus-aosp

* commit 'de9cdfa9d6d5fa5c46a0ec0f3f1e8de08a688841':
  Fix verification of switch offsets in large methods.

13 years agoFixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackO...
Johnnie Birch [Tue, 28 Sep 2010 21:58:37 +0000 (14:58 -0700)]
Fixed bug in OP_GOTO_32.S, added support for additional parameters to dvmHandleStackOverflow

Change-Id: I4d8d75418395661ffc8e7055eeb4600bb5b8b0bc

13 years agoFix verification of switch offsets in large methods.
Andy McFadden [Tue, 28 Sep 2010 21:43:28 +0000 (14:43 -0700)]
Fix verification of switch offsets in large methods.

The verifier was only using the low 16 bits when checking the offset
to a switch table.  This was failing on really large methods.

We also blew up the arbitrary size cap again, so I made it a warning
rather than a failure (it really wasn't doing anybody any good).

Changed to width-specific types for the various offsets and sizes.

Bug 3044850.

(cherry-pick+squash from dalvik-dev)

Change-Id: Ic7ebb86728cb39151f617a3e69e1c1994e61b5d9

13 years agoam 252dfcbb: am b755f9a3: Do not grow if we are invoked for an external allocation.
Carl Shapiro [Tue, 28 Sep 2010 21:00:06 +0000 (14:00 -0700)]
am 252dfcbb: am b755f9a3: Do not grow if we are invoked for an external allocation.

Merge commit '252dfcbbc8ab27ba7f86908fbf8c13425d166a70'

* commit '252dfcbbc8ab27ba7f86908fbf8c13425d166a70':
  Do not grow if we are invoked for an external allocation.

13 years agoam b36ea791: Merge "Change GC card making to use object head, bug fix for volatile...
buzbee [Tue, 28 Sep 2010 19:28:21 +0000 (12:28 -0700)]
am b36ea791: Merge "Change GC card making to use object head, bug fix for volatile sput obj" into gingerbread

Merge commit 'b36ea7918612c81cb42ff2021443358a9f109a6d' into gingerbread-plus-aosp

* commit 'b36ea7918612c81cb42ff2021443358a9f109a6d':
  Change GC card making to use object head, bug fix for volatile sput obj

13 years agoMerge "Change GC card making to use object head, bug fix for volatile sput obj" into...
buzbee [Tue, 28 Sep 2010 19:26:06 +0000 (12:26 -0700)]
Merge "Change GC card making to use object head, bug fix for volatile sput obj" into gingerbread

13 years agoam b755f9a3: Do not grow if we are invoked for an external allocation.
Carl Shapiro [Tue, 28 Sep 2010 18:35:26 +0000 (11:35 -0700)]
am b755f9a3: Do not grow if we are invoked for an external allocation.

Merge commit 'b755f9a3caeaf65e95480ac66c2c95553bf79389' into gingerbread-plus-aosp

* commit 'b755f9a3caeaf65e95480ac66c2c95553bf79389':
  Do not grow if we are invoked for an external allocation.

13 years agoam ee0a6abe: am e8edf08f: Perform only one garbage collection before attempting a...
Carl Shapiro [Tue, 28 Sep 2010 17:56:55 +0000 (10:56 -0700)]
am ee0a6abe: am e8edf08f: Perform only one garbage collection before attempting a trim.

Merge commit 'ee0a6abec5a36d52cf9ddc09278cf3af7fe17ea1'

* commit 'ee0a6abec5a36d52cf9ddc09278cf3af7fe17ea1':
  Perform only one garbage collection before attempting a trim.

13 years agoChange GC card making to use object head, bug fix for volatile sput obj
buzbee [Mon, 27 Sep 2010 18:30:22 +0000 (11:30 -0700)]
Change GC card making to use object head, bug fix for volatile sput obj

This CL changes the way we mark GC card to consistently use the object
head (previously, we marked somewhere in the object - often the head, but
not always).  Also, previously a coding error caused us to skip the card
mark for OP_APUT_OBJECT_VOLATILES.  Fixed here.

Change-Id: I133ef6395c51a0466c9708209b08e79c3083aff2

13 years agoam ab7d3a27: am 812c1bed: Provide the required out parameter to the trim routine.
Carl Shapiro [Tue, 28 Sep 2010 04:02:35 +0000 (21:02 -0700)]
am ab7d3a27: am 812c1bed: Provide the required out parameter to the trim routine.

Merge commit 'ab7d3a27de4d9b1302640df5e1a42bd180259711'

* commit 'ab7d3a27de4d9b1302640df5e1a42bd180259711':
  Provide the required out parameter to the trim routine.

13 years agoDo not grow if we are invoked for an external allocation.
Carl Shapiro [Tue, 28 Sep 2010 00:25:49 +0000 (17:25 -0700)]
Do not grow if we are invoked for an external allocation.

The garbage collection can elect to grow the size of an mspace if the
heap utilization is sufficiently large.  This can remove pages from use
by the external allocation mechanism.

Change-Id: Ie2e9e3da9251068707a60a5835b50e485031578b

13 years agoam e8edf08f: Perform only one garbage collection before attempting a trim.
Carl Shapiro [Tue, 28 Sep 2010 02:47:16 +0000 (19:47 -0700)]
am e8edf08f: Perform only one garbage collection before attempting a trim.

Merge commit 'e8edf08f04ecbe37f3e18a650a7c9002ceee4275' into gingerbread-plus-aosp

* commit 'e8edf08f04ecbe37f3e18a650a7c9002ceee4275':
  Perform only one garbage collection before attempting a trim.

13 years agoPerform only one garbage collection before attempting a trim.
Carl Shapiro [Mon, 27 Sep 2010 23:55:21 +0000 (16:55 -0700)]
Perform only one garbage collection before attempting a trim.

Change-Id: Id7ea77fd8e6055a76a5f52bb96dd0544f88ce06b

13 years agoam 812c1bed: Provide the required out parameter to the trim routine.
Carl Shapiro [Mon, 27 Sep 2010 21:29:18 +0000 (14:29 -0700)]
am 812c1bed: Provide the required out parameter to the trim routine.

Merge commit '812c1bed55e0ed9b092d320cb29d8adc17e5a10b' into gingerbread-plus-aosp

* commit '812c1bed55e0ed9b092d320cb29d8adc17e5a10b':
  Provide the required out parameter to the trim routine.

13 years agoProvide the required out parameter to the trim routine.
Carl Shapiro [Mon, 27 Sep 2010 21:10:10 +0000 (14:10 -0700)]
Provide the required out parameter to the trim routine.

Resolves http://b/issue?id=3040192.

Change-Id: I886a2dc99956b06e953f03ac390865b118b634a3

13 years agoam 41ad1bc3: am 85dc40d2: Take another tilt at the "--core-library" messaging windmill.
Dan Bornstein [Sun, 26 Sep 2010 23:04:51 +0000 (16:04 -0700)]
am 41ad1bc3: am 85dc40d2: Take another tilt at the "--core-library" messaging windmill.

Merge commit '41ad1bc3aa0ca63d8d66a36f45b6f7b2261b40a7'

* commit '41ad1bc3aa0ca63d8d66a36f45b6f7b2261b40a7':
  Take another tilt at the "--core-library" messaging windmill.

13 years agoam 85dc40d2: Take another tilt at the "--core-library" messaging windmill.
Dan Bornstein [Sun, 26 Sep 2010 23:02:23 +0000 (16:02 -0700)]
am 85dc40d2: Take another tilt at the "--core-library" messaging windmill.

Merge commit '85dc40d2a0cb19792bf3ee6f6c57fed08eb91ea4' into gingerbread-plus-aosp

* commit '85dc40d2a0cb19792bf3ee6f6c57fed08eb91ea4':
  Take another tilt at the "--core-library" messaging windmill.

13 years agoTake another tilt at the "--core-library" messaging windmill.
Dan Bornstein [Sun, 26 Sep 2010 22:03:28 +0000 (15:03 -0700)]
Take another tilt at the "--core-library" messaging windmill.

This time, I added a note about what appears to be the most common
inadvertent triggering, and I point people at JarJar as a possible
solution when the core class inclusion was intentional.

Change-Id: I2d576df0b8944882838cbb6e2b050d59434a238b

13 years agoam 50672515: am 60cc993e: Support -Xbootclasspath/a and /p for dvmProcessOptions...
Norris, Lee [Sun, 26 Sep 2010 16:13:21 +0000 (09:13 -0700)]
am 50672515: am 60cc993e: Support -Xbootclasspath/a and /p for dvmProcessOptions in dalvik/vm/Init.c

Merge commit '506725152f92738218823ed52e437458a043c7cb'

* commit '506725152f92738218823ed52e437458a043c7cb':
  Support -Xbootclasspath/a and /p for dvmProcessOptions in dalvik/vm/Init.c

13 years agoam 60cc993e: Support -Xbootclasspath/a and /p for dvmProcessOptions in dalvik/vm...
Norris, Lee [Sun, 26 Sep 2010 16:09:47 +0000 (09:09 -0700)]
am 60cc993e: Support -Xbootclasspath/a and /p for dvmProcessOptions in dalvik/vm/Init.c

Merge commit '60cc993e5afb3327482b172cc7e54c469b231741' into gingerbread-plus-aosp

* commit '60cc993e5afb3327482b172cc7e54c469b231741':
  Support -Xbootclasspath/a and /p for dvmProcessOptions in dalvik/vm/Init.c

13 years agoam 4f85bfce: am 35b0f486: Merge "Wait for the GC to quiesce before attempting foregro...
Carl Shapiro [Sat, 25 Sep 2010 00:52:39 +0000 (17:52 -0700)]
am 4f85bfce: am 35b0f486: Merge "Wait for the GC to quiesce before attempting foreground GCs." into gingerbread

Merge commit '4f85bfcebb2617b8776a07ed0c030aba40d2314a'

* commit '4f85bfcebb2617b8776a07ed0c030aba40d2314a':
  Wait for the GC to quiesce before attempting foreground GCs.

13 years agoam 35b0f486: Merge "Wait for the GC to quiesce before attempting foreground GCs....
Carl Shapiro [Sat, 25 Sep 2010 00:49:51 +0000 (17:49 -0700)]
am 35b0f486: Merge "Wait for the GC to quiesce before attempting foreground GCs." into gingerbread

Merge commit '35b0f486feb23a5c199c02ab45bfa613503e2b8f' into gingerbread-plus-aosp

* commit '35b0f486feb23a5c199c02ab45bfa613503e2b8f':
  Wait for the GC to quiesce before attempting foreground GCs.

13 years agoMerge "Wait for the GC to quiesce before attempting foreground GCs." into gingerbread
Carl Shapiro [Sat, 25 Sep 2010 00:47:37 +0000 (17:47 -0700)]
Merge "Wait for the GC to quiesce before attempting foreground GCs." into gingerbread

13 years agoWait for the GC to quiesce before attempting foreground GCs.
Carl Shapiro [Sat, 25 Sep 2010 00:36:53 +0000 (17:36 -0700)]
Wait for the GC to quiesce before attempting foreground GCs.

Previously, dvmTrackExternalAllocation waited for the GC to complete
before retrying its allocation.  However, there is no guarantee that
the GC will not be active at the time we are woken.  Furthermore, the
code did not revalidate that the external allocation is still
possible, an assumption made by all externalAlloc calls.

With this change, the code loops until the GC is no longer active,
validates that the allocation is still possible, and then proceeds
with its routine for allocating additional storage.  In addition, if
we try a few heroic measures to establish the externalAllocPossible
invariant rather than immediately failing the call.

Change-Id: I2e3b8a6c9fab617990edc085f52d0df35ad6d0f6

13 years agoam a342c5a9: am ddd9d0b3: Show errors from getSchedulerGroup().
Andy McFadden [Fri, 24 Sep 2010 23:03:02 +0000 (16:03 -0700)]
am a342c5a9: am ddd9d0b3: Show errors from getSchedulerGroup().

Merge commit 'a342c5a9a3c475cfe0ebe579af4250b71d952cbf'

* commit 'a342c5a9a3c475cfe0ebe579af4250b71d952cbf':
  Show errors from getSchedulerGroup().

13 years agoam ddd9d0b3: Show errors from getSchedulerGroup().
Andy McFadden [Fri, 24 Sep 2010 22:54:54 +0000 (15:54 -0700)]
am ddd9d0b3: Show errors from getSchedulerGroup().

Merge commit 'ddd9d0b3527072f83db00105e28fa88c47bd763b' into gingerbread-plus-aosp

* commit 'ddd9d0b3527072f83db00105e28fa88c47bd763b':
  Show errors from getSchedulerGroup().

13 years agoShow errors from getSchedulerGroup().
Andy McFadden [Fri, 24 Sep 2010 21:18:03 +0000 (14:18 -0700)]
Show errors from getSchedulerGroup().

If we failed to get the cgroup info, we were showing "unknown" in the
stack trace, and sometimes showing an error message in the log file.
Now we put a very brief error description into the cgroup text field,
so it shows up in the stack trace itself.

Also, replaced three strsep() calls with two strchr() calls.

Also, check return value from pthread_kill() calls.

Bug 3032532.

Change-Id: I3730cfb8a5c59048d35d746d8bffb4fa61bd5a6c

13 years agoMerge remote branch 'goog/dalvik-dev' into dalvik-dev-to-master
Brian Carlstrom [Fri, 24 Sep 2010 21:14:21 +0000 (14:14 -0700)]
Merge remote branch 'goog/dalvik-dev' into dalvik-dev-to-master

13 years agoam 9b55721f: am 85a3c66f: am b14f405c: Turn off verbose chatter about libs in /vendor
Dima Zavin [Fri, 24 Sep 2010 06:45:57 +0000 (23:45 -0700)]
am 9b55721f: am 85a3c66f: am b14f405c: Turn off verbose chatter about libs in /vendor

Merge commit '9b55721ff026fe0d8aa2b9d2c71255151b15ca52' into dalvik-dev

* commit '9b55721ff026fe0d8aa2b9d2c71255151b15ca52':
  Turn off verbose chatter about libs in /vendor

13 years agoam 85a3c66f: am b14f405c: Turn off verbose chatter about libs in /vendor
Dima Zavin [Fri, 24 Sep 2010 06:42:02 +0000 (23:42 -0700)]
am 85a3c66f: am b14f405c: Turn off verbose chatter about libs in /vendor

Merge commit '85a3c66f556ef3a4f6cf64bf1d7c1bafe60795d6'

* commit '85a3c66f556ef3a4f6cf64bf1d7c1bafe60795d6':
  Turn off verbose chatter about libs in /vendor

13 years agoam b14f405c: Turn off verbose chatter about libs in /vendor
Dima Zavin [Fri, 24 Sep 2010 06:34:41 +0000 (23:34 -0700)]
am b14f405c: Turn off verbose chatter about libs in /vendor

Merge commit 'b14f405c4492f770c14c9252e81ff4df4401c0ef' into gingerbread-plus-aosp

* commit 'b14f405c4492f770c14c9252e81ff4df4401c0ef':
  Turn off verbose chatter about libs in /vendor

13 years agoam 72a1940f: am 6634a3c3: am 629e6923: Print the JIT codegen type in the VM configura...
Ben Cheng [Fri, 24 Sep 2010 06:01:09 +0000 (23:01 -0700)]
am 72a1940f: am 6634a3c3: am 629e6923: Print the JIT codegen type in the VM configuration list.

Merge commit '72a1940f5169b2af6d25a8bb0059edaaa951a96a' into dalvik-dev

* commit '72a1940f5169b2af6d25a8bb0059edaaa951a96a':
  Print the JIT codegen type in the VM configuration list.

13 years agoam 6634a3c3: am 629e6923: Print the JIT codegen type in the VM configuration list.
Ben Cheng [Fri, 24 Sep 2010 05:50:18 +0000 (22:50 -0700)]
am 6634a3c3: am 629e6923: Print the JIT codegen type in the VM configuration list.

Merge commit '6634a3c373ae46893234f0d92264e1d7d97f083d'

* commit '6634a3c373ae46893234f0d92264e1d7d97f083d':
  Print the JIT codegen type in the VM configuration list.

13 years agoTurn off verbose chatter about libs in /vendor
Dima Zavin [Fri, 24 Sep 2010 05:38:45 +0000 (22:38 -0700)]
Turn off verbose chatter about libs in /vendor

Change-Id: I243d538d342b5e0424321b09b2b17555ef6343dd
Signed-off-by: Dima Zavin <dima@android.com>
13 years agoam 629e6923: Print the JIT codegen type in the VM configuration list.
Ben Cheng [Fri, 24 Sep 2010 03:16:50 +0000 (20:16 -0700)]
am 629e6923: Print the JIT codegen type in the VM configuration list.

Merge commit '629e692379a8b12641a4402ff1c9f67af879f68e' into gingerbread-plus-aosp

* commit '629e692379a8b12641a4402ff1c9f67af879f68e':
  Print the JIT codegen type in the VM configuration list.

13 years agoPrint the JIT codegen type in the VM configuration list.
Ben Cheng [Thu, 23 Sep 2010 08:23:14 +0000 (01:23 -0700)]
Print the JIT codegen type in the VM configuration list.

Example:
Configured with: debugger profiler hprof jit(armv7-a-neon) show_exception=1

So that the CPU capability on JIT-enabled devices can be exposed.

(cherry-picked from dalvik-dev)

Change-Id: I887201e7023ca94cd9c3d690f03b7b042175e6ed

13 years agoMerge "Print the JIT codegen type in the VM configuration list." into dalvik-dev
Ben Cheng [Fri, 24 Sep 2010 02:06:02 +0000 (19:06 -0700)]
Merge "Print the JIT codegen type in the VM configuration list." into dalvik-dev

13 years agoam 4cd5f4e3: Merge "Add user-friendly constructors to StdField"
Brett Chabot [Thu, 23 Sep 2010 23:56:56 +0000 (16:56 -0700)]
am 4cd5f4e3: Merge "Add user-friendly constructors to StdField"

Merge commit '4cd5f4e3732f5fc5f4f13aeefc1a479f2bf77618' into dalvik-dev

* commit '4cd5f4e3732f5fc5f4f13aeefc1a479f2bf77618':
  Add user-friendly constructors to StdField

13 years agoMerge "Add user-friendly constructors to StdField"
Brett Chabot [Thu, 23 Sep 2010 23:51:18 +0000 (16:51 -0700)]
Merge "Add user-friendly constructors to StdField"

13 years agoAdd user-friendly constructors to StdField
Piotr Gurgul [Thu, 23 Sep 2010 18:30:14 +0000 (11:30 -0700)]
Add user-friendly constructors to StdField

This is to simplify programmatic use of StdField to create dex fields
dynamically without knowledge of the dex internal format.

Change-Id: Ib11980509e0336d1e0253b6d480240d6832b73dd

13 years agoFix the dalvik-dev build
buzbee [Thu, 23 Sep 2010 18:04:05 +0000 (11:04 -0700)]
Fix the dalvik-dev build

Looks like some code got duplicated.

Change-Id: Ia304dbf41172fa940db848324acc4f6ed7917fee

13 years agoam 7232f715: am ce3de859: am 4934b377: Several fixes for JIT and self-verification...
Ben Cheng [Thu, 23 Sep 2010 16:57:11 +0000 (09:57 -0700)]
am 7232f715: am ce3de859: am 4934b377: Several fixes for JIT and self-verification under corner cases.

Merge commit '7232f7150c2757c6784171cd0c96f90d0e438bca' into dalvik-dev

* commit '7232f7150c2757c6784171cd0c96f90d0e438bca':
  Several fixes for JIT and self-verification under corner cases.

13 years agoPrint the JIT codegen type in the VM configuration list.
Ben Cheng [Thu, 23 Sep 2010 08:23:14 +0000 (01:23 -0700)]
Print the JIT codegen type in the VM configuration list.

Example:
Configured with: debugger profiler hprof jit(armv7-a-neon) show_exception=1

So that the CPU capability on JIT-enabled devices can be exposed.

Change-Id: Id35c0f68e0b9885279917ddef00b74f5c92a6786

13 years agoam ce3de859: am 4934b377: Several fixes for JIT and self-verification under corner...
Ben Cheng [Thu, 23 Sep 2010 07:10:45 +0000 (00:10 -0700)]
am ce3de859: am 4934b377: Several fixes for JIT and self-verification under corner cases.

Merge commit 'ce3de859ef352e91d6cfd368014e4ccfe95595d9'

* commit 'ce3de859ef352e91d6cfd368014e4ccfe95595d9':
  Several fixes for JIT and self-verification under corner cases.

13 years agoam 4934b377: Several fixes for JIT and self-verification under corner cases.
Ben Cheng [Thu, 23 Sep 2010 06:21:00 +0000 (23:21 -0700)]
am 4934b377: Several fixes for JIT and self-verification under corner cases.

Merge commit '4934b377d9cf5df6f80da7caab4f2178c6cec307' into gingerbread-plus-aosp

* commit '4934b377d9cf5df6f80da7caab4f2178c6cec307':
  Several fixes for JIT and self-verification under corner cases.

13 years agoSeveral fixes for JIT and self-verification under corner cases.
Ben Cheng [Tue, 21 Sep 2010 05:20:31 +0000 (22:20 -0700)]
Several fixes for JIT and self-verification under corner cases.

1) Fix the self-verification mode to handle backward chaining cell
properly when a single-step instruction is in the middle of the cyclic
portion of the trace. Then found issue 2 when changing the JIT
threshold to 1.
2) When the code cache is full, the VM may stop making forward progress
and bounces back and forth between the debug and fast intepreters as the
translation request is constantly rejected. The fix is to stay in the
debug interpreter until the corner case condition is cleared. Then found
issue 3.
3) Under self-verification mode, the code cache reset request may get
delayed indefinitely due to spurious indication that a thread is
running JIT'ed code. Trivial fix - make sure the inJitCodeCache flag is
cleared.

(cherry-picked from dalvik-dev)

Change-Id: Ic0b9952c0ae545f68f7eb2ae06a82a634ab62e9e

13 years agoMerge "Fix x86 mterp "longjmp"" into dalvik-dev
buzbee [Wed, 22 Sep 2010 21:57:50 +0000 (14:57 -0700)]
Merge "Fix x86 mterp "longjmp"" into dalvik-dev

13 years agoam 419215fa: am 8f6d07fa: am 95a884f7: Fix computation of primitive array widths.
Andy McFadden [Wed, 22 Sep 2010 21:55:17 +0000 (14:55 -0700)]
am 419215fa: am 8f6d07fa: am 95a884f7: Fix computation of primitive array widths.

Merge commit '419215faf3ba03185960095cab1a5eec9aab05e9' into dalvik-dev

* commit '419215faf3ba03185960095cab1a5eec9aab05e9':
  Fix computation of primitive array widths.

13 years agoam 8f6d07fa: am 95a884f7: Fix computation of primitive array widths.
Andy McFadden [Wed, 22 Sep 2010 21:41:56 +0000 (14:41 -0700)]
am 8f6d07fa: am 95a884f7: Fix computation of primitive array widths.

Merge commit '8f6d07fa2d6ec4828e824cb89052341171a4b978'

* commit '8f6d07fa2d6ec4828e824cb89052341171a4b978':
  Fix computation of primitive array widths.

13 years agoam 95a884f7: Fix computation of primitive array widths.
Andy McFadden [Wed, 22 Sep 2010 21:29:30 +0000 (14:29 -0700)]
am 95a884f7: Fix computation of primitive array widths.

Merge commit '95a884f7844a6e7bdd820489742254f3fd002f6d' into gingerbread-plus-aosp

* commit '95a884f7844a6e7bdd820489742254f3fd002f6d':
  Fix computation of primitive array widths.

13 years agoMerge "Fail early rather than crippling the GC if -Xms == -Xmx." into dalvik-dev
Elliott Hughes [Wed, 22 Sep 2010 21:27:22 +0000 (14:27 -0700)]
Merge "Fail early rather than crippling the GC if -Xms == -Xmx." into dalvik-dev

13 years agoFail early rather than crippling the GC if -Xms == -Xmx.
Elliott Hughes [Wed, 22 Sep 2010 21:09:07 +0000 (14:09 -0700)]
Fail early rather than crippling the GC if -Xms == -Xmx.

We should revert this when the bug is fixed.

Bug: 2714377
Change-Id: Ie3600ef60fea5e4e5988680042c7e2e595bdc622

13 years agoFix computation of primitive array widths.
Andy McFadden [Wed, 22 Sep 2010 19:13:29 +0000 (12:13 -0700)]
Fix computation of primitive array widths.

The code was comparing class pointers, but the class objects for arrays
of primitives are initialized on demand.  If the class wasn't yet
instantiated, the array width code was returning a default value of 4.
This meant the "write values to an array of longs through the unsafe
methods" code was actually scribbling on the wrong part of the array,
which went unnoticed until recently.  (The new-ish ldrexd/strexd code
requires 64-bit alignment.)

We now use the existing array element width computation function.  The
code needed a bit of rearranging since it expected an instance of the
class rather than the class.

Bug 3023981.

(cherry-pick from dalvik-dev)

Change-Id: Ife3258eb6798f8e7eaee7c7b6793a16137de389b

13 years agoMerge "Fix computation of primitive array widths." into dalvik-dev
Andy McFadden [Wed, 22 Sep 2010 21:21:43 +0000 (14:21 -0700)]
Merge "Fix computation of primitive array widths." into dalvik-dev

13 years agoFix x86 mterp "longjmp"
buzbee [Wed, 22 Sep 2010 21:05:11 +0000 (14:05 -0700)]
Fix x86 mterp "longjmp"

The recent x86 mterp update failed to properly restore callee save
registers when returning from the call to dvmMterpStdRun.

Change-Id: Ied73cc5fb380a6375d1f71ce679003fbc293d08d

13 years agoFix getExceptionMessage().
Andy McFadden [Wed, 22 Sep 2010 19:37:49 +0000 (12:37 -0700)]
Fix getExceptionMessage().

dvmAddTrackedAlloc() doesn't like NULL objects.

Bug 3023981.

Change-Id: I181e4dab841b063d9e2f450292732d808e70aaba