Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Peugeot Polygon Concept: ecco il futuro delle utilitarie
Peugeot Polygon Concept: ecco il futuro delle utilitarie
Polygon è la concept car di Peugeot che mostra il futuro delle soluzioni del segmento B: tra design compatti e innovativi affiancati da dimensioni compatte uno scherzo dalla manovrabilità incredibile per le manovre a bassa velocità
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-03-2008, 16:34   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
[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, 18: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, 18:21   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
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 18:24.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2008, 18: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, 08:58   #5
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
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, 09: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 09:16.
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 09:17   #7
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
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, 09: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, 09: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, 09: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, 09:28   #11
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
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 09:40.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 09: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, 09: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, 10: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 10:10.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10: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, 10: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 10:54.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2008, 10: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, 11:07   #18
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7134
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, 11: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, 13: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


Peugeot Polygon Concept: ecco il futuro delle utilitarie Peugeot Polygon Concept: ecco il futuro delle ut...
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
Edge AI: NVIDIA Jetson raggiungerà...
La missione robotica LINK per salvare il...
Potrebbe essere stato lanciato l'ultimo ...
PamStealer, il malware per Mac che prima...
NAVEE EXO S Pro, il robot esoscheletro p...
Samsung Galaxy A57 5G a 399€ con 256 GB:...
Volevano collegare delle aragoste vive a...
La crisi dei PC è peggiore del pr...
Alibaba pronta a vietare Claude Code ai ...
Sovranità sui dati: Cloud Firewal...
FiberCop porterà la fibra Gigabit...
Data center in Lombardia: 20 progetti sc...
Tutti i modi in cui la scommessa di Orac...
Kioxia e SanDisk sbandierano i numeri de...
iPhone 18 Pro potrebbe usare modem Qualc...
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: 23:33.


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