|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
[C] Dubbi sul file locking
Ciao a tutti!
Ho dei dubbi riguardo l'uso della funzione fcntl() per effettuare il locking esclusivo sui file (ma penso riguardi anche quello condiviso). 1- Se io ad esempio definisco la struttura di tipo flock così: Codice:
struck flock *lock=(struct flock *)malloc(sizeof(struct lock)); lock->l_type=F_WRLCK; lock->l_whence=SEEK_END; lock->l_start=0; lock->l_len=40; Codice:
fcntl(fd,F_SETLKW,lock) Codice:
As for F_SETLK, but if conflicting lock is held on the file, then wait for that lock to be released. If a signal is caught while waiting, then the call is interrupted and (after the signal handler has returned) returns immediately. 2 - Avendo sempre questa struttura flock, se chiamo la fcntl così: Codice:
fcntl(fd,F_GETLK,lock) 3 - Avendo sempre la solita struct, facendo fcntl: Codice:
fcntl(fd,F_SETLK,lock) Grazie |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
up
|
|
|
|
|
|
#3 | |||
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
Se non intendi gestire i segnali puoi ignorare questo comportamento. Quote:
Nota che F_UNLCK viene ritornato anche se il lock esiste, ma è stato posto dallo stesso processo. Quote:
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|||
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Ok, grazie mille ora è chiaro
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Un'altra cosa scusa
Mettiamo il caso che il processo A apra il file e imposti il lock alla fine del file. Cioè prima mi sposto tramite la lseek alla fine del file, dopodiché imposto un lock a partire da quella posizione per 40 byte. Mettiamo il caso che ora il processo B apra quel file; facendo una lseek ora alla fine del file, qual'è adesso la fine del file? Quella che aveva il processo A prima del lock, oppure è dopo i 40 byte del lock? Inoltre quando setto un lock di n byte su una porzione del file, mi sposta anche il file descriptor n byte più avanti? Grazie. |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
La semplice imposizione di un lock non altera la dimensione del file, quindi la posizione finale rimane invariata.
Quote:
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Ma per fare un lock alla fine del file sono giuste queste istruzioni?
Codice:
lock->l_type=F_WRLCK; lock->l_whence=SEEK_CUR; lock->l_start=0; lock->l_len=40; fcntl(fd,F_SETLK,lock); Ultima modifica di Manugal : 28-11-2006 alle 18:17. |
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Sì, hai bloccato i prossimi 40 byte dopo la fine del file.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Allora è strano perché quando faccio partire il processo B (con il lock già impostato dal processo A), non mi ritorna -1 ma continua avanti come se non fosse successo niente. Questo è il codice:
Codice:
#include "acme.h"
int acmebook(int fd){
struct flock *lock=(struct flock *)malloc(sizeof(struct flock));
char *name=(char *)malloc(sizeof(char)*15);
char *surname=(char *)malloc(sizeof(char)*25);
ssize_t nwrite;
size_t len,lenname,lensurname;
lock->l_type=F_WRLCK;
lock->l_whence=SEEK_CUR;
lock->l_start=0;
lock->l_len=40;
if(fcntl(fd,F_SETLK,lock) == -1){
if(lock!=NULL){
free(lock);
lock=NULL;
}
if(name!=NULL){
free(name);
name=NULL;
}
if(surname!=NULL){
free(surname);
surname=NULL;
}
return -1;
}
printf("Insert name and surname: ");
scanf("%s %s", name, surname);
lenname=strlen(name);
lensurname=strlen(surname);
char *passenger=(char *)malloc(sizeof(char)*lenname*lensurname+3);
sprintf(passenger, "%s %s\n", name, surname);
len=strlen(passenger);
if((nwrite = write(fd,passenger,len)) <= 0){
if(lock!=NULL){
free(lock);
lock=NULL;
}
if(name!=NULL){
free(name);
name=NULL;
}
if(surname!=NULL){
free(surname);
surname=NULL;
}
if(passenger!=NULL){
free(passenger);
passenger=NULL;
}
return -1;
}
lock->l_type=F_UNLCK;
if(fcntl(fd,F_SETLK,lock) == -1){
if(lock!=NULL){
free(lock);
lock=NULL;
}
if(name!=NULL){
free(name);
name=NULL;
}
if(surname!=NULL){
free(surname);
surname=NULL;
}
if(passenger!=NULL){
free(passenger);
passenger=NULL;
}
return -1;
}
printf("Thanks Mr./Mrs. %s. Your seat has been reserved.\n", passenger);
if(lock!=NULL){
free(lock);
lock=NULL;
}
if(name!=NULL){
free(name);
name=NULL;
}
if(surname!=NULL){
free(surname);
surname=NULL;
}
if(passenger!=NULL){
free(passenger);
passenger=NULL;
}
return 0;
}
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Scusa ho ricontrollato sembra corretto (infatti adesso il lock me lo da). Grazie della disponibilità.
|
|
|
|
|
|
#11 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Un consiglio casuale: non usare malloc/free per ogni variabile locale che ti capita a tiro
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 23:25.


















