Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Latest commit

 

History

History
History
79 lines (76 loc) · 4.01 KB

File metadata and controls

79 lines (76 loc) · 4.01 KB
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
* Copyright (c) 2007 Sun Microsystems, Inc. All rights reserved.
*
* Sun Microsystems, Inc. has intellectual property rights relating to technology embodied in the product
* that is described in this document. In particular, and without limitation, these intellectual property
* rights may include one or more of the U.S. patents listed at http://www.sun.com/patents and one or
* more additional patents or pending patent applications in the U.S. and in other countries.
*
* U.S. Government Rights - Commercial software. Government users are subject to the Sun
* Microsystems, Inc. standard license agreement and applicable provisions of the FAR and its
* supplements.
*
* Use is subject to license terms. Sun, Sun Microsystems, the Sun logo, Java and Solaris are trademarks or
* registered trademarks of Sun Microsystems, Inc. in the U.S. and other countries. All SPARC trademarks
* are used under license and are trademarks or registered trademarks of SPARC International, Inc. in the
* U.S. and other countries.
*
* UNIX is a registered trademark in the U.S. and other countries, exclusively licensed through X/Open
* Company, Ltd.
*/
package com.sun.max.annotate;
import java.lang.annotation.*;
/**
* Every thus annotated method is to be inlined unconditionally by the VM's optimizing compiler
* and the receiver is never null-checked.
*
* This annotation exists primarily for annotating methods that <b>must</b> be inlined
* for semantic reasons as opposed to those that could be inlined for performance reasons.
* Using this annotation for the latter should be done very rarely and only when
* profiling highlights a performance bottleneck or such a bottleneck is known <i>a priori</i>.
*
* If the {@linkplain #override() override} element of this annotation is set to true, then
* an annotated method must be {@code static} or {@code final} (implicitly or explicitly).
* Additionally, only a INLINE virtual method with this element set to true can be overridden.
*
* @author Bernd Mathiske
* @author Doug Simon
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface INLINE {
/**
* If true, this element specifies that the annotated method provides the prototypical implementation
* of the functionality expected (in the target VM) of every method that overrides
* the annotated method. That is, the code produced by the compiler for every overriding method
* must be functionality equivalent to the code produced for the prototypical method.
*
* <b>WARNING: Setting this element to true implies that you guarantee that all overriders
* satisfy the above stated invariant.</b> There is no (easy) way to test for violations of
* the invariant.
*
* A method annotated with INLINE should only be overridden for one of the following reasons:
*
* 1. To coerce the value returned by the overridden method to a subtype.
* See {@link MemberActor#holder()} and {@link FieldActor#holder()} for an example.
*
* 2. A method is overridden to make bootstrapping work.
* See {@link ClassActor#toJava()} and {@link ArrayClassActor#toJava()} for an example.
*
* 3. A method is overridden because a subclass can provide a more efficient implementation
* and it is known that certain call sites will be reduced to a constant receiver
* (not just a known receiver type but a known receiver object) via annotation driven
* compile-time {@linkplain FOLD folding}. This is how calls to the {@link GeneralLayout layout}
* interface methods are reduced to monomorphic calls at compile-time.
*
* See {@link ClassActor#toJava()} and {@link ArrayClassActor#toJava()} for an example.
*/
boolean override() default false;
/**
* If true, this element specifies that inlining of the thus annotated method is only allowed
* after snippet compilation has concluded.
*
* @see CompilerScheme#areSnippetsCompiled()
*/
boolean afterSnippetsAreCompiled() default false;
}
Morty Proxy This is a proxified and sanitized view of the page, visit original site.