src/jdk.dynalink/share/classes/jdk/dynalink/support/ChainedCallSite.java
author jlaskey
Thu, 21 Jun 2018 08:58:59 -0300
changeset 50695 36ca515343e0
parent 47216 71c04702a3d5
permissions -rw-r--r--
8203637: Fix Sources Reviewed-by: hannesw, sundar
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     1
/*
35407
204abe4d8cbc 8147591: Revisit Collection.toArray(new T[size]) calls in nashorn and dynalink code
mhaupt
parents: 34447
diff changeset
     2
 * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     4
 *
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    10
 *
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    15
 * accompanied this code).
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    16
 *
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    20
 *
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    23
 * questions.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    24
 */
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    25
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    26
/*
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    27
 * This file is available under and governed by the GNU General Public
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    28
 * License version 2 only, as published by the Free Software Foundation.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    29
 * However, the following notice accompanied the original version of this
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    30
 * file, and Oracle licenses the original version of this file under the BSD
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    31
 * license:
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    32
 */
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    33
/*
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    34
   Copyright 2009-2013 Attila Szegedi
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    35
50695
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    36
   Redistribution and use in source and binary forms, with or without
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    37
   modification, are permitted provided that the following conditions are
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    38
   met:
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    39
   * Redistributions of source code must retain the above copyright
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    40
     notice, this list of conditions and the following disclaimer.
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    41
   * Redistributions in binary form must reproduce the above copyright
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    42
     notice, this list of conditions and the following disclaimer in the
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    43
     documentation and/or other materials provided with the distribution.
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    44
   * Neither the name of the copyright holder nor the names of
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    45
     contributors may be used to endorse or promote products derived from
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    46
     this software without specific prior written permission.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    47
50695
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    48
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    49
   IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    50
   TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    51
   PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDER
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    52
   BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    53
   CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    54
   SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    55
   BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    56
   WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    57
   OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
36ca515343e0 8203637: Fix Sources
jlaskey
parents: 47216
diff changeset
    58
   ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    59
*/
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    60
34447
ec4c069f9436 8141338: Move jdk.internal.dynalink package to jdk.dynalink
attila
parents: 33337
diff changeset
    61
package jdk.dynalink.support;
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    62
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    63
import java.lang.invoke.MethodHandle;
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    64
import java.lang.invoke.MethodHandles;
33006
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
    65
import java.util.Arrays;
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    66
import java.util.Iterator;
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    67
import java.util.LinkedList;
34447
ec4c069f9436 8141338: Move jdk.internal.dynalink package to jdk.dynalink
attila
parents: 33337
diff changeset
    68
import jdk.dynalink.CallSiteDescriptor;
ec4c069f9436 8141338: Move jdk.internal.dynalink package to jdk.dynalink
attila
parents: 33337
diff changeset
    69
import jdk.dynalink.linker.GuardedInvocation;
ec4c069f9436 8141338: Move jdk.internal.dynalink package to jdk.dynalink
attila
parents: 33337
diff changeset
    70
import jdk.dynalink.linker.support.Lookup;
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    71
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    72
/**
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    73
 * A relinkable call site that implements a polymorphic inline caching strategy.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    74
 * It remembers up to 8 {@link GuardedInvocation}s it was linked with, and on
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    75
 * each relink request builds a cascading chain of method handles of one
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    76
 * invocation falling back to the next one. The number of remembered invocations
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    77
 * can be customized by overriding {@link #getMaxChainLength()} in a subclass.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    78
 * When this call site is relinked with a new invocation and the length of the
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    79
 * chain is already at the maximum, it will throw away the oldest invocation.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    80
 * Invocations with invalidated switch points and ones for which their
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    81
 * invalidating exception triggered are removed eagerly from the chain. The
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    82
 * invocations are never reordered; the most recently linked method handle is
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    83
 * always at the start of the chain and the least recently linked at its end.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    84
 * The call site can be safely relinked on more than one thread concurrently.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    85
 * Race conditions in linking are resolved by throwing away the
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    86
 * {@link GuardedInvocation} produced on the losing thread without incorporating
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
    87
 * it into the chain, so it can lead to repeated linking for the same arguments.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    88
 */
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
    89
