Dawidh
18-10-2007, 19:04
ciao a tutti.. allora, il programma funziona nel seguente modo:
partono 4 thread, 1 fa da client e manda richieste (mettendo tutto in una coda circolare) e sblocca un thread, in caso dovrebbe lasciare la richiesta in coda e un thread appena si libera la preleva.
gli altri 3 threads invece prendono tali richiesta dalla coda e fanno delle cose:
il problema è qui:
void put_richiesta(struct buffer *b)
{
struct element *x;
int i=0;
pthread_mutex_lock(&b->m);
fprintf(stderr, "T bloccato\n");
b->blocked_readers++;
pthread_cond_wait(&b->block_read, &b->m);
fprintf(stderr, "T sbloccato........\n");
fprintf(stderr, "prima dell'estrazione "); print_CA();
if (extract_CA(x) == 1) {
//fprintf(stderr, "1");
for (i=0; i<x->t; i++) {
fprintf(stderr, "%s\n", x->msg);
sleep(1);
}
//fprintf(stderr, "2");
pthread_mutex_unlock(&b->m);
fprintf(stderr, "dopo l'estrazione ");print_CA();
}
else {
fprintf(stderr, "Non ci sono elementi in coda\n");
pthread_mutex_unlock(&b->m);
}
extract_CA(x);
pthread_mutex_unlock(&b->m);
}
praticamente preleva la richiesta: fa delle stampe ogni secondo del messaggio preso. La prima volta che si fa una insert (e quindi subito dopo viene fatta la signal e poi la extract descitta qui sopra) tutto funziona bene, però quando si inserisce una nuova richiesta,viene inserita (sicuro perchè viene stampato un log delle operazioni) però il programma si blocca alla riga che vi ho segnato in rosso. dando errore di segmentation fault
:muro: :muro: :muro: non sappiamo il perché, tutto il resto va bene, perché stampiamo log ogni momento, dovrebbe estrarre dalla seconda posizione della coda (anche i puntatori sono messi giusti) ma non lo fa. Avete qualche idea del perché?????????
Grazie
partono 4 thread, 1 fa da client e manda richieste (mettendo tutto in una coda circolare) e sblocca un thread, in caso dovrebbe lasciare la richiesta in coda e un thread appena si libera la preleva.
gli altri 3 threads invece prendono tali richiesta dalla coda e fanno delle cose:
il problema è qui:
void put_richiesta(struct buffer *b)
{
struct element *x;
int i=0;
pthread_mutex_lock(&b->m);
fprintf(stderr, "T bloccato\n");
b->blocked_readers++;
pthread_cond_wait(&b->block_read, &b->m);
fprintf(stderr, "T sbloccato........\n");
fprintf(stderr, "prima dell'estrazione "); print_CA();
if (extract_CA(x) == 1) {
//fprintf(stderr, "1");
for (i=0; i<x->t; i++) {
fprintf(stderr, "%s\n", x->msg);
sleep(1);
}
//fprintf(stderr, "2");
pthread_mutex_unlock(&b->m);
fprintf(stderr, "dopo l'estrazione ");print_CA();
}
else {
fprintf(stderr, "Non ci sono elementi in coda\n");
pthread_mutex_unlock(&b->m);
}
extract_CA(x);
pthread_mutex_unlock(&b->m);
}
praticamente preleva la richiesta: fa delle stampe ogni secondo del messaggio preso. La prima volta che si fa una insert (e quindi subito dopo viene fatta la signal e poi la extract descitta qui sopra) tutto funziona bene, però quando si inserisce una nuova richiesta,viene inserita (sicuro perchè viene stampato un log delle operazioni) però il programma si blocca alla riga che vi ho segnato in rosso. dando errore di segmentation fault
:muro: :muro: :muro: non sappiamo il perché, tutto il resto va bene, perché stampiamo log ogni momento, dovrebbe estrarre dalla seconda posizione della coda (anche i puntatori sono messi giusti) ma non lo fa. Avete qualche idea del perché?????????
Grazie