Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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à
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-07-2011, 11:56   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6512
[C]n Cache alignement

Ciao a tutti,

sto riguardando il cache alignment su un libro, in cui ad un certo punto fa un esempio con del codice:

Quote:
size_t bytes = 128;
size_t m=16; // ( cache line in bytes)
char* base = (char*)malloc(m+bytes);

// Round pointer up to next line
char* result = (char)*((UIntPtr)(base+m)& -m);

// Record where block actually starts
((char**)result)[-1] = base;
Non ho capito cosa fanno le ultime due istruzioni. Qualcuno può chiarirmi? Grazie.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2011, 00:17   #2
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Ciao a tutti,

sto riguardando il cache alignment su un libro, in cui ad un certo punto fa un esempio con del codice:



Non ho capito cosa fanno le ultime due istruzioni. Qualcuno può chiarirmi? Grazie.
malloc ti ritorna un puntantore non necessariamente allineato ai 16 bytes come vuoi tu (ad esempio 20).
quindi nella penultima linea salvi in result il primo indirizzo in base allineato a 16 (e.g. 32).
quindi con l'ultima riga salvi nei quattro byte precedenti a result il puntatore all'indirizzo originale, presumibilmente per poterne fare la free successivamente.

Questo almeno in teoria, in quella penultima linea ci sono diverse cose che non tornano (e sicuramente non compila), tra cui il fatto che quel (char)* probabilmente e' un (char*), e quell' & in mezzo non e' chiaro a cosa serva. Senza contare che se quell'UIntPtr e' un puntatore a unsigned int, allora sfori l'array che e' un piacere :P
Francamente userei qualcosa di piu' semplice rispetto a quella linea, tipo
Codice:
char* result = base + m - (base%m);
Il codice (il mio, ma a naso forse anche quello originale) funziona nell'ipotesi che la memoria ritornata sia cmq allineata almeno a sizeof(void*), altrimenti potresti non avere spazio sufficiente per salvare
il puntatore nell'ultima riga.

Detto questo, se sei in ambiente unix prova a dare una occhiata a posix_memalign.
__________________
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 25-07-2011, 18:44   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6512
Quote:
Originariamente inviato da marco.r Guarda i messaggi
Questo almeno in teoria, in quella penultima linea ci sono diverse cose che non tornano (e sicuramente non compila), tra cui il fatto che quel (char)* probabilmente e' un (char*),
Si, ho sbagliato a trascrivere

Quote:
Originariamente inviato da marco.r Guarda i messaggi
e quell' & in mezzo non e' chiaro a cosa serva.
Questo invece l'ho trascritto correttamente, non capisco proprio cosa cosa faccia quella istruzione a livello di sintassi C, al di là dell'allineamento

Quote:
Originariamente inviato da marco.r Guarda i messaggi
Senza contare che se quell'UIntPtr e' un puntatore a unsigned int, allora sfori l'array che e' un piacere :P
Già..

Quote:
Originariamente inviato da marco.r Guarda i messaggi
Francamente userei qualcosa di piu' semplice rispetto a quella linea, tipo
Codice:
char* result = base + m - (base%m);
Concordo.

Quote:
Originariamente inviato da marco.r Guarda i messaggi
Il codice (il mio, ma a naso forse anche quello originale) funziona nell'ipotesi che la memoria ritornata sia cmq allineata almeno a sizeof(void*), altrimenti potresti non avere spazio sufficiente per salvare
il puntatore nell'ultima riga.
Mm, puoi spiegarmi meglio?

Quote:
Originariamente inviato da marco.r Guarda i messaggi
Detto questo, se sei in ambiente unix prova a dare una occhiata a posix_memalign.
Thanks!!
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2011, 19:43   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
L' & -m serve ad azzerare i bit meno significati (i primi 4, visto che m è pari a 16) del puntatore, così da farlo diventare allineato a 128 bit.

Non è un'istruzione strana. E' molto comune e usata per questa particolare operazione (classico "and masking"; alcuni microprocessori hanno addirittura istruzioni dedicate).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2011, 23:27   #5
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
L' & -m serve ad azzerare i bit meno significati (i primi 4, visto che m è pari a 16) del puntatore, così da farlo diventare allineato a 128 bit.

Non è un'istruzione strana. E' molto comune e usata per questa particolare operazione (classico "and masking"; alcuni microprocessori hanno addirittura istruzioni dedicate).
L'istruzione non e' strana, ma in mezzo a quei cast e refusi l'avevo scambiata per un &prefisso (prendi l'indirizzo di) e non l'omonimo operatore binario
Allora ora e' tutto chiaro, direi che funziona come inteso.
__________________
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 26-07-2011, 07:29   #6
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
L'offuscamento del codice è una delle "feature" del C.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Il remake di Assassin's Creed IV: Black ...
Tutti i robot aspirapolvere in offerta s...
Amazon Haul spinge la promo di San Valen...
Offerte hardware Amazon per l'upgrade de...
iPhone 17e dovrà fare i conti con...
Offerte Amazon sugli iPhone di ultima ge...
DJI Mini 5 Pro Combo Fly More scende a 8...
Ubisoft potrebbe licenziare ancora ma se...
Samsung Galaxy S26: un leak anticipa col...
Aetherflux e Lockheed Martin insieme per...
SpaceX sta proseguendo i test della terz...
Axiom Space ha mostrato un nuovo video d...
Realme: la trasformazione in sub-brand d...
PlayStation 6 si farà attendere: ...
BWT Alpine chiude la prima tornata di pr...
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: 13:33.


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