blob: 432b368989f5690581f9fd132a18cba51feae79a [file] [log] [blame]
Ben Chenge9695e52009-06-16 16:11:47 -07001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Ben Chenge9695e52009-06-16 16:11:47 -070017#ifndef _DALVIK_VM_COMPILER_OPTIMIZATION_H
18#define _DALVIK_VM_COMPILER_OPTIMIZATION_H
19
Ben Cheng4238ec22009-08-24 16:32:22 -070020#include "Dalvik.h"
21
Ben Chenge9695e52009-06-16 16:11:47 -070022/* Forward declarations */
23struct CompilationUnit;
24struct LIR;
25
26/*
27 * Data structure tracking the mapping between a Dalvik register (pair) and a
28 * native register (pair). The idea is to reuse the previously loaded value
29 * if possible, otherwise to keep the value in a native register as long as
30 * possible.
31 */
32typedef struct RegisterScoreboard {
33 BitVector *nullCheckedRegs; // Track which registers have been null-checked
34 int liveDalvikReg; // Track which Dalvik register is live
35 int nativeReg; // And the mapped native register
36 int nativeRegHi; // And the mapped native register
37 bool isWide; // Whether a pair of registers are alive
38} RegisterScoreboard;
39
40void dvmCompilerApplyLocalOptimizations(struct CompilationUnit *cUnit,
41 struct LIR *head,
42 struct LIR *tail);
43
44void dvmCompilerApplyGlobalOptimizations(struct CompilationUnit *cUnit);
45
46#endif /* _DALVIK_VM_COMPILER_OPTIMIZATION_H */