langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Code.java
author sadayapalam
Mon, 23 Mar 2015 09:48:37 +0530
changeset 29777 95a89a2efd89
parent 29772 4e4e74b99d27
child 45504 ea7475564d07
permissions -rw-r--r--
7040592: Gen.java: fix code for handling 'null' literal when expected type is array Summary: Eliminate needless checkcast when null is assigned to a multi-dimensional array typedobject Reviewed-by: mcimadamore
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
28330
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
     2
 * Copyright (c) 1999, 2015, Oracle and/or its affiliates. All rights reserved.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
06bc494ca11e Initial load
duke
parents:
diff changeset
     4
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
06bc494ca11e Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 4866
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 4866
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    10
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
06bc494ca11e Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
06bc494ca11e Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
06bc494ca11e Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
06bc494ca11e Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
06bc494ca11e Initial load
duke
parents:
diff changeset
    16
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
06bc494ca11e Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
06bc494ca11e Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
06bc494ca11e Initial load
duke
parents:
diff changeset
    20
 *
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 4866
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 4866
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 4866
diff changeset
    23
 * questions.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    24
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    25
06bc494ca11e Initial load
duke
parents:
diff changeset
    26
package com.sun.tools.javac.jvm;
06bc494ca11e Initial load
duke
parents:
diff changeset
    27
06bc494ca11e Initial load
duke
parents:
diff changeset
    28
import com.sun.tools.javac.code.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    29
import com.sun.tools.javac.code.Symbol.*;
14949
45f43822bbde 8000518: Javac generates duplicate name_and_type constant pool entry for class BinaryOpValueExp.java
vromero
parents: 14803
diff changeset
    30
import com.sun.tools.javac.code.Types.UniqueType;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
    31
import com.sun.tools.javac.tree.JCTree;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    32
import com.sun.tools.javac.util.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
import com.sun.tools.javac.util.JCDiagnostic.DiagnosticPosition;
06bc494ca11e Initial load
duke
parents:
diff changeset
    34
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
    35
import static com.sun.tools.javac.code.TypeTag.BOT;
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
    36
import static com.sun.tools.javac.code.TypeTag.INT;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    37
import static com.sun.tools.javac.jvm.ByteCodes.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    38
import static com.sun.tools.javac.jvm.UninitializedType.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    39
import static com.sun.tools.javac.jvm.ClassWriter.StackMapTableFrame;
06bc494ca11e Initial load
duke
parents:
diff changeset
    40
06bc494ca11e Initial load
duke
parents:
diff changeset
    41
/** An internal structure that corresponds to the code attribute of
06bc494ca11e Initial load
duke
parents:
diff changeset
    42
 *  methods in a classfile. The class also provides some utility operations to
06bc494ca11e Initial load
duke
parents:
diff changeset
    43
 *  generate bytecode instructions.
06bc494ca11e Initial load
duke
parents:
diff changeset
    44
 *
5847
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    45
 *  <p><b>This is NOT part of any supported API.
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    46
 *  If you write code that depends on this, you do so at your own risk.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    47
 *  This code and its internal interfaces are subject to change or
06bc494ca11e Initial load
duke
parents:
diff changeset
    48
 *  deletion without notice.</b>
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    50
public class Code {
06bc494ca11e Initial load
duke
parents:
diff changeset
    51
06bc494ca11e Initial load
duke
parents:
diff changeset
    52
    public final boolean debugCode;
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
    public final boolean needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
    public enum StackMapFormat {
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
        NONE,
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
        CLDC {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 10
diff changeset
    58
            Name getAttributeName(Names names) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    59
                return names.StackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
    60
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
    61
        },
06bc494ca11e Initial load
duke
parents:
diff changeset
    62
        JSR202 {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 10
diff changeset
    63
            Name getAttributeName(Names names) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    64
                return names.StackMapTable;
06bc494ca11e Initial load
duke
parents:
diff changeset
    65
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
    66
        };
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 10
diff changeset
    67
        Name getAttributeName(Names names) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    68
            return names.empty;
06bc494ca11e Initial load
duke
parents:
diff changeset
    69
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
    70
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
    71
06bc494ca11e Initial load
duke
parents:
diff changeset
    72
    final Types types;
06bc494ca11e Initial load
duke
parents:
diff changeset
    73
    final Symtab syms;
06bc494ca11e Initial load
duke
parents:
diff changeset
    74
06bc494ca11e Initial load
duke
parents:
diff changeset
    75
/*---------- classfile fields: --------------- */
06bc494ca11e Initial load
duke
parents:
diff changeset
    76
06bc494ca11e Initial load
duke
parents:
diff changeset
    77
    /** The maximum stack size.
06bc494ca11e Initial load
duke
parents:
diff changeset
    78
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    79
    public int max_stack = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
    80
06bc494ca11e Initial load
duke
parents:
diff changeset
    81
    /** The maximum number of local variable slots.
06bc494ca11e Initial load
duke
parents:
diff changeset
    82
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    83
    public int max_locals = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
    84
06bc494ca11e Initial load
duke
parents:
diff changeset
    85
    /** The code buffer.
06bc494ca11e Initial load
duke
parents:
diff changeset
    86
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    87
    public byte[] code = new byte[64];
06bc494ca11e Initial load
duke
parents:
diff changeset
    88
06bc494ca11e Initial load
duke
parents:
diff changeset
    89
    /** the current code pointer.
06bc494ca11e Initial load
duke
parents:
diff changeset
    90
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    91
    public int cp = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
    92
06bc494ca11e Initial load
duke
parents:
diff changeset
    93
    /** Check the code against VM spec limits; if
06bc494ca11e Initial load
duke
parents:
diff changeset
    94
     *  problems report them and return true.
06bc494ca11e Initial load
duke
parents:
diff changeset
    95
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    96
    public boolean checkLimits(DiagnosticPosition pos, Log log) {
06bc494ca11e Initial load
duke
parents:
diff changeset
    97
        if (cp > ClassFile.MAX_CODE) {
06bc494ca11e Initial load
duke
parents:
diff changeset
    98
            log.error(pos, "limit.code");
06bc494ca11e Initial load
duke
parents:
diff changeset
    99
            return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   100
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   101
        if (max_locals > ClassFile.MAX_LOCALS) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   102
            log.error(pos, "limit.locals");
06bc494ca11e Initial load
duke
parents:
diff changeset
   103
            return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   104
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
        if (max_stack > ClassFile.MAX_STACK) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   106
            log.error(pos, "limit.stack");
06bc494ca11e Initial load
duke
parents:
diff changeset
   107
            return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   109
        return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   110
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   111
06bc494ca11e Initial load
duke
parents:
diff changeset
   112
    /** A buffer for expression catch data. Each enter is a vector
06bc494ca11e Initial load
duke
parents:
diff changeset
   113
     *  of four unsigned shorts.
06bc494ca11e Initial load
duke
parents:
diff changeset
   114
     */
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 21711
diff changeset
   115
    ListBuffer<char[]> catchInfo = new ListBuffer<>();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   116
06bc494ca11e Initial load
duke
parents:
diff changeset
   117
    /** A buffer for line number information. Each entry is a vector
06bc494ca11e Initial load
duke
parents:
diff changeset
   118
     *  of two unsigned shorts.
06bc494ca11e Initial load
duke
parents:
diff changeset
   119
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   120
    List<char[]> lineInfo = List.nil(); // handled in stack fashion
06bc494ca11e Initial load
duke
parents:
diff changeset
   121
06bc494ca11e Initial load
duke
parents:
diff changeset
   122
    /** The CharacterRangeTable
06bc494ca11e Initial load
duke
parents:
diff changeset
   123
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   124
    public CRTable crt;
06bc494ca11e Initial load
duke
parents:
diff changeset
   125
06bc494ca11e Initial load
duke
parents:
diff changeset
   126
/*---------- internal fields: --------------- */
06bc494ca11e Initial load
duke
parents:
diff changeset
   127
13844
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
   128
    /** Are we generating code with jumps &ge; 32K?
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   129
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   130
    public boolean fatcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   131
06bc494ca11e Initial load
duke
parents:
diff changeset
   132
    /** Code generation enabled?
06bc494ca11e Initial load
duke
parents:
diff changeset
   133
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   134
    private boolean alive = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   135
06bc494ca11e Initial load
duke
parents:
diff changeset
   136
    /** The current machine state (registers and stack).
06bc494ca11e Initial load
duke
parents:
diff changeset
   137
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   138
    State state;
06bc494ca11e Initial load
duke
parents:
diff changeset
   139
06bc494ca11e Initial load
duke
parents:
diff changeset
   140
    /** Is it forbidden to compactify code, because something is
06bc494ca11e Initial load
duke
parents:
diff changeset
   141
     *  pointing to current location?
06bc494ca11e Initial load
duke
parents:
diff changeset
   142
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   143
    private boolean fixedPc = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   144
06bc494ca11e Initial load
duke
parents:
diff changeset
   145
    /** The next available register.
06bc494ca11e Initial load
duke
parents:
diff changeset
   146
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   147
    public int nextreg = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   148
06bc494ca11e Initial load
duke
parents:
diff changeset
   149
    /** A chain for jumps to be resolved before the next opcode is emitted.
06bc494ca11e Initial load
duke
parents:
diff changeset
   150
     *  We do this lazily to avoid jumps to jumps.
06bc494ca11e Initial load
duke
parents:
diff changeset
   151
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   152
    Chain pendingJumps = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   153
06bc494ca11e Initial load
duke
parents:
diff changeset
   154
    /** The position of the currently statement, if we are at the
06bc494ca11e Initial load
duke
parents:
diff changeset
   155
     *  start of this statement, NOPOS otherwise.
06bc494ca11e Initial load
duke
parents:
diff changeset
   156
     *  We need this to emit line numbers lazily, which we need to do
06bc494ca11e Initial load
duke
parents:
diff changeset
   157
     *  because of jump-to-jump optimization.
06bc494ca11e Initial load
duke
parents:
diff changeset
   158
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   159
    int pendingStatPos = Position.NOPOS;
06bc494ca11e Initial load
duke
parents:
diff changeset
   160
06bc494ca11e Initial load
duke
parents:
diff changeset
   161
    /** Set true when a stackMap is needed at the current PC. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   162
    boolean pendingStackMap = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   163
06bc494ca11e Initial load
duke
parents:
diff changeset
   164
    /** The stack map format to be generated. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   165
    StackMapFormat stackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
   166
06bc494ca11e Initial load
duke
parents:
diff changeset
   167
    /** Switch: emit variable debug info.
06bc494ca11e Initial load
duke
parents:
diff changeset
   168
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   169
    boolean varDebugInfo;
06bc494ca11e Initial load
duke
parents:
diff changeset
   170
06bc494ca11e Initial load
duke
parents:
diff changeset
   171
    /** Switch: emit line number info.
06bc494ca11e Initial load
duke
parents:
diff changeset
   172
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   173
    boolean lineDebugInfo;
06bc494ca11e Initial load
duke
parents:
diff changeset
   174
06bc494ca11e Initial load
duke
parents:
diff changeset
   175
    /** Emit line number info if map supplied
06bc494ca11e Initial load
duke
parents:
diff changeset
   176
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   177
    Position.LineMap lineMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
   178
06bc494ca11e Initial load
duke
parents:
diff changeset
   179
    /** The constant pool of the current class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   180
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   181
    final Pool pool;
06bc494ca11e Initial load
duke
parents:
diff changeset
   182
06bc494ca11e Initial load
duke
parents:
diff changeset
   183
    final MethodSymbol meth;
06bc494ca11e Initial load
duke
parents:
diff changeset
   184
06bc494ca11e Initial load
duke
parents:
diff changeset
   185
    /** Construct a code object, given the settings of the fatcode,
06bc494ca11e Initial load
duke
parents:
diff changeset
   186
     *  debugging info switches and the CharacterRangeTable.
06bc494ca11e Initial load
duke
parents:
diff changeset
   187
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   188
    public Code(MethodSymbol meth,
06bc494ca11e Initial load
duke
parents:
diff changeset
   189
                boolean fatcode,
06bc494ca11e Initial load
duke
parents:
diff changeset
   190
                Position.LineMap lineMap,
06bc494ca11e Initial load
duke
parents:
diff changeset
   191
                boolean varDebugInfo,
06bc494ca11e Initial load
duke
parents:
diff changeset
   192
                StackMapFormat stackMap,
06bc494ca11e Initial load
duke
parents:
diff changeset
   193
                boolean debugCode,
06bc494ca11e Initial load
duke
parents:
diff changeset
   194
                CRTable crt,
06bc494ca11e Initial load
duke
parents:
diff changeset
   195
                Symtab syms,
06bc494ca11e Initial load
duke
parents:
diff changeset
   196
                Types types,
28330
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
   197
                Pool pool) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   198
        this.meth = meth;
06bc494ca11e Initial load
duke
parents:
diff changeset
   199
        this.fatcode = fatcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   200
        this.lineMap = lineMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
   201
        this.lineDebugInfo = lineMap != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   202
        this.varDebugInfo = varDebugInfo;
06bc494ca11e Initial load
duke
parents:
diff changeset
   203
        this.crt = crt;
06bc494ca11e Initial load
duke
parents:
diff changeset
   204
        this.syms = syms;
06bc494ca11e Initial load
duke
parents:
diff changeset
   205
        this.types = types;
06bc494ca11e Initial load
duke
parents:
diff changeset
   206
        this.debugCode = debugCode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   207
        this.stackMap = stackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
   208
        switch (stackMap) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   209
        case CLDC:
06bc494ca11e Initial load
duke
parents:
diff changeset
   210
        case JSR202:
06bc494ca11e Initial load
duke
parents:
diff changeset
   211
            this.needStackMap = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   212
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   213
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   214
            this.needStackMap = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   215
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   216
        state = new State();
06bc494ca11e Initial load
duke
parents:
diff changeset
   217
        lvar = new LocalVar[20];
06bc494ca11e Initial load
duke
parents:
diff changeset
   218
        this.pool = pool;
06bc494ca11e Initial load
duke
parents:
diff changeset
   219
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   220
06bc494ca11e Initial load
duke
parents:
diff changeset
   221
06bc494ca11e Initial load
duke
parents:
diff changeset
   222
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
   223
 * Typecodes & related stuff
06bc494ca11e Initial load
duke
parents:
diff changeset
   224
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
   225
06bc494ca11e Initial load
duke
parents:
diff changeset
   226
    /** Given a type, return its type code (used implicitly in the
06bc494ca11e Initial load
duke
parents:
diff changeset
   227
     *  JVM architecture).
06bc494ca11e Initial load
duke
parents:
diff changeset
   228
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   229
    public static int typecode(Type type) {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
   230
        switch (type.getTag()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   231
        case BYTE: return BYTEcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   232
        case SHORT: return SHORTcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   233
        case CHAR: return CHARcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   234
        case INT: return INTcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   235
        case LONG: return LONGcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   236
        case FLOAT: return FLOATcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   237
        case DOUBLE: return DOUBLEcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   238
        case BOOLEAN: return BYTEcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   239
        case VOID: return VOIDcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   240
        case CLASS:
06bc494ca11e Initial load
duke
parents:
diff changeset
   241
        case ARRAY:
06bc494ca11e Initial load
duke
parents:
diff changeset
   242
        case METHOD:
06bc494ca11e Initial load
duke
parents:
diff changeset
   243
        case BOT:
06bc494ca11e Initial load
duke
parents:
diff changeset
   244
        case TYPEVAR:
06bc494ca11e Initial load
duke
parents:
diff changeset
   245
        case UNINITIALIZED_THIS:
06bc494ca11e Initial load
duke
parents:
diff changeset
   246
        case UNINITIALIZED_OBJECT:
06bc494ca11e Initial load
duke
parents:
diff changeset
   247
            return OBJECTcode;
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
   248
        default: throw new AssertionError("typecode " + type.getTag());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   249
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   250
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   251
06bc494ca11e Initial load
duke
parents:
diff changeset
   252
    /** Collapse type code for subtypes of int to INTcode.
06bc494ca11e Initial load
duke
parents:
diff changeset
   253
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   254
    public static int truncate(int tc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   255
        switch (tc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   256
        case BYTEcode: case SHORTcode: case CHARcode: return INTcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
   257
        default: return tc;
06bc494ca11e Initial load
duke
parents:
diff changeset
   258
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   259
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   260
06bc494ca11e Initial load
duke
parents:
diff changeset
   261
    /** The width in bytes of objects of the type.
06bc494ca11e Initial load
duke
parents:
diff changeset
   262
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   263
    public static int width(int typecode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   264
        switch (typecode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   265
        case LONGcode: case DOUBLEcode: return 2;
06bc494ca11e Initial load
duke
parents:
diff changeset
   266
        case VOIDcode: return 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   267
        default: return 1;
06bc494ca11e Initial load
duke
parents:
diff changeset
   268
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   269
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   270
06bc494ca11e Initial load
duke
parents:
diff changeset
   271
    public static int width(Type type) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   272
        return type == null ? 1 : width(typecode(type));
06bc494ca11e Initial load
duke
parents:
diff changeset
   273
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   274
06bc494ca11e Initial load
duke
parents:
diff changeset
   275
    /** The total width taken up by a vector of objects.
06bc494ca11e Initial load
duke
parents:
diff changeset
   276
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   277
    public static int width(List<Type> types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   278
        int w = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   279
        for (List<Type> l = types; l.nonEmpty(); l = l.tail)
06bc494ca11e Initial load
duke
parents:
diff changeset
   280
            w = w + width(l.head);
06bc494ca11e Initial load
duke
parents:
diff changeset
   281
        return w;
06bc494ca11e Initial load
duke
parents:
diff changeset
   282
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   283
06bc494ca11e Initial load
duke
parents:
diff changeset
   284
    /** Given a type, return its code for allocating arrays of that type.
06bc494ca11e Initial load
duke
parents:
diff changeset
   285
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   286
    public static int arraycode(Type type) {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
   287
        switch (type.getTag()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   288
        case BYTE: return 8;
06bc494ca11e Initial load
duke
parents:
diff changeset
   289
        case BOOLEAN: return 4;
06bc494ca11e Initial load
duke
parents:
diff changeset
   290
        case SHORT: return 9;
06bc494ca11e Initial load
duke
parents:
diff changeset
   291
        case CHAR: return 5;
06bc494ca11e Initial load
duke
parents:
diff changeset
   292
        case INT: return 10;
06bc494ca11e Initial load
duke
parents:
diff changeset
   293
        case LONG: return 11;
06bc494ca11e Initial load
duke
parents:
diff changeset
   294
        case FLOAT: return 6;
06bc494ca11e Initial load
duke
parents:
diff changeset
   295
        case DOUBLE: return 7;
06bc494ca11e Initial load
duke
parents:
diff changeset
   296
        case CLASS: return 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   297
        case ARRAY: return 1;
06bc494ca11e Initial load
duke
parents:
diff changeset
   298
        default: throw new AssertionError("arraycode " + type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   299
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   300
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   301
06bc494ca11e Initial load
duke
parents:
diff changeset
   302
06bc494ca11e Initial load
duke
parents:
diff changeset
   303
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
   304
 * Emit code
06bc494ca11e Initial load
duke
parents:
diff changeset
   305
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
   306
06bc494ca11e Initial load
duke
parents:
diff changeset
   307
    /** The current output code pointer.
06bc494ca11e Initial load
duke
parents:
diff changeset
   308
     */
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   309
    public int curCP() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   310
        /*
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   311
         * This method has side-effects because calling it can indirectly provoke
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   312
         *  extra code generation, like goto instructions, depending on the context
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   313
         *  where it's called.
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   314
         *  Use with care or even better avoid using it.
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   315
         */
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   316
        if (pendingJumps != null) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   317
            resolvePending();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   318
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   319
        if (pendingStatPos != Position.NOPOS) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   320
            markStatBegin();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
   321
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   322
        fixedPc = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   323
        return cp;
