Archived
3
0
This commit is contained in:
lapupe 2016-10-28 14:24:15 +02:00
parent b2abfb970e
commit 59db09d6f4
3 changed files with 77 additions and 68 deletions

View File

@ -199,11 +199,13 @@ int srv_get_new_process (char *buf, struct process *p)
int srv_read (const struct service *srv, char ** buf) int srv_read (const struct service *srv, char ** buf)
{ {
//printf("---%s\n", srv->spath);
return file_read (srv->service_fd, buf); return file_read (srv->service_fd, buf);
} }
int srv_write (const struct service *srv, const char * buf, size_t msize) int srv_write (const struct service *srv, const char * buf, size_t msize)
{ {
//printf("---%s\n", srv->spath);
return file_write (srv->service_fd, buf, msize); return file_write (srv->service_fd, buf, msize);
} }
@ -386,12 +388,14 @@ int app_destroy (struct process *p)
} }
int app_read (struct process *p, char ** buf) int app_read (struct process *p, char ** buf)
{ {
//printf("---%s\n", p->path_proc);
return file_read (p->proc_fd, buf); return file_read (p->proc_fd, buf);
} }
int app_write (struct process *p, char * buf, size_t msize) int app_write (struct process *p, char * buf, size_t msize)
{ {
//printf("---%s\n", p->path_proc);
return file_write (p->proc_fd, buf, msize); return file_write (p->proc_fd, buf, msize);
} }

View File

@ -38,7 +38,6 @@ void * pongd_thread(void * pdata) {
if (cfd == -1) if (cfd == -1)
handle_error("accept"); handle_error("accept");
proc->proc_fd = cfd; proc->proc_fd = cfd;
printf("ok\n");
while (1) { while (1) {
if ((nbytes = app_read (proc, &buf)) == -1) { if ((nbytes = app_read (proc, &buf)) == -1) {
@ -56,7 +55,6 @@ void * pongd_thread(void * pdata) {
if ((nbytes = app_write (proc, buf, nbytes)) == -1) { if ((nbytes = app_write (proc, buf, nbytes)) == -1) {
fprintf(stdout, "MAIN_LOOP: error service_write %d\n", nbytes); fprintf(stdout, "MAIN_LOOP: error service_write %d\n", nbytes);
} }
printf("write success\n");
} }
} }

View File

@ -570,6 +570,7 @@ void main_loop (struct service *srv) {
//request //request
info_request tab_req[NBCLIENT]; info_request tab_req[NBCLIENT];
int ret; int ret;
int i;
//pid server //pid server
pthread_t pid_s; pthread_t pid_s;
//pid client //pid client
@ -627,81 +628,87 @@ void main_loop (struct service *srv) {
} }
//printf("Server-select...OK\n"); //printf("Server-select...OK\n");
if(FD_ISSET(listener, &read_fds)) { for (i = 0; i <= fdmax; i++) {
/* handle new connections */ if(FD_ISSET(i, &read_fds)) {
peer_addr_size = sizeof(struct sockaddr_un); if(i == listener) {
newfd = accept(sfd, (struct sockaddr *) &peer_addr, &peer_addr_size); /* handle new connections */
if (newfd == -1) { peer_addr_size = sizeof(struct sockaddr_un);
handle_error("accept"); newfd = accept(sfd, (struct sockaddr *) &peer_addr, &peer_addr_size);
} if (newfd == -1) {
else handle_error("accept");
{
printf("Server-accept() is OK...\n");
FD_SET(newfd, &master); /* add to master set */
if(newfd > fdmax)
{ /* keep track of the maximum */
fdmax = newfd;
}
srv->service_fd = newfd;
}
} else {
nbytes = srv_read (srv, &buf);
if ( nbytes == -1) {
handle_error("file_read");
} else if( nbytes == 0) {
/* close it... */
close(srv->service_fd);
/* remove from master set */
FD_CLR(srv->service_fd, &master);
}else {
buf[BUFSIZ - 1] = '\0';
printf ("msg received (%d) : %s\n", nbytes, buf);
if (strncmp ("exit", buf, 4) == 0) {
break;
}
tab_req[nbclient].p = malloc(sizeof(struct process));
// -1 : error, 0 = no new process, 1 = new process
ret = srv_get_new_request (buf, &tab_req[nbclient]);
if (ret == -1) {
perror("srv_get_new_request()");
exit(1);
} else if (ret == 0) {
break;
}
request_print(&tab_req[nbclient]);
if (strcmp("listen", tab_req[nbclient].request) == 0) {
int ret = pthread_create( &pid_s, NULL, &server_thread, (void *) &tab_req[nbclient]);
if (ret) {
perror("pthread_create()");
exit(errno);
} else {
printf("\n----------Creation of server thread ------------\n");
} }
nbclient++; else
}else { {
int ret = pthread_create( &tab_client[nbclient], NULL, &client_thread, (void *) &tab_req[nbclient]); printf("Server-accept() is OK...\n");
if (ret) { FD_SET(newfd, &master); /* add to master set */
perror("pthread_create()"); if(newfd > fdmax)
exit(errno); { /* keep track of the maximum */
} else { fdmax = newfd;
printf("\n----------Creation of client thread ------------\n"); }
} }
nbclient++; } else {
nbytes = file_read (i, &buf);
if ( nbytes == -1) {
handle_error("file_read");
} else if( nbytes == 0) {
/* close it... */
close(i);
/* remove from master set */
FD_CLR(i, &master);
}else {
buf[BUFSIZ - 1] = '\0';
printf ("msg received (%d) : %s\n", nbytes, buf);
if (strncmp ("exit", buf, 4) == 0) {
break;
}
} tab_req[nbclient].p = malloc(sizeof(struct process));
} // -1 : error, 0 = no new process, 1 = new process
ret = srv_get_new_request (buf, &tab_req[nbclient]);
if (ret == -1) {
perror("srv_get_new_request()");
exit(1);
} else if (ret == 0) {
break;
}
request_print(&tab_req[nbclient]);
if (strcmp("listen", tab_req[nbclient].request) == 0) {
int ret = pthread_create( &pid_s, NULL, &server_thread, (void *) &tab_req[nbclient]);
if (ret) {
perror("pthread_create()");
exit(errno);
} else {
printf("\n----------Creation of server thread ------------\n");
}
nbclient++;
}else {
int ret = pthread_create( &tab_client[nbclient], NULL, &client_thread, (void *) &tab_req[nbclient]);
if (ret) {
perror("pthread_create()");
exit(errno);
} else {
printf("\n----------Creation of client thread ------------\n");
}
nbclient++;
}
}
} //i == listener
} //if FDISSET
}//boucle for
if (strncmp ("exit", buf, 4) == 0) {
break;
} }
} }//boucle while
if (pthread_cancel(pid_s) != 0) { if (pthread_cancel(pid_s) != 0) {
printf("Aucun thread correspond \n"); printf("Aucun thread correspond \n");
} }
pthread_join(pid_s, NULL); pthread_join(pid_s, NULL);
int i;
/*for (i = 0; i < nbclient; i++) { /*for (i = 0; i < nbclient; i++) {
pthread_join(tab_client[i], NULL); pthread_join(tab_client[i], NULL);
}*/ }*/