OSDN Git Service
Ben Cheng [Mon, 24 Jan 2011 18:14:29 +0000 (10:14 -0800)]
Fix push/pop instruction selection and encoding.
1) Thumb 'push' can handle lr and 'pop' can handle pc, so make use of them.
2) Thumb2 push was incorrectly encoded as stmia, which should be stmdb
instead.
None of the above affect the code that we currently ship.
Change-Id: I89ab46b032a3d562355c2cc3bc05fe308ba40957
jeffhao [Fri, 21 Jan 2011 21:37:57 +0000 (13:37 -0800)]
Made handling of sim exceptions nicer.
Change-Id: I089512c046d90ea37da4a33433edc4ec308a628d
Andy McFadden [Thu, 20 Jan 2011 19:12:31 +0000 (11:12 -0800)]
am
4482a157: am
d50993ff: am
6ff6ec6b: Fix dalvik test 084.
* commit '
4482a1573b3ec0d3d312a8a6c1af52952d5d02d8':
Fix dalvik test 084.
Andy McFadden [Thu, 20 Jan 2011 19:00:23 +0000 (11:00 -0800)]
am
d50993ff: am
6ff6ec6b: Fix dalvik test 084.
* commit '
d50993ff6ec834801d1442b0872de33f6d930c4d':
Fix dalvik test 084.
Andy McFadden [Thu, 20 Jan 2011 18:58:21 +0000 (10:58 -0800)]
am
6ff6ec6b: Fix dalvik test 084.
* commit '
6ff6ec6b6361db707e4b0318075fc38dd319a49a':
Fix dalvik test 084.
Andy McFadden [Thu, 20 Jan 2011 18:41:57 +0000 (10:41 -0800)]
Fix dalvik test 084.
Two threads were waiting for initialization of a class to complete.
There was nothing encouraging one thread to resume execution first,
but on single-core devices it always worked out the same way.
Bug
3366697
Change-Id: I29430d398dfbd9509d7db2b7db2800d340b29d19
Elliott Hughes [Thu, 20 Jan 2011 18:12:50 +0000 (10:12 -0800)]
Merge "Light refactoring of handleExecuteInline." into dalvik-dev
Elliott Hughes [Thu, 20 Jan 2011 02:18:42 +0000 (18:18 -0800)]
Light refactoring of handleExecuteInline.
I wanted the code to JIT a call a C function extracted so I can potentially
use it elsewhere. The functions that sometimes JIT instructions directly and
other times bail out to C can now call this, simplifying the body of the
switch. I think there's a behavioral change here with the ThumbVFP
genInlineSqrt, which previously had the wrong return value.
Tested on passion to ensure that the performance characteristics of assembler
intrinsics, C intrinsics, and library native methods haven't changed (using
the Math and Float classes).
Change-Id: Id79771a31abe3a516f403486454e9c0d9793622a
buzbee [Thu, 20 Jan 2011 17:22:08 +0000 (09:22 -0800)]
Merge "Support traceview-style profiling in all builds" into dalvik-dev
Carl Shapiro [Thu, 20 Jan 2011 06:42:38 +0000 (22:42 -0800)]
am
c99b53ca: am
94918db6: am
84547e16: Merge "Remove logging of memory management statistics to the event log." into honeycomb
* commit '
c99b53ca275132337a941e47c693548ae48286d6':
Remove logging of memory management statistics to the event log.
Carl Shapiro [Thu, 20 Jan 2011 06:28:45 +0000 (22:28 -0800)]
resolved conflicts for merge of
5b1a7218 to dalvik-dev
Change-Id: I034801caaa259ad000021e9135121790b0ec9629
Carl Shapiro [Thu, 20 Jan 2011 01:26:44 +0000 (17:26 -0800)]
am
94918db6: am
84547e16: Merge "Remove logging of memory management statistics to the event log." into honeycomb
* commit '
94918db6ac491d361f7d2fea63e88c67c16e8103':
Remove logging of memory management statistics to the event log.
Carl Shapiro [Thu, 20 Jan 2011 01:24:14 +0000 (17:24 -0800)]
am
84547e16: Merge "Remove logging of memory management statistics to the event log." into honeycomb
* commit '
84547e16cfef6e2f1ebe377a466e858a61b59e45':
Remove logging of memory management statistics to the event log.
Carl Shapiro [Thu, 20 Jan 2011 01:22:50 +0000 (17:22 -0800)]
Merge "Remove logging of memory management statistics to the event log." into honeycomb
buzbee [Wed, 19 Jan 2011 23:31:15 +0000 (15:31 -0800)]
Support traceview-style profiling in all builds
This change builds on an earlier bccheng change that allowed JIT'd code
to avoid reverting to the debug portable interpeter when doing traceview-style
method profiling. That CL introduced a new traceview build (libdvm_traceview)
because the performance delta was too great to enable the capability for
all builds.
In this CL, we remove the libdvm_traceview build and provide full-speed
method tracing in all builds. This is done by introducing "_PROF"
versions of invoke and return templates used by the JIT. Normally, these
templates are not used, and performace in unaffected. However, when method
profiling is enabled, all existing translation are purged and new translations
are created using the _PROF templates. These templates introduce a
smallish performance penalty above and beyond the actual tracing cost, but
again are only used when tracing has been enabled.
Strictly speaking, there is a slight burden that is placed on invokes and
returns in the non-tracing case - on the order of an additional 3 or 4
cycles per invoke/return. Those operations are already heavyweight enough
that I was unable to measure the added cost in benchmarks.
Change-Id: Ic09baf4249f1e716e136a65458f4e06cea35fc18
Carl Shapiro [Wed, 19 Jan 2011 23:37:31 +0000 (15:37 -0800)]
Remove logging of memory management statistics to the event log.
While the event log used to report better information than the logcat
log messages, this is no longer the case.
Change-Id: Iaf7bef5252c284c1a159bc8c0447247c5b5f47e4
Carl Shapiro [Wed, 19 Jan 2011 23:45:06 +0000 (15:45 -0800)]
am
98ce90f3: am
e39e28a8: Merge "Include -XX:DisableExplicitGC in the usage output." into honeycomb
* commit '
98ce90f3d007d77b8f7b65c987cc14dddb8cbfd6':
Include -XX:DisableExplicitGC in the usage output.
Carl Shapiro [Wed, 19 Jan 2011 23:42:58 +0000 (15:42 -0800)]
am
e39e28a8: Merge "Include -XX:DisableExplicitGC in the usage output." into honeycomb
* commit '
e39e28a8451222714120406d998a6d776e62bc68':
Include -XX:DisableExplicitGC in the usage output.
Carl Shapiro [Wed, 19 Jan 2011 23:41:34 +0000 (15:41 -0800)]
Merge "Include -XX:DisableExplicitGC in the usage output." into honeycomb
Carl Shapiro [Wed, 19 Jan 2011 23:39:41 +0000 (15:39 -0800)]
Include -XX:DisableExplicitGC in the usage output.
Change-Id: I290d7b5762b616b02f59a653ac5a83388c299a93
Andy McFadden [Wed, 19 Jan 2011 23:36:55 +0000 (15:36 -0800)]
am
f9c12c6d: am
9cef8218: am
836741f0: Merge "Change suspend order in GC" into honeycomb
* commit '
f9c12c6d0c0dba11ca5e4dd419344a7b7915c782':
Change suspend order in GC
Andy McFadden [Wed, 19 Jan 2011 23:34:09 +0000 (15:34 -0800)]
am
9cef8218: am
836741f0: Merge "Change suspend order in GC" into honeycomb
* commit '
9cef82185def11b5d712961dabc66adf56913963':
Change suspend order in GC
Andy McFadden [Wed, 19 Jan 2011 23:32:01 +0000 (15:32 -0800)]
am
836741f0: Merge "Change suspend order in GC" into honeycomb
* commit '
836741f0984579c415f63b39efae6ce5aa695bcd':
Change suspend order in GC
Andy McFadden [Wed, 19 Jan 2011 23:30:18 +0000 (15:30 -0800)]
Merge "Change suspend order in GC" into honeycomb
Andy McFadden [Wed, 19 Jan 2011 22:48:52 +0000 (14:48 -0800)]
Change suspend order in GC
The GC currently does this:
1. acquire heapLock
2. suspend all threads
3. acquire heapWorkerLock
When the HeapWorker thread is suspended in #2, it might be holding
the lock we want in step #3, leading to VM deadlock. This change
reverses the order of #2 and #3, which should allow the HeapWorker
thread to progress to a point where it releases the lock before
the GC requests the suspension.
If futexes are being unfair, the GC might have to wait a bit
longer while the HeapWorker does stuff (it might unlock, do work,
and re-lock without the scheduler giving time to the GC thread;
with the old scheme the HeapWorker would see the pending thread
suspension immediately and stop). A better fix is planned.
Bug
3340837
Change-Id: Ib9b37c130903a2800f8f28ae61540a428dbfc5be
Carl Shapiro [Wed, 19 Jan 2011 22:37:34 +0000 (14:37 -0800)]
am
044f1e87: am
0bd1ebdb: am
461d57dc: Merge "Add an option to disable explicit GC requests." into honeycomb
* commit '
044f1e87e45cea4d1e5cddf92e2e59e8c18b3359':
Add an option to disable explicit GC requests.
Carl Shapiro [Wed, 19 Jan 2011 22:33:32 +0000 (14:33 -0800)]
am
0bd1ebdb: am
461d57dc: Merge "Add an option to disable explicit GC requests." into honeycomb
* commit '
0bd1ebdbeb876acfca801e337fe58ffe184edc1a':
Add an option to disable explicit GC requests.
Carl Shapiro [Wed, 19 Jan 2011 22:32:00 +0000 (14:32 -0800)]
am
461d57dc: Merge "Add an option to disable explicit GC requests." into honeycomb
* commit '
461d57dc62af82c9095a0ce3feb8fc0a4f88ddc9':
Add an option to disable explicit GC requests.
Carl Shapiro [Wed, 19 Jan 2011 22:29:43 +0000 (14:29 -0800)]
Merge "Add an option to disable explicit GC requests." into honeycomb
Carl Shapiro [Wed, 19 Jan 2011 20:56:14 +0000 (12:56 -0800)]
Add an option to disable explicit GC requests.
Change-Id: Ibb2ca9d99fccfba61492a8059201777f59c81274
Andy McFadden [Wed, 19 Jan 2011 19:39:26 +0000 (11:39 -0800)]
am
9a20dcf4: am
4b2dc337: am
6009938d: Increase LinearAlloc limit
* commit '
9a20dcf449caafaffacd3502b1a08f25b27394d2':
Increase LinearAlloc limit
Andy McFadden [Wed, 19 Jan 2011 19:29:20 +0000 (11:29 -0800)]
am
4b2dc337: am
6009938d: Increase LinearAlloc limit
* commit '
4b2dc33744c00da2a89b075e8e631f3917f83d7f':
Increase LinearAlloc limit
Andy McFadden [Wed, 19 Jan 2011 19:27:48 +0000 (11:27 -0800)]
am
6009938d: Increase LinearAlloc limit
* commit '
6009938d52c3ba5ae1fdf0074ab618d1166750bf':
Increase LinearAlloc limit
Andy McFadden [Wed, 19 Jan 2011 19:00:53 +0000 (11:00 -0800)]
Increase LinearAlloc limit
When run on framework.jar, dexopt needs about 4MB of LinearAlloc
space. We were capped at 5MB. Bump up the limit to 8MB to give
us some additional head room.
Bug
3362346
Change-Id: I61e06e4cd7d24d45e426026a5adddd7badc3b839
buzbee [Wed, 19 Jan 2011 18:16:31 +0000 (10:16 -0800)]
Merge "Consolidate mterp's debug/profile/suspend control" into dalvik-dev
buzbee [Fri, 14 Jan 2011 21:37:31 +0000 (13:37 -0800)]
Consolidate mterp's debug/profile/suspend control
This is a step towards full debug & profiling support in JIT'd code.
Previously, the interpreter made multiple distinct checks for pending
suspend requests, debugger and profiler checks at each safe point.
This CL moves the individual controls into a single control word,
significantly speeding up the safe-point check code path in the common
fast case.
In short, any time some VM component wants control to break at a safe
point it will set a bit in gDvm.interpBreak, which will be examined
at the safe point check in footer.S. In the old code, the safe point
check consisted of 11 instructions (including 6 loads). The new sequence
is 6 instructions (4 loads - two of which are needed and two are
speculative to fill otherwise stalling slots).
This code path is hot enough in the interpreter that we actually see
some measureable speedups in benchmarks. The old sieve benchmark
improves from 252 to 256 (~1.5%).
As part of the change, global debuggerActive and activeProfilers variables
have been eliminated as redundant. Note also that there is a subtle
change in thread suspension. Thread suspend request counts are kept on
a per-thread basis, and previously each thread would only examine its own
suspend count. With this change, a bit has been allocated in interpBreak
to signify that at least one suspend request is active across all
threads. This bit is treated as "some thread is supposed to
suspend, check to see if it's me".
Change-Id: I527dc918f58d1486ef3324136080ef541a775ba8
Carl Shapiro [Wed, 19 Jan 2011 06:13:54 +0000 (22:13 -0800)]
am
2287bffd: am
9622ef8d: am
b2e15681: Merge "Implement growth limits to support multiple heap configurations." into honeycomb
* commit '
2287bffddbb9150bdefaec8e6d9baf2726a86c90':
Implement growth limits to support multiple heap configurations.
Jesse Wilson [Wed, 19 Jan 2011 06:13:50 +0000 (22:13 -0800)]
am
f18a4274: am
6210c50d: am
eef67346: Merge "Fix proxy expectation." into honeycomb
* commit '
f18a427413d1cea7e245256810346837bd88cd8c':
Fix proxy expectation.
Carl Shapiro [Wed, 19 Jan 2011 06:02:28 +0000 (22:02 -0800)]
am
9622ef8d: am
b2e15681: Merge "Implement growth limits to support multiple heap configurations." into honeycomb
* commit '
9622ef8d66f3a2c1780166a84485e6130727fcc1':
Implement growth limits to support multiple heap configurations.
Jesse Wilson [Wed, 19 Jan 2011 06:02:26 +0000 (22:02 -0800)]
am
6210c50d: am
eef67346: Merge "Fix proxy expectation." into honeycomb
* commit '
6210c50d31f45c28c2cddca405a4b946f7fbfb39':
Fix proxy expectation.
Carl Shapiro [Wed, 19 Jan 2011 02:41:06 +0000 (18:41 -0800)]
am
b2e15681: Merge "Implement growth limits to support multiple heap configurations." into honeycomb
* commit '
b2e15681cb52079d8e63a68a611036911b94d1fe':
Implement growth limits to support multiple heap configurations.
Jesse Wilson [Wed, 19 Jan 2011 02:39:31 +0000 (18:39 -0800)]
am
eef67346: Merge "Fix proxy expectation." into honeycomb
* commit '
eef673461bdbfbd8fde35c302ee5df5330f643a5':
Fix proxy expectation.
Carl Shapiro [Wed, 19 Jan 2011 02:16:46 +0000 (18:16 -0800)]
Merge "Implement growth limits to support multiple heap configurations." into honeycomb
Carl Shapiro [Wed, 19 Jan 2011 01:59:30 +0000 (17:59 -0800)]
Implement growth limits to support multiple heap configurations.
When a growth limit is in effect, allocations will be limited to
number of bytes specified by the growth limit instead of the maximum
heap size. Growth limits are specified on the command line with the
new parameter -XX:HeapGrowthLimit. A growth limit can be removed at
runtime by calling the new clearGrowthLimit method.
This is a work around until we can adjust the maximum heap size at
runtime.
Change-Id: Ic01e32823b5ca8cf29c0948fb6cd2df10967c1fb
Jesse Wilson [Wed, 19 Jan 2011 01:24:19 +0000 (17:24 -0800)]
Merge "Fix proxy expectation." into honeycomb
Jesse Wilson [Wed, 19 Jan 2011 01:20:33 +0000 (17:20 -0800)]
Fix proxy expectation.
Change-Id: I70589302c686387a1f89e8f79eb58c4b6b8214a6
Jesse Wilson [Wed, 19 Jan 2011 00:05:37 +0000 (16:05 -0800)]
Merge "Add an undocumented --incremental option to dx." into dalvik-dev
Jesse Wilson [Tue, 18 Jan 2011 01:29:35 +0000 (17:29 -0800)]
Add an undocumented --incremental option to dx.
Change-Id: I48879b2f724e9b92c99c669803f9c8de01487327
jeffhao [Tue, 18 Jan 2011 21:27:37 +0000 (13:27 -0800)]
Merge "Optimized dx instruction expansion to only generate necessary moves." into dalvik-dev
jeffhao [Mon, 17 Jan 2011 19:37:21 +0000 (11:37 -0800)]
Optimized dx instruction expansion to only generate necessary moves.
When an instruction's fields do not fit into an instruction format, dx
expands the instruction. Before, this would always use new registers for
sources and destination, generating moves for each. However, some of
these moves would be unnecessary if an original register already fit
into the instruction format. This change checks to see if the original
register fits before using a new register and generating a new move.
Change-Id: I17c6722cf4053573bf913a28d631386f2c3a733d
Carl Shapiro [Mon, 17 Jan 2011 22:51:40 +0000 (14:51 -0800)]
am
acbb1f4c: am
88b5885e: am
241cec80: Remove unused heap dumping code.
* commit '
acbb1f4c8a6a4085cd237b50fd0f2d1efe432e9f':
Remove unused heap dumping code.
Carl Shapiro [Mon, 17 Jan 2011 22:47:59 +0000 (14:47 -0800)]
am
88b5885e: am
241cec80: Remove unused heap dumping code.
* commit '
88b5885e8ba78898eadf6d201cebe97794fe578d':
Remove unused heap dumping code.
Carl Shapiro [Mon, 17 Jan 2011 22:42:22 +0000 (14:42 -0800)]
am
241cec80: Remove unused heap dumping code.
* commit '
241cec80a79551730122fb9dbc92a3527392b1de':
Remove unused heap dumping code.
Jesse Wilson [Mon, 17 Jan 2011 22:13:49 +0000 (14:13 -0800)]
Merge "Make DexMerger's dex reader general purpose." into dalvik-dev
Jesse Wilson [Mon, 17 Jan 2011 02:06:57 +0000 (18:06 -0800)]
Make DexMerger's dex reader general purpose.
Use this to implement FindUsages, which prints references to
fields and methods within a dex. This is the FindUsages output
for "Ljava/lang/Number;", "longValue" on libcore's dex file:
Method referenced by Ljava/io/EmulatedFields;#get invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/io/EmulatedFieldsForDumping;#write invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/io/ObjectOutputStream;#writeFieldValues invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method declared by Ljava/lang/Number;#longValue
Method declared by Ljava/lang/Byte;#longValue
Method declared by Ljava/lang/Double;#longValue
Method declared by Ljava/lang/Float;#longValue
Method declared by Ljava/lang/Integer;#longValue
Method declared by Ljava/lang/Long;#longValue
Method declared by Ljava/lang/Short;#longValue
Method referenced by Ljava/lang/reflect/Array;#set invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#divideBigIntegers invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#divideBigIntegers invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#divideBigIntegers invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#readObject invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#setUnscaledValue invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#valueExact invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/BigDecimal;#doubleValue invoke-virtual/range {vCCCC..vNNNN}, meth@BBBB
Method referenced by Ljava/math/BigDecimal;#doubleValue invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method declared by Ljava/math/BigDecimal;#longValue
Method referenced by Ljava/math/BigDecimal;#longValue invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method declared by Ljava/math/BigInteger;#longValue
Method referenced by Ljava/math/Conversion;#bigInteger2Double invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/math/Conversion;#bigInteger2Double invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/text/NumberFormat;#format invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/text/DateFormat;#format invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/text/DecimalFormat;#format invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/text/DecimalFormat;#parse invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/text/SimpleDateFormat;#formatToCharacterIterator invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transform invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transformFromDateTime invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transformFromInteger invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transformFromInteger invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transformFromInteger invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transformFromInteger invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transform_g invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transform_g invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transform_g invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Formatter;#transform_g invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Ljava/util/Scanner;#nextLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method declared by Ljava/util/concurrent/atomic/AtomicInteger;#longValue
Method declared by Ljava/util/concurrent/atomic/AtomicLong;#longValue
Method referenced by Llibcore/icu/NativeDecimalFormat;#formatToCharacterIterator invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xalan/xslt/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xml/dtm/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xml/dtm/ref/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xml/serializer/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xml/utils/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/apache/xpath/functions/SecuritySupport12;#getLastModified invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSON;#toLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSONArray;#getLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSONArray;#optLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSONObject;#numberToString invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSONObject;#getLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Method referenced by Lorg/json/JSONObject;#optLong invoke-virtual {vD, vE, vF, vG, vA}, meth@CCCC
Change-Id: Ia50f28f53ce5838799e2d5f03a7a2f1c551299de
Carl Shapiro [Mon, 17 Jan 2011 07:22:27 +0000 (23:22 -0800)]
am
9c947b14: am
56750efd: am
0f403d5f: Remove some inline declarations to improve debugging.
* commit '
9c947b14fcaae1233b58c2c3ab3351b632dba76b':
Remove some inline declarations to improve debugging.
Carl Shapiro [Mon, 17 Jan 2011 07:22:25 +0000 (23:22 -0800)]
am
cb7e217f: am
548d70b0: am
23966773: Rename absoluteMaxSize to maximumSize.
* commit '
cb7e217fb0a6c024abaa0f233edfd7d99aacc64d':
Rename absoluteMaxSize to maximumSize.
Carl Shapiro [Mon, 17 Jan 2011 07:22:21 +0000 (23:22 -0800)]
am
70f4dccb: am
c5ec711d: am
ac8f1125: Merge "Make the soft limited predicate look more like a predicate." into honeycomb
* commit '
70f4dccb8a5d393cf9a076e72d8af4425c99b8bb':
Make the soft limited predicate look more like a predicate.
Carl Shapiro [Mon, 17 Jan 2011 07:06:13 +0000 (23:06 -0800)]
am
56750efd: am
0f403d5f: Remove some inline declarations to improve debugging.
* commit '
56750efd3a5fffaef6306df89fc9a2054d5e5861':
Remove some inline declarations to improve debugging.
Carl Shapiro [Mon, 17 Jan 2011 07:01:20 +0000 (23:01 -0800)]
am
548d70b0: am
23966773: Rename absoluteMaxSize to maximumSize.
* commit '
548d70b045b434be5343fb1549a6d538c5c12ff7':
Rename absoluteMaxSize to maximumSize.
Carl Shapiro [Mon, 17 Jan 2011 07:00:48 +0000 (23:00 -0800)]
am
c5ec711d: am
ac8f1125: Merge "Make the soft limited predicate look more like a predicate." into honeycomb
* commit '
c5ec711d856778b6fd108b15a0a77f68995d44af':
Make the soft limited predicate look more like a predicate.
Carl Shapiro [Mon, 17 Jan 2011 03:29:23 +0000 (19:29 -0800)]
Remove unused heap dumping code.
Change-Id: Id8774848a870003c60be2ebcc505ce30795a4fcf
Carl Shapiro [Mon, 17 Jan 2011 01:31:37 +0000 (17:31 -0800)]
am
0f403d5f: Remove some inline declarations to improve debugging.
* commit '
0f403d5f9286b42c3596004eb8015718269d9092':
Remove some inline declarations to improve debugging.
Carl Shapiro [Mon, 17 Jan 2011 01:20:49 +0000 (17:20 -0800)]
Remove some inline declarations to improve debugging.
Change-Id: I41b044fb9ae66c1d531f4d61c73ce6fcd597102f
Carl Shapiro [Sun, 16 Jan 2011 22:11:01 +0000 (14:11 -0800)]
am
23966773: Rename absoluteMaxSize to maximumSize.
* commit '
23966773259b828001634a71cafdc4fa98904bea':
Rename absoluteMaxSize to maximumSize.
Carl Shapiro [Sun, 16 Jan 2011 22:05:53 +0000 (14:05 -0800)]
Rename absoluteMaxSize to maximumSize.
Change-Id: I3ec30b35f3689ad76a805af3b261cdaa7adbc3d7
Jesse Wilson [Sat, 15 Jan 2011 00:27:49 +0000 (16:27 -0800)]
Improve the interface for reading Dex files.
I'm planning on making this code reusable for grepping
dex files.
Change-Id: Iebf545ed6d6a4eb347ccc4a39fe40c02d75d69e4
Carl Shapiro [Sun, 16 Jan 2011 21:53:46 +0000 (13:53 -0800)]
am
ac8f1125: Merge "Make the soft limited predicate look more like a predicate." into honeycomb
* commit '
ac8f112513e3481e7295eaeaf5843a55fa9b1b63':
Make the soft limited predicate look more like a predicate.
Carl Shapiro [Sun, 16 Jan 2011 21:51:44 +0000 (13:51 -0800)]
Merge "Make the soft limited predicate look more like a predicate." into honeycomb
Carl Shapiro [Sat, 15 Jan 2011 03:05:23 +0000 (19:05 -0800)]
Make the soft limited predicate look more like a predicate.
Change-Id: I8edfafdfa8d73ebe1e3288bc0c8df2c6acbce2af
Andy McFadden [Fri, 14 Jan 2011 23:38:50 +0000 (15:38 -0800)]
am
480de458: am
5918b804: am
22acd2ae: Merge "Fix JNI invocation of constructors." into honeycomb
* commit '
480de458e3735af6868dc5546f335aec3233cd6a':
Fix JNI invocation of constructors.
Andy McFadden [Fri, 14 Jan 2011 23:36:19 +0000 (15:36 -0800)]
am
5918b804: am
22acd2ae: Merge "Fix JNI invocation of constructors." into honeycomb
* commit '
5918b80472fe57aea34446ea25f2a8ca7a5290b0':
Fix JNI invocation of constructors.
Andy McFadden [Fri, 14 Jan 2011 23:34:54 +0000 (15:34 -0800)]
am
22acd2ae: Merge "Fix JNI invocation of constructors." into honeycomb
* commit '
22acd2ae4b1f0f4f3aab4f55026c2e1d0d409dad':
Fix JNI invocation of constructors.
Andy McFadden [Fri, 14 Jan 2011 23:33:16 +0000 (15:33 -0800)]
Merge "Fix JNI invocation of constructors." into honeycomb
Andy McFadden [Fri, 14 Jan 2011 23:32:13 +0000 (15:32 -0800)]
Merge "Fix JNI invocation of constructors." into dalvik-dev
Andy McFadden [Fri, 14 Jan 2011 22:52:48 +0000 (14:52 -0800)]
Fix JNI invocation of constructors.
The code that "virtualizes" method invocations was attempting to
virtualize a call to a constructor. Constructors are direct methods,
so this resulted in a spurious CloneNotSupportedException.
Bug
3354578
(cherry-pick from dalvik-dev)
Change-Id: Ib158ab7fc6b2874eba1fc2afa45fd5436c1f2a8a
Andy McFadden [Fri, 14 Jan 2011 22:52:48 +0000 (14:52 -0800)]
Fix JNI invocation of constructors.
The code that "virtualizes" method invocations was attempting to
virtualize a call to a constructor. Constructors are direct methods,
so this resulted in a spurious CloneNotSupportedException.
Bug
3354578
Change-Id: Icac922593f1d872fffaf3bce98c8e24e287bf7af
Jesse Wilson [Fri, 14 Jan 2011 21:58:58 +0000 (13:58 -0800)]
Merge "Read Dex files from a byte[] rather than a RandomAccessFile." into dalvik-dev
Jesse Wilson [Fri, 14 Jan 2011 21:16:06 +0000 (13:16 -0800)]
Read Dex files from a byte[] rather than a RandomAccessFile.
This improves time to merge a trivial file with core.dex from
3.8 seconds to 0.8 seconds.
Also fixing read method names to be consistent with the spec.
Change-Id: I9033bcb497afe7a0d73e00cca14fa046b53a62bf
Dan Bornstein [Fri, 14 Jan 2011 20:47:25 +0000 (12:47 -0800)]
am
9c07fafa: (-s ours) am
a5c42dab: (-s ours) am
602b8ffb: (-s ours) am
6ad1992b: am
70b130f5: (-s ours) Clean up/out some comments. DO NOT MERGE.
* commit '
9c07fafa999beb107c7a780031b08caaaedd2b5e':
Clean up/out some comments. DO NOT MERGE.
Dan Bornstein [Fri, 14 Jan 2011 20:44:39 +0000 (12:44 -0800)]
am
a5c42dab: (-s ours) am
602b8ffb: (-s ours) am
6ad1992b: am
70b130f5: (-s ours) Clean up/out some comments. DO NOT MERGE.
* commit '
a5c42dab9f2bfe9ec1e85b2b2721d6be58892e25':
Clean up/out some comments. DO NOT MERGE.
Dan Bornstein [Fri, 14 Jan 2011 20:41:45 +0000 (12:41 -0800)]
am
602b8ffb: (-s ours) am
6ad1992b: am
70b130f5: (-s ours) Clean up/out some comments. DO NOT MERGE.
* commit '
602b8ffb35fb555fa77081446efa598206e0c3bf':
Clean up/out some comments. DO NOT MERGE.
Dan Bornstein [Fri, 14 Jan 2011 20:39:45 +0000 (12:39 -0800)]
am
6ad1992b: am
70b130f5: (-s ours) Clean up/out some comments. DO NOT MERGE.
* commit '
6ad1992b311937963d44be68f3ec0255a87d82b8':
Clean up/out some comments. DO NOT MERGE.
Dan Bornstein [Fri, 14 Jan 2011 20:37:13 +0000 (12:37 -0800)]
am
70b130f5: (-s ours) Clean up/out some comments. DO NOT MERGE.
* commit '
70b130f5398c43418b6eacba2cc09f71d9febdc4':
Clean up/out some comments. DO NOT MERGE.
Dan Bornstein [Fri, 14 Jan 2011 20:26:12 +0000 (12:26 -0800)]
Clean up/out some comments. DO NOT MERGE.
Change-Id: I16063cf9132e0f2d6556ce06e1ebfb90ecff05aa
Jesse Wilson [Fri, 14 Jan 2011 19:22:36 +0000 (11:22 -0800)]
Merge "New tool merge two dex files into one." into dalvik-dev
Ben Cheng [Fri, 14 Jan 2011 19:14:08 +0000 (11:14 -0800)]
am
45e9a990: am
80211d2b: Only generate debugging LIRs in verbose mode.
* commit '
45e9a9908f8874b64294dbd3e4dcfb6b76c4b6e3':
Only generate debugging LIRs in verbose mode.
Dan Bornstein [Fri, 14 Jan 2011 19:12:15 +0000 (11:12 -0800)]
am
660095cc: am
efb37a32: am
f741b8e1: am
80a30431: (-s ours) Remove some pointless tests.
* commit '
660095cc310535c4874e953f5eea0abc2540f655':
Remove some pointless tests.
Ben Cheng [Fri, 14 Jan 2011 19:08:38 +0000 (11:08 -0800)]
am
80211d2b: Only generate debugging LIRs in verbose mode.
* commit '
80211d2b18daa79c7b4c9b04f0cb366660c86f73':
Only generate debugging LIRs in verbose mode.
Dan Bornstein [Fri, 14 Jan 2011 19:04:47 +0000 (11:04 -0800)]
am
efb37a32: am
f741b8e1: am
80a30431: (-s ours) Remove some pointless tests.
* commit '
efb37a324e037b9dfbeee7627d7b0417e1b9aed8':
Remove some pointless tests.
Ben Cheng [Fri, 14 Jan 2011 18:23:37 +0000 (10:23 -0800)]
Only generate debugging LIRs in verbose mode.
This should reduce memory usage and JIT time a bit.
Affected opcodes: kArmPseudoSSARep and kArmPseudoDalvikByteCodeBoundary.
Change-Id: I18ce9338b8d258270df51a66f9dc98cd2d9dd0e8
Carl Shapiro [Fri, 14 Jan 2011 01:52:58 +0000 (17:52 -0800)]
am
c45c71a8: am
9c6e857f: Merge "Minor cleanup of some initialization code." into honeycomb
* commit '
c45c71a82832422d8d45b6bf7f236d51d77e04f8':
Minor cleanup of some initialization code.
Carl Shapiro [Fri, 14 Jan 2011 01:48:52 +0000 (17:48 -0800)]
am
9c6e857f: Merge "Minor cleanup of some initialization code." into honeycomb
* commit '
9c6e857fb13cad874a2f430438babe44bcddf5d0':
Minor cleanup of some initialization code.
Carl Shapiro [Fri, 14 Jan 2011 01:45:21 +0000 (17:45 -0800)]
Merge "Minor cleanup of some initialization code." into honeycomb
Carl Shapiro [Fri, 14 Jan 2011 01:25:19 +0000 (17:25 -0800)]
Minor cleanup of some initialization code.
This change removes the "dvm" prefix from static functions and makes
the memory option processor use the potentially wider size_t type for
manipulating memory sizes instead of the unsigned int type.
Change-Id: Ia85b01d2a852080e56e4da7c9393fe4e6c2bdf00
Andy McFadden [Fri, 14 Jan 2011 00:42:28 +0000 (16:42 -0800)]
am
db3c9225: am
d5dae2a4: Merge "Fix invoke-interface verification failures" into honeycomb
* commit '
db3c9225ce1cb2af645958a517233787899c2cfe':
Fix invoke-interface verification failures
Andy McFadden [Fri, 14 Jan 2011 00:38:19 +0000 (16:38 -0800)]
am
d5dae2a4: Merge "Fix invoke-interface verification failures" into honeycomb
* commit '
d5dae2a47d5730887408feed993d8e9006953749':
Fix invoke-interface verification failures
Andy McFadden [Fri, 14 Jan 2011 00:35:26 +0000 (16:35 -0800)]
Merge "Fix invoke-interface verification failures" into honeycomb
Carl Shapiro [Fri, 14 Jan 2011 00:31:46 +0000 (16:31 -0800)]
am
c3be0be1: am
a4f35892: Merge "Remove a stray empty line." into honeycomb
* commit '
c3be0be1932640691e64f1427a6308edee5561ca':
Remove a stray empty line.
Carl Shapiro [Fri, 14 Jan 2011 00:27:18 +0000 (16:27 -0800)]
am
a4f35892: Merge "Remove a stray empty line." into honeycomb
* commit '
a4f3589250f6d786654131e44291c9c19c80333c':
Remove a stray empty line.