Torna indietro   Hardware Upgrade Forum > Software > Linux, Unix, OS alternativi

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-03-2005, 16:05   #1
fpucci
Senior Member
 
Iscritto dal: Jul 2002
Città: Roma
Messaggi: 806
Processi e Memoria in HP-UX

Spero di avere qualche delucidazione in merito.

Supponiamo di avere N-processi applicativi che girano contemporaneamente (oltre a quelli di sistema).

Poiché ogni processo ha uno spazio di 4Gb di indirizzi virtuali (configurabili nel kernel) che può indirizzare, (di cui 1 per il codice, 1Gb per i dati, 1Gb per gli oggetti condivisi (libreria, memoria), ed un altro Gb di indirizzi per l'I/O), cosa succede quando sia la memoria di sistema che quella virtuale stanno per finire?

Ovvero, se faccio partire altri procesi e quelli già presenti non sfruttano tutti i 4Gb a loro riservati, il sistema assegna la memoria non utilizzata dai processi già attivi e la assegna ai nuovi processi in partenza (diminuendo la memoria disponibile per cisacun processo) oppure si comporta diversamente?
Come si comporterebbe?

Il sistema in questione è una macchina HP 9000/800 con HP-UX B.11.11
fpucci è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2005, 18:26   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Non conosco quella architettura, ma normalmente ciascun processo dispone di una propria regione di 4 GB di indirizzi virtuali, indipendente dagli altri processi. Sotto linux solo 3 sono effettivamente utilizzabili dall'applicazione.
Questo è vero solo per architetture a 32 bit ovviamente,
__________________
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 10-03-2005, 01:39   #3
fpucci
Senior Member
 
Iscritto dal: Jul 2002
Città: Roma
Messaggi: 806
Quote:
Originariamente inviato da ilsensine
Non conosco quella architettura, ma normalmente ciascun processo dispone di una propria regione di 4 GB di indirizzi virtuali, indipendente dagli altri processi. [...]
Certo, ma cosa succede a questa quota di 4Gb quando la memoria sta per finire? Rimane sempre quel valore oppure potrebbe diminuire per permettere fi dar nascere altri processi?

Quote:
Questo è vero solo per architetture a 32 bit ovviamente,
Si, si parla di architeture a 32 bit ovviamente, con spazi di indirizzamento a 4Gb
fpucci è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2005, 07:56   #4
Scoperchiatore
Senior Member
 
L'Avatar di Scoperchiatore
 
Iscritto dal: Sep 2001
Città: Roma
Messaggi: 1944
Quote:
Originariamente inviato da fpucci
Certo, ma cosa succede a questa quota di 4Gb quando la memoria sta per finire? Rimane sempre quel valore oppure potrebbe diminuire per permettere fi dar nascere altri processi?


Si, si parla di architeture a 32 bit ovviamente, con spazi di indirizzamento a 4Gb
No, si dice che il sistema va in trashing e non permette il nascere di nuovi processi. Contemporaneamente uccide quelli non kernel che allocano nuova memoria.

E' un problema che su Win mi si è verificato un paio di volte, soprattutto con un paging ristretto e una CPU non velocissima. E' praticamente impossibile lavorare....
Anzi, no, NT regge bene quando trasha
__________________
"Oggi è una di quelle giornate in cui il sole sorge veramente per umiliarti" Chuck Palahniuk

Io c'ero
Scoperchiatore è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2005, 09:27   #5
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da fpucci
Certo, ma cosa succede a questa quota di 4Gb quando la memoria sta per finire? Rimane sempre quel valore oppure potrebbe diminuire per permettere fi dar nascere altri processi?
Il problema è molto più complesso di quanto credi. Posso parlare per linux, ma credo che per altri s/o il discorso è simile.
Non confondere _mai_ memoria virtuale e memoria fisica. La memoria virtuale è soltanto un insieme (contenitore) di pagine virtuali, dove il sistema operativo può mappare, come e quando ritiene opportuno, alcune pagine. In particolare una pagina virtuale può contenere:
1) Niente: Ti sembrerà strano, ma è il caso più frequente. Quando accedi alla pagina viene generata una eccezione, in corrispondenza della quale il kernel mappa "fisicamente" la pagina richiesta. La pagina può essere di uno dei tipi descritti sotto, oppure può essere una pagina finita in swap, oppure una pagina COW (copy(create)-on-write). Se nessuna pagina può essere recuperata (ad es. in condizioni gravi di OOM), si attiva l'OOM killer che si occupa di uccidere il processo che ha generato l'eccezione, oppure altri processi per soddisfare la richiesta di memoria. Il funzionamento dell'OOM killer è quanto di più problematico ci sia da gestire.
2) Memoria fisica. Sotto pressione di memoria, la pagina fisica può essere spedita in swap e si ritorna al caso 1). Linux utilizza spesso ottimizzazioni particolari dove una pagina è sia in swap che in memoria, in modo da poter liberare memoria fisica velocemente quando richiesto, avendo già effettuato lo swapout in condizioni di carico meno critiche.
3) Un file: in questo caso le pagine mappate provengono dalla page cache del sistema operativo, e sono comuni (condivise) tra tutti i processi che mappano il file. La page cache può essere ridotta o espansa secondo le situazioni di carico, riscrivendole o recuperandole dal file. Le pagine del file che non sono correntemente in page cache rientrano nel caso 1).
4) Memoria condivisa tra più programmi. Può essere gestita come in 2), con la particolarità che la pagina fisica è unica per tutte le applicazioni che la utilizzano. Esistono casi particolari di condivisione, gestiti in mamiera molto efficiente tramite le tecniche COW; la funzione fork() è il principale utilizzatore del COW.
5) Memoria di i/o: tecnica utilizzata ad es. da xfree per accedere ai registri delle schede video. Nessuna pagina della memoria di sistema sarà mai associata alla mappatura virtuale, che per contro finirà direttamente sulla iomem di un dispositivo.
6) mmap di un dispositivo: il suo significato effettivo dipende dal dispositivo. Alcune volte è analoga al caso 5), ma spesso è qualcosa di diverso.

