From af7acf2ed6de83624492365a6012aeb3e07e2ea5 Mon Sep 17 00:00:00 2001 From: Andrew Haley Date: Mon, 12 Jun 2006 13:37:54 +0000 Subject: re PR java/27908 (VMSecureRandom generateSeed infinite loop? (Regression)) 2006-06-12 Andrew Haley * testsuite/libjava.lang/PR27908.out: New. * testsuite/libjava.lang/PR27908.java: New. From-SVN: r114568 --- libjava/ChangeLog | 5 ++ libjava/testsuite/libjava.lang/PR27908.java | 80 +++++++++++++++++++++++++++++ libjava/testsuite/libjava.lang/PR27908.out | 3 ++ 3 files changed, 88 insertions(+) create mode 100644 libjava/testsuite/libjava.lang/PR27908.java create mode 100644 libjava/testsuite/libjava.lang/PR27908.out (limited to 'libjava') diff --git a/libjava/ChangeLog b/libjava/ChangeLog index be95312..918037f 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2006-06-12 Andrew Haley + + * testsuite/libjava.lang/PR27908.out: New. + * testsuite/libjava.lang/PR27908.java: New. + 2006-06-10 Thomas Fitzsimmons * configure.ac (ac_configure_args): Add --disable-plugin. 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; + } + } + +} diff --git a/libjava/testsuite/libjava.lang/PR27908.out b/libjava/testsuite/libjava.lang/PR27908.out new file mode 100644 index 0000000..81bc2b2 --- /dev/null +++ b/libjava/testsuite/libjava.lang/PR27908.out @@ -0,0 +1,3 @@ +run2 exits! +run3 exits! +run1 exits! -- cgit v1.1