aboutsummaryrefslogtreecommitdiff
path: root/libjava/testsuite/libjava.lang/PR27908.java
diff options
context:
space:
mode:
authorAndrew Haley <aph@redhat.com>2006-06-12 13:37:54 +0000
committerAndrew Haley <aph@gcc.gnu.org>2006-06-12 13:37:54 +0000
commitaf7acf2ed6de83624492365a6012aeb3e07e2ea5 (patch)
treee852ebce97681c2801a4731c4b602c01529d4c4b /libjava/testsuite/libjava.lang/PR27908.java
parentdda69cbfb766b86ee8f9e04d0256f660ced51342 (diff)
downloadgcc-af7acf2ed6de83624492365a6012aeb3e07e2ea5.zip
gcc-af7acf2ed6de83624492365a6012aeb3e07e2ea5.tar.gz
gcc-af7acf2ed6de83624492365a6012aeb3e07e2ea5.tar.bz2
re PR java/27908 (VMSecureRandom generateSeed infinite loop? (Regression))
2006-06-12 Andrew Haley <aph@redhat.com> * testsuite/libjava.lang/PR27908.out: New. * testsuite/libjava.lang/PR27908.java: New. From-SVN: r114568
Diffstat (limited to 'libjava/testsuite/libjava.lang/PR27908.java')
-rw-r--r--libjava/testsuite/libjava.lang/PR27908.java80
1 files changed, 80 insertions, 0 deletions
diff --git a/libjava/testsuite/libjava.lang/PR27908.java b/libjava/testsuite/libjava.lang/PR27908.java
new file mode 100644
index 0000000..66e7fca
--- /dev/null
+++ b/libjava/testsuite/libjava.lang/PR27908.java
@@ -0,0 +1,80 @@
+class PR27908
+{
+ public static void main (String[] argv)
+ {
+ run1 r1 = new run1();
+ run2 r2 = new run2();
+ run3 r3 = new run3();
+
+ new Thread (r1).start();
+ new Thread (r2).start();
+ new Thread (r3).start();
+
+ Thread.yield();
+
+ r1.stop();
+ r2.stop();
+ r3.stop();
+ }
+
+ private static class run1 implements Runnable
+ {
+ volatile int counter;
+ volatile boolean running;
+
+ public void run ()
+ {
+ counter = 0;
+ running = true;
+ while (running)
+ counter++;
+ System.out.println ("run1 exits!");
+ }
+
+ private void stop ()
+ {
+ running = false;
+ }
+ }
+
+ private static class run2 implements Runnable
+ {
+ volatile int counter;
+ boolean running;
+
+ public void run ()
+ {
+ counter = 0;
+ running = true;
+ while (running)
+ counter++;
+ System.out.println ("run2 exits!");
+ }
+
+ private void stop ()
+ {
+ running = false;
+ }
+ }
+
+ static class run3 implements Runnable
+ {
+ volatile int counter;
+ private volatile boolean running;
+
+ public void run ()
+ {
+ counter = 0;
+ running = true;
+ while (running)
+ counter++;
+ System.out.println ("run3 exits!");
+ }
+
+ void stop ()
+ {
+ running = false;
+ }
+ }
+
+}