diff options
author | Andrew Haley <aph@redhat.com> | 2006-06-12 13:37:54 +0000 |
---|---|---|
committer | Andrew Haley <aph@gcc.gnu.org> | 2006-06-12 13:37:54 +0000 |
commit | af7acf2ed6de83624492365a6012aeb3e07e2ea5 (patch) | |
tree | e852ebce97681c2801a4731c4b602c01529d4c4b /libjava/testsuite/libjava.lang/PR27908.java | |
parent | dda69cbfb766b86ee8f9e04d0256f660ced51342 (diff) | |
download | gcc-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.java | 80 |
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; + } + } + +} |