Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-03-2008, 17:34   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
[C++] g++ Big endian flag

Ciao ragazzi,
sto lavorando su architettura PowerPC. Ho bisogno di convertire i miei dati in big endian. Quindi, il programma che crea i files binari devo ricompilarlo. Quale è il flag da usare in g++ per fare questo?

l'opzione -big non funziona.

Grazie.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2008, 19:14   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
-mbig (o -mbig-endian)
Ma il gcc per PowerPC non è big endian di default?
__________________
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 05-03-2008, 19:21   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
-mbig (o -mbig-endian)
Ma il gcc per PowerPC non è big endian di default?
Guarda, siceramente non lo so. Comunque quelle due opzioni le ho provate, ma mi dice:

Codice:
cc1plus: error: invalid option `big'
Mi è venuto il sospetto che nel mio applicativo ci sia questo problema, in quanto, andando a leggere i files binari, i valori sono tutti sballati. Cosa che non è mai successa su architetture Intel ed Amd. O il problema è questo, o quello che ho postato qua:

http://www.hwupgrade.it/forum/showthread.php?t=1693840

Ultima modifica di Unrue : 05-03-2008 alle 19:24.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2008, 19:31   #4
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Se il tuo programma va in esecuzione, allora l'endianess è corretta altrimenti non ti partiva proprio.
Riguardo l'accesso ai dati, deve essere _tua_ responsabilità gestire l'endianess dei dati. Ad esempio un semplice
int a = 0x01020304;
fwrite(&a, sizeof(a), 1, file);
scrive per forza due cose diverse su processori little o big endian, e non c'è flag di compilazione che può aiutarti.
__________________
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 06-03-2008, 09:58   #5
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Se il tuo programma va in esecuzione, allora l'endianess è corretta altrimenti non ti partiva proprio.
Riguardo l'accesso ai dati, deve essere _tua_ responsabilità gestire l'endianess dei dati. Ad esempio un semplice
int a = 0x01020304;
fwrite(&a, sizeof(a), 1, file);
scrive per forza due cose diverse su processori little o big endian, e non c'è flag di compilazione che può aiutarti.
No aspetta, non ho capito. Ad esempio, io ho un file binario in cui ho scritto dei double. Se setto il flag per big endian nel programma che crea il file e lo stesso in quello che lo legge, perché devo cambiare le routines di lettura/scrittura? Allora quei flags a cosa servono? Non dovrò mica riscrivere tutte le routines?

Il file binario in questione l'ho ricreato sotto architettura Power, ovviamente.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:12   #6
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Unrue Guarda i messaggi
No aspetta, non ho capito. Ad esempio, io ho un file binario in cui ho scritto dei double. Se setto il flag per big endian nel programma che crea il file e lo stesso in quello che lo legge, perché devo cambiare le routines di lettura/scrittura?
Per i double non lo so, non so se sono scritti in formato diverso tra little/big endian. Bella questione, qualcuno ne sa qualcosa?
Per gli int ti assicuro che avrai problemi.

Quote:
Allora quei flags a cosa servono?
A compilare il codice in modo da usare l'endianess corretta per il processore target. Certi processori possono operare in little o big endian (viene fissato dal s/o), in questi casi devi dire al gcc per quale tipo di architettura vuoi fare l'eseguibile. Un eseguibile per big endian non può essere eseguito su processori little endian, e viceversa.
Mi risulta che il PowerPC sia solo big endian, magari mi sbaglio.

Quote:
Non dovrò mica riscrivere tutte le routines?
Probabilmente. Il problema della compatibilità dei dati tra little e big endian dovevi già pianificarla dall'inizio, se era un requisito.
__________________
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

Ultima modifica di ilsensine : 06-03-2008 alle 10:16.
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:17   #7
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Per i double non lo so, non so se sono scritti in formato diverso tra little/big endian. Bella questione, qualcuno ne sa qualcosa?
Per gli int ti assicuro che avrai problemi.
Fortunatamente uso solo double.

Quote:
Originariamente inviato da ilsensine Guarda i messaggi
A compilare il codice in modo da usare l'endianess corretta per il processore target. Certi processori possono operare in little o big endian (viene fissato dal s/o), in questi casi devi dire al gcc per quale tipo di architettura vuoi fare l'eseguibile. Un eseguibile per big endian non può essere eseguito su processori little endian, e viceversa.
Mi risulta che il PowerPC sia solo big endian, magari mi sbaglio.
Mm, scusa ma continua a non tornarmi. Io ho ricompilato tutti i miei sorgenti sotto architettura Power. Quindi, tutti gli eseguibili seguono la codifica big endian quando leggo e scrivo. Di conseguenza, se opero sempre e solo sotto architettura Power, non dovrei preoccuparmi di convertire, perchè non c'è nulla da convertire essendo già tutto in big endian. Ovviamente se passo da un'architettura all'altra dovrei farlo certo. O no?
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:24   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Fammi capire: ti serve un formato generico per scrivere i dati in un file binario che sia compatibile con endianess diverse ?
Imho settare l'endianess non serve a niente, a meno che l'architettura di destinazione non supporti formati eseguibili con endiness diversi.
Se non setti l'endianess e rimani sulla stessa architettura non ti devi occupare del problema.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:26   #9
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Di conseguenza, se opero sempre e solo sotto architettura Power, non dovrei preoccuparmi di convertire, perchè non c'è nulla da convertire essendo già tutto in big endian.
Ah allora se quei file non verranno mai letti da processori little endian non c'è nessun problema. Li vedi diversi da quelli generati da computer x86, ma è normale.
__________________
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 06-03-2008, 10:26   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Per i double non lo so, non so se sono scritti in formato diverso tra little/big endian. Bella questione, qualcuno ne sa qualcosa?
Credo di sì, dopo tutto si tratta sempre di un formato derivato dall'architettura del processore...per il controller della memoria andare a scrivere in memoria due int o un double è la stessa cosa.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:28   #11
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
Quote:
Originariamente inviato da cionci Guarda i messaggi
Fammi capire: ti serve un formato generico per scrivere i dati in un file binario che sia compatibile con endianess diverse ?
Imho settare l'endianess non serve a niente, a meno che l'architettura di destinazione non supporti formati eseguibili con endiness diversi.
Se non setti l'endianess e rimani sulla stessa architettura non ti devi occupare del problema.
La mia applicazione fino a poco tempo fa ha girato sotto architettura x86. Adesso, per problemi su quella macchina, sono costretto ad usare una macchina con architettura Power.

Ora, sapevo che se portavo i binari creati sotto x86 in Power, avevo il problema del big endian, per questo li ho ricreati tutti sotto il Power.

Quindi, dovrebbero già essere in formato big endian.

Sapreste dirmi qualcosa sul problema postato e linkato nel thread sopra? Credo che la causa sia quella.

Ultima modifica di Unrue : 06-03-2008 alle 10:40.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10:47   #12
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cionci Guarda i messaggi
per il controller della memoria andare a scrivere in memoria due int o un double è la stessa cosa.
L'endianess non c'entra con il controller della memoria, ma come il processore memorizza i byte nei registri.
I valori in virgola mobile forse sono dettati da degli standard, quindi non sono sicuro se i big endian invertono i byte. Anche se da quello che dice Unrue sembrerebbe di sì.
__________________
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 06-03-2008, 10:51   #13
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Quindi, dovrebbero già essere in formato big endian.
Dovrebbero, e il programma dovrebbe funzionare senza problemi. A meno di errori di altro tipo, che dovresti investigare.

Quote:
Sapreste dirmi qualcosa sul problema postato e linkato nel thread sopra? Credo che la causa sia quella.
Io non ne so nulla di quel MPI...
__________________
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 06-03-2008, 11:06   #14
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
L'endianess non c'entra con il controller della memoria, ma come il processore memorizza i byte nei registri.
I valori in virgola mobile forse sono dettati da degli standard, quindi non sono sicuro se i big endian invertono i byte. Anche se da quello che dice Unrue sembrerebbe di sì.
Che senso ha parlare di little e big-endian sui registri del processore ?
Che io sappia riguarda solamente l'ordine con cui i dati vengono trasferiti dal controller nella memoria...
Come venga trasferito un double (8 byte) poi dipende ancora di più dal controller della memoria stesso...

Ultima modifica di cionci : 06-03-2008 alle 11:10.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 11:25   #15
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cionci Guarda i messaggi
Che senso ha parlare di little e big-endian sui registri del processore ?
Ha senso, per come il processore vede i byte dei registri:
Codice:
union A
{
  char bytes[4];
  int value;
};

register A a;
register int b;
a.value = 0x01020304;
b = a.bytes[0];
Il compilatore può ottimizzare le variabili "a" e "b" in modo da mantenerle in due registri. L'accesso alla memoria può essere completamente evitato, eppure il risultato è diverso tra little e big endian.
Quote:
Che io sappia riguarda solamente l'ordine con cui i dati vengono trasferiti dal controller nella memoria...
Esistono processori che consentono configurazioni "frankenstein": core big endian, bus little endian o viceversa.
__________________
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 06-03-2008, 11:52   #16
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Il risultato può essere diverso anche per scelta di traduzione in assembly, questo per mantenere coerenza fra l'accesso alla memoria e ai registri.
Imho a livello di assembly questa cosa non può esistere...cioè è come se accedessi ad AL ed ottenessi il byte più significativo di un intero.

Ultima modifica di cionci : 06-03-2008 alle 11:54.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 11:58   #17
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cionci Guarda i messaggi
Il risultato può essere diverso anche per scelta di traduzione in assembly, questo per mantenere coerenza fra l'accesso alla memoria e ai registri.
E se il controller scrive in memoria con un endianess diverso, che si inventa il compilatore?
Come ti ho detto, ci sono processori che consentono queste diavolerie. Ho letto il datasheet di uno di questi, non ricordo se era l'mx1 o qualche altro.
__________________
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 06-03-2008, 12:07   #18
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6328
Ragazzi, se vi interessa ho risolto il problema della corruzione dei dati letti. Riguarda MPI-2, non la codifica big endian se volete ve la espongo.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 12:29   #19
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
E se il controller scrive in memoria con un endianess diverso, che si inventa il compilatore?
Come ti ho detto, ci sono processori che consentono queste diavolerie. Ho letto il datasheet di uno di questi, non ricordo se era l'mx1 o qualche altro.
Sono proprio masochisti certi progettisti
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 14:12   #20
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Ragazzi, se vi interessa ho risolto il problema della corruzione dei dati letti. Riguarda MPI-2, non la codifica big endian se volete ve la espongo.
Anche se non c'entro una ceppa sono interessato alla spiegazione
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Starlink Mobile: SpaceX potrebbe lanciar...
Volkswagen trasforma lo stabilimento di ...
Meta AI più reattivo e imparziale...
In Cina la prima GPU discreta al mondo c...
Vertiv CoolCenter, il sistema di raffred...
Konecta entra nel Kraken BPO Partner Pro...
Un dialogo con l'AI sposta voti meglio d...
iPhone 17 al minimo storico: oggi il 256...
Gli utenti italiani scelgono ChatGPT: &e...
Anche Xiaomi avrà il suo trifold:...
È Natale in casa Tesla: arriva la...
Shai-Hulud diventa più cattivo: e...
Aereo ultraleggero si schianta in atterr...
Windows 11 ha una nuova schermata Esegui...
Netflix si prende HBO, Harry Potter e il...
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: 19:09.


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