06bc494ca11e Initial load
duke
parents:
diff changeset
   324
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   325
06bc494ca11e Initial load
duke
parents:
diff changeset
   326
    /** Emit a byte of code.
06bc494ca11e Initial load
duke
parents:
diff changeset
   327
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   328
    private  void emit1(int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   329
        if (!alive) return;
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
   330
        code = ArrayUtils.ensureCapacity(code, cp);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   331
        code[cp++] = (byte)od;
06bc494ca11e Initial load
duke
parents:
diff changeset
   332
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   333
06bc494ca11e Initial load
duke
parents:
diff changeset
   334
    /** Emit two bytes of code.
06bc494ca11e Initial load
duke
parents:
diff changeset
   335
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   336
    private void emit2(int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   337
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   338
        if (cp + 2 > code.length) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   339
            emit1(od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
   340
            emit1(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   341
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   342
            code[cp++] = (byte)(od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
   343
            code[cp++] = (byte)od;
06bc494ca11e Initial load
duke
parents:
diff changeset
   344
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   345
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   346
06bc494ca11e Initial load
duke
parents:
diff changeset
   347
    /** Emit four bytes of code.
06bc494ca11e Initial load
duke
parents:
diff changeset
   348
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   349
    public void emit4(int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   350
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   351
        if (cp + 4 > code.length) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   352
            emit1(od >> 24);
06bc494ca11e Initial load
duke
parents:
diff changeset
   353
            emit1(od >> 16);
06bc494ca11e Initial load
duke
parents:
diff changeset
   354
            emit1(od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
   355
            emit1(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   356
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   357
            code[cp++] = (byte)(od >> 24);
06bc494ca11e Initial load
duke
parents:
diff changeset
   358
            code[cp++] = (byte)(od >> 16);
06bc494ca11e Initial load
duke
parents:
diff changeset
   359
            code[cp++] = (byte)(od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
   360
            code[cp++] = (byte)od;
06bc494ca11e Initial load
duke
parents:
diff changeset
   361
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   362
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   363
06bc494ca11e Initial load
duke
parents:
diff changeset
   364
    /** Emit an opcode.
06bc494ca11e Initial load
duke
parents:
diff changeset
   365
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   366
    private void emitop(int op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   367
        if (pendingJumps != null) resolvePending();
06bc494ca11e Initial load
duke
parents:
diff changeset
   368
        if (alive) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   369
            if (pendingStatPos != Position.NOPOS)
06bc494ca11e Initial load
duke
parents:
diff changeset
   370
                markStatBegin();
06bc494ca11e Initial load
duke
parents:
diff changeset
   371
            if (pendingStackMap) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   372
                pendingStackMap = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   373
                emitStackMap();
06bc494ca11e Initial load
duke
parents:
diff changeset
   374
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   375
            if (debugCode)
06bc494ca11e Initial load
duke
parents:
diff changeset
   376
                System.err.println("emit@" + cp + " stack=" +
06bc494ca11e Initial load
duke
parents:
diff changeset
   377
                                   state.stacksize + ": " +
06bc494ca11e Initial load
duke
parents:
diff changeset
   378
                                   mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
   379
            emit1(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   380
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   381
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   382
06bc494ca11e Initial load
duke
parents:
diff changeset
   383
    void postop() {
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
   384
        Assert.check(alive || state.stacksize == 0);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   385
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   386
16801
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   387
    /** Emit a ldc (or ldc_w) instruction, taking into account operand size
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   388
    */
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   389
    public void emitLdc(int od) {
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   390
        if (od <= 255) {
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   391
            emitop1(ldc1, od);
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   392
        }
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   393
        else {
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   394
            emitop2(ldc2, od);
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   395
        }
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   396
    }
