Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Abbiamo provato le nuove CPU Intel Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: più core e ottimizzazioni al funzionamento interno migliorano le prestazioni, anche in virtù di prezzi annunciati interessanti. A questo si aggiungono nuove ottimizzazioni software. Purtroppo, a fronte di prestazioni di calcolo elevate, il quadro rimane incerto nel gaming, dove l'andamento rimane altalenante. Infine, rimane il problema della piattaforma a fine vita.
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-07-2004, 17:08   #1
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
[C] Segmentation fault su memoria condivisa

Salve a tutti, ormai sto infestando questa sezione con i miei post ma non so a chi altro rivolgermi per dei chiarimenti quindi... sopportatemi
Veniamo al dunque, il programma seguente si compila correttamente ma mi dà un segmentation fault a tempo d'esecuzione. In pratica io voglio creare un segmento di memoria condivisa da utilizzare come un array (in modo tale che possano accedervi il processo padre e i processi figli) ma mi dà quell'errore lì. Qualcuno può dirmi come mai? grazie
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/stat.h>
#include <unistd.h>

int *automobili;
int *direzione;

int main (int argc, char* argv[]) {
	int autom, direz, N;
	N=10;
	if (autom=shmget(IPC_PRIVATE, N*sizeof(pid_t), 0666) <0) perror("Errore nella creazione del segmento di memoria condivisa 'automobili'");
	automobili=(int *) shmat (autom, 0, SHM_RND);
	if (direz=shmget(IPC_PRIVATE, N*sizeof(int), 0666) <0) perror("Errore nella creazione del segmento di memoria condivisa 'direzione'");
	direzione=(int *) shmat (direz, 0, SHM_RND);
	automobili[0]=3;
	automobili[1]=getpid();
	printf("%d %d", automobili[0], automobili[1]);
}

Ultima modifica di VegetaSSJ5 : 12-07-2004 alle 17:12.
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2004, 17:15   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Nulla di grave, il classico problema hardware tra la sedia e la tastiera
Codice:
--- segfault.c.org	2004-07-12 17:29:06.000000000 +0200
+++ segfault.c	2004-07-12 17:29:40.000000000 +0200
@@ -14,9 +14,9 @@
 int main (int argc, char* argv[]) {
         int autom, direz, N;
         N=10;
-        if (autom=shmget(IPC_PRIVATE, N*sizeof(pid_t), 0666) <0) perror("Errore nella creazione del segmento di memoria condivisa 'automobili'");
+        if ((autom=shmget(IPC_PRIVATE, N*sizeof(pid_t), 0666)) <0) perror("Errore nella creazione del segmento di memoria condivisa 'automobili'");
         automobili=(int *) shmat (autom, 0, SHM_RND);
-        if (direz=shmget(IPC_PRIVATE, N*sizeof(int), 0666) <0) perror("Errore nella creazione del segmento di memoria condivisa 'direzione'");
+        if ((direz=shmget(IPC_PRIVATE, N*sizeof(int), 0666)) <0) perror("Errore nella creazione del segmento di memoria condivisa 'direzione'");
         direzione=(int *) shmat (direz, 0, SHM_RND);
         automobili[0]=3;
         automobili[1]=getpid();
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2004, 17:16   #3
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
nb non compilate MAI con -Wall, mi raccomando
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2004, 17:49   #4
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
grazie ilsensine! cmq il problema non ero io ma l'editor kate che mi segnava come ultima parentesi quella che tu poi hai aggiunto
come mai non bisogna mai compilare com -Wall??
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2004, 17:57   #5
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da VegetaSSJ5
come mai non bisogna mai compilare com -Wall??
Era una nota ironica. Se compilavi con -Wall, il compilatore ti avrebbe segnalato che c'era qualcosa di sospetto.
Io compilo _sempre_ con -Wall (e per la produzione con -Wall -Werror).
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 14:44   #6
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
ilsensine ti ringrazio molto, sei il mio angelo custode, tuttavia ci sono per me dei misteri inspiegabili tipo il seguente: il padre stampa il valore giusto di automobili[i] invece il figlio no
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/stat.h>
#include <unistd.h>

int *automobili;
int *direzione;

void funzione (int N);

int main (int argc, char* argv[]) {
	int autom, direz, N;
	N=10;
	if ((autom=shmget(IPC_PRIVATE, N*sizeof(pid_t), 0666)) <0) perror("Errore");
	automobili=(int *) shmat (autom, 0, SHM_RND);
	if ((direz=shmget(IPC_PRIVATE, N*sizeof(int), 0666)) <0) perror("Errore");
	direzione=(int *) shmat (direz, 0, SHM_RND);
	funzione(3);
}

void funzione (int N) {
	int i;
	pid_t padre=getpid();
	for (i=0; i<N; i++) {
		if (getpid()==padre) {
			if ((automobili[i]=(int)fork()) < 0) perror("Errore generando l'automobile");
			if (getpid()==padre) printf("\nPADRE, automobili[%d]= %d\n\n", i, automobili[i]);
		}
		if (getpid()!=padre) {
			printf("\nAUTO %d, automobili[%d]= %d", i, i, automobili[i]);
			i=N;
		}
	}
}
se invece sostituisco il ciclo for con quest'altro tutto funziona correttamente
Codice:
for (i=0; i<N; i++) {
		pid_t pid=fork();
		if (pid==0) printf("figlio %d dopo fork %d %d\n", i, automobili[0], automobili[1]);
		else printf("padre dopo fork %d %d\n", automobili[0], automobili[1]);
		if (pid==0) {
			automobili[0]=140;
			automobili[1]=(int)getpid();
			printf("Figlio %d dopo assegnamento %d %d\n", i, automobili[0], automobili[1]);
		}
		else {
			printf("padre dopo assegnamento %d %d\n", automobili[0], automobili[1]);
			automobili[0]=111;
			automobili[1]=(int)getpid();
			printf("padre dopo riassegnamento %d %d\n", automobili[0], automobili[1]);
		}
		if (pid==0) {
			sleep(1);
			printf("figlio %d dopo riassegnamento %d %d\n", i, automobili[0], automobili[1]);
			i=N;
		}
	}
}

