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
Discussione Chiusa
 
Strumenti
Old 19-06-2008, 10:17   #1
SoppalcoFC
Junior Member
 
Iscritto dal: May 2008
Messaggi: 1
Progetto in C - Allocatore di memoria

Il problema

Si vuole realizzare un allocatore di memoria dinamica (per un sistema che non dispone di particolari supporti hardware quali una MMU per la memoria virtuale) capace di compattare la memoria allocata, quando necessario, per cercare di soddisfare le richieste di allocazione anche in caso di memoria frammentata. L'allocatore deve fornire servizi analoghi a quelli di malloc() e free(), ma in più deve essere in grado di spostare i blocchi di memoria, senza ovviamente alterare l'esecuzione del programma, se necessario per
soddisfare alcune richieste. Si è scelto di realizzare l'allocatore tramite il sistema degli handle (doppi puntatori): in pratica, quando un programma richiede un blocco di memoria, non viene restituito direttamente un puntatore alla memoria allocata (come fa, per esempio, la malloc()), bensì un puntatore a un puntatore alla memoria allocata. Se p è un handle a un blocco allocato, **p punterà al primo byte del blocco di
memoria allocata. Il puntatore intermedio è sotto controllo dell'allocatore stesso: *p sarà quindi un puntatore contenuto in un'area speciale della memoria riservata agli handle, e l'allocatore potrà modificare il contenuto di *p (ma non quello di p, visto che p è una variabile del programma che usa l'allocatore) per riflettere l'eventuale spostamento di un blocco in memoria. Lo spostamento va effettuato tutte le volte che nello heap gestito dall'allocatore c'è sufficiente memoria complessiva a soddisfare una richiesta, ma questa memoria non è contigua (per esempio, in conseguenza a numerose allocazione e deallocazioni in ordine sparso),
cosicché non è possibile trovare un blocco contiguo di memoria della dimensione richiesta. In questa situazione, l'allocatore deve ricompattare i blocchi allocati, aggiornare i puntatori intermedi nell'area degli handle, e infine allocare il blocco richiesto.

API

L'allocatore di memoria deve fornire la seguente API:
heap *createH(int nhandles, int size) – crea un nuovo heap, capace di gestire al più nhandles handle, e con uno spazio per i dati di size bytes.
void **allocH(heap *h, int size) – alloca size bytes nello heap h, restituisce il puntatore a un handle (o NULL in caso di errore). Se c'è sufficiente spazio disponibile, ma non contiguo, effettua una ricompattazione e poi alloca il blocco.
void freeH(heap *h, void **handle) – libera la memoria allocata dall'handle handle nello heap h. L'handle deve essere stato ottenuto da una precedente chiamata a allocH().
int availH(heap *h) – restituisce la quantità di spazio libero nello heap h (ovvero, la somma della dimensione di tutti gli eventuali frammenti liberi).
void compactH(heap *h) – forza una ricompattazione dello heap h.
void destroyH(heap *h) – distrugge lo heap h; dopo questa operazione, tutti gli handle ottenuti da allocH() su quello heap sono invalidi.


Io ho pensato a gestire le strutture dati nel modo seguente:

Codice:

#define N_HEAP 100

typedef struct handle {
char *dati;
int size;
} handle;

typedef struct heap {
int nhandles;
int size;
handle ** hl;
void* mem;
} heap;

// struttura che utilizzo per tener traccia degli heap effettivamente creati con all'interno
// il puntatore all'area di memoria corrispondente al primo byte

static heap * Heap_Used[N_HEAP];


Secondo voi va bene questa scelta o c'e' un modo migliore per procedere nello svolgimento del progetto? Grazie per l'aiuto!!
SoppalcoFC è offline  
Old 19-06-2008, 14:05   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
http://www.hwupgrade.it/forum/showthread.php?t=1649196
__________________
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  
 Discussione Chiusa


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...
Booking.com e OpenAI annunciano SME AI A...
Xiaomi SU7 Ultra: da domani tutti i gioc...
Sharp Inspire Expo 2026: da produttore d...
Razer Synapse Web è realtà...
Concessionarie Audi chiudono improvvisam...
Resident Evil Requiem: 4K, 60 FPS e ray ...
Le batterie LFP sono piccole e pesanti? ...
Motorola inarrestabile: nuova serie moto...
Decima generazione Pokémon: grafi...
Una nuova legge consente di rottamare un...
Google mostra per sbaglio Android per PC...
Tesla non convince più: crolla il...
OpenAI lancia Prism: l'AI ora lavora fia...
Nissan mette i pannelli solari su Ariya:...
Day 3 a Barcellona: la prima di Norris 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: 01:39.


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