e2de240b437f 4965689: class literal code wastes a byte
vromero
parents: 15385
diff changeset
   397
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   398
    /** Emit a multinewarray instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
   399
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   400
    public void emitMultianewarray(int ndims, int type, Type arrayType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   401
        emitop(multianewarray);
06bc494ca11e Initial load
duke
parents:
diff changeset
   402
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   403
        emit2(type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   404
        emit1(ndims);
06bc494ca11e Initial load
duke
parents:
diff changeset
   405
        state.pop(ndims);
06bc494ca11e Initial load
duke
parents:
diff changeset
   406
        state.push(arrayType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   407
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   408
06bc494ca11e Initial load
duke
parents:
diff changeset
   409
    /** Emit newarray.
06bc494ca11e Initial load
duke
parents:
diff changeset
   410
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   411
    public void emitNewarray(int elemcode, Type arrayType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   412
        emitop(newarray);
06bc494ca11e Initial load
duke
parents:
diff changeset
   413
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   414
        emit1(elemcode);
06bc494ca11e Initial load
duke
parents:
diff changeset
   415
        state.pop(1); // count
06bc494ca11e Initial load
duke
parents:
diff changeset
   416
        state.push(arrayType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   417
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   418
06bc494ca11e Initial load
duke
parents:
diff changeset
   419
    /** Emit anewarray.
06bc494ca11e Initial load
duke
parents:
diff changeset
   420
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   421
    public void emitAnewarray(int od, Type arrayType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   422
        emitop(anewarray);
06bc494ca11e Initial load
duke
parents:
diff changeset
   423
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   424
        emit2(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   425
        state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   426
        state.push(arrayType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   427
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   428
06bc494ca11e Initial load
duke
parents:
diff changeset
   429
    /** Emit an invokeinterface instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
   430
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   431
    public void emitInvokeinterface(int meth, Type mtype) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   432
        int argsize = width(mtype.getParameterTypes());
06bc494ca11e Initial load
duke
parents:
diff changeset
   433
        emitop(invokeinterface);
06bc494ca11e Initial load
duke
parents:
diff changeset
   434
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   435
        emit2(meth);
06bc494ca11e Initial load
duke
parents:
diff changeset
   436
        emit1(argsize + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   437
        emit1(0);
06bc494ca11e Initial load
duke
parents:
diff changeset
   438
        state.pop(argsize + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   439
        state.push(mtype.getReturnType());
06bc494ca11e Initial load
duke
parents:
diff changeset
   440
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   441
06bc494ca11e Initial load
duke
parents:
diff changeset
   442
    /** Emit an invokespecial instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
   443
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   444
    public void emitInvokespecial(int meth, Type mtype) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   445
        int argsize = width(mtype.getParameterTypes());
06bc494ca11e Initial load
duke
parents:
diff changeset
   446
        emitop(invokespecial);
06bc494ca11e Initial load
duke
parents:
diff changeset
   447
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   448
        emit2(meth);
06bc494ca11e Initial load
duke
parents:
diff changeset
   449
        Symbol sym = (Symbol)pool.pool[meth];
06bc494ca11e Initial load
duke
parents:
diff changeset
   450
        state.pop(argsize);
06bc494ca11e Initial load
duke
parents:
diff changeset
   451
        if (sym.isConstructor())
06bc494ca11e Initial load
duke
parents:
diff changeset
   452
            state.markInitialized((UninitializedType)state.peek());
06bc494ca11e Initial load
duke
parents:
diff changeset
   453
        state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   454
        state.push(mtype.getReturnType());
06bc494ca11e Initial load
duke
parents:
diff changeset
   455
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   456
06bc494ca11e Initial load
duke
parents:
diff changeset
   457
    /** Emit an invokestatic instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
   458
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   459
    public void emitInvokestatic(int meth, Type mtype) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   460
        int argsize = width(mtype.getParameterTypes());
06bc494ca11e Initial load
duke
parents:
diff changeset
   461
        emitop(invokestatic);
06bc494ca11e Initial load
duke
parents:
diff changeset
   462
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   463
        emit2(meth);
06bc494ca11e Initial load
duke
parents:
diff changeset
   464
        state.pop(argsize);
06bc494ca11e Initial load
duke
parents:
diff changeset
   465
        state.push(mtype.getReturnType());
06bc494ca11e Initial load
duke
parents:
diff changeset
   466
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   467
06bc494ca11e Initial load
duke
parents:
diff changeset
   468
    /** Emit an invokevirtual instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
   469
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   470
    public void emitInvokevirtual(int meth, Type mtype) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   471
        int argsize = width(mtype.getParameterTypes());
06bc494ca11e Initial load
duke
parents:
diff changeset
   472
        emitop(invokevirtual);
06bc494ca11e Initial load
duke
parents:
diff changeset
   473
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   474
        emit2(meth);
06bc494ca11e Initial load
duke
parents:
diff changeset
   475
        state.pop(argsize + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   476
        state.push(mtype.getReturnType());
06bc494ca11e Initial load
duke
parents:
diff changeset
   477
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   478
2723
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   479
    /** Emit an invokedynamic instruction.
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   480
     */
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   481
    public void emitInvokedynamic(int desc, Type mtype) {
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   482
        int argsize = width(mtype.getParameterTypes());
21711
1118b43b5111 8027142: Invokedynamic instructions don't get line number table entries
jlahoda
parents: 21703
diff changeset
   483
        emitop(invokedynamic);
2723
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   484
        if (!alive) return;
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   485
        emit2(desc);
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   486
        emit2(0);
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   487
        state.pop(argsize);
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   488
        state.push(mtype.getReturnType());
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   489
    }
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
   490
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   491
    /** Emit an opcode with no operand field.
06bc494ca11e Initial load
duke
parents:
diff changeset
   492
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   493
    public void emitop0(int op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   494
        emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   495
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   496
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   497
        case aaload: {
06bc494ca11e Initial load
duke
parents:
diff changeset
   498
            state.pop(1);// index
06bc494ca11e Initial load
duke
parents:
diff changeset
   499
            Type a = state.stack[state.stacksize-1];
29777
95a89a2efd89 7040592: Gen.java: fix code for handling 'null' literal when expected type is array
sadayapalam
parents: 29772
diff changeset
   500
            Assert.check(!a.hasTag(BOT)); // null type as is cannot be indexed.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   501
            state.pop(1);
29777
95a89a2efd89 7040592: Gen.java: fix code for handling 'null' literal when expected type is array
sadayapalam
parents: 29772
diff changeset
   502
            state.push(types.erasure(types.elemtype(a))); }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   503
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   504
        case goto_:
06bc494ca11e Initial load
duke
parents:
diff changeset
   505
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   506
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   507
        case nop:
06bc494ca11e Initial load
duke
parents:
diff changeset
   508
        case ineg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   509
        case lneg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   510
        case fneg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   511
        case dneg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   512
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   513
        case aconst_null:
06bc494ca11e Initial load
duke
parents:
diff changeset
   514
            state.push(syms.botType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   515
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   516
        case iconst_m1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   517
        case iconst_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   518
        case iconst_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   519
        case iconst_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   520
        case iconst_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   521
        case iconst_4:
06bc494ca11e Initial load
duke
parents:
diff changeset
   522
        case iconst_5:
06bc494ca11e Initial load
duke
parents:
diff changeset
   523
        case iload_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   524
        case iload_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   525
        case iload_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   526
        case iload_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   527
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   528
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   529
        case lconst_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   530
        case lconst_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   531
        case lload_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   532
        case lload_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   533
        case lload_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   534
        case lload_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   535
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   536
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   537
        case fconst_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   538
        case fconst_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   539
        case fconst_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   540
        case fload_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   541
        case fload_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   542
        case fload_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   543
        case fload_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   544
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   545
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   546
        case dconst_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   547
        case dconst_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   548
        case dload_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   549
        case dload_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   550
        case dload_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   551
        case dload_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   552
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   553
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   554
        case aload_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   555
            state.push(lvar[0].sym.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   556
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   557
        case aload_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   558
            state.push(lvar[1].sym.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   559
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   560
        case aload_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   561
            state.push(lvar[2].sym.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   562
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   563
        case aload_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   564
            state.push(lvar[3].sym.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   565
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   566
        case iaload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   567
        case baload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   568
        case caload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   569
        case saload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   570
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   571
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   572
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   573
        case laload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   574
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   575
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   576
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   577
        case faload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   578
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   579
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   580
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   581
        case daload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   582
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   583
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   584
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   585
        case istore_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   586
        case istore_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   587
        case istore_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   588
        case istore_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   589
        case fstore_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   590
        case fstore_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   591
        case fstore_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   592
        case fstore_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   593
        case astore_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   594
        case astore_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   595
        case astore_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   596
        case astore_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   597
        case pop:
06bc494ca11e Initial load
duke
parents:
diff changeset
   598
        case lshr:
06bc494ca11e Initial load
duke
parents:
diff changeset
   599
        case lshl:
06bc494ca11e Initial load
duke
parents:
diff changeset
   600
        case lushr:
06bc494ca11e Initial load
duke
parents:
diff changeset
   601
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   602
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   603
        case areturn:
06bc494ca11e Initial load
duke
parents:
diff changeset
   604
        case ireturn:
06bc494ca11e Initial load
duke
parents:
diff changeset
   605
        case freturn:
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
   606
            Assert.check(state.nlocks == 0);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   607
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   608
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   609
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   610
        case athrow:
06bc494ca11e Initial load
duke
parents:
diff changeset
   611
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   612
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   613
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   614
        case lstore_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   615
        case lstore_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   616
        case lstore_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   617
        case lstore_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   618
        case dstore_0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   619
        case dstore_1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   620
        case dstore_2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   621
        case dstore_3:
06bc494ca11e Initial load
duke
parents:
diff changeset
   622
        case pop2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   623
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   624
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   625
        case lreturn:
06bc494ca11e Initial load
duke
parents:
diff changeset
   626
        case dreturn:
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
   627
            Assert.check(state.nlocks == 0);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   628
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   629
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   630
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   631
        case dup:
06bc494ca11e Initial load
duke
parents:
diff changeset
   632
            state.push(state.stack[state.stacksize-1]);
06bc494ca11e Initial load
duke
parents:
diff changeset
   633
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   634
        case return_:
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
   635
            Assert.check(state.nlocks == 0);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   636
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   637
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   638
        case arraylength:
06bc494ca11e Initial load
duke
parents:
diff changeset
   639
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   640
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   641
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   642
        case isub:
06bc494ca11e Initial load
duke
parents:
diff changeset
   643
        case iadd:
06bc494ca11e Initial load
duke
parents:
diff changeset
   644
        case imul:
06bc494ca11e Initial load
duke
parents:
diff changeset
   645
        case idiv:
06bc494ca11e Initial load
duke
parents:
diff changeset
   646
        case imod:
06bc494ca11e Initial load
duke
parents:
diff changeset
   647
        case ishl:
06bc494ca11e Initial load
duke
parents:
diff changeset
   648
        case ishr:
06bc494ca11e Initial load
duke
parents:
diff changeset
   649
        case iushr:
06bc494ca11e Initial load
duke
parents:
diff changeset
   650
        case iand:
06bc494ca11e Initial load
duke
parents:
diff changeset
   651
        case ior:
06bc494ca11e Initial load
duke
parents:
diff changeset
   652
        case ixor:
06bc494ca11e Initial load
duke
parents:
diff changeset
   653
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   654
            // state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   655
            // state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   656
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   657
        case aastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   658
            state.pop(3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   659
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   660
        case land:
06bc494ca11e Initial load
duke
parents:
diff changeset
   661
        case lor:
06bc494ca11e Initial load
duke
parents:
diff changeset
   662
        case lxor:
06bc494ca11e Initial load
duke
parents:
diff changeset
   663
        case lmod:
06bc494ca11e Initial load
duke
parents:
diff changeset
   664
        case ldiv:
06bc494ca11e Initial load
duke
parents:
diff changeset
   665
        case lmul:
06bc494ca11e Initial load
duke
parents:
diff changeset
   666
        case lsub:
06bc494ca11e Initial load
duke
parents:
diff changeset
   667
        case ladd:
06bc494ca11e Initial load
duke
parents:
diff changeset
   668
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   669
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   670
        case lcmp:
06bc494ca11e Initial load
duke
parents:
diff changeset
   671
            state.pop(4);
06bc494ca11e Initial load
duke
parents:
diff changeset
   672
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   673
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   674
        case l2i:
06bc494ca11e Initial load
duke
parents:
diff changeset
   675
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   676
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   677
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   678
        case i2l:
06bc494ca11e Initial load
duke
parents:
diff changeset
   679
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   680
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   681
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   682
        case i2f:
06bc494ca11e Initial load
duke
parents:
diff changeset
   683
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   684
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   685
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   686
        case i2d:
06bc494ca11e Initial load
duke
parents:
diff changeset
   687
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   690
        case l2f:
06bc494ca11e Initial load
duke
parents:
diff changeset
   691
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   692
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   693
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   694
        case l2d:
06bc494ca11e Initial load
duke
parents:
diff changeset
   695
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   697
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
        case f2i:
06bc494ca11e Initial load
duke
parents:
diff changeset
   699
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   702
        case f2l:
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   704
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   705
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   706
        case f2d:
06bc494ca11e Initial load
duke
parents:
diff changeset
   707
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   708
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   709
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   710
        case d2i:
06bc494ca11e Initial load
duke
parents:
diff changeset
   711
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   712
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   713
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   714
        case d2l:
06bc494ca11e Initial load
duke
parents:
diff changeset
   715
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   716
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   717
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   718
        case d2f:
06bc494ca11e Initial load
duke
parents:
diff changeset
   719
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   720
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   721
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   722
        case tableswitch:
06bc494ca11e Initial load
duke
parents:
diff changeset
   723
        case lookupswitch:
06bc494ca11e Initial load
duke
parents:
diff changeset
   724
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   725
            // the caller is responsible for patching up the state
06bc494ca11e Initial load
duke
parents:
diff changeset
   726
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   727
        case dup_x1: {
06bc494ca11e Initial load
duke
parents:
diff changeset
   728
            Type val1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   729
            Type val2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   730
            state.push(val1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   731
            state.push(val2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   732
            state.push(val1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   733
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   734
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   735
        case bastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   736
            state.pop(3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   737
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   738
        case int2byte:
06bc494ca11e Initial load
duke
parents:
diff changeset
   739
        case int2char:
06bc494ca11e Initial load
duke
parents:
diff changeset
   740
        case int2short:
06bc494ca11e Initial load
duke
parents:
diff changeset
   741
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   742
        case fmul:
06bc494ca11e Initial load
duke
parents:
diff changeset
   743
        case fadd:
06bc494ca11e Initial load
duke
parents:
diff changeset
   744
        case fsub:
06bc494ca11e Initial load
duke
parents:
diff changeset
   745
        case fdiv:
06bc494ca11e Initial load
duke
parents:
diff changeset
   746
        case fmod:
06bc494ca11e Initial load
duke
parents:
diff changeset
   747
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   748
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   749
        case castore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   750
        case iastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   751
        case fastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   752
        case sastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   753
            state.pop(3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   754
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   755
        case lastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   756
        case dastore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   757
            state.pop(4);
06bc494ca11e Initial load
duke
parents:
diff changeset
   758
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   759
        case dup2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   760
            if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   761
                Type value1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   762
                Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   763
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   764
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   765
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   766
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   767
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   768
                Type value = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   769
                state.push(value);
06bc494ca11e Initial load
duke
parents:
diff changeset
   770
                state.push(value);
06bc494ca11e Initial load
duke
parents:
diff changeset
   771
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   772
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   773
        case dup2_x1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   774
            if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   775
                Type value1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   776
                Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   777
                Type value3 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   778
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   779
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   780
                state.push(value3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   781
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   782
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   783
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   784
                Type value1 = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   785
                Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   786
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   787
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   788
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   789
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   790
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   791
        case dup2_x2:
06bc494ca11e Initial load
duke
parents:
diff changeset
   792
            if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   793
                Type value1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   794
                Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   795
                if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   796
                    // form 1
06bc494ca11e Initial load
duke
parents:
diff changeset
   797
                    Type value3 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   798
                    Type value4 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   799
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   800
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   801
                    state.push(value4);
06bc494ca11e Initial load
duke
parents:
diff changeset
   802
                    state.push(value3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   803
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   804
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   805
                } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   806
                    // form 3
06bc494ca11e Initial load
duke
parents:
diff changeset
   807
                    Type value3 = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   808
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   809
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   810
                    state.push(value3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   811
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   812
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   813
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   814
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   815
                Type value1 = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   816
                if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   817
                    // form 2
06bc494ca11e Initial load
duke
parents:
diff changeset
   818
                    Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   819
                    Type value3 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   820
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   821
                    state.push(value3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   822
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   823
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   824
                } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   825
                    // form 4
06bc494ca11e Initial load
duke
parents:
diff changeset
   826
                    Type value2 = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   827
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   828
                    state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   829
                    state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   830
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   831
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   832
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   833
        case dup_x2: {
06bc494ca11e Initial load
duke
parents:
diff changeset
   834
            Type value1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   835
            if (state.stack[state.stacksize-1] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   836
                // form 1
06bc494ca11e Initial load
duke
parents:
diff changeset
   837
                Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   838
                Type value3 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   839
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   840
                state.push(value3);
06bc494ca11e Initial load
duke
parents:
diff changeset
   841
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   842
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   843
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   844
                // form 2
06bc494ca11e Initial load
duke
parents:
diff changeset
   845
                Type value2 = state.pop2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   846
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   847
                state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   848
                state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   849
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   850
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   851
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   852
        case fcmpl:
06bc494ca11e Initial load
duke
parents:
diff changeset
   853
        case fcmpg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   854
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   855
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   856
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   857
        case dcmpl:
06bc494ca11e Initial load
duke
parents:
diff changeset
   858
        case dcmpg:
06bc494ca11e Initial load
duke
parents:
diff changeset
   859
            state.pop(4);
06bc494ca11e Initial load
duke
parents:
diff changeset
   860
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   861
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   862
        case swap: {
06bc494ca11e Initial load
duke
parents:
diff changeset
   863
            Type value1 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   864
            Type value2 = state.pop1();
06bc494ca11e Initial load
duke
parents:
diff changeset
   865
            state.push(value1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   866
            state.push(value2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   867
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   868
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   869
        case dadd:
06bc494ca11e Initial load
duke
parents:
diff changeset
   870
        case dsub:
06bc494ca11e Initial load
duke
parents:
diff changeset
   871
        case dmul:
06bc494ca11e Initial load
duke
parents:
diff changeset
   872
        case ddiv:
06bc494ca11e Initial load
duke
parents:
diff changeset
   873
        case dmod:
06bc494ca11e Initial load
duke
parents:
diff changeset
   874
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   875
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   876
        case ret:
06bc494ca11e Initial load
duke
parents:
diff changeset
   877
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   878
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   879
        case wide:
06bc494ca11e Initial load
duke
parents:
diff changeset
   880
            // must be handled by the caller.
06bc494ca11e Initial load
duke
parents:
diff changeset
   881
            return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   882
        case monitorenter:
06bc494ca11e Initial load
duke
parents:
diff changeset
   883
        case monitorexit:
06bc494ca11e Initial load
duke
parents:
diff changeset
   884
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   885
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   886
06bc494ca11e Initial load
duke
parents:
diff changeset
   887
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   888
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
   889
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   890
        postop();
06bc494ca11e Initial load
duke
parents:
diff changeset
   891
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   892
06bc494ca11e Initial load
duke
parents:
diff changeset
   893
    /** Emit an opcode with a one-byte operand field.
06bc494ca11e Initial load
duke
parents:
diff changeset
   894
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   895
    public void emitop1(int op, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   896
        emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   897
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   898
        emit1(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   899
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   900
        case bipush:
06bc494ca11e Initial load
duke
parents:
diff changeset
   901
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   902
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   903
        case ldc1:
06bc494ca11e Initial load
duke
parents:
diff changeset
   904
            state.push(typeForPool(pool.pool[od]));
06bc494ca11e Initial load
duke
parents:
diff changeset
   905
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   906
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   907
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
   908
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   909
        postop();
06bc494ca11e Initial load
duke
parents:
diff changeset
   910
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   911
06bc494ca11e Initial load
duke
parents:
diff changeset
   912
    /** The type of a constant pool entry. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   913
    private Type typeForPool(Object o) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   914
        if (o instanceof Integer) return syms.intType;
06bc494ca11e Initial load
duke
parents:
diff changeset
   915
        if (o instanceof Float) return syms.floatType;
06bc494ca11e Initial load
duke
parents:
diff changeset
   916
        if (o instanceof String) return syms.stringType;
06bc494ca11e Initial load
duke
parents:
diff changeset
   917
        if (o instanceof Long) return syms.longType;
06bc494ca11e Initial load
duke
parents:
diff changeset
   918
        if (o instanceof Double) return syms.doubleType;
06bc494ca11e Initial load
duke
parents:
diff changeset
   919
        if (o instanceof ClassSymbol) return syms.classType;
18644
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   920
        if (o instanceof Pool.MethodHandle) return syms.methodHandleType;
14949
45f43822bbde 8000518: Javac generates duplicate name_and_type constant pool entry for class BinaryOpValueExp.java
vromero
parents: 14803
diff changeset
   921
        if (o instanceof UniqueType) return typeForPool(((UniqueType)o).type);
18644
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   922
        if (o instanceof Type) {
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
   923
            Type ty = (Type) o;
18644
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   924
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   925
            if (ty instanceof Type.ArrayType) return syms.classType;
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   926
            if (ty instanceof Type.MethodType) return syms.methodTypeType;
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   927
        }
02f65c63159c 8007546: ClassCastException on JSR308 tests
emc
parents: 18010
diff changeset
   928
        throw new AssertionError("Invalid type of constant pool entry: " + o.getClass());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   929
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   930
06bc494ca11e Initial load
duke
parents:
diff changeset
   931
    /** Emit an opcode with a one-byte operand field;
06bc494ca11e Initial load
duke
parents:
diff changeset
   932
     *  widen if field does not fit in a byte.
06bc494ca11e Initial load
duke
parents:
diff changeset
   933
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   934
    public void emitop1w(int op, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   935
        if (od > 0xFF) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   936
            emitop(wide);
06bc494ca11e Initial load
duke
parents:
diff changeset
   937
            emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   938
            emit2(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   939
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   940
            emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   941
            emit1(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
   942
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   943
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   944
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   945
        case iload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   946
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   947
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   948
        case lload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   949
            state.push(syms.longType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   950
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   951
        case fload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   952
            state.push(syms.floatType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   953
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   954
        case dload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   955
            state.push(syms.doubleType);
06bc494ca11e Initial load
duke
parents:
diff changeset
   956
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   957
        case aload:
06bc494ca11e Initial load
duke
parents:
diff changeset
   958
            state.push(lvar[od].sym.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   959
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   960
        case lstore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   961
        case dstore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   962
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   963
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   964
        case istore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   965
        case fstore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   966
        case astore:
06bc494ca11e Initial load
duke
parents:
diff changeset
   967
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   968
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   969
        case ret:
06bc494ca11e Initial load
duke
parents:
diff changeset
   970
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
   971
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   972
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   973
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
   974
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   975
        postop();
06bc494ca11e Initial load
duke
parents:
diff changeset
   976
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   977
06bc494ca11e Initial load
duke
parents:
diff changeset
   978
    /** Emit an opcode with two one-byte operand fields;
06bc494ca11e Initial load
duke
parents:
diff changeset
   979
     *  widen if either field does not fit in a byte.
06bc494ca11e Initial load
duke
parents:
diff changeset
   980
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   981
    public void emitop1w(int op, int od1, int od2) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   982
        if (od1 > 0xFF || od2 < -128 || od2 > 127) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   983
            emitop(wide);
06bc494ca11e Initial load
duke
parents:
diff changeset
   984
            emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   985
            emit2(od1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   986
            emit2(od2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   987
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   988
            emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
   989
            emit1(od1);
06bc494ca11e Initial load
duke
parents:
diff changeset
   990
            emit1(od2);
06bc494ca11e Initial load
duke
parents:
diff changeset
   991
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   992
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
   993
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   994
        case iinc:
06bc494ca11e Initial load
duke
parents:
diff changeset
   995
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   996
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   997
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
   998
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   999
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1000
06bc494ca11e Initial load
duke
parents:
diff changeset
  1001
    /** Emit an opcode with a two-byte operand field.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1002
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1003
    public void emitop2(int op, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1004
        emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1005
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1006
        emit2(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1007
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1008
        case getstatic:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1009
            state.push(((Symbol)(pool.pool[od])).erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1010
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1011
        case putstatic:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1012
            state.pop(((Symbol)(pool.pool[od])).erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1013
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1014
        case new_:
17578
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1015
            Symbol sym;
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1016
            if (pool.pool[od] instanceof UniqueType) {
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1017
                // Required by change in Gen.makeRef to allow
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1018
                // annotated types.
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1019
                // TODO: is this needed anywhere else?
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1020
                sym = ((UniqueType)(pool.pool[od])).type.tsym;
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1021
            } else {
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1022
                sym = (Symbol)(pool.pool[od]);
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1023
            }
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  1024
            state.push(uninitializedObject(sym.erasure(types), cp-3));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1025
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1026
        case sipush:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1027
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1028
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1029
        case if_acmp_null:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1030
        case if_acmp_nonnull:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1031
        case ifeq:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1032
        case ifne:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1033
        case iflt:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1034
        case ifge:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1035
        case ifgt:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1036
        case ifle:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1037
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1038
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1039
        case if_icmpeq:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1040
        case if_icmpne:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1041
        case if_icmplt:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1042
        case if_icmpge:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1043
        case if_icmpgt:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1044
        case if_icmple:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1045
        case if_acmpeq:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1046
        case if_acmpne:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1047
            state.pop(2);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1048
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1049
        case goto_:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1050
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1051
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1052
        case putfield:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1053
            state.pop(((Symbol)(pool.pool[od])).erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1054
            state.pop(1); // object ref
06bc494ca11e Initial load
duke
parents:
diff changeset
  1055
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1056
        case getfield:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1057
            state.pop(1); // object ref
06bc494ca11e Initial load
duke
parents:
diff changeset
  1058
            state.push(((Symbol)(pool.pool[od])).erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1059
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1060
        case checkcast: {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1061
            state.pop(1); // object ref
06bc494ca11e Initial load
duke
parents:
diff changeset
  1062
            Object o = pool.pool[od];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1063
            Type t = (o instanceof Symbol)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1064
                ? ((Symbol)o).erasure(types)
14949
45f43822bbde 8000518: Javac generates duplicate name_and_type constant pool entry for class BinaryOpValueExp.java
vromero
parents: 14803
diff changeset
  1065
                : types.erasure((((UniqueType)o).type));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1066
            state.push(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1067
            break; }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1068
        case ldc2w:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1069
            state.push(typeForPool(pool.pool[od]));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1070
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1071
        case instanceof_:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1072
            state.pop(1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1073
            state.push(syms.intType);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1074
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1075
        case ldc2:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1076
            state.push(typeForPool(pool.pool[od]));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1077
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1078
        case jsr:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1079
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1080
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1081
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1082
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1083
        // postop();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1084
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1085
06bc494ca11e Initial load
duke
parents:
diff changeset
  1086
    /** Emit an opcode with a four-byte operand field.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1087
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1088
    public void emitop4(int op, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1089
        emitop(op);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1090
        if (!alive) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1091
        emit4(od);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1092
        switch (op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1093
        case goto_w:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1094
            markDead();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1095
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1096
        case jsr_w:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1097
            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1098
        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1099
            throw new AssertionError(mnem(op));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1100
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1101
        // postop();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1102
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1103
06bc494ca11e Initial load
duke
parents:
diff changeset
  1104
    /** Align code pointer to next `incr' boundary.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1105
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1106
    public void align(int incr) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1107
        if (alive)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1108
            while (cp % incr != 0) emitop0(nop);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1109
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1110
13844
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1111
    /** Place a byte into code at address pc.
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1112
     *  Pre: {@literal pc + 1 <= cp }.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1113
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1114
    private void put1(int pc, int op) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1115
        code[pc] = (byte)op;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1116
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1117
13844
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1118
    /** Place two bytes into code at address pc.
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1119
     *  Pre: {@literal pc + 2 <= cp }.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1120
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1121
    private void put2(int pc, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1122
        // pre: pc + 2 <= cp
06bc494ca11e Initial load
duke
parents:
diff changeset
  1123
        put1(pc, od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1124
        put1(pc+1, od);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1125
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1126
13844
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1127
    /** Place four  bytes into code at address pc.
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  1128
     *  Pre: {@literal pc + 4 <= cp }.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1129
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1130
    public void put4(int pc, int od) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1131
        // pre: pc + 4 <= cp
06bc494ca11e Initial load
duke
parents:
diff changeset
  1132
        put1(pc  , od >> 24);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1133
        put1(pc+1, od >> 16);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1134
        put1(pc+2, od >> 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1135
        put1(pc+3, od);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1136
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1137
06bc494ca11e Initial load
duke
parents:
diff changeset
  1138
    /** Return code byte at position pc as an unsigned int.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1139
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1140
    private int get1(int pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1141
        return code[pc] & 0xFF;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1142
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1143
06bc494ca11e Initial load
duke
parents:
diff changeset
  1144
    /** Return two code bytes at position pc as an unsigned int.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1145
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1146
    private int get2(int pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1147
        return (get1(pc) << 8) | get1(pc+1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1148
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1149
06bc494ca11e Initial load
duke
parents:
diff changeset
  1150
    /** Return four code bytes at position pc as an int.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1151
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1152
    public int get4(int pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1153
        // pre: pc + 4 <= cp
06bc494ca11e Initial load
duke
parents:
diff changeset
  1154
        return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1155
            (get1(pc) << 24) |
06bc494ca11e Initial load
duke
parents:
diff changeset
  1156
            (get1(pc+1) << 16) |
06bc494ca11e Initial load
duke
parents:
diff changeset
  1157
            (get1(pc+2) << 8) |
06bc494ca11e Initial load
duke
parents:
diff changeset
  1158
            (get1(pc+3));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1159
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1160
06bc494ca11e Initial load
duke
parents:
diff changeset
  1161
    /** Is code generation currently enabled?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1162
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1163
    public boolean isAlive() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1164
        return alive || pendingJumps != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1165
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1166
06bc494ca11e Initial load
duke
parents:
diff changeset
  1167
    /** Switch code generation on/off.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1168
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1169
    public void markDead() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1170
        alive = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1171
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1172
06bc494ca11e Initial load
duke
parents:
diff changeset
  1173
    /** Declare an entry point; return current code pointer
06bc494ca11e Initial load
duke
parents:
diff changeset
  1174
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1175
    public int entryPoint() {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1176
        int pc = curCP();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1177
        alive = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1178
        pendingStackMap = needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1179
        return pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1180
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1181
06bc494ca11e Initial load
duke
parents:
diff changeset
  1182
    /** Declare an entry point with initial state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1183
     *  return current code pointer
06bc494ca11e Initial load
duke
parents:
diff changeset
  1184
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1185
    public int entryPoint(State state) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1186
        int pc = curCP();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1187
        alive = true;
28330
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1188
        State newState = state.dup();
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1189
        setDefined(newState.defined);
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1190
        this.state = newState;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1191
        Assert.check(state.stacksize <= max_stack);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1192
        if (debugCode) System.err.println("entry point " + state);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1193
        pendingStackMap = needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1194
        return pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1195
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1196
06bc494ca11e Initial load
duke
parents:
diff changeset
  1197
    /** Declare an entry point with initial state plus a pushed value;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1198
     *  return current code pointer
06bc494ca11e Initial load
duke
parents:
diff changeset
  1199
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1200
    public int entryPoint(State state, Type pushed) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1201
        int pc = curCP();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1202
        alive = true;
28330
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1203
        State newState = state.dup();
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1204
        setDefined(newState.defined);
d4bcdcac1211 8064857: javac generates LVT entry with length 0 for local variable
vromero
parents: 27227
diff changeset
  1205
        this.state = newState;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1206
        Assert.check(state.stacksize <= max_stack);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1207
        this.state.push(pushed);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1208
        if (debugCode) System.err.println("entry point " + state);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1209
        pendingStackMap = needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1210
        return pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1211
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1212
06bc494ca11e Initial load
duke
parents:
diff changeset
  1213
06bc494ca11e Initial load
duke
parents:
diff changeset
  1214
/**************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1215
 * Stack map generation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1216
 *************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1217
06bc494ca11e Initial load
duke
parents:
diff changeset
  1218
    /** An entry in the stack map. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1219
    static class StackMapFrame {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1220
        int pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1221
        Type[] locals;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1222
        Type[] stack;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1223
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1224
06bc494ca11e Initial load
duke
parents:
diff changeset
  1225
    /** A buffer of cldc stack map entries. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1226
    StackMapFrame[] stackMapBuffer = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1227
06bc494ca11e Initial load
duke
parents:
diff changeset
  1228
    /** A buffer of compressed StackMapTable entries. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1229
    StackMapTableFrame[] stackMapTableBuffer = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1230
    int stackMapBufferSize = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1231
06bc494ca11e Initial load
duke
parents:
diff changeset
  1232
    /** The last PC at which we generated a stack map. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1233
    int lastStackMapPC = -1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1234
06bc494ca11e Initial load
duke
parents:
diff changeset
  1235
    /** The last stack map frame in StackMapTable. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1236
    StackMapFrame lastFrame = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1237
06bc494ca11e Initial load
duke
parents:
diff changeset
  1238
    /** The stack map frame before the last one. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1239
    StackMapFrame frameBeforeLast = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1240
06bc494ca11e Initial load
duke
parents:
diff changeset
  1241
    /** Emit a stack map entry.  */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1242
    public void emitStackMap() {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1243
        int pc = curCP();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1244
        if (!needStackMap) return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1245
06bc494ca11e Initial load
duke
parents:
diff changeset
  1246
06bc494ca11e Initial load
duke
parents:
diff changeset
  1247
06bc494ca11e Initial load
duke
parents:
diff changeset
  1248
        switch (stackMap) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1249
            case CLDC:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1250
                emitCLDCStackMap(pc, getLocalsSize());
06bc494ca11e Initial load
duke
parents:
diff changeset
  1251
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1252
            case JSR202:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1253
                emitStackMapFrame(pc, getLocalsSize());
06bc494ca11e Initial load
duke
parents:
diff changeset
  1254
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1255
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1256
                throw new AssertionError("Should have chosen a stackmap format");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1257
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1258
        // DEBUG code follows
06bc494ca11e Initial load
duke
parents:
diff changeset
  1259
        if (debugCode) state.dump(pc);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1260
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1261
06bc494ca11e Initial load
duke
parents:
diff changeset
  1262
    private int getLocalsSize() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1263
        int nextLocal = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1264
        for (int i=max_locals-1; i>=0; i--) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1265
            if (state.defined.isMember(i) && lvar[i] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1266
                nextLocal = i + width(lvar[i].sym.erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1267
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1268
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1269
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1270
        return nextLocal;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1271
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1272
06bc494ca11e Initial load
duke
parents:
diff changeset
  1273
    /** Emit a CLDC stack map frame. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1274
    void emitCLDCStackMap(int pc, int localsSize) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1275
        if (lastStackMapPC == pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1276
            // drop existing stackmap at this offset
06bc494ca11e Initial load
duke
parents:
diff changeset
  1277
            stackMapBuffer[--stackMapBufferSize] = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1278
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1279
        lastStackMapPC = pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1280
06bc494ca11e Initial load
duke
parents:
diff changeset
  1281
        if (stackMapBuffer == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1282
            stackMapBuffer = new StackMapFrame[20];
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1283
        } else {
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1284
            stackMapBuffer = ArrayUtils.ensureCapacity(stackMapBuffer, stackMapBufferSize);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1285
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1286
        StackMapFrame frame =
06bc494ca11e Initial load
duke
parents:
diff changeset
  1287
            stackMapBuffer[stackMapBufferSize++] = new StackMapFrame();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1288
        frame.pc = pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1289
06bc494ca11e Initial load
duke
parents:
diff changeset
  1290
        frame.locals = new Type[localsSize];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1291
        for (int i=0; i<localsSize; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1292
            if (state.defined.isMember(i) && lvar[i] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1293
                Type vtype = lvar[i].sym.type;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1294
                if (!(vtype instanceof UninitializedType))
06bc494ca11e Initial load
duke
parents:
diff changeset
  1295
                    vtype = types.erasure(vtype);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1296
                frame.locals[i] = vtype;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1297
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1298
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1299
        frame.stack = new Type[state.stacksize];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1300
        for (int i=0; i<state.stacksize; i++)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1301
            frame.stack[i] = state.stack[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1302
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1303
06bc494ca11e Initial load
duke
parents:
diff changeset
  1304
    void emitStackMapFrame(int pc, int localsSize) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1305
        if (lastFrame == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1306
            // first frame
06bc494ca11e Initial load
duke
parents:
diff changeset
  1307
            lastFrame = getInitialFrame();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1308
        } else if (lastFrame.pc == pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1309
            // drop existing stackmap at this offset
06bc494ca11e Initial load
duke
parents:
diff changeset
  1310
            stackMapTableBuffer[--stackMapBufferSize] = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1311
            lastFrame = frameBeforeLast;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1312
            frameBeforeLast = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1313
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1314
06bc494ca11e Initial load
duke
parents:
diff changeset
  1315
        StackMapFrame frame = new StackMapFrame();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1316
        frame.pc = pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1317
06bc494ca11e Initial load
duke
parents:
diff changeset
  1318
        int localCount = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1319
        Type[] locals = new Type[localsSize];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1320
        for (int i=0; i<localsSize; i++, localCount++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1321
            if (state.defined.isMember(i) && lvar[i] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1322
                Type vtype = lvar[i].sym.type;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1323
                if (!(vtype instanceof UninitializedType))
06bc494ca11e Initial load
duke
parents:
diff changeset
  1324
                    vtype = types.erasure(vtype);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1325
                locals[i] = vtype;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1326
                if (width(vtype) > 1) i++;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1327
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1328
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1329
        frame.locals = new Type[localCount];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1330
        for (int i=0, j=0; i<localsSize; i++, j++) {
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1331
            Assert.check(j < localCount);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1332
            frame.locals[j] = locals[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1333
            if (width(locals[i]) > 1) i++;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1334
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1335
06bc494ca11e Initial load
duke
parents:
diff changeset
  1336
        int stackCount = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1337
        for (int i=0; i<state.stacksize; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1338
            if (state.stack[i] != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1339
                stackCount++;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1340
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1341
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1342
        frame.stack = new Type[stackCount];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1343
        stackCount = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1344
        for (int i=0; i<state.stacksize; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1345
            if (state.stack[i] != null) {
7215
49e5caf5b854 6999635: Multicatch: crash while compiling simple code with a multicatch parameter
mcimadamore
parents: 5847
diff changeset
  1346
                frame.stack[stackCount++] = types.erasure(state.stack[i]);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1347
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1348
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1349
06bc494ca11e Initial load
duke
parents:
diff changeset
  1350
        if (stackMapTableBuffer == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1351
            stackMapTableBuffer = new StackMapTableFrame[20];
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1352
        } else {
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1353
            stackMapTableBuffer = ArrayUtils.ensureCapacity(
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1354
                                    stackMapTableBuffer,
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1355
                                    stackMapBufferSize);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1356
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1357
        stackMapTableBuffer[stackMapBufferSize++] =
06bc494ca11e Initial load
duke
parents:
diff changeset
  1358
                StackMapTableFrame.getInstance(frame, lastFrame.pc, lastFrame.locals, types);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1359
06bc494ca11e Initial load
duke
parents:
diff changeset
  1360
        frameBeforeLast = lastFrame;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1361
        lastFrame = frame;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1362
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1363
06bc494ca11e Initial load
duke
parents:
diff changeset
  1364
    StackMapFrame getInitialFrame() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1365
        StackMapFrame frame = new StackMapFrame();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1366
        List<Type> arg_types = ((MethodType)meth.externalType(types)).argtypes;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1367
        int len = arg_types.length();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1368
        int count = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1369
        if (!meth.isStatic()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1370
            Type thisType = meth.owner.type;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1371
            frame.locals = new Type[len+1];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1372
            if (meth.isConstructor() && thisType != syms.objectType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1373
                frame.locals[count++] = UninitializedType.uninitializedThis(thisType);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1374
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1375
                frame.locals[count++] = types.erasure(thisType);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1376
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1377
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1378
            frame.locals = new Type[len];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1379
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1380
        for (Type arg_type : arg_types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1381
            frame.locals[count++] = types.erasure(arg_type);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1382
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1383
        frame.pc = -1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1384
        frame.stack = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1385
        return frame;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1386
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1387
06bc494ca11e Initial load
duke
parents:
diff changeset
  1388
06bc494ca11e Initial load
duke
parents:
diff changeset
  1389
/**************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1390
 * Operations having to do with jumps
06bc494ca11e Initial load
duke
parents:
diff changeset
  1391
 *************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1392
06bc494ca11e Initial load
duke
parents:
diff changeset
  1393
    /** A chain represents a list of unresolved jumps. Jump locations
06bc494ca11e Initial load
duke
parents:
diff changeset
  1394
     *  are sorted in decreasing order.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1395
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1396
    public static class Chain {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1397
06bc494ca11e Initial load
duke
parents:
diff changeset
  1398
        /** The position of the jump instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1399
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1400
        public final int pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1401
06bc494ca11e Initial load
duke
parents:
diff changeset
  1402
        /** The machine state after the jump instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1403
         *  Invariant: all elements of a chain list have the same stacksize
06bc494ca11e Initial load
duke
parents:
diff changeset
  1404
         *  and compatible stack and register contents.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1405
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1406
        Code.State state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1407
06bc494ca11e Initial load
duke
parents:
diff changeset
  1408
        /** The next jump in the list.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1409
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1410
        public final Chain next;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1411
06bc494ca11e Initial load
duke
parents:
diff changeset
  1412
        /** Construct a chain from its jump position, stacksize, previous
06bc494ca11e Initial load
duke
parents:
diff changeset
  1413
         *  chain, and machine state.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1414
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1415
        public Chain(int pc, Chain next, Code.State state) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1416
            this.pc = pc;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1417
            this.next = next;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1418
            this.state = state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1419
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1420
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1421
06bc494ca11e Initial load
duke
parents:
diff changeset
  1422
    /** Negate a branch opcode.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1423
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1424
    public static int negate(int opcode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1425
        if (opcode == if_acmp_null) return if_acmp_nonnull;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1426
        else if (opcode == if_acmp_nonnull) return if_acmp_null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1427
        else return ((opcode + 1) ^ 1) - 1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1428
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1429
06bc494ca11e Initial load
duke
parents:
diff changeset
  1430
    /** Emit a jump instruction.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1431
     *  Return code pointer of instruction to be patched.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1432
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1433
    public int emitJump(int opcode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1434
        if (fatcode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1435
            if (opcode == goto_ || opcode == jsr) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1436
                emitop4(opcode + goto_w - goto_, 0);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1437
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1438
                emitop2(negate(opcode), 8);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1439
                emitop4(goto_w, 0);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1440
                alive = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1441
                pendingStackMap = needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1442
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1443
            return cp - 5;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1444
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1445
            emitop2(opcode, 0);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1446
            return cp - 3;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1447
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1448
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1449
06bc494ca11e Initial load
duke
parents:
diff changeset
  1450
    /** Emit a branch with given opcode; return its chain.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1451
     *  branch differs from jump in that jsr is treated as no-op.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1452
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1453
    public Chain branch(int opcode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1454
        Chain result = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1455
        if (opcode == goto_) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1456
            result = pendingJumps;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1457
            pendingJumps = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1458
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1459
        if (opcode != dontgoto && isAlive()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1460
            result = new Chain(emitJump(opcode),
06bc494ca11e Initial load
duke
parents:
diff changeset
  1461
                               result,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1462
                               state.dup());
06bc494ca11e Initial load
duke
parents:
diff changeset
  1463
            fixedPc = fatcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1464
            if (opcode == goto_) alive = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1465
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1466
        return result;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1467
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1468
06bc494ca11e Initial load
duke
parents:
diff changeset
  1469
    /** Resolve chain to point to given target.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1470
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1471
    public void resolve(Chain chain, int target) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1472
        boolean changed = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1473
        State newState = state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1474
        for (; chain != null; chain = chain.next) {
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1475
            Assert.check(state != chain.state
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1476
                    && (target > chain.pc || state.stacksize == 0));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1477
            if (target >= cp) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1478
                target = cp;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1479
            } else if (get1(target) == goto_) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1480
                if (fatcode) target = target + get4(target + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1481
                else target = target + get2(target + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1482
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1483
            if (get1(chain.pc) == goto_ &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1484
                chain.pc + 3 == target && target == cp && !fixedPc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1485
                // If goto the next instruction, the jump is not needed:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1486
                // compact the code.
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1487
                if (varDebugInfo) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1488
                    adjustAliveRanges(cp, -3);
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1489
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1490
                cp = cp - 3;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1491
                target = target - 3;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1492
                if (chain.next == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1493
                    // This is the only jump to the target. Exit the loop
06bc494ca11e Initial load
duke
parents:
diff changeset
  1494
                    // without setting new state. The code is reachable
06bc494ca11e Initial load
duke
parents:
diff changeset
  1495
                    // from the instruction before goto_.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1496
                    alive = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1497
                    break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1498
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1499
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1500
                if (fatcode)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1501
                    put4(chain.pc + 1, target - chain.pc);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1502
                else if (target - chain.pc < Short.MIN_VALUE ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1503
                         target - chain.pc > Short.MAX_VALUE)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1504
                    fatcode = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1505
                else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1506
                    put2(chain.pc + 1, target - chain.pc);
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1507
                Assert.check(!alive ||
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1508
                    chain.state.stacksize == newState.stacksize &&
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1509
                    chain.state.nlocks == newState.nlocks);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1510
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1511
            fixedPc = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1512
            if (cp == target) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1513
                changed = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1514
                if (debugCode)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1515
                    System.err.println("resolving chain state=" + chain.state);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1516
                if (alive) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1517
                    newState = chain.state.join(newState);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1518
                } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1519
                    newState = chain.state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1520
                    alive = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1521
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1522
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1523
        }
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1524
        Assert.check(!changed || state != newState);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1525
        if (state != newState) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1526
            setDefined(newState.defined);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1527
            state = newState;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1528
            pendingStackMap = needStackMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1529
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1530
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1531
06bc494ca11e Initial load
duke
parents:
diff changeset
  1532
    /** Resolve chain to point to current code pointer.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1533
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1534
    public void resolve(Chain chain) {
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1535
        Assert.check(
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1536
            !alive ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1537
            chain==null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1538
            state.stacksize == chain.state.stacksize &&
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1539
            state.nlocks == chain.state.nlocks);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1540
        pendingJumps = mergeChains(chain, pendingJumps);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1541
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1542
06bc494ca11e Initial load
duke
parents:
diff changeset
  1543
    /** Resolve any pending jumps.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1544
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1545
    public void resolvePending() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1546
        Chain x = pendingJumps;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1547
        pendingJumps = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1548
        resolve(x, cp);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1549
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1550
06bc494ca11e Initial load
duke
parents:
diff changeset
  1551
    /** Merge the jumps in of two chains into one.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1552
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1553
    public static Chain mergeChains(Chain chain1, Chain chain2) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1554
        // recursive merge sort
06bc494ca11e Initial load
duke
parents:
diff changeset
  1555
        if (chain2 == null) return chain1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1556
        if (chain1 == null) return chain2;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1557
        Assert.check(
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1558
            chain1.state.stacksize == chain2.state.stacksize &&
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1559
            chain1.state.nlocks == chain2.state.nlocks);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1560
        if (chain1.pc < chain2.pc)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1561
            return new Chain(
06bc494ca11e Initial load
duke
parents:
diff changeset
  1562
                chain2.pc,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1563
                mergeChains(chain1, chain2.next),
06bc494ca11e Initial load
duke
parents:
diff changeset
  1564
                chain2.state);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1565
        return new Chain(
06bc494ca11e Initial load
duke
parents:
diff changeset
  1566
                chain1.pc,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1567
                mergeChains(chain1.next, chain2),
06bc494ca11e Initial load
duke
parents:
diff changeset
  1568
                chain1.state);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1569
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1570
06bc494ca11e Initial load
duke
parents:
diff changeset
  1571
06bc494ca11e Initial load
duke
parents:
diff changeset
  1572
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1573
 * Catch clauses
06bc494ca11e Initial load
duke
parents:
diff changeset
  1574
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1575
06bc494ca11e Initial load
duke
parents:
diff changeset
  1576
    /** Add a catch clause to code.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1577
     */
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  1578
    public void addCatch(char startPc, char endPc,
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  1579
                         char handlerPc, char catchType) {
10811
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1580
            catchInfo.append(new char[]{startPc, endPc, handlerPc, catchType});
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1581
        }
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1582
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1583
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1584
    public void compressCatchTable() {
20249
93f8eae31092 6386236: Please rename com.sun.tools.javac.util.ListBuffer.lb()
alundblad
parents: 19941
diff changeset
  1585
        ListBuffer<char[]> compressedCatchInfo = new ListBuffer<>();
10811
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1586
        List<Integer> handlerPcs = List.nil();
14803
88347e495d34 8004504: ListBuffer could reuse List.nil() as the sentinel element
jlahoda
parents: 14801
diff changeset
  1587
        for (char[] catchEntry : catchInfo) {
10811
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1588
            handlerPcs = handlerPcs.prepend((int)catchEntry[2]);
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1589
        }
14803
88347e495d34 8004504: ListBuffer could reuse List.nil() as the sentinel element
jlahoda
parents: 14801
diff changeset
  1590
        for (char[] catchEntry : catchInfo) {
10811
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1591
            int startpc = catchEntry[0];
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1592
            int endpc = catchEntry[1];
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1593
            if (startpc == endpc ||
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1594
                    (startpc == (endpc - 1) &&
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1595
                    handlerPcs.contains(startpc))) {
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1596
                continue;
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1597
            } else {
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1598
                compressedCatchInfo.append(catchEntry);
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1599
            }
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1600
        }
4d4ed480210e 7093325: Redundant entry in bytecode exception table
mcimadamore
parents: 9600
diff changeset
  1601
        catchInfo = compressedCatchInfo;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1602
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1603
06bc494ca11e Initial load
duke
parents:
diff changeset
  1604
06bc494ca11e Initial load
duke
parents:
diff changeset
  1605
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1606
 * Line numbers
06bc494ca11e Initial load
duke
parents:
diff changeset
  1607
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1608
06bc494ca11e Initial load
duke
parents:
diff changeset
  1609
    /** Add a line number entry.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1610
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1611
    public void addLineNumber(char startPc, char lineNumber) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1612
        if (lineDebugInfo) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1613
            if (lineInfo.nonEmpty() && lineInfo.head[0] == startPc)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1614
                lineInfo = lineInfo.tail;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1615
            if (lineInfo.isEmpty() || lineInfo.head[1] != lineNumber)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1616
                lineInfo = lineInfo.prepend(new char[]{startPc, lineNumber});
06bc494ca11e Initial load
duke
parents:
diff changeset
  1617
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1618
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1619
06bc494ca11e Initial load
duke
parents:
diff changeset
  1620
    /** Mark beginning of statement.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1621
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1622
    public void statBegin(int pos) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1623
        if (pos != Position.NOPOS) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1624
            pendingStatPos = pos;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1625
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1626
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1627
06bc494ca11e Initial load
duke
parents:
diff changeset
  1628
    /** Force stat begin eagerly
06bc494ca11e Initial load
duke
parents:
diff changeset
  1629
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1630
    public void markStatBegin() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1631
        if (alive && lineDebugInfo) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1632
            int line = lineMap.getLineNumber(pendingStatPos);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1633
            char cp1 = (char)cp;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1634
            char line1 = (char)line;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1635
            if (cp1 == cp && line1 == line)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1636
                addLineNumber(cp1, line1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1637
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1638
        pendingStatPos = Position.NOPOS;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1639
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1640
06bc494ca11e Initial load
duke
parents:
diff changeset
  1641
06bc494ca11e Initial load
duke
parents:
diff changeset
  1642
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1643
 * Simulated VM machine state
06bc494ca11e Initial load
duke
parents:
diff changeset
  1644
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1645
06bc494ca11e Initial load
duke
parents:
diff changeset
  1646
    class State implements Cloneable {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1647
        /** The set of registers containing values. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1648
        Bits defined;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1649
06bc494ca11e Initial load
duke
parents:
diff changeset
  1650
        /** The (types of the) contents of the machine stack. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1651
        Type[] stack;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1652
06bc494ca11e Initial load
duke
parents:
diff changeset
  1653
        /** The first stack position currently unused. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1654
        int stacksize;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1655
06bc494ca11e Initial load
duke
parents:
diff changeset
  1656
        /** The numbers of registers containing locked monitors. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1657
        int[] locks;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1658
        int nlocks;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1659
06bc494ca11e Initial load
duke
parents:
diff changeset
  1660
        State() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1661
            defined = new Bits();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1662
            stack = new Type[16];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1663
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1664
06bc494ca11e Initial load
duke
parents:
diff changeset
  1665
        State dup() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1666
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1667
                State state = (State)super.clone();
17282
c6964ad7df63 8008562: javac, a refactoring to Bits is necessary in order to provide a change history
vromero
parents: 16807
diff changeset
  1668
                state.defined = new Bits(defined);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1669
                state.stack = stack.clone();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1670
                if (locks != null) state.locks = locks.clone();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1671
                if (debugCode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1672
                    System.err.println("duping state " + this);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1673
                    dump();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1674
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1675
                return state;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1676
            } catch (CloneNotSupportedException ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1677
                throw new AssertionError(ex);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1678
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1679
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1680
06bc494ca11e Initial load
duke
parents:
diff changeset
  1681
        void lock(int register) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1682
            if (locks == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1683
                locks = new int[20];
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1684
            } else {
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1685
                locks = ArrayUtils.ensureCapacity(locks, nlocks);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1686
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1687
            locks[nlocks] = register;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1688
            nlocks++;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1689
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1690
06bc494ca11e Initial load
duke
parents:
diff changeset
  1691
        void unlock(int register) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1692
            nlocks--;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1693
            Assert.check(locks[nlocks] == register);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1694
            locks[nlocks] = -1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1695
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1696
06bc494ca11e Initial load
duke
parents:
diff changeset
  1697
        void push(Type t) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1698
            if (debugCode) System.err.println("   pushing " + t);
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1699
            switch (t.getTag()) {
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1700
            case VOID:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1701
                return;
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1702
            case BYTE:
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1703
            case CHAR:
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1704
            case SHORT:
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1705
            case BOOLEAN:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1706
                t = syms.intType;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1707
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1708
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1709
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1710
            }
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1711
            stack = ArrayUtils.ensureCapacity(stack, stacksize+2);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1712
            stack[stacksize++] = t;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1713
            switch (width(t)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1714
            case 1:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1715
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1716
            case 2:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1717
                stack[stacksize++] = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1718
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1719
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1720
                throw new AssertionError(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1721
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1722
            if (stacksize > max_stack)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1723
                max_stack = stacksize;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1724
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1725
06bc494ca11e Initial load
duke
parents:
diff changeset
  1726
        Type pop1() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1727
            if (debugCode) System.err.println("   popping " + 1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1728
            stacksize--;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1729
            Type result = stack[stacksize];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1730
            stack[stacksize] = null;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1731
            Assert.check(result != null && width(result) == 1);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1732
            return result;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1733
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1734
06bc494ca11e Initial load
duke
parents:
diff changeset
  1735
        Type peek() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1736
            return stack[stacksize-1];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1737
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1738
06bc494ca11e Initial load
duke
parents:
diff changeset
  1739
        Type pop2() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1740
            if (debugCode) System.err.println("   popping " + 2);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1741
            stacksize -= 2;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1742
            Type result = stack[stacksize];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1743
            stack[stacksize] = null;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1744
            Assert.check(stack[stacksize+1] == null
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1745
                    && result != null && width(result) == 2);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1746
            return result;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1747
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1748
06bc494ca11e Initial load
duke
parents:
diff changeset
  1749
        void pop(int n) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1750
            if (debugCode) System.err.println("   popping " + n);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1751
            while (n > 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1752
                stack[--stacksize] = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1753
                n--;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1754
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1755
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1756
06bc494ca11e Initial load
duke
parents:
diff changeset
  1757
        void pop(Type t) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1758
            pop(width(t));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1759
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1760
06bc494ca11e Initial load
duke
parents:
diff changeset
  1761
        /** Force the top of the stack to be treated as this supertype
06bc494ca11e Initial load
duke
parents:
diff changeset
  1762
         *  of its current type. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1763
        void forceStackTop(Type t) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1764
            if (!alive) return;
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14049
diff changeset
  1765
            switch (t.getTag()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1766
            case CLASS:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1767
            case ARRAY:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1768
                int width = width(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1769
                Type old = stack[stacksize-width];
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1770
                Assert.check(types.isSubtype(types.erasure(old),
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1771
                                       types.erasure(t)));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1772
                stack[stacksize-width] = t;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1773
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1774
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1775
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1776
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1777
06bc494ca11e Initial load
duke
parents:
diff changeset
  1778
        void markInitialized(UninitializedType old) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1779
            Type newtype = old.initializedType();
21703
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  1780
            for (int i=0; i<stacksize; i++) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1781
                if (stack[i] == old) stack[i] = newtype;
21703
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  1782
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1783
            for (int i=0; i<lvar.length; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1784
                LocalVar lv = lvar[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1785
                if (lv != null && lv.sym.type == old) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1786
                    VarSymbol sym = lv.sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1787
                    sym = sym.clone(sym.owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1788
                    sym.type = newtype;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1789
                    LocalVar newlv = lvar[i] = new LocalVar(sym);
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1790
                    newlv.aliveRanges = lv.aliveRanges;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1791
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1792
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1793
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1794
06bc494ca11e Initial load
duke
parents:
diff changeset
  1795
        State join(State other) {
17282
c6964ad7df63 8008562: javac, a refactoring to Bits is necessary in order to provide a change history
vromero
parents: 16807
diff changeset
  1796
            defined.andSet(other.defined);
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1797
            Assert.check(stacksize == other.stacksize
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1798
                    && nlocks == other.nlocks);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1799
            for (int i=0; i<stacksize; ) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1800
                Type t = stack[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1801
                Type tother = other.stack[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1802
                Type result =
06bc494ca11e Initial load
duke
parents:
diff changeset
  1803
                    t==tother ? t :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1804
                    types.isSubtype(t, tother) ? tother :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1805
                    types.isSubtype(tother, t) ? t :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1806
                    error();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1807
                int w = width(result);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1808
                stack[i] = result;
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1809
                if (w == 2) Assert.checkNull(stack[i+1]);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1810
                i += w;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1811
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1812
            return this;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1813
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1814
06bc494ca11e Initial load
duke
parents:
diff changeset
  1815
        Type error() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1816
            throw new AssertionError("inconsistent stack types at join point");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1817
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1818
06bc494ca11e Initial load
duke
parents:
diff changeset
  1819
        void dump() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1820
            dump(-1);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1821
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1822
06bc494ca11e Initial load
duke
parents:
diff changeset
  1823
        void dump(int pc) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1824
            System.err.print("stackMap for " + meth.owner + "." + meth);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1825
            if (pc == -1)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1826
                System.out.println();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1827
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1828
                System.out.println(" at " + pc);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1829
            System.err.println(" stack (from bottom):");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1830
            for (int i=0; i<stacksize; i++)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1831
                System.err.println("  " + i + ": " + stack[i]);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1832
06bc494ca11e Initial load
duke
parents:
diff changeset
  1833
            int lastLocal = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1834
            for (int i=max_locals-1; i>=0; i--) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1835
                if (defined.isMember(i)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1836
                    lastLocal = i;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1837
                    break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1838
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1839
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1840
            if (lastLocal >= 0)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1841
                System.err.println(" locals:");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1842
            for (int i=0; i<=lastLocal; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1843
                System.err.print("  " + i + ": ");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1844
                if (defined.isMember(i)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1845
                    LocalVar var = lvar[i];
06bc494ca11e Initial load
duke
parents:
diff changeset
  1846
                    if (var == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1847
                        System.err.println("(none)");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1848
                    } else if (var.sym == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1849
                        System.err.println("UNKNOWN!");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1850
                    else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1851
                        System.err.println("" + var.sym + " of type " +
06bc494ca11e Initial load
duke
parents:
diff changeset
  1852
                                           var.sym.erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1853
                } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1854
                    System.err.println("undefined");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1855
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1856
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1857
            if (nlocks != 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1858
                System.err.print(" locks:");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1859
                for (int i=0; i<nlocks; i++) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1860
                    System.err.print(" " + locks[i]);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1861
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1862
                System.err.println();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1863
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1864
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1865
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1866
18646
e628560a86d1 8017104: javac should have a class for primitive types that inherits from Type
vromero
parents: 18644
diff changeset
  1867
    static final Type jsrReturnValue = new JCPrimitiveType(INT, null);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1868
06bc494ca11e Initial load
duke
parents:
diff changeset
  1869
06bc494ca11e Initial load
duke
parents:
diff changeset
  1870
/* **************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  1871
 * Local variables
06bc494ca11e Initial load
duke
parents:
diff changeset
  1872
 ****************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  1873
06bc494ca11e Initial load
duke
parents:
diff changeset
  1874
    /** A live range of a local variable. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1875
    static class LocalVar {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1876
        final VarSymbol sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1877
        final char reg;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1878
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1879
        class Range {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1880
            char start_pc = Character.MAX_VALUE;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1881
            char length = Character.MAX_VALUE;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1882
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1883
            Range() {}
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1884
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1885
            Range(char start) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1886
                this.start_pc = start;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1887
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1888
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1889
            Range(char start, char length) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1890
                this.start_pc = start;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1891
                this.length = length;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1892
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1893
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1894
            boolean closed() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1895
                return start_pc != Character.MAX_VALUE && length != Character.MAX_VALUE;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1896
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1897
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1898
            @Override
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1899
            public String toString() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1900
                int currentStartPC = start_pc;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1901
                int currentLength = length;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1902
                return "startpc = " + currentStartPC + " length " + currentLength;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1903
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1904
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1905
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1906
        java.util.List<Range> aliveRanges = new java.util.ArrayList<>();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1907
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1908
        LocalVar(VarSymbol v) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1909
            this.sym = v;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1910
            this.reg = (char)v.adr;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1911
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1912
        public LocalVar dup() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1913
            return new LocalVar(sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1914
        }
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1915
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1916
        Range firstRange() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1917
            return aliveRanges.isEmpty() ? null : aliveRanges.get(0);
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1918
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1919
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1920
        Range lastRange() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1921
            return aliveRanges.isEmpty() ? null : aliveRanges.get(aliveRanges.size() - 1);
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1922
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1923
24648
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1924
        void removeLastRange() {
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1925
            Range lastRange = lastRange();
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1926
            if (lastRange != null) {
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1927
                aliveRanges.remove(lastRange);
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1928
            }
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1929
        }
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1930
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1931
        @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1932
        public String toString() {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1933
            if (aliveRanges == null) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1934
                return "empty local var";
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1935
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1936
            StringBuilder sb = new StringBuilder().append(sym)
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1937
                    .append(" in register ").append((int)reg).append(" \n");
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1938
            for (Range r : aliveRanges) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1939
                sb.append(" starts at pc=").append(Integer.toString(((int)r.start_pc)))
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1940
                    .append(" length=").append(Integer.toString(((int)r.length)))
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1941
                    .append("\n");
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1942
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1943
            return sb.toString();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1944
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1945
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1946
        public void openRange(char start) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1947
            if (!hasOpenRange()) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1948
                aliveRanges.add(new Range(start));
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1949
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1950
        }
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1951
25298
7940437438b9 8047719: Incorrect LVT in switch statement
vromero
parents: 24648
diff changeset
  1952
        public void closeRange(char length) {
7940437438b9 8047719: Incorrect LVT in switch statement
vromero
parents: 24648
diff changeset
  1953
            if (isLastRangeInitialized() && length > 0) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1954
                Range range = lastRange();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1955
                if (range != null) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1956
                    if (range.length == Character.MAX_VALUE) {
25298
7940437438b9 8047719: Incorrect LVT in switch statement
vromero
parents: 24648
diff changeset
  1957
                        range.length = length;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1958
                    }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1959
                }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1960
            } else {
24648
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1961
                removeLastRange();
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1962
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1963
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1964
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1965
        public boolean hasOpenRange() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1966
            if (aliveRanges.isEmpty()) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1967
                return false;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1968
            }
24648
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1969
            return lastRange().length == Character.MAX_VALUE;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1970
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1971
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1972
        public boolean isLastRangeInitialized() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1973
            if (aliveRanges.isEmpty()) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1974
                return false;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1975
            }
24648
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  1976
            return lastRange().start_pc != Character.MAX_VALUE;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1977
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1978
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1979
        public Range getWidestRange() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1980
            if (aliveRanges.isEmpty()) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1981
                return new Range();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1982
            } else {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1983
                Range firstRange = firstRange();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1984
                Range lastRange = lastRange();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1985
                char length = (char)(lastRange.length + (lastRange.start_pc - firstRange.start_pc));
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1986
                return new Range(firstRange.start_pc, length);
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1987
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1988
         }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  1989
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 21711
diff changeset
  1990
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1991
06bc494ca11e Initial load
duke
parents:
diff changeset
  1992
    /** Local variables, indexed by register. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1993
    LocalVar[] lvar;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1994
06bc494ca11e Initial load
duke
parents:
diff changeset
  1995
    /** Add a new local variable. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1996
    private void addLocalVar(VarSymbol v) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1997
        int adr = v.adr;
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  1998
        lvar = ArrayUtils.ensureCapacity(lvar, adr+1);
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1999
        Assert.checkNull(lvar[adr]);
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2000
        if (pendingJumps != null) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2001
            resolvePending();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2002
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2003
        lvar[adr] = new LocalVar(v);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2004
        state.defined.excl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2005
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2006
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2007
    void adjustAliveRanges(int oldCP, int delta) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2008
        for (LocalVar localVar: lvar) {
26784
6be305e56bcb 8058708: java.lang.AssertionError compiling source code
vromero
parents: 25874
diff changeset
  2009
            if (localVar != null) {
6be305e56bcb 8058708: java.lang.AssertionError compiling source code
vromero
parents: 25874
diff changeset
  2010
                for (LocalVar.Range range: localVar.aliveRanges) {
6be305e56bcb 8058708: java.lang.AssertionError compiling source code
vromero
parents: 25874
diff changeset
  2011
                    if (range.closed() && range.start_pc + range.length >= oldCP) {
6be305e56bcb 8058708: java.lang.AssertionError compiling source code
vromero
parents: 25874
diff changeset
  2012
                        range.length += delta;
6be305e56bcb 8058708: java.lang.AssertionError compiling source code
vromero
parents: 25874
diff changeset
  2013
                    }
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2014
                }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2015
            }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2016
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2017
    }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2018
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2019
    /**
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2020
     * Calculates the size of the LocalVariableTable.
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2021
     */
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2022
    public int getLVTSize() {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2023
        int result = varBufferSize;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2024
        for (int i = 0; i < varBufferSize; i++) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2025
            LocalVar var = varBuffer[i];
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2026
            result += var.aliveRanges.size() - 1;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2027
        }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2028
        return result;
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2029
    }
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2030
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2031
    /** Set the current variable defined state. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2032
    public void setDefined(Bits newDefined) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2033
        if (alive && newDefined != state.defined) {
17282
c6964ad7df63 8008562: javac, a refactoring to Bits is necessary in order to provide a change history
vromero
parents: 16807
diff changeset
  2034
            Bits diff = new Bits(state.defined).xorSet(newDefined);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2035
            for (int adr = diff.nextBit(0);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2036
                 adr >= 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2037
                 adr = diff.nextBit(adr+1)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2038
                if (adr >= nextreg)
06bc494ca11e Initial load
duke
parents:
diff changeset
  2039
                    state.defined.excl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2040
                else if (state.defined.isMember(adr))
06bc494ca11e Initial load
duke
parents:
diff changeset
  2041
                    setUndefined(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2042
                else
06bc494ca11e Initial load
duke
parents:
diff changeset
  2043
                    setDefined(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2044
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2045
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2046
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2047
06bc494ca11e Initial load
duke
parents:
diff changeset
  2048
    /** Mark a register as being (possibly) defined. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2049
    public void setDefined(int adr) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2050
        LocalVar v = lvar[adr];
06bc494ca11e Initial load
duke
parents:
diff changeset
  2051
        if (v == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2052
            state.defined.excl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2053
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2054
            state.defined.incl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2055
            if (cp < Character.MAX_VALUE) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2056
                v.openRange((char)cp);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2057
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2058
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2059
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2060
06bc494ca11e Initial load
duke
parents:
diff changeset
  2061
    /** Mark a register as being undefined. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2062
    public void setUndefined(int adr) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2063
        state.defined.excl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2064
        if (adr < lvar.length &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  2065
            lvar[adr] != null &&
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2066
            lvar[adr].isLastRangeInitialized()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2067
            LocalVar v = lvar[adr];
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2068
            char length = (char)(curCP() - v.lastRange().start_pc);
25298
7940437438b9 8047719: Incorrect LVT in switch statement
vromero
parents: 24648
diff changeset
  2069
            if (length < Character.MAX_VALUE) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2070
                lvar[adr] = v.dup();
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2071
                v.closeRange(length);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2072
                putVar(v);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2073
            } else {
24648
3b639cd0c8bd 8037937: javac: AssertionError during LVT generation, wrong variable ranges
vromero
parents: 24396
diff changeset
  2074
                v.removeLastRange();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2075
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2076
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2077
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2078
06bc494ca11e Initial load
duke
parents:
diff changeset
  2079
    /** End the scope of a variable. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2080
    private void endScope(int adr) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2081
        LocalVar v = lvar[adr];
06bc494ca11e Initial load
duke
parents:
diff changeset
  2082
        if (v != null) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2083
            if (v.isLastRangeInitialized()) {
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2084
                char length = (char)(curCP() - v.lastRange().start_pc);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2085
                if (length < Character.MAX_VALUE) {
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2086
                    v.closeRange(length);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2087
                    putVar(v);
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2088
                    fillLocalVarPosition(v);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2089
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2090
            }
21703
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2091
            /** the call to curCP() can implicitly adjust the current cp, if so
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2092
             * the alive range of local variables may be modified. Thus we need
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2093
             * all of them. For this reason assigning null to the given address
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2094
             * should be the last action to do.
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2095
             */
b12ce201d445 8027660: javac crash while creating LVT entry for a local variable defined in an inner block
vromero
parents: 20249
diff changeset
  2096
            lvar[adr] = null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2097
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2098
        state.defined.excl(adr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2099
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2100
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2101
    private void fillLocalVarPosition(LocalVar lv) {
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17578
diff changeset
  2102
        if (lv == null || lv.sym == null || !lv.sym.hasTypeAnnotations())
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2103
            return;
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2104
        for (Attribute.TypeCompound ta : lv.sym.getRawTypeAttributes()) {
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2105
            TypeAnnotationPosition p = ta.position;
19941
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2106
            LocalVar.Range widestRange = lv.getWidestRange();
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2107
            p.lvarOffset = new int[] { (int)widestRange.start_pc };
8b91e8eb2d20 7047734: javac, the LVT is not generated correctly in several scenarios
vromero
parents: 18646
diff changeset
  2108
            p.lvarLength = new int[] { (int)widestRange.length };
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2109
            p.lvarIndex = new int[] { (int)lv.reg };
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2110
            p.isValidOffset = true;
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2111
        }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2112
    }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2113
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2114
    // Method to be called after compressCatchTable to
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2115
    // fill in the exception table index for type
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2116
    // annotations on exception parameters.
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2117
    public void fillExceptionParameterPositions() {
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2118
        for (int i = 0; i < varBufferSize; ++i) {
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2119
            LocalVar lv = varBuffer[i];
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2120
            if (lv == null || lv.sym == null
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17578
diff changeset
  2121
                    || !lv.sym.hasTypeAnnotations()
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2122
                    || !lv.sym.isExceptionParameter())
17578
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  2123
                continue;
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2124
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2125
            for (Attribute.TypeCompound ta : lv.sym.getRawTypeAttributes()) {
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2126
                TypeAnnotationPosition p = ta.position;
23975
c7c81595aea9 8040319: Clean up type annotation exception index generating code in Code.java
emc
parents: 23966
diff changeset
  2127
                if (p.hasCatchType()) {
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2128
                    final int idx = findExceptionIndex(p);
23975
c7c81595aea9 8040319: Clean up type annotation exception index generating code in Code.java
emc
parents: 23966
diff changeset
  2129
                    if (idx == -1)
c7c81595aea9 8040319: Clean up type annotation exception index generating code in Code.java
emc
parents: 23966
diff changeset
  2130
                        Assert.error("Could not find exception index for type annotation " +
c7c81595aea9 8040319: Clean up type annotation exception index generating code in Code.java
emc
parents: 23966
diff changeset
  2131
                                     ta + " on exception parameter");
c7c81595aea9 8040319: Clean up type annotation exception index generating code in Code.java
emc
parents: 23966
diff changeset
  2132
                    p.setExceptionIndex(idx);
17578
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 17282
diff changeset
  2133
                }
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2134
            }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2135
        }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2136
    }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2137
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2138
    private int findExceptionIndex(TypeAnnotationPosition p) {
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2139
        final int catchType = p.getCatchType();
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2140
        final int startPos = p.getStartPos();
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2141
        final int len = catchInfo.length();
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2142
        List<char[]> iter = catchInfo.toList();
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2143
        for (int i = 0; i < len; ++i) {
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2144
            char[] catchEntry = iter.head;
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2145
            iter = iter.tail;
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2146
            int ct = catchEntry[3];
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2147
            int sp = catchEntry[0];
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 23975
diff changeset
  2148
            if (catchType == ct && sp == startPos) {
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2149
                return i;
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2150
            }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2151
        }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2152
        return -1;
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2153
    }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2154
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2155
    /** Put a live variable range into the buffer to be output to the
06bc494ca11e Initial load
duke
parents:
diff changeset
  2156
     *  class file.
06bc494ca11e Initial load
duke
parents:
diff changeset
  2157
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2158
    void putVar(LocalVar var) {
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2159
        // Keep local variables if
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2160
        // 1) we need them for debug information
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 14949
diff changeset
  2161
        // 2) it is an exception type and it contains type annotations
22443
0922d94d0576 8028576: Incorrect RuntimeVisibleTypeAnnotations for exception parameters when not generating debuging info
jlahoda
parents: 22163
diff changeset
  2162
        boolean keepLocalVariables = varDebugInfo ||
0922d94d0576 8028576: Incorrect RuntimeVisibleTypeAnnotations for exception parameters when not generating debuging info
jlahoda
parents: 22163
diff changeset
  2163
            (var.sym.isExceptionParameter() && var.sym.hasTypeAnnotations());
0922d94d0576 8028576: Incorrect RuntimeVisibleTypeAnnotations for exception parameters when not generating debuging info
jlahoda
parents: 22163
diff changeset
  2164
        if (!keepLocalVariables) return;
29772
4e4e74b99d27 8054220: Debugger doesn't show variables *outside* lambda
jlahoda
parents: 28330
diff changeset
  2165
        //don't keep synthetic vars, unless they are lambda method parameters
4e4e74b99d27 8054220: Debugger doesn't show variables *outside* lambda
jlahoda
parents: 28330
diff changeset
  2166
        boolean ignoredSyntheticVar = (var.sym.flags() & Flags.SYNTHETIC) != 0 &&
4e4e74b99d27 8054220: Debugger doesn't show variables *outside* lambda
jlahoda
parents: 28330
diff changeset
  2167
                ((var.sym.owner.flags() & Flags.LAMBDA_METHOD) == 0 ||
4e4e74b99d27 8054220: Debugger doesn't show variables *outside* lambda
jlahoda
parents: 28330
diff changeset
  2168
                 (var.sym.flags() & Flags.PARAMETER) == 0);
4e4e74b99d27 8054220: Debugger doesn't show variables *outside* lambda
jlahoda
parents: 28330
diff changeset
  2169
        if (ignoredSyntheticVar) return;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2170
        if (varBuffer == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  2171
            varBuffer = new LocalVar[20];
14049
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  2172
        else
3207422a0f9b 7193657: provide internal ArrayUtils class to simplify common usage of arrays in javac
jjg
parents: 14046
diff changeset
  2173
            varBuffer = ArrayUtils.ensureCapacity(varBuffer, varBufferSize);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2174
        varBuffer[varBufferSize++] = var;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2175
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2176
06bc494ca11e Initial load
duke
parents:
diff changeset
  2177
    /** Previously live local variables, to be put into the variable table. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2178
    LocalVar[] varBuffer;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2179
    int varBufferSize;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2180
06bc494ca11e Initial load
duke
parents:
diff changeset
  2181
    /** Create a new local variable address and return it.
06bc494ca11e Initial load
duke
parents:
diff changeset
  2182
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2183
    private int newLocal(int typecode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2184
        int reg = nextreg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2185
        int w = width(typecode);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2186
        nextreg = reg + w;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2187
        if (nextreg > max_locals) max_locals = nextreg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2188
        return reg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2189
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2190
06bc494ca11e Initial load
duke
parents:
diff changeset
  2191
    private int newLocal(Type type) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2192
        return newLocal(typecode(type));
06bc494ca11e Initial load
duke
parents:
diff changeset
  2193
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2194
06bc494ca11e Initial load
duke
parents:
diff changeset
  2195
    public int newLocal(VarSymbol v) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2196
        int reg = v.adr = newLocal(v.erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  2197
        addLocalVar(v);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2198
        return reg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2199
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2200
06bc494ca11e Initial load
duke
parents:
diff changeset
  2201
    /** Start a set of fresh registers.
06bc494ca11e Initial load
duke
parents:
diff changeset
  2202
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2203
    public void newRegSegment() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2204
        nextreg = max_locals;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2205
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2206
13844
56339cf983a3 7177970: fix issues in langtools doc comments
jjg
parents: 10811
diff changeset
  2207
    /** End scopes of all variables with registers &ge; first.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2208
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2209
    public void endScopes(int first) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2210
        int prevNextReg = nextreg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2211
        nextreg = first;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2212
        for (int i = nextreg; i < prevNextReg; i++) endScope(i);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2213
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2214
06bc494ca11e Initial load
duke
parents:
diff changeset
  2215
/**************************************************************************
06bc494ca11e Initial load
duke
parents:
diff changeset
  2216
 * static tables
06bc494ca11e Initial load
duke
parents:
diff changeset
  2217
 *************************************************************************/
06bc494ca11e Initial load
duke
parents:
diff changeset
  2218
06bc494ca11e Initial load
duke
parents:
diff changeset
  2219
    public static String mnem(int opcode) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2220
        return Mneumonics.mnem[opcode];
06bc494ca11e Initial load
duke
parents:
diff changeset
  2221
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2222
06bc494ca11e Initial load
duke
parents:
diff changeset
  2223
    private static class Mneumonics {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2224
        private final static String[] mnem = new String[ByteCodeCount];
06bc494ca11e Initial load
duke
parents:
diff changeset
  2225
        static {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2226
            mnem[nop] = "nop";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2227
            mnem[aconst_null] = "aconst_null";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2228
            mnem[iconst_m1] = "iconst_m1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2229
            mnem[iconst_0] = "iconst_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2230
            mnem[iconst_1] = "iconst_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2231
            mnem[iconst_2] = "iconst_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2232
            mnem[iconst_3] = "iconst_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2233
            mnem[iconst_4] = "iconst_4";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2234
            mnem[iconst_5] = "iconst_5";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2235
            mnem[lconst_0] = "lconst_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2236
            mnem[lconst_1] = "lconst_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2237
            mnem[fconst_0] = "fconst_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2238
            mnem[fconst_1] = "fconst_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2239
            mnem[fconst_2] = "fconst_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2240
            mnem[dconst_0] = "dconst_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2241
            mnem[dconst_1] = "dconst_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2242
            mnem[bipush] = "bipush";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2243
            mnem[sipush] = "sipush";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2244
            mnem[ldc1] = "ldc1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2245
            mnem[ldc2] = "ldc2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2246
            mnem[ldc2w] = "ldc2w";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2247
            mnem[iload] = "iload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2248
            mnem[lload] = "lload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2249
            mnem[fload] = "fload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2250
            mnem[dload] = "dload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2251
            mnem[aload] = "aload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2252
            mnem[iload_0] = "iload_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2253
            mnem[lload_0] = "lload_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2254
            mnem[fload_0] = "fload_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2255
            mnem[dload_0] = "dload_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2256
            mnem[aload_0] = "aload_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2257
            mnem[iload_1] = "iload_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2258
            mnem[lload_1] = "lload_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2259
            mnem[fload_1] = "fload_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2260
            mnem[dload_1] = "dload_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2261
            mnem[aload_1] = "aload_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2262
            mnem[iload_2] = "iload_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2263
            mnem[lload_2] = "lload_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2264
            mnem[fload_2] = "fload_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2265
            mnem[dload_2] = "dload_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2266
            mnem[aload_2] = "aload_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2267
            mnem[iload_3] = "iload_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2268
            mnem[lload_3] = "lload_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2269
            mnem[fload_3] = "fload_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2270
            mnem[dload_3] = "dload_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2271
            mnem[aload_3] = "aload_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2272
            mnem[iaload] = "iaload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2273
            mnem[laload] = "laload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2274
            mnem[faload] = "faload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2275
            mnem[daload] = "daload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2276
            mnem[aaload] = "aaload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2277
            mnem[baload] = "baload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2278
            mnem[caload] = "caload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2279
            mnem[saload] = "saload";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2280
            mnem[istore] = "istore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2281
            mnem[lstore] = "lstore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2282
            mnem[fstore] = "fstore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2283
            mnem[dstore] = "dstore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2284
            mnem[astore] = "astore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2285
            mnem[istore_0] = "istore_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2286
            mnem[lstore_0] = "lstore_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2287
            mnem[fstore_0] = "fstore_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2288
            mnem[dstore_0] = "dstore_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2289
            mnem[astore_0] = "astore_0";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2290
            mnem[istore_1] = "istore_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2291
            mnem[lstore_1] = "lstore_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2292
            mnem[fstore_1] = "fstore_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2293
            mnem[dstore_1] = "dstore_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2294
            mnem[astore_1] = "astore_1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2295
            mnem[istore_2] = "istore_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2296
            mnem[lstore_2] = "lstore_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2297
            mnem[fstore_2] = "fstore_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2298
            mnem[dstore_2] = "dstore_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2299
            mnem[astore_2] = "astore_2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2300
            mnem[istore_3] = "istore_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2301
            mnem[lstore_3] = "lstore_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2302
            mnem[fstore_3] = "fstore_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2303
            mnem[dstore_3] = "dstore_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2304
            mnem[astore_3] = "astore_3";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2305
            mnem[iastore] = "iastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2306
            mnem[lastore] = "lastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2307
            mnem[fastore] = "fastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2308
            mnem[dastore] = "dastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2309
            mnem[aastore] = "aastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2310
            mnem[bastore] = "bastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2311
            mnem[castore] = "castore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2312
            mnem[sastore] = "sastore";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2313
            mnem[pop] = "pop";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2314
            mnem[pop2] = "pop2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2315
            mnem[dup] = "dup";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2316
            mnem[dup_x1] = "dup_x1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2317
            mnem[dup_x2] = "dup_x2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2318
            mnem[dup2] = "dup2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2319
            mnem[dup2_x1] = "dup2_x1";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2320
            mnem[dup2_x2] = "dup2_x2";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2321
            mnem[swap] = "swap";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2322
            mnem[iadd] = "iadd";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2323
            mnem[ladd] = "ladd";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2324
            mnem[fadd] = "fadd";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2325
            mnem[dadd] = "dadd";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2326
            mnem[isub] = "isub";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2327
            mnem[lsub] = "lsub";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2328
            mnem[fsub] = "fsub";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2329
            mnem[dsub] = "dsub";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2330
            mnem[imul] = "imul";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2331
            mnem[lmul] = "lmul";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2332
            mnem[fmul] = "fmul";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2333
            mnem[dmul] = "dmul";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2334
            mnem[idiv] = "idiv";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2335
            mnem[ldiv] = "ldiv";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2336
            mnem[fdiv] = "fdiv";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2337
            mnem[ddiv] = "ddiv";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2338
            mnem[imod] = "imod";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2339
            mnem[lmod] = "lmod";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2340
            mnem[fmod] = "fmod";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2341
            mnem[dmod] = "dmod";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2342
            mnem[ineg] = "ineg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2343
            mnem[lneg] = "lneg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2344
            mnem[fneg] = "fneg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2345
            mnem[dneg] = "dneg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2346
            mnem[ishl] = "ishl";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2347
            mnem[lshl] = "lshl";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2348
            mnem[ishr] = "ishr";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2349
            mnem[lshr] = "lshr";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2350
            mnem[iushr] = "iushr";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2351
            mnem[lushr] = "lushr";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2352
            mnem[iand] = "iand";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2353
            mnem[land] = "land";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2354
            mnem[ior] = "ior";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2355
            mnem[lor] = "lor";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2356
            mnem[ixor] = "ixor";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2357
            mnem[lxor] = "lxor";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2358
            mnem[iinc] = "iinc";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2359
            mnem[i2l] = "i2l";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2360
            mnem[i2f] = "i2f";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2361
            mnem[i2d] = "i2d";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2362
            mnem[l2i] = "l2i";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2363
            mnem[l2f] = "l2f";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2364
            mnem[l2d] = "l2d";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2365
            mnem[f2i] = "f2i";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2366
            mnem[f2l] = "f2l";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2367
            mnem[f2d] = "f2d";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2368
            mnem[d2i] = "d2i";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2369
            mnem[d2l] = "d2l";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2370
            mnem[d2f] = "d2f";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2371
            mnem[int2byte] = "int2byte";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2372
            mnem[int2char] = "int2char";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2373
            mnem[int2short] = "int2short";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2374
            mnem[lcmp] = "lcmp";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2375
            mnem[fcmpl] = "fcmpl";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2376
            mnem[fcmpg] = "fcmpg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2377
            mnem[dcmpl] = "dcmpl";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2378
            mnem[dcmpg] = "dcmpg";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2379
            mnem[ifeq] = "ifeq";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2380
            mnem[ifne] = "ifne";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2381
            mnem[iflt] = "iflt";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2382
            mnem[ifge] = "ifge";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2383
            mnem[ifgt] = "ifgt";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2384
            mnem[ifle] = "ifle";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2385
            mnem[if_icmpeq] = "if_icmpeq";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2386
            mnem[if_icmpne] = "if_icmpne";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2387
            mnem[if_icmplt] = "if_icmplt";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2388
            mnem[if_icmpge] = "if_icmpge";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2389
            mnem[if_icmpgt] = "if_icmpgt";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2390
            mnem[if_icmple] = "if_icmple";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2391
            mnem[if_acmpeq] = "if_acmpeq";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2392
            mnem[if_acmpne] = "if_acmpne";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2393
            mnem[goto_] = "goto_";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2394
            mnem[jsr] = "jsr";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2395
            mnem[ret] = "ret";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2396
            mnem[tableswitch] = "tableswitch";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2397
            mnem[lookupswitch] = "lookupswitch";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2398
            mnem[ireturn] = "ireturn";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2399
            mnem[lreturn] = "lreturn";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2400
            mnem[freturn] = "freturn";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2401
            mnem[dreturn] = "dreturn";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2402
            mnem[areturn] = "areturn";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2403
            mnem[return_] = "return_";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2404
            mnem[getstatic] = "getstatic";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2405
            mnem[putstatic] = "putstatic";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2406
            mnem[getfield] = "getfield";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2407
            mnem[putfield] = "putfield";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2408
            mnem[invokevirtual] = "invokevirtual";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2409
            mnem[invokespecial] = "invokespecial";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2410
            mnem[invokestatic] = "invokestatic";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2411
            mnem[invokeinterface] = "invokeinterface";
2723
b659ca23d5f5 6829189: Java programming with JSR 292 needs language support
jrose
parents: 1264
diff changeset
  2412
            mnem[invokedynamic] = "invokedynamic";
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2413
            mnem[new_] = "new_";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2414
            mnem[newarray] = "newarray";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2415
            mnem[anewarray] = "anewarray";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2416
            mnem[arraylength] = "arraylength";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2417
            mnem[athrow] = "athrow";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2418
            mnem[checkcast] = "checkcast";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2419
            mnem[instanceof_] = "instanceof_";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2420
            mnem[monitorenter] = "monitorenter";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2421
            mnem[monitorexit] = "monitorexit";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2422
            mnem[wide] = "wide";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2423
            mnem[multianewarray] = "multianewarray";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2424
            mnem[if_acmp_null] = "if_acmp_null";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2425
            mnem[if_acmp_nonnull] = "if_acmp_nonnull";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2426
            mnem[goto_w] = "goto_w";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2427
            mnem[jsr_w] = "jsr_w";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2428
            mnem[breakpoint] = "breakpoint";
06bc494ca11e Initial load
duke
parents:
diff changeset
  2429
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2430
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2431
}