test/compiler/uncommontrap/TestStackBangMonitorOwned.java

Tue, 01 Apr 2014 09:36:49 +0200

author
roland
date
Tue, 01 Apr 2014 09:36:49 +0200
changeset 6723
0bf37f737702
parent 0
f90c822e73f8
permissions
-rw-r--r--

8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
Summary: make compiled code bang the stack by the worst case size of the interpreter frame at deoptimization points.
Reviewed-by: twisti, kvn

aoqi@0 1 /*
aoqi@0 2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
aoqi@0 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
aoqi@0 4 *
aoqi@0 5 * This code is free software; you can redistribute it and/or modify it
aoqi@0 6 * under the terms of the GNU General Public License version 2 only, as
aoqi@0 7 * published by the Free Software Foundation.
aoqi@0 8 *
aoqi@0 9 * This code is distributed in the hope that it will be useful, but WITHOUT
aoqi@0 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
aoqi@0 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
aoqi@0 12 * version 2 for more details (a copy is included in the LICENSE file that
aoqi@0 13 * accompanied this code).
aoqi@0 14 *
aoqi@0 15 * You should have received a copy of the GNU General Public License version
aoqi@0 16 * 2 along with this work; if not, write to the Free Software Foundation,
aoqi@0 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
aoqi@0 18 *
aoqi@0 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
aoqi@0 20 * or visit www.oracle.com if you need additional information or have any
aoqi@0 21 * questions.
aoqi@0 22 */
aoqi@0 23
aoqi@0 24 /*
aoqi@0 25 * @test
aoqi@0 26 * @bug 8032410
aoqi@0 27 * @summary Stack overflow at deoptimization doesn't release owned monitors
aoqi@0 28 * @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,TestStackBangMonitorOwned::m1 -XX:CompileCommand=exclude,TestStackBangMonitorOwned::m2 -Xss256K -XX:-UseOnStackReplacement TestStackBangMonitorOwned
aoqi@0 29 *
aoqi@0 30 */
aoqi@0 31 public class TestStackBangMonitorOwned {
aoqi@0 32
aoqi@0 33 static class UnloadedClass1 {
aoqi@0 34 volatile int field;
aoqi@0 35 }
aoqi@0 36
aoqi@0 37 static Object m1(boolean deopt) {
aoqi@0 38 long l0, l1, l2, l3, l4, l5, l6, l7, l8, l9, l10, l11, l12,
aoqi@0 39 l13, l14, l15, l16, l17, l18, l19, l20, l21, l22, l23, l24,
aoqi@0 40 l25, l26, l27, l28, l29, l30, l31, l32, l33, l34, l35, l36,
aoqi@0 41 l37, l38, l39, l40, l41, l42, l43, l44, l45, l46, l47, l48,
aoqi@0 42 l49, l50, l51, l52, l53, l54, l55, l56, l57, l58, l59, l60,
aoqi@0 43 l61, l62, l63, l64, l65, l66, l67, l68, l69, l70, l71, l72,
aoqi@0 44 l73, l74, l75, l76, l77, l78, l79, l80, l81, l82, l83, l84,
aoqi@0 45 l85, l86, l87, l88, l89, l90, l91, l92, l93, l94, l95, l96,
aoqi@0 46 l97, l98, l99, l100, l101, l102, l103, l104, l105, l106, l107,
aoqi@0 47 l108, l109, l110, l111, l112, l113, l114, l115, l116, l117,
aoqi@0 48 l118, l119, l120, l121, l122, l123, l124, l125, l126, l127,
aoqi@0 49 l128, l129, l130, l131, l132, l133, l134, l135, l136, l137,
aoqi@0 50 l138, l139, l140, l141, l142, l143, l144, l145, l146, l147,
aoqi@0 51 l148, l149, l150, l151, l152, l153, l154, l155, l156, l157,
aoqi@0 52 l158, l159, l160, l161, l162, l163, l164, l165, l166, l167,
aoqi@0 53 l168, l169, l170, l171, l172, l173, l174, l175, l176, l177,
aoqi@0 54 l178, l179, l180, l181, l182, l183, l184, l185, l186, l187,
aoqi@0 55 l188, l189, l190, l191, l192, l193, l194, l195, l196, l197,
aoqi@0 56 l198, l199, l200, l201, l202, l203, l204, l205, l206, l207,
aoqi@0 57 l208, l209, l210, l211, l212, l213, l214, l215, l216, l217,
aoqi@0 58 l218, l219, l220, l221, l222, l223, l224, l225, l226, l227,
aoqi@0 59 l228, l229, l230, l231, l232, l233, l234, l235, l236, l237,
aoqi@0 60 l238, l239, l240, l241, l242, l243, l244, l245, l246, l247,
aoqi@0 61 l248, l249, l250, l251, l252, l253, l254, l255, l256, l257,
aoqi@0 62 l258, l259, l260, l261, l262, l263, l264, l265, l266, l267,
aoqi@0 63 l268, l269, l270, l271, l272, l273, l274, l275, l276, l277,
aoqi@0 64 l278, l279, l280, l281, l282, l283, l284, l285, l286, l287,
aoqi@0 65 l288, l289, l290, l291, l292, l293, l294, l295, l296, l297,
aoqi@0 66 l298, l299, l300, l301, l302, l303, l304, l305, l306, l307,
aoqi@0 67 l308, l309, l310, l311, l312, l313, l314, l315, l316, l317,
aoqi@0 68 l318, l319, l320, l321, l322, l323, l324, l325, l326, l327,
aoqi@0 69 l328, l329, l330, l331, l332, l333, l334, l335, l336, l337,
aoqi@0 70 l338, l339, l340, l341, l342, l343, l344, l345, l346, l347,
aoqi@0 71 l348, l349, l350, l351, l352, l353, l354, l355, l356, l357,
aoqi@0 72 l358, l359, l360, l361, l362, l363, l364, l365, l366, l367,
aoqi@0 73 l368, l369, l370, l371, l372, l373, l374, l375, l376, l377,
aoqi@0 74 l378, l379, l380, l381, l382, l383, l384, l385, l386, l387,
aoqi@0 75 l388, l389, l390, l391, l392, l393, l394, l395, l396, l397,
aoqi@0 76 l398, l399, l400, l401, l402, l403, l404, l405, l406, l407,
aoqi@0 77 l408, l409, l410, l411, l412, l413, l414, l415, l416, l417,
aoqi@0 78 l418, l419, l420, l421, l422, l423, l424, l425, l426, l427,
aoqi@0 79 l428, l429, l430, l431, l432, l433, l434, l435, l436, l437,
aoqi@0 80 l438, l439, l440, l441, l442, l443, l444, l445, l446, l447,
aoqi@0 81 l448, l449, l450, l451, l452, l453, l454, l455, l456, l457,
aoqi@0 82 l458, l459, l460, l461, l462, l463, l464, l465, l466, l467,
aoqi@0 83 l468, l469, l470, l471, l472, l473, l474, l475, l476, l477,
aoqi@0 84 l478, l479, l480, l481, l482, l483, l484, l485, l486, l487,
aoqi@0 85 l488, l489, l490, l491, l492, l493, l494, l495, l496, l497,
aoqi@0 86 l498, l499, l500, l501, l502, l503, l504, l505, l506, l507,
aoqi@0 87 l508, l509, l510, l511;
aoqi@0 88
aoqi@0 89 long ll0, ll1, ll2, ll3, ll4, ll5, ll6, ll7, ll8, ll9, ll10, ll11, ll12,
aoqi@0 90 ll13, ll14, ll15, ll16, ll17, ll18, ll19, ll20, ll21, ll22, ll23, ll24,
aoqi@0 91 ll25, ll26, ll27, ll28, ll29, ll30, ll31, ll32, ll33, ll34, ll35, ll36,
aoqi@0 92 ll37, ll38, ll39, ll40, ll41, ll42, ll43, ll44, ll45, ll46, ll47, ll48,
aoqi@0 93 ll49, ll50, ll51, ll52, ll53, ll54, ll55, ll56, ll57, ll58, ll59, ll60,
aoqi@0 94 ll61, ll62, ll63, ll64, ll65, ll66, ll67, ll68, ll69, ll70, ll71, ll72,
aoqi@0 95 ll73, ll74, ll75, ll76, ll77, ll78, ll79, ll80, ll81, ll82, ll83, ll84,
aoqi@0 96 ll85, ll86, ll87, ll88, ll89, ll90, ll91, ll92, ll93, ll94, ll95, ll96,
aoqi@0 97 ll97, ll98, ll99, ll100, ll101, ll102, ll103, ll104, ll105, ll106, ll107,
aoqi@0 98 ll108, ll109, ll110, ll111, ll112, ll113, ll114, ll115, ll116, ll117,
aoqi@0 99 ll118, ll119, ll120, ll121, ll122, ll123, ll124, ll125, ll126, ll127,
aoqi@0 100 ll128, ll129, ll130, ll131, ll132, ll133, ll134, ll135, ll136, ll137,
aoqi@0 101 ll138, ll139, ll140, ll141, ll142, ll143, ll144, ll145, ll146, ll147,
aoqi@0 102 ll148, ll149, ll150, ll151, ll152, ll153, ll154, ll155, ll156, ll157,
aoqi@0 103 ll158, ll159, ll160, ll161, ll162, ll163, ll164, ll165, ll166, ll167,
aoqi@0 104 ll168, ll169, ll170, ll171, ll172, ll173, ll174, ll175, ll176, ll177,
aoqi@0 105 ll178, ll179, ll180, ll181, ll182, ll183, ll184, ll185, ll186, ll187,
aoqi@0 106 ll188, ll189, ll190, ll191, ll192, ll193, ll194, ll195, ll196, ll197,
aoqi@0 107 ll198, ll199, ll200, ll201, ll202, ll203, ll204, ll205, ll206, ll207,
aoqi@0 108 ll208, ll209, ll210, ll211, ll212, ll213, ll214, ll215, ll216, ll217,
aoqi@0 109 ll218, ll219, ll220, ll221, ll222, ll223, ll224, ll225, ll226, ll227,
aoqi@0 110 ll228, ll229, ll230, ll231, ll232, ll233, ll234, ll235, ll236, ll237,
aoqi@0 111 ll238, ll239, ll240, ll241, ll242, ll243, ll244, ll245, ll246, ll247,
aoqi@0 112 ll248, ll249, ll250, ll251, ll252, ll253, ll254, ll255, ll256, ll257,
aoqi@0 113 ll258, ll259, ll260, ll261, ll262, ll263, ll264, ll265, ll266, ll267,
aoqi@0 114 ll268, ll269, ll270, ll271, ll272, ll273, ll274, ll275, ll276, ll277,
aoqi@0 115 ll278, ll279, ll280, ll281, ll282, ll283, ll284, ll285, ll286, ll287,
aoqi@0 116 ll288, ll289, ll290, ll291, ll292, ll293, ll294, ll295, ll296, ll297,
aoqi@0 117 ll298, ll299, ll300, ll301, ll302, ll303, ll304, ll305, ll306, ll307,
aoqi@0 118 ll308, ll309, ll310, ll311, ll312, ll313, ll314, ll315, ll316, ll317,
aoqi@0 119 ll318, ll319, ll320, ll321, ll322, ll323, ll324, ll325, ll326, ll327,
aoqi@0 120 ll328, ll329, ll330, ll331, ll332, ll333, ll334, ll335, ll336, ll337,
aoqi@0 121 ll338, ll339, ll340, ll341, ll342, ll343, ll344, ll345, ll346, ll347,
aoqi@0 122 ll348, ll349, ll350, ll351, ll352, ll353, ll354, ll355, ll356, ll357,
aoqi@0 123 ll358, ll359, ll360, ll361, ll362, ll363, ll364, ll365, ll366, ll367,
aoqi@0 124 ll368, ll369, ll370, ll371, ll372, ll373, ll374, ll375, ll376, ll377,
aoqi@0 125 ll378, ll379, ll380, ll381, ll382, ll383, ll384, ll385, ll386, ll387,
aoqi@0 126 ll388, ll389, ll390, ll391, ll392, ll393, ll394, ll395, ll396, ll397,
aoqi@0 127 ll398, ll399, ll400, ll401, ll402, ll403, ll404, ll405, ll406, ll407,
aoqi@0 128 ll408, ll409, ll410, ll411, ll412, ll413, ll414, ll415, ll416, ll417,
aoqi@0 129 ll418, ll419, ll420, ll421, ll422, ll423, ll424, ll425, ll426, ll427,
aoqi@0 130 ll428, ll429, ll430, ll431, ll432, ll433, ll434, ll435, ll436, ll437,
aoqi@0 131 ll438, ll439, ll440, ll441, ll442, ll443, ll444, ll445, ll446, ll447,
aoqi@0 132 ll448, ll449, ll450, ll451, ll452, ll453, ll454, ll455, ll456, ll457,
aoqi@0 133 ll458, ll459, ll460, ll461, ll462, ll463, ll464, ll465, ll466, ll467,
aoqi@0 134 ll468, ll469, ll470, ll471, ll472, ll473, ll474, ll475, ll476, ll477,
aoqi@0 135 ll478, ll479, ll480, ll481, ll482, ll483, ll484, ll485, ll486, ll487,
aoqi@0 136 ll488, ll489, ll490, ll491, ll492, ll493, ll494, ll495, ll496, ll497,
aoqi@0 137 ll498, ll499, ll500, ll501, ll502, ll503, ll504, ll505, ll506, ll507,
aoqi@0 138 ll508, ll509, ll510, ll511;
aoqi@0 139
aoqi@0 140 if (deopt) {
aoqi@0 141 method_entered = true;
aoqi@0 142 synchronized(monitor) {
aoqi@0 143 do_monitor_acquire = true;
aoqi@0 144 UnloadedClass1 res = new UnloadedClass1(); // forces deopt with c2
aoqi@0 145 res.field = 0; //forced deopt with c1
aoqi@0 146 return res;
aoqi@0 147 }
aoqi@0 148 }
aoqi@0 149 return null;
aoqi@0 150 }
aoqi@0 151
aoqi@0 152 static boolean m2(boolean deopt) {
aoqi@0 153 long l0, l1, l2, l3, l4, l5, l6, l7, l8, l9, l10, l11, l12,
aoqi@0 154 l13, l14, l15, l16, l17, l18, l19, l20, l21, l22, l23, l24,
aoqi@0 155 l25, l26, l27, l28, l29, l30, l31, l32, l33, l34, l35, l36,
aoqi@0 156 l37, l38, l39, l40, l41, l42, l43, l44, l45, l46, l47, l48,
aoqi@0 157 l49, l50, l51, l52, l53, l54, l55, l56, l57, l58, l59, l60,
aoqi@0 158 l61, l62, l63, l64, l65, l66, l67, l68, l69, l70, l71, l72,
aoqi@0 159 l73, l74, l75, l76, l77, l78, l79, l80, l81, l82, l83, l84,
aoqi@0 160 l85, l86, l87, l88, l89, l90, l91, l92, l93, l94, l95, l96,
aoqi@0 161 l97, l98, l99, l100, l101, l102, l103, l104, l105, l106, l107,
aoqi@0 162 l108, l109, l110, l111, l112, l113, l114, l115, l116, l117,
aoqi@0 163 l118, l119, l120, l121, l122, l123, l124, l125, l126, l127,
aoqi@0 164 l128, l129, l130, l131, l132, l133, l134, l135, l136, l137,
aoqi@0 165 l138, l139, l140, l141, l142, l143, l144, l145, l146, l147,
aoqi@0 166 l148, l149, l150, l151, l152, l153, l154, l155, l156, l157,
aoqi@0 167 l158, l159, l160, l161, l162, l163, l164, l165, l166, l167,
aoqi@0 168 l168, l169, l170, l171, l172, l173, l174, l175, l176, l177,
aoqi@0 169 l178, l179, l180, l181, l182, l183, l184, l185, l186, l187,
aoqi@0 170 l188, l189, l190, l191, l192, l193, l194, l195, l196, l197,
aoqi@0 171 l198, l199, l200, l201, l202, l203, l204, l205, l206, l207,
aoqi@0 172 l208, l209, l210, l211, l212, l213, l214, l215, l216, l217,
aoqi@0 173 l218, l219, l220, l221, l222, l223, l224, l225, l226, l227,
aoqi@0 174 l228, l229, l230, l231, l232, l233, l234, l235, l236, l237,
aoqi@0 175 l238, l239, l240, l241, l242, l243, l244, l245, l246, l247,
aoqi@0 176 l248, l249, l250, l251, l252, l253, l254, l255, l256, l257,
aoqi@0 177 l258, l259, l260, l261, l262, l263, l264, l265, l266, l267,
aoqi@0 178 l268, l269, l270, l271, l272, l273, l274, l275, l276, l277,
aoqi@0 179 l278, l279, l280, l281, l282, l283, l284, l285, l286, l287,
aoqi@0 180 l288, l289, l290, l291, l292, l293, l294, l295, l296, l297,
aoqi@0 181 l298, l299, l300, l301, l302, l303, l304, l305, l306, l307,
aoqi@0 182 l308, l309, l310, l311, l312, l313, l314, l315, l316, l317,
aoqi@0 183 l318, l319, l320, l321, l322, l323, l324, l325, l326, l327,
aoqi@0 184 l328, l329, l330, l331, l332, l333, l334, l335, l336, l337,
aoqi@0 185 l338, l339, l340, l341, l342, l343, l344, l345, l346, l347,
aoqi@0 186 l348, l349, l350, l351, l352, l353, l354, l355, l356, l357,
aoqi@0 187 l358, l359, l360, l361, l362, l363, l364, l365, l366, l367,
aoqi@0 188 l368, l369, l370, l371, l372, l373, l374, l375, l376, l377,
aoqi@0 189 l378, l379, l380, l381, l382, l383, l384, l385, l386, l387,
aoqi@0 190 l388, l389, l390, l391, l392, l393, l394, l395, l396, l397,
aoqi@0 191 l398, l399, l400, l401, l402, l403, l404, l405, l406, l407,
aoqi@0 192 l408, l409, l410, l411, l412, l413, l414, l415, l416, l417,
aoqi@0 193 l418, l419, l420, l421, l422, l423, l424, l425, l426, l427,
aoqi@0 194 l428, l429, l430, l431, l432, l433, l434, l435, l436, l437,
aoqi@0 195 l438, l439, l440, l441, l442, l443, l444, l445, l446, l447,
aoqi@0 196 l448, l449, l450, l451, l452, l453, l454, l455, l456, l457,
aoqi@0 197 l458, l459, l460, l461, l462, l463, l464, l465, l466, l467,
aoqi@0 198 l468, l469, l470, l471, l472, l473, l474, l475, l476, l477,
aoqi@0 199 l478, l479, l480, l481, l482, l483, l484, l485, l486, l487,
aoqi@0 200 l488, l489, l490, l491, l492, l493, l494, l495, l496, l497,
aoqi@0 201 l498, l499, l500, l501, l502, l503, l504, l505, l506, l507,
aoqi@0 202 l508, l509, l510, l511;
aoqi@0 203
aoqi@0 204 boolean do_m3 = false;
aoqi@0 205 try {
aoqi@0 206 do_m3 = m2(deopt);
aoqi@0 207 } catch (StackOverflowError e) {
aoqi@0 208 return true;
aoqi@0 209 }
aoqi@0 210 if (do_m3) {
aoqi@0 211 try {
aoqi@0 212 m1(deopt);
aoqi@0 213 } catch (StackOverflowError e) {}
aoqi@0 214 }
aoqi@0 215 return false;
aoqi@0 216 }
aoqi@0 217
aoqi@0 218 // Used for synchronization betwen threads
aoqi@0 219 static volatile boolean thread_started = false;
aoqi@0 220 static volatile boolean do_monitor_acquire = false;
aoqi@0 221 static volatile boolean monitor_acquired = false;
aoqi@0 222 static volatile boolean method_entered = false;
aoqi@0 223
aoqi@0 224 static Object monitor = new Object();
aoqi@0 225
aoqi@0 226 static public void main(String[] args) {
aoqi@0 227 // get m1 compiled
aoqi@0 228 for (int i = 0; i < 20000; i++) {
aoqi@0 229 m1(false);
aoqi@0 230 }
aoqi@0 231
aoqi@0 232 Thread thread = new Thread() {
aoqi@0 233 public void run() {
aoqi@0 234 thread_started = true;
aoqi@0 235 while(!do_monitor_acquire);
aoqi@0 236 System.out.println("Ok to try to acquire the lock");
aoqi@0 237 synchronized(monitor) {
aoqi@0 238 monitor_acquired = true;
aoqi@0 239 }
aoqi@0 240 }
aoqi@0 241 };
aoqi@0 242
aoqi@0 243 thread.setDaemon(true);
aoqi@0 244 thread.start();
aoqi@0 245
aoqi@0 246 while(!thread_started);
aoqi@0 247
aoqi@0 248 m2(true);
aoqi@0 249
aoqi@0 250 if (!method_entered) {
aoqi@0 251 System.out.println("TEST PASSED");
aoqi@0 252 return;
aoqi@0 253 }
aoqi@0 254
aoqi@0 255 for (int i = 0; i < 10; i++) {
aoqi@0 256 System.out.println("Is lock acquired?");
aoqi@0 257 if (monitor_acquired) {
aoqi@0 258 System.out.println("TEST PASSED");
aoqi@0 259 return;
aoqi@0 260 }
aoqi@0 261 try {
aoqi@0 262 Thread.sleep(10000);
aoqi@0 263 } catch(InterruptedException ie) {
aoqi@0 264 }
aoqi@0 265 }
aoqi@0 266 System.out.println("TEST FAILED");
aoqi@0 267 }
aoqi@0 268 }

mercurial