OSDN Git Service
Elliott Hughes [Wed, 27 Apr 2011 19:23:43 +0000 (12:23 -0700)]
Remove the old forcecopy in favor of the new.
Also remove some more half-baked multi-VM cruft, fix command-line
parsing (so -Xforcecopy-fuck-yeah won't work any more), and remove
an unused #define.
Bug:
3412449
Change-Id: If914e23dd3bbcf0ac113a445777e0f550ca05703
Elliott Hughes [Wed, 27 Apr 2011 18:39:58 +0000 (11:39 -0700)]
Merge "Add -Xjniopts:forcecopy-unmap to catch more errors than forcecopy." into dalvik-dev
Elliott Hughes [Wed, 27 Apr 2011 01:32:17 +0000 (18:32 -0700)]
Add -Xjniopts:forcecopy-unmap to catch more errors than forcecopy.
In particular, this spots the BreakIterator bug that forcecopy didn't.
It's about 2x slower than regular forcecopy mode, so I've added a new
option rather than just replace the fast-but-less-effective forcecopy.
Bug:
3412449
Change-Id: I1f226ceeab2508dff607ba25b0afee51cf9c3f83
Ben Cheng [Tue, 26 Apr 2011 17:42:39 +0000 (10:42 -0700)]
am
de9e2b90: Bug fixes for ld/st elimination.
* commit '
de9e2b90c156664a1bdc2b5c9911e4dfa527c148':
Bug fixes for ld/st elimination.
Ben Cheng [Tue, 26 Apr 2011 17:00:22 +0000 (10:00 -0700)]
Bug fixes for ld/st elimination.
1) Only optimize each block once. Strictly speaking this is not a
correctness issue however it triggers the subsequent problem.
2) Ignore dead instructions.
1: ldr r2, [r5, #8]
2: ldr r3, [r5, #8](nop)
3: str r3, [r5, #4]
4: movs r3, r2
When using instruction 1 to initiate redundant ld/st eliminations, if
instruction 2 (which is already dead) is not ignored, it will be turned
into a "mov r3, r2" and that will clobber r3 used by the str.
Change-Id: I8eecd13eeb30e4a67ecf1f8fbad925b1e6e91fc8
jeffhao [Tue, 26 Apr 2011 07:42:10 +0000 (00:42 -0700)]
am
98bfc3b7: Bug fix for SCCP improperly handling phis with some constant sources.
* commit '
98bfc3b7162417dc1816a75dc566de3572a7e5da':
Bug fix for SCCP improperly handling phis with some constant sources.
jeffhao [Mon, 25 Apr 2011 22:15:08 +0000 (15:15 -0700)]
Bug fix for SCCP improperly handling phis with some constant sources.
Change-Id: Ib6e2ab17b50c90d7d83658c69dfba1d065a42155
jeffhao [Mon, 25 Apr 2011 22:15:08 +0000 (15:15 -0700)]
Bug fix for SCCP improperly handling phis with some constant sources.
Change-Id: Ifa9424f822aac1e88267e02696b7ff0c18227dd0
buzbee [Mon, 25 Apr 2011 18:23:46 +0000 (11:23 -0700)]
Refine & simplify the interBreak mechanism
Replace dvmUpdateInterpBreak() and friends with more direct
enable/disable subMode calls. Hide breakFlags manipulation from
higher-level callers and infer what is needed from the active
subMode.
Add documentation to the interpreter control section of
mterp/README.txt
Change-Id: If7ebee5d8e4db8154c4caed72cf89ec088045998
Elliott Hughes [Mon, 25 Apr 2011 17:37:13 +0000 (10:37 -0700)]
Merge "Move JNIHelp's implementation to C++." into dalvik-dev
Elliott Hughes [Sat, 23 Apr 2011 02:22:54 +0000 (19:22 -0700)]
Move JNIHelp's implementation to C++.
Ouch.
Change-Id: I81c0457a95549f1bef7cc8d9ab23d6ca4475cdb5
Ben Cheng [Sat, 23 Apr 2011 00:16:42 +0000 (17:16 -0700)]
Local optimization fixes for diverences found by self verification.
1) Only optimize each block once. Strictly speaking this is not a
correctness issue however it triggers the subsequent problem.
2) Ignore dead instructions.
1: ldr r2, [r5, #8]
2: ldr r3, [r5, #8](nop)
3: str r3, [r5, #4]
4: movs r3, r2
When using instruction 1 to initiate redundant ld/st eliminations, if
instruction 2 (which is already dead) is not ignored, it will be turned
into a "mov r3, r2" and that will clobber r3 used by the str.
Change-Id: I6b9a88d3688889d917b90f4b8f55278df1701c6a
Elliott Hughes [Sat, 23 Apr 2011 00:42:05 +0000 (17:42 -0700)]
Fix a buffer overrun in jniLogException.
...by not having a fixed-length buffer at all. What are we, C programmmers?
Bug:
4330470
Change-Id: I1b514ffc08abb1a5b1681e7d655800b3a5539093
buzbee [Fri, 22 Apr 2011 22:12:40 +0000 (15:12 -0700)]
InterpBreak cleanup (part 1)
Moved the suspend count variables from the interpBreak structure. These
are already protected by a mutex, and we need the space in interpBreak
for additional subMode flags. This CL just does the move and expands
the width of subMode to 16-bits.
Change-Id: I4a6070b1ba4fb08a0f6e0aba6f150b30f9159eed
buzbee [Fri, 22 Apr 2011 17:27:14 +0000 (10:27 -0700)]
Consolidate curFrame fields in thread storage
We ended up with two locations in the Thread structure for saved
Dalvik frame pointer. This change consolidates them.
Change-Id: I78f288e4e57e232f29663be930101e775bfe370f
Ben Cheng [Fri, 22 Apr 2011 17:24:18 +0000 (10:24 -0700)]
am
381333db: Fix self-verification with backward branches or invokes.
* commit '
381333db555c2fcc12d63116b87ae39d2c0ed910':
Fix self-verification with backward branches or invokes.
Ben Cheng [Fri, 22 Apr 2011 17:22:20 +0000 (10:22 -0700)]
am
9f54185b: Set "needFallThroughBranch" flag during block split.
* commit '
9f54185b4186def90351903bb2e97090e06ab559':
Set "needFallThroughBranch" flag during block split.
Ben Cheng [Thu, 14 Apr 2011 00:08:29 +0000 (17:08 -0700)]
Fix self-verification with backward branches or invokes.
Bug:
4282508
Change-Id: Iae9d33fd3dc97e88a465fa3128f5108c877470e9
Ben Cheng [Fri, 22 Apr 2011 06:09:39 +0000 (23:09 -0700)]
Set "needFallThroughBranch" flag during block split.
Bonus changes:
* Add a undefined Thumb instruction between the last code block and the
beginning of PC reconstruction cell to capture such codegen problem on
the spot.
* Fix a loop formation problem to exclude nested loops.
Bug:
4320840
Change-Id: I49d3fbba0073d8c2d4a0b241258239cb952c6bdd
Jesse Wilson [Fri, 22 Apr 2011 00:53:48 +0000 (17:53 -0700)]
Merge "Combine CstUtf8 and CstString." into dalvik-dev
Jesse Wilson [Wed, 13 Apr 2011 16:27:11 +0000 (09:27 -0700)]
Combine CstUtf8 and CstString.
The only benefit we were seeing is that one wrapped its toHuman
in quotes, the other didn't.
It was far too easy to use the wrong one. We had code defending
against that in NameValuePair and CstArray.
Change-Id: Ib2e6a1596b97decced37952d46e1831b7bcd0d5d
Elliott Hughes [Thu, 21 Apr 2011 23:39:38 +0000 (16:39 -0700)]
Merge "Fix -Xjniopts:forcecopy, which I broke." into dalvik-dev
Elliott Hughes [Thu, 21 Apr 2011 23:37:16 +0000 (16:37 -0700)]
Fix -Xjniopts:forcecopy, which I broke.
"create"/"destroy" is the natural pair, and prevents us accidentally
recursing when we actually meant to call ::free instead.
Change-Id: Ice65034f3a48b6d6f96c3b0adb0c0ffbd2f41463
buzbee [Thu, 21 Apr 2011 20:45:56 +0000 (13:45 -0700)]
am
90232632: Kill stale assert, fix for
4310384
* commit '
902326326616642ae5ad0dd3c493a9e3abcd55da':
Kill stale assert, fix for
4310384
buzbee [Thu, 21 Apr 2011 18:19:27 +0000 (11:19 -0700)]
Kill stale assert, fix for
4310384
There was an old assert in dvmPopFrame that did a sanity check on
the JNI local reference table it was popping. In the asserting case,
we had internal native method calls and no JNI - and thus no sane
local reference table. Further, the localRefTable code has changed enough
that this particular sanity check is no longer useful. Assert deleted,
along with another related (and previously-commented out) assert.
Change-Id: I3a806838fa2b5909c3e3b3ad27aeed29e3e467ab
Carl Shapiro [Thu, 21 Apr 2011 01:07:44 +0000 (18:07 -0700)]
Remove DVM_LOCK_INIT and DVM_LOCK_INITIAL_THIN_VALUE.
The original implementation for thin locks used a magic non-zero value
to encode the initial thin lock state. This magic value was kept
around in DVM_LOCK_INITIAL_THIN_VALUE and stored into the lock word of
newly allocated objects. A later revision to the thin locking code
made the initial thin lock value be 0. That change eliminated the
requirement that lock words be explicitly initialized as the allocator
always returns zero-filled memory.
Change-Id: I34e0b43b4c4db0f45cf7cf524e15d4a6096c1365
Carl Shapiro [Thu, 21 Apr 2011 00:30:50 +0000 (17:30 -0700)]
Merge "Remove unneeded void argument list declarations." into dalvik-dev
Carl Shapiro [Wed, 20 Apr 2011 23:51:38 +0000 (16:51 -0700)]
Remove unneeded void argument list declarations.
Change-Id: Ica749f6defa890363ec531b29e25bc415dc2cbb9
Carl Shapiro [Wed, 20 Apr 2011 23:12:46 +0000 (16:12 -0700)]
Move the interpreter into C++.
Change-Id: I4b7d6ed9c54dbf3244304a7ea0f13e6c37cca2aa
Carl Shapiro [Wed, 20 Apr 2011 20:23:36 +0000 (13:23 -0700)]
Merge "Move the compiler into C++." into dalvik-dev
Carl Shapiro [Wed, 20 Apr 2011 15:47:15 +0000 (08:47 -0700)]
am
4dd60e2c: am
6892cab9: am
e4195e1c: Fix a type error in the allocation of non-moving arrays.
* commit '
4dd60e2c7f9551a3d027fefd2cac5eb3dce9f844':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Wed, 20 Apr 2011 15:24:59 +0000 (08:24 -0700)]
am
6892cab9: am
e4195e1c: Fix a type error in the allocation of non-moving arrays.
* commit '
6892cab90362639344373ce6d71c8fdd9903ae22':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Wed, 20 Apr 2011 14:46:59 +0000 (07:46 -0700)]
am
e4195e1c: Fix a type error in the allocation of non-moving arrays.
* commit '
e4195e1c91f4ea3c6192070fd3c9b9e4e6d429ae':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Mon, 18 Apr 2011 22:08:21 +0000 (15:08 -0700)]
Fix a type error in the allocation of non-moving arrays.
Originally, non-moving arrays were allocated with dvmAllocObjectArray.
However, dvmAllocObjectArray does not respect the width of the user
supplied element class and substitutes a hard coded value of 4 bytes.
This change replaces dvmAllocObjectArray with dvmAllocArrayByClass.
dvmAllocArrayByClass consults the element class for its width when
computing the storage size for the array being allocated.
Bug:
4309030
Carl Shapiro [Wed, 20 Apr 2011 01:20:31 +0000 (18:20 -0700)]
Revert "am
024b7b9d: am
a0739ea3: am
af242824: Revert "Fix a type error in the allocation of non-moving arrays." per Ryan\'s request"
This reverts commit
d336a946ee81fd26cffcca63bccc18a4a7536303, reversing
changes made to
f4b9e2752312c0c513f6ec416e900e5392e9a96c.
Change-Id: I72a877f57b64618345bebfbe22e57bbe334c7726
Carl Shapiro [Wed, 20 Apr 2011 00:34:24 +0000 (17:34 -0700)]
Move the compiler into C++.
Change-Id: Idffbdb02c29e2be03a75f5a0a664603f2299504a
Jesse Wilson [Tue, 19 Apr 2011 23:59:02 +0000 (16:59 -0700)]
Merge "Change Type, Method and Field to be IDs rather than values." into dalvik-dev
Carl Shapiro [Tue, 19 Apr 2011 21:48:03 +0000 (14:48 -0700)]
Merge "Replace public uses of dvmAllocArray with dvmAllocArrayByClass." into dalvik-dev
Sriram Raman [Tue, 19 Apr 2011 21:42:32 +0000 (14:42 -0700)]
am
d336a946: am
024b7b9d: am
a0739ea3: am
af242824: Revert "Fix a type error in the allocation of non-moving arrays." per Ryan\'s request
* commit '
d336a946ee81fd26cffcca63bccc18a4a7536303':
Revert "Fix a type error in the allocation of non-moving arrays." per Ryan's request
Sriram Raman [Tue, 19 Apr 2011 21:36:54 +0000 (14:36 -0700)]
am
024b7b9d: am
a0739ea3: am
af242824: Revert "Fix a type error in the allocation of non-moving arrays." per Ryan\'s request
* commit '
024b7b9d9bed86522bfdec95973008e0e3c2f19b':
Revert "Fix a type error in the allocation of non-moving arrays." per Ryan's request
Sriram Raman [Tue, 19 Apr 2011 21:34:29 +0000 (14:34 -0700)]
am
a0739ea3: am
af242824: Revert "Fix a type error in the allocation of non-moving arrays." per Ryan\'s request
* commit '
a0739ea3040b578a53de817688ab5e9f17c0ce72':
Revert "Fix a type error in the allocation of non-moving arrays." per Ryan's request
Sriram Raman [Tue, 19 Apr 2011 21:29:47 +0000 (14:29 -0700)]
am
af242824: Revert "Fix a type error in the allocation of non-moving arrays." per Ryan\'s request
* commit '
af242824dcedbbe39c92b49d148e7ff50267e47f':
Revert "Fix a type error in the allocation of non-moving arrays." per Ryan's request
Sriram Raman [Tue, 19 Apr 2011 21:17:27 +0000 (17:17 -0400)]
Revert "Fix a type error in the allocation of non-moving arrays." per Ryan's request
This reverts commit
bdd06aadab6214d2378b7d5078f92bfb14e7e3dc.
Change-Id: Ifbb4bd7941fe4f2e9d02ca2b7d77186edae4dd55
Carl Shapiro [Tue, 19 Apr 2011 21:11:51 +0000 (14:11 -0700)]
Replace public uses of dvmAllocArray with dvmAllocArrayByClass.
Change-Id: Ica5d457566ebf1196af5c0ef260ddeb95f569b81
Jesse Wilson [Tue, 19 Apr 2011 20:43:18 +0000 (13:43 -0700)]
Change Type, Method and Field to be IDs rather than values.
This makes it possible to declare constants for types like
void and int.
http://code.google.com/p/android/issues/detail?id=6322
Change-Id: Ic0b6e7d9b89aba40457c3015b75ab24c413a6f33
Carl Shapiro [Tue, 19 Apr 2011 19:35:25 +0000 (12:35 -0700)]
am
f4b9e275: am
8bfb6dec: am
bb8c2f35: am
bdd06aad: Fix a type error in the allocation of non-moving arrays.
* commit '
f4b9e2752312c0c513f6ec416e900e5392e9a96c':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Tue, 19 Apr 2011 19:11:33 +0000 (12:11 -0700)]
am
8bfb6dec: am
bb8c2f35: am
bdd06aad: Fix a type error in the allocation of non-moving arrays.
* commit '
8bfb6dec87783ee5d80a043d6a30abbf200a553b':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Tue, 19 Apr 2011 19:07:46 +0000 (12:07 -0700)]
am
bb8c2f35: am
bdd06aad: Fix a type error in the allocation of non-moving arrays.
* commit '
bb8c2f35e2155b6eec92e692666df8c67810ded6':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Tue, 19 Apr 2011 18:43:46 +0000 (11:43 -0700)]
am
bdd06aad: Fix a type error in the allocation of non-moving arrays.
* commit '
bdd06aadab6214d2378b7d5078f92bfb14e7e3dc':
Fix a type error in the allocation of non-moving arrays.
Carl Shapiro [Tue, 19 Apr 2011 18:34:34 +0000 (11:34 -0700)]
Merge "Remove dvmAllocObjectArray and all of its uses." into dalvik-dev
Dan Bornstein [Tue, 19 Apr 2011 17:32:23 +0000 (10:32 -0700)]
Tweaks for C++ compilation.
Change-Id: I6ac0ffe4941c6d655025a0738413b60b636400a9
Carl Shapiro [Tue, 19 Apr 2011 01:34:17 +0000 (18:34 -0700)]
Remove dvmAllocObjectArray and all of its uses.
This replaces uses of dvmAllocObjectArray with equivalent but safer
calls to dvmAllocArrayByClass. dvmAllocObjectArray performed no type
checking of its arguments and was easy to use incorrectly.
Change-Id: Ia82fe73cb9d73bbb27f5961242ad5961f9f9924c
Carl Shapiro [Tue, 19 Apr 2011 01:03:26 +0000 (18:03 -0700)]
Merge "Improve the impossible allocation log message." into dalvik-dev
Jesse Wilson [Tue, 19 Apr 2011 00:27:58 +0000 (17:27 -0700)]
Merge "Adjust basis against which enum performance is compared." into dalvik-dev
Carl Shapiro [Tue, 19 Apr 2011 00:24:30 +0000 (17:24 -0700)]
Improve the impossible allocation log message.
Change-Id: Icf4c9b22c0f11159efb7cb43ab1158cc4f10c82f
Carl Shapiro [Mon, 18 Apr 2011 22:08:21 +0000 (15:08 -0700)]
Fix a type error in the allocation of non-moving arrays.
Originally, non-moving arrays were allocated with dvmAllocObjectArray.
However, dvmAllocObjectArray does not respect the width of the user
supplied element class and substitutes a hard coded value of 4 bytes.
This change replaces dvmAllocObjectArray with dvmAllocArrayByClass.
dvmAllocArrayByClass consults the element class for its width when
computing the storage size for the array being allocated.
Bug:
4309030
Change-Id: I9cfe1b62ea61f03e46f44ad2be0d1cce1bef7cdd
Jesse Wilson [Mon, 18 Apr 2011 23:04:26 +0000 (16:04 -0700)]
Adjust basis against which enum performance is compared.
The new basis assumes how much work Enum.valueOf() needs
to do and checks that it does just that and little else.
It makes no attempt to compute a general speed of the VM
or to compare ratios of unrelated operations.
Change-Id: I0014fb37cfcf36016e72e97ca182e3836044782e
Carl Shapiro [Mon, 18 Apr 2011 22:08:21 +0000 (15:08 -0700)]
Fix a type error in the allocation of non-moving arrays.
Originally, non-moving arrays were allocated with dvmAllocObjectArray.
However, dvmAllocObjectArray does not respect the width of the user
supplied element class and substitutes a hard coded value of 4 bytes.
This change replaces dvmAllocObjectArray with dvmAllocArrayByClass.
dvmAllocArrayByClass consults the element class for its width when
computing the storage size for the array being allocated.
Bug:
4309030
Change-Id: I4f3802b38261f5ad7052d577049732f59a667ea6
buzbee [Mon, 18 Apr 2011 19:51:07 +0000 (12:51 -0700)]
Merge "[JIT] Clear inJitCodeCache flag on return" into dalvik-dev
Carl Shapiro [Mon, 18 Apr 2011 19:46:33 +0000 (12:46 -0700)]
Merge "Move the remaining non-compiler VM code into C++." into dalvik-dev
buzbee [Mon, 18 Apr 2011 19:40:16 +0000 (12:40 -0700)]
[JIT] Clear inJitCodeCache flag on return
This CL plugs a hole in which control could return to the interpreter
from JIT'd code without resetting the inJitCodeCache flag.
Change-Id: Id0241bf3490f5bef9b274483af694c81f33334cf
Jesse Wilson [Sat, 16 Apr 2011 16:45:04 +0000 (09:45 -0700)]
Support catch blocks.
Add support for throw calls. This is awkwardly named throwValue
because 'throw' is a keyword. Better names very welcome.
Add support for unused parameters.
Add support for float, double and long comparisons.
Add support for array operations.
Change-Id: I48380fca06c13175cd13b4e3613a4ba63902ed33
http://code.google.com/p/android/issues/detail?id=6322
Jesse Wilson [Sat, 16 Apr 2011 14:28:11 +0000 (07:28 -0700)]
Merge "Return Code instances from Method.declare." into dalvik-dev
Jesse Wilson [Fri, 15 Apr 2011 21:28:02 +0000 (14:28 -0700)]
Return Code instances from Method.declare.
Add type cast, and instanceof.
Add a unit test for recursive method calls.
Add return type checking.
Improve documentation on BinaryOp.
Change-Id: Ib85ed81be90756793067913efe86e1e442483f76
http://code.google.com/p/android/issues/detail?id=6322
Carl Shapiro [Sat, 16 Apr 2011 01:38:06 +0000 (18:38 -0700)]
Move the remaining non-compiler VM code into C++.
Change-Id: Id8693208d2741c55a7b0474d1264f2112019d11f
Elliott Hughes [Sat, 16 Apr 2011 01:41:26 +0000 (18:41 -0700)]
Fix build by reverting NELEM change.
Change-Id: Ie68f42213e7a915fb1be45ae87790117f8356c4e
Elliott Hughes [Sat, 16 Apr 2011 01:00:11 +0000 (18:00 -0700)]
In C++, we can offer a better NELEM.
Change-Id: Iaedc727becb4af1c779299d4da7c91bd522fe9cc
Carl Shapiro [Sat, 16 Apr 2011 00:31:38 +0000 (17:31 -0700)]
Merge "Move the verifier and parts of the interpreter into C++." into dalvik-dev
Elliott Hughes [Sat, 16 Apr 2011 00:23:39 +0000 (17:23 -0700)]
Merge "Start actually using C++ in the JNI implementation." into dalvik-dev
Carl Shapiro [Fri, 15 Apr 2011 22:48:54 +0000 (15:48 -0700)]
Move the verifier and parts of the interpreter into C++.
Change-Id: I8ce5fb558871d9709b251512dd01206be5ca8497
Elliott Hughes [Fri, 15 Apr 2011 22:27:38 +0000 (15:27 -0700)]
Start actually using C++ in the JNI implementation.
Change-Id: I9ed07e71d00de4caf314845c4e11201112bd65be
Jesse Wilson [Fri, 15 Apr 2011 17:34:33 +0000 (10:34 -0700)]
Don't require a dalvikvm to build.
Change-Id: I362820131580dfd1c6fc1eb45d0264723730f865
http://code.google.com/p/android/issues/detail?id=6322
Jesse Wilson [Fri, 15 Apr 2011 17:27:24 +0000 (10:27 -0700)]
Merge "Bare-bones dex code generator." into dalvik-dev
Jesse Wilson [Thu, 14 Apr 2011 21:02:45 +0000 (14:02 -0700)]
Bare-bones dex code generator.
This is functional but incomplete. In particular, the following
are still coming:
- instructions for cast/instanceof/arrays/float comparison/try/catch
- debug information
- annotations
The API is also incomplete. When this is done I'm going to remove
the type parameters to see if that's a net win. I suspect it will
be because generics currently hurt the ability to do assignments
between unknown types - you can't currently assign from Label<?> to
Label<?>, for example.
I'm anticipating changes to the way Code instances are created.
In the current API these are created without an attached method and
later attached to a method with Method.declare(). This doesn't work
very well, particularly since the code blocks don't know how many
parameters they take, whether they're static, or what their return
type is. I'm tempted to make declare() return a writable Code instance,
or to simply combine the Code and Method classes.
This code can benefit from more error detection. It's currently quite
easy to do bad things with labels: use them on the wrong Code instance,
reuse them, don't use them, etc. Better error checking is due here.
Change-Id: I4fe20552f2c571e41bedba6ff9db6686688d97ee
http://code.google.com/p/android/issues/detail?id=6322
Elliott Hughes [Fri, 15 Apr 2011 01:12:15 +0000 (18:12 -0700)]
More JNI implementation cleanup.
Change-Id: I5218c42df18eb5b8647fce073abd8434b40adb80
Elliott Hughes [Fri, 15 Apr 2011 00:36:08 +0000 (17:36 -0700)]
Merge "Switch the JNI code over to C++." into dalvik-dev
Elliott Hughes [Thu, 14 Apr 2011 23:59:31 +0000 (16:59 -0700)]
Switch the JNI code over to C++.
Change-Id: I82dbaf8931bda5a466fd5ad6b08f7f9b36d7ce37
Dan Bornstein [Thu, 14 Apr 2011 22:46:37 +0000 (15:46 -0700)]
Merge "Cleanup." into dalvik-dev
Elliott Hughes [Thu, 14 Apr 2011 22:01:53 +0000 (15:01 -0700)]
Fix out-of-date comments.
Mainly by deletion.
Change-Id: Ieb156192f1991937b26db9eb6cac45c4647430d6
Dan Bornstein [Thu, 14 Apr 2011 21:25:56 +0000 (14:25 -0700)]
Cleanup.
I have it on enthusiastic authority that the foreach would never have
any value, so away it goes. I got rid of the pointless re-init of
Class too.
Change-Id: I794d5f1286d7c240f7d17b24e1e9e8e93b87316a
Carl Shapiro [Thu, 14 Apr 2011 21:21:47 +0000 (14:21 -0700)]
Move JDWP into C++ and add extern "C" to remaining non-compiler includes.
Change-Id: I19cba56e8f75b76f902c87ff5c5b3e2c17cb5c00
Dan Bornstein [Thu, 14 Apr 2011 21:01:32 +0000 (14:01 -0700)]
Merge "Compile libdex as C++." into dalvik-dev
Nick Kralevich [Thu, 14 Apr 2011 20:41:40 +0000 (13:41 -0700)]
am
780d3e25: make dvmOpenCachedDexFile resistant to umask changes.
* commit '
780d3e25adde11603bb6bab1b42a1e8e985aec15':
make dvmOpenCachedDexFile resistant to umask changes.
Dan Bornstein [Thu, 14 Apr 2011 20:08:06 +0000 (13:08 -0700)]
Compile libdex as C++.
The major-looking code changes were all just to unravel some gotos.
Change-Id: I86f98a48b160f357ce93c87446bad5d705d5f05b
Nick Kralevich [Thu, 14 Apr 2011 18:37:24 +0000 (11:37 -0700)]
make dvmOpenCachedDexFile resistant to umask changes.
Change-Id: I61734941bd94a013a82c1dd0ebeac43fefa680e1
Elliott Hughes [Thu, 14 Apr 2011 20:17:50 +0000 (13:17 -0700)]
am
80aedd4d: The jni-tips documentation has moved to frameworks/base.
* commit '
80aedd4dfc1252cb214fdff5baeb55166e3bf021':
The jni-tips documentation has moved to frameworks/base.
Elliott Hughes [Thu, 14 Apr 2011 18:52:03 +0000 (11:52 -0700)]
The jni-tips documentation has moved to frameworks/base.
Change-Id: I77fbc3ed593c51f61de9590beaadaa52f08387f8
Carl Shapiro [Thu, 14 Apr 2011 18:30:39 +0000 (11:30 -0700)]
Merge "Move fundamental object definitions and operations to C++" into dalvik-dev
Ben Cheng [Thu, 14 Apr 2011 03:30:42 +0000 (20:30 -0700)]
Merge "Fix self-verification with backward branches or invokes." into dalvik-dev
Carl Shapiro [Thu, 14 Apr 2011 03:14:49 +0000 (20:14 -0700)]
Move fundamental object definitions and operations to C++
Change-Id: Ibc3766edfbf7fdbde2d762d6e88a0bb02df2be31
Ben Cheng [Thu, 14 Apr 2011 00:08:29 +0000 (17:08 -0700)]
Fix self-verification with backward branches or invokes.
Bug:
4282508
Change-Id: Ifde257af9d510ba15382ff5980793e7ad2678436
Dan Bornstein [Tue, 12 Apr 2011 00:08:20 +0000 (17:08 -0700)]
Add a class flag CLASS_ISCLASS.
This flag is only turned on for the unique class Class, and it is
meant to make it possible to quickly test objects for "classiness" as
well as trivially figure out if one is looking at the class Class
itself.
Bonus: Made a few places that directly set class->accessFlags use
the prescribed macro for doing same.
Change-Id: I89fce708c407b597f28ce610b778123f5dcaecf6
Carl Shapiro [Wed, 13 Apr 2011 22:40:58 +0000 (15:40 -0700)]
Merge "Move the reflection code into C++." into dalvik-dev
buzbee [Wed, 13 Apr 2011 22:39:45 +0000 (15:39 -0700)]
am
e7147462: Fix debugger performance regression
* commit '
e71474621b968a9bc649d067155d31213f5764a9':
Fix debugger performance regression
Carl Shapiro [Wed, 13 Apr 2011 22:15:55 +0000 (15:15 -0700)]
Move the reflection code into C++.
Smart pointers would make dvmGenerateProxyClass cleaner. This code should
be revisited once those interfaces come into existence.
Change-Id: If25abb87e22d658ad88f997324c35703b23f623c
buzbee [Wed, 13 Apr 2011 21:10:04 +0000 (14:10 -0700)]
Fix debugger performance regression
http://b/issue?id=
4282910
The interpreter was reporting every instruction as a method entry point,
causing significant performance degradation in the debugger.
Change-Id: If6fb092d6ade7fc3d74be3c7f806bf2d6923a063
Carl Shapiro [Wed, 13 Apr 2011 02:14:06 +0000 (19:14 -0700)]
Convert the internal and in-line natives to C++.
Change-Id: I2ece682bc3b4d3b55ab27c60fd84a0b3243d7ca6
Carl Shapiro [Mon, 11 Apr 2011 22:29:57 +0000 (15:29 -0700)]
Merge "Add additional asserts and combine declarations with definitions." into dalvik-dev
Carl Shapiro [Mon, 11 Apr 2011 22:09:05 +0000 (15:09 -0700)]
Add additional asserts and combine declarations with definitions.
Change-Id: Ibdc37f3d7eb6385da1059d5525727b090626ec4c
buzbee [Mon, 11 Apr 2011 21:24:19 +0000 (14:24 -0700)]
am
0161e158: Merge "Add missing JUMBO opcodes to volatile rewriting"
* commit '
0161e1582b13173cc5a125cf504fd7714c9c82b2':
Add missing JUMBO opcodes to volatile rewriting