11 #define LISTEN_PORT 2156
12 #define BACKLOG 10 //max pending connections
13 #define RECEIVE_BUFFER_SIZE 2048
15 extern int classsize[];
17 objstr_t *mainobjstore;
21 //todo:initialize main object store
22 //do we want this to be a global variable, or provide
23 //separate access funtions and hide the structure?
24 mainobjstore = objstrCreate(DEFAULT_OBJ_STORE_SIZE);
25 if (mhashCreate(HASH_SIZE, LOADFACTOR))
28 if (lhashCreate(HASH_SIZE, LOADFACTOR))
31 //pthread_t threadListen;
32 //pthread_create(&threadListen, NULL, dstmListen, NULL);
39 int listenfd, acceptfd;
40 struct sockaddr_in my_addr;
41 struct sockaddr_in client_addr;
42 socklen_t addrlength = sizeof(struct sockaddr);
43 pthread_t thread_dstm_accept;
46 listenfd = socket(AF_INET, SOCK_STREAM, 0);
53 my_addr.sin_family = AF_INET;
54 my_addr.sin_port = htons(LISTEN_PORT);
55 my_addr.sin_addr.s_addr = INADDR_ANY;
56 memset(&(my_addr.sin_zero), '\0', 8);
58 if (bind(listenfd, (struct sockaddr *)&my_addr, addrlength) == -1)
64 if (listen(listenfd, BACKLOG) == -1)
70 printf("Listening on port %d, fd = %d\n", LISTEN_PORT, listenfd);
73 acceptfd = accept(listenfd, (struct sockaddr *)&client_addr, &addrlength);
74 pthread_create(&thread_dstm_accept, NULL, dstmAccept, (void *)acceptfd);
79 void *dstmAccept(void *acceptfd)
81 int numbytes,i,choice, oid;
82 char buffer[RECEIVE_BUFFER_SIZE], control;
85 int fd_flags = fcntl((int)acceptfd, F_GETFD), size;
87 printf("Recieved connection: fd = %d\n", (int)acceptfd);
88 numbytes = recv((int)acceptfd, (void *)buffer, sizeof(buffer), 0);
99 oid = *((int *)(buffer+1));
101 printf("DEBUG -> Received oid is %d\n", oid);
103 srcObj = mhashSearch(oid);
104 h = (objheader_t *) srcObj;
106 buffer[0] = OBJECT_NOT_FOUND;
108 buffer[0] = OBJECT_FOUND;
109 size = sizeof(objheader_t) + sizeof(classsize[h->type]);
110 memcpy(buffer+1, srcObj, size);
113 printf("DEBUG -> Sending oid = %d, type %d\n", h->oid, h->type);
116 if(send((int)acceptfd, (void *)buffer, sizeof(buffer), 0) < 0) {
120 case READ_MULT_REQUEST:
124 case MOVE_MULT_REQUEST:
133 printf("Error receiving");
135 //printf("Read %d bytes from %d\n", numbytes, (int)acceptfd);
136 //printf("%s", buffer);
138 if (close((int)acceptfd) == -1)
143 printf("Closed connection: fd = %d\n", (int)acceptfd);