Ultima modifica di VegetaSSJ5 : 13-07-2004 alle 14:47.
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 15:13   #7
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Codice:
		if (getpid()==padre) {
			if ((automobili[i]=(int)fork()) < 0) perror("Errore generando l'automobile");
			if (getpid()==padre) printf("\nPADRE, automobili[%d]= %d\n\n", i, automobili[i]);
		}
		if (getpid()!=padre) {
			printf("\nAUTO %d, automobili[%d]= %d", i, i, automobili[i]);
			i=N;
		}
Hint: hai almeno 2 race condition in questo codice...una è veramente mastodontica, la seconda più subdola.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 15:18   #8
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Codice:
--- race.c.org	2004-07-13 15:26:25.000000000 +0200
+++ race.c	2004-07-13 15:33:06.000000000 +0200
@@ -6,6 +6,7 @@
 #include <sys/shm.h>
 #include <sys/stat.h>
 #include <unistd.h>
+#include <sched.h>
 
 int *automobili;
 int *direzione;
@@ -24,10 +25,13 @@
 
 void funzione (int N) {
         int i;
+        pid_t val;
         pid_t padre=getpid();
         for (i=0; i<N; i++) {
                 if (getpid()==padre) {
-                        if ((automobili[i]=(int)fork()) < 0) perror("Errore generando l'automobile");
+                        if((val = fork())<0) perror("fork");
+                        if(val) automobili[i] = val; // Fix prima race
+                        else sched_yield(); // Fix seconda race!!
                         if (getpid()==padre) printf("\nPADRE, automobili[%d]= %d\n\n", i, automobili[i]);
                 }
                 if (getpid()!=padre) {
La seconda race potrebbe o meno occorrere, a seconda dello scheduler e del kernel (è veramente subdola). Lo sched_yield ti pone al sicuro.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 19:06   #9
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
grazie ilsensine.
puoi dirmi cosa sono le race condition? che cosa fa la funzione sched_yeld?
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 20:04   #10
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
allora mi sono informato (google)

race condition:
"Le race condition sono gli errori piu' comuni nella programmazione
multithreaded o multiprocesso. Una race condition si verifica quando
una assunzione fatta dal programmatore che non dovrebbe cambiare per un
dato lasso di tempo, cambia per forza...."
fonte

sched_yield():
pone il processo chiamante allo stato READY.

puoi dirmi quali sono le race condition nel mio caso? quale utilità può avere porre il processo figlio allo stato ready?

Ultima modifica di VegetaSSJ5 : 13-07-2004 alle 20:18.
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2004, 20:48   #11
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quando invochi la fork, normalmente il controllo passa al neonato processo child. Non c'è una regola per stabilire chi deve continuare (padre o figlio), ma su linux normalmente si preferisce così. Se questo accade, il figlio continua mentre la fork del padre non è ancora ritornata (in quanto il controllo è passato al figlio). Il figlio quindi continua per la sua strada e...legge automobili[i].

>> Domanda: se il fork del padre ancora non è ritornato, cosa c'è dentro automobili[i]? <<

sched_yield è documentato nelle pagine man, che ti consiglio di leggere
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2004, 13:48   #12
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
Quote:
Originariamente inviato da ilsensine
Quando invochi la fork, normalmente il controllo passa al neonato processo child. Non c'è una regola per stabilire chi deve continuare (padre o figlio), ma su linux normalmente si preferisce così. Se questo accade, il figlio continua mentre la fork del padre non è ancora ritornata (in quanto il controllo è passato al figlio). Il figlio quindi continua per la sua strada e...legge automobili[i].

>> Domanda: se il fork del padre ancora non è ritornato, cosa c'è dentro automobili[i]? <<

sched_yield è documentato nelle pagine man, che ti consiglio di leggere

sei mitico ilsensine!
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
L'esperimento BASE del CERN è riu...
Afeela è morta: chiusa definitiva...
Intel BOT altera i risultati, Geekbench ...
Intel e AMD faticano a soddisfare la dom...
Microsoft e NVIDIA insieme per dare una ...
Ring rinnova l'intera gamma video: 4K su...
Recensione Galaxy Buds4 Pro: le cuffie S...
Spotify si arricchisce ancora: arriva So...
I digital twin di AVEVA a supporto delle...
Iliad non si ferma: clienti in crescita ...
XuanTie C950, il chip IA di Alibaba basa...
Volkswagen richiama 94.000 auto elettric...
Le nuove LaserJet di HP portano la critt...
FSR 4 gira sulla GPU di PS5 Pro, ma non ...
Intel rinnova l'offerta professionale: C...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 06:04.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v