decoration decoration
Stories

GROKLAW
When you want to know more...
decoration
For layout only
Home
Archives
Site Map
Search
About Groklaw
Awards
Legal Research
Timelines
ApplevSamsung
ApplevSamsung p.2
ArchiveExplorer
Autozone
Bilski
Cases
Cast: Lawyers
Comes v. MS
Contracts/Documents
Courts
DRM
Gordon v MS
GPL
Grokdoc
HTML How To
IPI v RH
IV v. Google
Legal Docs
Lodsys
MS Litigations
MSvB&N
News Picks
Novell v. MS
Novell-MS Deal
ODF/OOXML
OOXML Appeals
OraclevGoogle
Patents
ProjectMonterey
Psystar
Quote Database
Red Hat v SCO
Salus Book
SCEA v Hotz
SCO Appeals
SCO Bankruptcy
SCO Financials
SCO Overview
SCO v IBM
SCO v Novell
SCO:Soup2Nuts
SCOsource
Sean Daly
Software Patents
Switch to Linux
Transcripts
Unix Books

Gear

Groklaw Gear

Click here to send an email to the editor of this weblog.


You won't find me on Facebook


Donate

Donate Paypal


No Legal Advice

The information on Groklaw is not intended to constitute legal advice. While Mark is a lawyer and he has asked other lawyers and law students to contribute articles, all of these articles are offered to help educate, not to provide specific legal advice. They are not your lawyers.

Here's Groklaw's comments policy.


What's New

STORIES
No new stories

COMMENTS last 48 hrs
No new comments


Sponsors

Hosting:
hosted by ibiblio

On servers donated to ibiblio by AMD.

Webmaster
dalvik-cache, static vs runtime | 439 comments | Create New Account
Comments belong to whoever posts them. Please notify us of inappropriate comments.
dalvik-cache, static vs runtime
Authored by: SpaceLifeForm on Monday, May 14 2012 @ 08:25 PM EDT
There is a great writeup on this that I can
not find at this time but it describes how
almost everything is resolved before the
dalvik vm processes the dex file.

The main point of the work is that as
much as possible is resolved ahead of
time.

It is not a dynamic thing that happens
when the user 'runs' an app.

It is all by design so that the user
experiences good performance.

Hence the reason for the cache.

---

You are being MICROattacked, from various angles, in a SOFT manner.

[ Reply to This | Parent | # ]

dalvik-cache, static vs runtime
Authored by: SpaceLifeForm on Tuesday, May 15 2012 @ 01:02 AM EDT
Good question. Obviously, some stuff must be dealt with at runtime. I have not studied the code, but am guessing mmap is used. But everything that can be dealt with ahead of time would hopefully be realized.

But, yes, something still is resolved to make it work.

Does that mean it infringing the patent?

Link

Note that the link is three years old now, so it may not be totally correct or current.

Preparation

There are at least three different ways to create a "prepared" DEX file, sometimes known as "ODEX" (for Optimized DEX):

The VM does it "just in time". The output goes into a special dalvik-cache directory. This works on the desktop and engineering-only device builds where the permissions on the dalvik-cache directory are not restricted. On production devices, this is not allowed.

The system installer does it when an application is first added. It has the privileges required to write to dalvik-cache.

The build system does it ahead of time. The relevant jar / apk files are present, but the classes.dex is stripped out. The optimized DEX is stored next to the original zip archive, not in dalvik-cache, and is part of the system image.

The rules may not be applicable if you have a rooted device.

---

You are being MICROattacked, from various angles, in a SOFT manner.

[ Reply to This | Parent | # ]

Groklaw © Copyright 2003-2013 Pamela Jones.
All trademarks and copyrights on this page are owned by their respective owners.
Comments are owned by the individual posters.

PJ's articles are licensed under a Creative Commons License. ( Details )