Rev 3022 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 3022 | Rev 4668 | ||
---|---|---|---|
Line 25... | Line 25... | ||
25 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
25 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
26 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
26 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
27 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
28 | */ |
28 | */ |
29 | 29 | ||
30 | #define THREADS 5 |
30 | #define THREADS 20 |
- | 31 | #define DELAY 10 |
|
31 | 32 | ||
32 | #include <atomic.h> |
33 | #include <atomic.h> |
33 | #include <thread.h> |
34 | #include <thread.h> |
34 | #include <stdio.h> |
35 | #include <stdio.h> |
35 | #include <unistd.h> |
36 | #include <unistd.h> |
Line 40... | Line 41... | ||
40 | static bool sh_quiet; |
41 | static bool sh_quiet; |
41 | 42 | ||
42 | static void threadtest(void *data) |
43 | static void threadtest(void *data) |
43 | { |
44 | { |
44 | thread_detach(thread_get_id()); |
45 | thread_detach(thread_get_id()); |
45 | 46 | ||
46 | while (atomic_get(&finish)) { |
47 | while (atomic_get(&finish)) |
47 | if (!sh_quiet) |
- | |
48 | printf("%llu ", thread_get_id()); |
- | |
49 | usleep(100000); |
48 | usleep(100000); |
50 | } |
49 | |
51 | atomic_inc(&threads_finished); |
50 | atomic_inc(&threads_finished); |
52 | } |
51 | } |
53 | 52 | ||
54 | char * test_thread1(bool quiet) |
53 | char *test_thread1(void) |
55 | { |
54 | { |
56 | unsigned int i, total = 0; |
55 | unsigned int i; |
57 | sh_quiet = quiet; |
56 | unsigned int total = 0; |
58 | 57 | ||
59 | atomic_set(&finish, 1); |
58 | atomic_set(&finish, 1); |
60 | atomic_set(&threads_finished, 0); |
59 | atomic_set(&threads_finished, 0); |
61 | 60 | ||
- | 61 | TPRINTF("Creating threads"); |
|
62 | for (i = 0; i < THREADS; i++) { |
62 | for (i = 0; i < THREADS; i++) { |
63 | if (thread_create(threadtest, NULL, "threadtest", NULL) < 0) { |
63 | if (thread_create(threadtest, NULL, "threadtest", NULL) < 0) { |
64 | if (!quiet) |
- | |
65 | printf("Could not create thread %d\n", i); |
64 | TPRINTF("\nCould not create thread %u\n", i); |
66 | break; |
65 | break; |
67 | } |
66 | } |
- | 67 | TPRINTF("."); |
|
68 | total++; |
68 | total++; |
69 | } |
69 | } |
70 | 70 | ||
71 | if (!quiet) |
- | |
72 | printf("Running threads for 10 seconds...\n"); |
71 | TPRINTF("\nRunning threads for %u seconds...", DELAY); |
73 | sleep(10); |
72 | sleep(DELAY); |
- | 73 | TPRINTF("\n"); |
|
74 | 74 | ||
75 | atomic_set(&finish, 0); |
75 | atomic_set(&finish, 0); |
76 | while (atomic_get(&threads_finished) < total) { |
76 | while (atomic_get(&threads_finished) < total) { |
77 | if (!quiet) |
- | |
78 | printf("Threads left: %d\n", total - atomic_get(&threads_finished)); |
77 | TPRINTF("Threads left: %u\n", total - atomic_get(&threads_finished)); |
79 | sleep(1); |
78 | sleep(1); |
80 | } |
79 | } |
81 | 80 | ||
82 | return NULL; |
81 | return NULL; |
83 | } |
82 | } |