ms-queue: remove more externs and unintended shared data
authorBrian Norris <banorris@uci.edu>
Wed, 6 Mar 2013 01:37:28 +0000 (17:37 -0800)
committerBrian Norris <banorris@uci.edu>
Wed, 6 Mar 2013 01:45:09 +0000 (17:45 -0800)
ms-queue/main.c
ms-queue/my_queue.c
ms-queue/my_queue.h

index fefb3861834f0f237aa6ad6f3e7c3b9d903d8d8c..8813e37bb44ec93671b505ff00fca1e192018ba6 100644 (file)
@@ -7,8 +7,20 @@
 
 static int procs = 2;
 static int iterations = 1;
-private_t private;
 static queue_t *queue;
+static thrd_t *threads;
+static int num_threads;
+
+int get_thread_num()
+{
+       thrd_t curr = thrd_current();
+       int i;
+       for (i = 0; i < num_threads; i++)
+               if (curr.priv == threads[i].priv)
+                       return i;
+       assert(0);
+       return -1;
+}
 
 static void parse_args(int argc, char **argv)
 {
@@ -35,7 +47,6 @@ static void main_task(void *param)
        unsigned val;
        int pid = *((int *)param);
 
-       init_private(pid);
        for (i = 0; i < iterations; i++) {
                val = 1 + pid * iterations + i;
                enqueue(queue, val);
@@ -46,8 +57,7 @@ static void main_task(void *param)
 
 int user_main(int argc, char **argv)
 {
-       int i, num_threads;
-       thrd_t *t;
+       int i;
        int *param;
 
        parse_args(argc, argv);
@@ -57,19 +67,19 @@ int user_main(int argc, char **argv)
        assert(queue);
 
        num_threads = procs;
-       t = malloc(num_threads * sizeof(thrd_t));
+       threads = malloc(num_threads * sizeof(thrd_t));
        param = malloc(num_threads * sizeof(*param));
 
-       init_queue(queue);
+       init_queue(queue, num_threads);
        for (i = 0; i < num_threads; i++) {
                param[i] = i;
-               thrd_create(&t[i], main_task, &param[i]);
+               thrd_create(&threads[i], main_task, &param[i]);
        }
        for (i = 0; i < num_threads; i++)
-               thrd_join(t[i]);
+               thrd_join(threads[i]);
 
        free(param);
-       free(t);
+       free(threads);
        free(queue);
 
        return 0;
index eb5d54ad7352f9be434bd9b76b06063963d81727..9ffb343dd3174ec970da9685c2e203ad1c38f242 100644 (file)
@@ -1,31 +1,31 @@
 #include <threads.h>
+#include <stdlib.h>
 
 #include "my_queue.h"
 
-extern private_t private;
-
-void init_private(int pid)
-{
-       private.node = 2 + pid;
-}
+static unsigned int *node_nums;
 
 static unsigned int new_node()
 {
-       return private.node;
+       return node_nums[get_thread_num()];
 }
 
 static void reclaim(unsigned int node)
 {
-       private.node = node;
+       node_nums[get_thread_num()] = node;
 }
 
-void init_queue(queue_t *q)
+void init_queue(queue_t *q, int num_threads)
 {
        unsigned int i;
        pointer head;
        pointer tail;
        pointer next;
 
+       node_nums = malloc(num_threads * sizeof(*node_nums));
+       for (i = 0; i < num_threads; i++)
+               node_nums[i] = 2 + i;
+
        /* initialize queue */
        head = MAKE_POINTER(1, 0);
        tail = MAKE_POINTER(1, 0);
index 4ce05b49af99184007088b45ef697601ce11c9b2..5877a680b7c634b636af7d0b1d994b0004ce3387 100644 (file)
@@ -19,17 +19,13 @@ typedef struct node {
        pointer_t next;
 } node_t;
 
-typedef struct private {
-       unsigned int node;
-} private_t;
-
-typedef struct shared_mem {
+typedef struct {
        pointer_t head;
        pointer_t tail;
        node_t nodes[MAX_NODES + 1];
 } queue_t;
 
-void init_private(int pid);
-void init_queue(queue_t *q);
+void init_queue(queue_t *q, int num_threads);
 void enqueue(queue_t *q, unsigned int val);
 unsigned int dequeue(queue_t *q);
+int get_thread_num();