Torna indietro   Hardware Upgrade Forum > Software > Programmazione

AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-03-2011, 17:39   #1
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
[C/C++] File locking tra pthreads

Cercando qua e là non mi è mai capitato di incontrare una funzione equivalente al LockFile di windows, cioè che faccia il lock esclusivo o condiviso tra threads (anche di diversi processi) per i pthreads

Ora, mi trovo ad averne bisogno e mi chiedevo, non c'è proprio niente che faccia al caso mio e sarò costretto a inventarmi improbabili combinazioni di flock (o fcntl, insomma lock dei file tra i processi) e rwlock o c'è qualcosa che posso usare direttamente?
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 28-03-2011, 00:25   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
Prova a guardarti la struttura pthread_mutex_t e le varie funzioni:
http://linux.die.net/man/3/pthread_mutex_lock
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 28-03-2011, 01:54   #3
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
ah ecco, perfetto, pthread_rwlockattr_setpshared fa al caso mio, thank you
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 16:37   #4
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
in realtà non fa al caso mio come credevo, per il semplice fatto che è necessario condividere la memoria in cui è allocato il lock per poterlo utilizzare.. ma non c'è una soluzione standard? insomma mi sembra un problema tipico quello di lockare un file, eppure non trovo niente che faccia quel che voglio :/ (cioè l'equivalente di flock, fcntl o lockf per i thread)
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 23:14   #5
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
Cercando qua e là non mi è mai capitato di incontrare una funzione equivalente al LockFile di windows, cioè che faccia il lock esclusivo o condiviso tra threads (anche di diversi processi) per i pthreads

Ora, mi trovo ad averne bisogno e mi chiedevo, non c'è proprio niente che faccia al caso mio e sarò costretto a inventarmi improbabili combinazioni di flock (o fcntl, insomma lock dei file tra i processi) e rwlock o c'è qualcosa che posso usare direttamente?
Perche' non puoi usare il solo flock ?
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2011, 13:14   #6
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
perché flock fa mutua esclusione tra i processi, non tra i thread di uno stesso processo, ad esempio

alla fine penso che userò un segmento di memoria condiviso in cui mettere una qualche struttura dati che contiene i miei rwlock indicizzati per numero di inode

a questo proposito, l'ideale sarebbe una std::map.. ma c'è qualche modo per allocare un oggetto dove dico io (nel mio caso, nel segmento che prendo con shmget), e posso essere sicuro che non venga allocato niente al di fuori? ad esempio che non ci siano "new" all'interno, che sarebbero un problema
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2011, 16:43   #7
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
perché flock fa mutua esclusione tra i processi, non tra i thread di uno stesso processo, ad esempio
Giusto, me n'ero dimenticato

Quote:
alla fine penso che userò un segmento di memoria condiviso in cui mettere una qualche struttura dati che contiene i miei rwlock indicizzati per numero di inode

a questo proposito, l'ideale sarebbe una std::map.. ma c'è qualche modo per allocare un oggetto dove dico io (nel mio caso, nel segmento che prendo con shmget), e posso essere sicuro che non venga allocato niente al di fuori? ad esempio che non ci siano "new" all'interno, che sarebbero un problema
Se non ricordo male in boost::inteprocess dovrebbe esserci una versione portabile che fa quel che ti serve, senza dover ricorrere a delle mappe.
In ogni caso per il discorso della map dovresti passarle un allocatore tuo (che vada ad allocare dalla memoria condivisa), non una passeggiata.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2011, 17:12   #8
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da marco.r Guarda i messaggi
Giusto, me n'ero dimenticato


Se non ricordo male in boost::inteprocess dovrebbe esserci una versione portabile che fa quel che ti serve, senza dover ricorrere a delle mappe.
In ogni caso per il discorso della map dovresti passarle un allocatore tuo (che vada ad allocare dalla memoria condivisa), non una passeggiata.
intanto ho dimenticato di premettere che è un progetto per un corso di programmazione di sistema (server e client tftp windows e linux) e non posso utilizzare librerie che mi semplifichino il lavoro in questo modo

ok, sembra abbastanza complicato in effetti gestire correttamente la memoria in questo modo.. magari mi conviene usare una più semplice hash table

per altro avrei anche il problema che per fare molte cose (ad esempio inizializzare gli rwlock con pthread_rwlock_t) dovrei lockare il segmento, e mi sembra di capire che non sia proprio un'operazione standard, e comunque richiede i privilegi di root (che potrebbe anche andare bene per il server, ma per il client richiedere i privilegi di root mi sembra esagerato)

ps: soluzioni meno complicate sono sempre molto bene accette

Ultima modifica di tuccio` : 02-04-2011 alle 17:30.
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2011, 14:35   #9
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
intanto ho dimenticato di premettere che è un progetto per un corso di programmazione di sistema (server e client tftp windows e linux)

Bernaschi?

Io sto lavorando ad un server SMTP/POP con simili caratteristiche, e sono incappato nello stesso problema. Casomai trovassi una buona soluzione lo scriverò qui (o casomai l'abbia trovata tu, condividila ).
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2011, 15:59   #10
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
sì sì, progetto consegnato etc, manca solo la verbalizzazione

Ultima modifica di tuccio` : 24-06-2011 alle 16:44.
tuccio` è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Henry Cavill svela il nuovo reboot di Hi...
Galaxy S25 512GB: il top compatto Samsun...
La fine di un'era: Tesla dice basta a Mo...
L'Europa è indietro di 20 anni ri...
Microsoft: trimestre record da 81 miliar...
Amazon trasforma qualsiasi TV in smart: ...
Meta ha quasi smesso di parlare di metav...
STMicroelectronics sorprende nel Q4: rit...
Recensione realme P4 Power: con una batt...
Chrome può navigare da solo adess...
Amazon rende smart il citofono di casa: ...
Samsung chiude il 2025 con risultati rec...
Tesla svela i dati finanziari di fine 20...
Nuovo kit Mesh FRITZ! con Wi‑Fi 7:...
Windows 11 ha raggiunto quota un miliard...
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: 11:14.


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