Come vedi, non è facile stabilire "quando la memoria sta per finire" solamente guardando la mappatura virtuale dei processi. E' frequente il caso in cui un processo utilizza una libreria, che viene mappata come un file, ma della quale utilizza solo poche pagine: il "grosso" della libreria risulterebbe comunque mappato (e disponibile all'applicazione in caso di necessità), ma le pagine virtuali non corrisponderebbero a nessuna pagina fisica e così rimarranno probabilmente fino al termine dell'applicazione.
__________________
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 10-03-2005, 15:02   #6
fpucci
Senior Member
 
Iscritto dal: Jul 2002
Città: Roma
Messaggi: 806
Quote:
Originariamente inviato da ilsensine
Come vedi, non è facile stabilire "quando la memoria sta per finire" solamente guardando la mappatura virtuale dei processi. E' frequente il caso in cui un processo utilizza una libreria, che viene mappata come un file, ma della quale utilizza solo poche pagine: il "grosso" della libreria risulterebbe comunque mappato (e disponibile all'applicazione in caso di necessità), ma le pagine virtuali non corrisponderebbero a nessuna pagina fisica e così rimarranno probabilmente fino al termine dell'applicazione.
Grazie per la spiegazione.
Purtroppo il problema è che a me va in errore un tentativo di riallocazione di un'area di memoria [realloc()] di 2Mb con un messaggio di errore "Not enought memory..."!

Stavo pensando di mettere le mani su uno dei parametri del kernel (credo che sia uno di quelli che vengono gestiti anche dalla setrlimit()) ma non saprei proprio se sia la strada giusta... e quale sia la strada giusta...
fpucci è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2005, 15:09   #7
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da fpucci
Grazie per la spiegazione.
Purtroppo il problema è che a me va in errore un tentativo di riallocazione di un'area di memoria [realloc()] di 2Mb con un messaggio di errore "Not enought memory..."!
Questo può accadere per più motivi:
- hai esaurito gli indirizzi virtuali per il tuo processo
- hai esaurito la quota di memoria per il tuo processo (settabile tramite il comando ulimit)
- hai frammentato troppo l'heap e non riesci a trovare 2 MB di indirizzi virtuali contigui
Sono tutti casi improbabili, a meno che non hai qualche serio memory leak nel programma o allochi una quantità di memoria veramente enorme
Quote:
Stavo pensando di mettere le mani su uno dei parametri del kernel (credo che sia uno di quelli che vengono gestiti anche dalla setrlimit()) ma non saprei proprio se sia la strada giusta... e quale sia la strada giusta...
Se è un problema di quote per il processo puoi verificarlo facilmente maneggiando con il comando ulimit, prima di eseguire il programma. Occhio che innalzare gli hard limit richiede i privilegi di root.
__________________
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
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Switch 2: la crisi dei chip potrebbe ess...
Samsung si prepara a raddoppiare i prezz...
Il Play Store inizia ad avvisare gli ute...
AliExpress punta sulle aziende italiane:...
Oura acquisice una nuova startup: potreb...
Gli occhiali smart con IA sono il nuovo ...
Il nuovo Apple M5 Max si comporta bene n...
Shark annuncia il lancio di CryoGlow: la...
TCL perde in tribunale: quei TV 'QLED' n...
NVIDIA: la scarsità di hardware c...
Nintendo fa causa al governo USA per i d...
iPhone 17 256GB a 899€, MacBook Air 16/2...
C'è l'IA dietro la tua canzone pr...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
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: 07:18.


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