From 803e3563c0f5c255596be365fee03588bad8efec Mon Sep 17 00:00:00 2001 From: aph Date: Mon, 19 Jun 2006 17:39:16 +0000 Subject: [PATCH] 2006-06-19 Andrew Haley * testsuite/libjava.lang/PR27908.out: New. * testsuite/libjava.lang/PR27908.java: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@114779 138bc75d-0d04-0410-961f-82ee72b054a4 --- libjava/ChangeLog | 5 ++ libjava/testsuite/libjava.lang/PR27908.java | 87 +++++++++++++++++++++++++++++ libjava/testsuite/libjava.lang/PR27908.out | 0 3 files changed, 92 insertions(+) create mode 100644 libjava/testsuite/libjava.lang/PR27908.java create mode 100644 libjava/testsuite/libjava.lang/PR27908.out diff --git a/libjava/ChangeLog b/libjava/ChangeLog index e67b5f8..92ed467 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2006-06-19 Andrew Haley + + * testsuite/libjava.lang/PR27908.out: New. + * testsuite/libjava.lang/PR27908.java: New. + 2006-06-19 Keith Seitz * include/posix-threads.h (_Jv_ThreadDebugSuspend): Declare. diff --git a/libjava/testsuite/libjava.lang/PR27908.java b/libjava/testsuite/libjava.lang/PR27908.java new file mode 100644 index 0000000..09f9654 --- /dev/null +++ b/libjava/testsuite/libjava.lang/PR27908.java @@ -0,0 +1,87 @@ +class PR27908 +{ + public static void main (String[] argv) + throws InterruptedException + { + run1 r1 = new run1(); + run2 r2 = new run2(); + run3 r3 = new run3(); + + Thread t1, t2, t3; + + (t1 = new Thread (r1)).start(); + (t2 = new Thread (r2)).start(); + (t3 = new Thread (r3)).start(); + + Thread.yield(); + + r1.stop(); + r2.stop(); + r3.stop(); + + Thread.sleep(5000); + + if (t1.isAlive() || t2.isAlive() || t3.isAlive()) + { + System.out.println ("fail"); + System.exit(1); + } + } + + private static class run1 implements Runnable + { + volatile int counter; + volatile boolean running; + + public void run () + { + counter = 0; + running = true; + while (running) + counter++; + } + + 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++; + } + + 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++; + } + + 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..e69de29 -- 2.7.4