Mercurial > hg > truffle
annotate src/os_cpu/solaris_x86/vm/solaris_x86_64.il @ 16425:8eec87d7bfc4
made Factory.newClassLoader() private
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Tue, 08 Jul 2014 21:23:22 +0200 |
parents | b9a9ed0f8eeb |
children |
rev | line source |
---|---|
0 | 1 // |
6842
b9a9ed0f8eeb
7197424: update copyright year to match last edit in jdk8 hotspot repository
mikael
parents:
5903
diff
changeset
|
2 // Copyright (c) 2004, 2012, Oracle and/or its affiliates. All rights reserved. |
0 | 3 // DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 // | |
5 // This code is free software; you can redistribute it and/or modify it | |
6 // under the terms of the GNU General Public License version 2 only, as | |
7 // published by the Free Software Foundation. | |
8 // | |
9 // This code is distributed in the hope that it will be useful, but WITHOUT | |
10 // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 // version 2 for more details (a copy is included in the LICENSE file that | |
13 // accompanied this code). | |
14 // | |
15 // You should have received a copy of the GNU General Public License version | |
16 // 2 along with this work; if not, write to the Free Software Foundation, | |
17 // Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 // | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1547
diff
changeset
|
19 // Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1547
diff
changeset
|
20 // or visit www.oracle.com if you need additional information or have any |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1547
diff
changeset
|
21 // questions. |
0 | 22 // |
23 // | |
24 | |
25 // The argument size of each inline directive is ignored by the compiler | |
26 // and is set to the number of arguments as documentation. | |
27 | |
28 // Get the raw thread ID from %gs:0 | |
29 .inline _raw_thread_id,0 | |
30 movq %fs:0, %rax | |
31 .end | |
32 | |
5903
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
33 // Get current sp |
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
34 .inline _get_current_sp,0 |
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
35 .volatile |
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
36 movq %rsp, %rax |
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
37 .end |
da4be62fb889
7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents:
4749
diff
changeset
|
38 |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
39 // Get current fp |
472
7b920868b475
6773838: There is no calling stack for Compiler thread in hs_err file on x86
coleenp
parents:
0
diff
changeset
|
40 .inline _get_current_fp,0 |
7b920868b475
6773838: There is no calling stack for Compiler thread in hs_err file on x86
coleenp
parents:
0
diff
changeset
|
41 .volatile |
0 | 42 movq %rbp, %rax |
43 .end | |
44 | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
45 // Support for os::rdtsc() |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
46 .inline _raw_rdtsc,0 |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
47 rdtsc |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
48 salq $32, %rdx |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
49 orq %rdx, %rax |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
50 .end |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2042
diff
changeset
|
51 |
0 | 52 // Support for jint Atomic::add(jint add_value, volatile jint* dest) |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
53 .inline _Atomic_add,2 |
0 | 54 movl %edi, %eax // save add_value for return |
55 lock | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
56 xaddl %edi, (%rsi) |
0 | 57 addl %edi, %eax |
58 .end | |
59 | |
60 // Support for jlong Atomic::add(jlong add_value, volatile jlong* dest) | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
61 .inline _Atomic_add_long,2 |
0 | 62 movq %rdi, %rax // save add_value for return |
63 lock | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
64 xaddq %rdi, (%rsi) |
0 | 65 addq %rdi, %rax |
66 .end | |
67 | |
68 // Support for jint Atomic::xchg(jint exchange_value, volatile jint* dest). | |
69 .inline _Atomic_xchg,2 | |
70 xchgl (%rsi), %edi | |
71 movl %edi, %eax | |
72 .end | |
73 | |
74 // Support for jlong Atomic::xchg(jlong exchange_value, volatile jlong* dest). | |
75 .inline _Atomic_xchg_long,2 | |
76 xchgq (%rsi), %rdi | |
77 movq %rdi, %rax | |
78 .end | |
79 | |
80 // Support for jint Atomic::cmpxchg(jint exchange_value, | |
81 // volatile jint *dest, | |
82 // jint compare_value) | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
83 .inline _Atomic_cmpxchg,3 |
0 | 84 movl %edx, %eax // compare_value |
85 lock | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
86 cmpxchgl %edi, (%rsi) |
0 | 87 .end |
88 | |
89 // Support for jlong Atomic::cmpxchg(jlong exchange_value, | |
90 // volatile jlong* dest, | |
91 // jlong compare_value) | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
92 .inline _Atomic_cmpxchg_long,3 |
0 | 93 movq %rdx, %rax // compare_value |
94 lock | |
1547
fb1a39993f69
6951319: enable solaris builds using Sun Studio 12 update 1
jcoomes
parents:
579
diff
changeset
|
95 cmpxchgq %rdi, (%rsi) |
0 | 96 .end |
97 | |
98 // Support for OrderAccess::acquire() | |
99 .inline _OrderAccess_acquire,0 | |
100 movl 0(%rsp), %eax | |
101 .end | |
102 | |
103 // Support for OrderAccess::fence() | |
104 .inline _OrderAccess_fence,0 | |
105 lock | |
106 addl $0, (%rsp) | |
107 .end | |
108 | |
109 // Support for u2 Bytes::swap_u2(u2 x) | |
110 .inline _raw_swap_u2,1 | |
111 movw %di, %ax | |
112 rorw $8, %ax | |
113 .end | |
114 | |
115 // Support for u4 Bytes::swap_u4(u4 x) | |
116 .inline _raw_swap_u4,1 | |
117 movl %edi, %eax | |
118 bswapl %eax | |
119 .end | |
120 | |
121 // Support for u8 Bytes::swap_u8(u8 x) | |
122 .inline _raw_swap_u8,1 | |
123 movq %rdi, %rax | |
124 bswapq %rax | |
125 .end | |
126 | |
127 // Support for void Prefetch::read | |
128 .inline _Prefetch_read,2 | |
129 prefetcht0 (%rdi, %rsi, 1) | |
130 .end | |
131 | |
132 // Support for void Prefetch::write | |
133 // We use prefetcht0 because em64t doesn't support prefetchw. | |
134 // prefetchw is a 3dnow instruction. | |
135 .inline _Prefetch_write,2 | |
136 prefetcht0 (%rdi, %rsi, 1) | |
137 .end |