public class ChainedCallSite extends AbstractRelinkableCallSite {
32941
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    90
    private static final MethodHandle PRUNE_CATCHES;
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    91
    private static final MethodHandle PRUNE_SWITCHPOINTS;
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    92
    static {
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    93
        final MethodHandle PRUNE = Lookup.findOwnSpecial(MethodHandles.lookup(), "prune", MethodHandle.class,
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    94
                MethodHandle.class, boolean.class);
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    95
        PRUNE_CATCHES      = MethodHandles.insertArguments(PRUNE, 2, true);
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    96
        PRUNE_SWITCHPOINTS = MethodHandles.insertArguments(PRUNE, 2, false);
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
    97
    }
19455
b972b61a6921 8022509: Various Dynalink security enhancements
attila
parents: 16245
diff changeset
    98
33006
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
    99
    /**
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   100
     * Contains the invocations currently linked into this call site's target. They are used when we are
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   101
     * relinking to rebuild the guardWithTest chain. Valid values for this field are: {@code null} if there's
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   102
     * no linked invocations, or an instance of {@link GuardedInvocation} if there is exactly one previous
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   103
     * invocation, or an instance of {@code GuardedInvocation[]} if there is more than one previous
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   104
     * invocation.
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   105
     */
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   106
    private Object invocations;
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   107
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   108
    /**
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   109
     * Creates a new chained call site.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   110
     * @param descriptor the descriptor for the call site.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   111
     */
24778
2ff5d7041566 8044638: Tidy up Nashorn codebase for code standards
attila
parents: 24720
diff changeset
   112
    public ChainedCallSite(final CallSiteDescriptor descriptor) {
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   113
        super(descriptor);
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   114
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   115
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   116
    /**
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   117
     * The maximum number of method handles in the chain. Defaults to 8. You can
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   118
     * override it in a subclass if you need to change the value.
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   119
     * @return the maximum number of method handles in the chain. The return
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   120
     * value is checked, and if your override returns a value less than 1, a
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   121
     * {@link RuntimeException} will be thrown.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   122
     */
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   123
    protected int getMaxChainLength() {
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   124
        return 8;
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   125
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   126
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   127
    @Override
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   128
    public void relink(final GuardedInvocation guardedInvocation, final MethodHandle relinkAndInvoke) {
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   129
        relinkInternal(guardedInvocation, relinkAndInvoke, false, false);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   130
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   131
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   132
    @Override
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   133
    public void resetAndRelink(final GuardedInvocation guardedInvocation, final MethodHandle relinkAndInvoke) {
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   134
        relinkInternal(guardedInvocation, relinkAndInvoke, true, false);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   135
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   136
24778
2ff5d7041566 8044638: Tidy up Nashorn codebase for code standards
attila
parents: 24720
diff changeset
   137
    private MethodHandle relinkInternal(final GuardedInvocation invocation, final MethodHandle relink, final boolean reset, final boolean removeCatches) {
33006
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   138
        final Object currentInvocations = invocations;
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   139
        final LinkedList<GuardedInvocation> newInvocations;
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   140
        if (currentInvocations == null || reset) {
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   141
            newInvocations = new LinkedList<>();
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   142
        } else if (currentInvocations instanceof GuardedInvocation) {
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   143
            newInvocations = new LinkedList<>();
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   144
            newInvocations.add((GuardedInvocation)currentInvocations);
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   145
        } else if (currentInvocations instanceof GuardedInvocation[]) {
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   146
            newInvocations = new LinkedList<>(Arrays.asList(((GuardedInvocation[])currentInvocations)));
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   147
        } else {
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   148
            throw new AssertionError();
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   149
        }
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   150
24720
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   151
        // First, prune the chain of invalidated switchpoints, we always do this
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   152
        // We also remove any catches if the remove catches flag is set
24778
2ff5d7041566 8044638: Tidy up Nashorn codebase for code standards
attila
parents: 24720
diff changeset
   153
        for(final Iterator<GuardedInvocation> it = newInvocations.iterator(); it.hasNext();) {
24720
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   154
            final GuardedInvocation inv = it.next();
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   155
            if(inv.hasBeenInvalidated() || (removeCatches && inv.getException() != null)) {
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   156
                it.remove();
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   157
            }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   158
        }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   159
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   160
        // prune() is allowed to invoke this method with invocation == null meaning we're just pruning the chain and not
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   161
        // adding any new invocations to it.
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   162
        if(invocation != null) {
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   163
            // Remove oldest entry if we're at max length
33330
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   164
            if(newInvocations.size() == checkMaxChainLength(getMaxChainLength())) {
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   165
                newInvocations.removeFirst();
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   166
            }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   167
            newInvocations.addLast(invocation);
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   168
        }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   169
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   170
        // prune-and-invoke is used as the fallback for invalidated switchpoints. If a switchpoint gets invalidated, we
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   171
        // rebuild the chain and get rid of all invalidated switchpoints instead of letting them linger.
32941
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
   172
        final MethodHandle pruneAndInvokeSwitchPoints = makePruneAndInvokeMethod(relink, PRUNE_SWITCHPOINTS);
be82ab9eb287 8139269: Do not expose prune method handles from ChainedCallSite
attila
parents: 25865
diff changeset
   173
        final MethodHandle pruneAndInvokeCatches      = makePruneAndInvokeMethod(relink, PRUNE_CATCHES);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   174
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   175
        // Fold the new chain
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   176
        MethodHandle target = relink;
24778
2ff5d7041566 8044638: Tidy up Nashorn codebase for code standards
attila
parents: 24720
diff changeset
   177
        for(final GuardedInvocation inv: newInvocations) {
24720
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   178
            target = inv.compose(target, pruneAndInvokeSwitchPoints, pruneAndInvokeCatches);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   179
        }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   180
33006
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   181
        switch (newInvocations.size()) {
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   182
            case 0:
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   183
                invocations = null;
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   184
                break;
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   185
            case 1:
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   186
                invocations = newInvocations.getFirst();
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   187
                break;
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   188
            default:
35407
204abe4d8cbc 8147591: Revisit Collection.toArray(new T[size]) calls in nashorn and dynalink code
mhaupt
parents: 34447
diff changeset
   189
                invocations = newInvocations.toArray(new GuardedInvocation[0]);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   190
        }
33006
99298bc38e28 8139270: Drastically reduce memory footprint of ChainedCallSite
attila
parents: 32941
diff changeset
   191
        setTarget(target);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   192
        return target;
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   193
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   194
33330
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   195
    private static int checkMaxChainLength(final int maxChainLength) {
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   196
        if (maxChainLength > 0) {
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   197
            return maxChainLength;
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   198
        }
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   199
        throw new RuntimeException("getMaxChainLength() returned a non-positive value");
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   200
35531ae624ef 8139304: Remove elaborate call site descriptor class hierarchy and factory for them. Remove AutoDiscovery, DefaultPrelinkFilter, and BottomGuardingDynamicLinker as they can be inlined into DynamicLinkerFactory. Remove CallerSensitiveDetector as it can be inlined into AbstractJavaLinker. Make ClassMap non-public.
attila
parents: 33006
diff changeset
   201
    }
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   202
    /**
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   203
     * Creates a method that rebuilds our call chain, pruning it of any invalidated switchpoints, and then invokes that
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   204
     * chain.
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   205
     * @param relinkAndInvoke the ultimate fallback for the chain passed from the dynamic linker.
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   206
     * @return a method handle for prune-and-invoke
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   207
     */
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   208
    private MethodHandle makePruneAndInvokeMethod(final MethodHandle relinkAndInvoke, final MethodHandle prune) {
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   209
        // Bind prune to (this, relink)
33333
0bad500ce4e0 8139590: Improve Dynalink JavaDoc
attila
parents: 33330
diff changeset
   210
        final MethodHandle boundPrune = MethodHandles.insertArguments(prune, 0, this, relinkAndInvoke);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   211
        // Make it ignore all incoming arguments
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   212
        final MethodHandle ignoreArgsPrune = MethodHandles.dropArguments(boundPrune, 0, type().parameterList());
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   213
        // Invoke prune, then invoke the call site target with original arguments
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   214
        return MethodHandles.foldArguments(MethodHandles.exactInvoker(type()), ignoreArgsPrune);
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   215
    }
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   216
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   217
    @SuppressWarnings("unused")
24778
2ff5d7041566 8044638: Tidy up Nashorn codebase for code standards
attila
parents: 24720
diff changeset
   218
    private MethodHandle prune(final MethodHandle relink, final boolean catches) {
24720
75f8388b79df 8035836: Array performance improvements
lagergren
parents: 19630
diff changeset
   219
        return relinkInternal(null, relink, false, catches);
16234
86cb162cec6c 8008085: Integrate Dynalink source code into Nashorn codebase
attila
parents:
diff changeset
   220
    }
16245
6a1c6c8bc113 8008371: Fix Dynalink compiler warnings and whitespace
attila
parents: 16234
diff changeset
   221
}