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