|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#21 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Ho installato il compilatore Intel:
![]() http://software.intel.com/en-us/inte...llel-studio-xe http://software.intel.com/en-us/non-...re-development Ora debbo capire come si usa. |
|
|
|
|
|
#22 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Confermato. Si tratta di un bug di GCC a 32 bit. Compilando col compilatore Intel funziona tutto a meraviglia(anche senza allineamento):
![]() E io che stavo impazzendo a cercare il bug nel mio codice... Ultima modifica di Vincenzo1968 : 04-01-2013 alle 22:57. |
|
|
|
|
|
#23 |
|
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Uomo di poca fede.
P.S. Anche GCC è farina del sacco di Stallman.
__________________
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 |
|
|
|
|
|
#24 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Praticamente è da quando hanno deciso di sostituire bison con un parser a discesa ricorsiva scritto a mano che gcc presenta qualche bug...
Scheeeeeerzo No, ma, a parte gli scherzi, vorrei segnalare il bug al team degli sviluppatori GCC. Vorrei mandargli i sorgenti del mio programma, il log di Valgrind, i test che ho effettuato e i risultati ottenuti. Come si fa? Chi debbo contattare? A chi debbo telefonare? Debbo prendere l'aereo e consegnare il tutto personalmente? WarDuck, Cesare, Marco: grazie di cuore a tutti voi per i vostri preziosi consigli e suggerimenti. Senza di voi probabilmente starei ancora impazzendo cercando di scovare il bug. Un ringraziamento particolare a Marco per l'ottimo Valgrind. |
|
|
|
|
|
#25 | |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Alt! Fermi tutti!
In realtà ho sbagliato a passare il parametro per la compilazione a 32 bit: doveva essere -m32(come in GCC) e non -mia32. compilando con -mia32 il parametro viene ignorato e viene prodotto un eseguibile a 64 bit(ecco perché funziona, come nel caso di GCC). Me ne sono accorto col comando "file" che mostra se un file eseguibile è a 32 o 64 bit. La compoilazione a 32 bit col compilatore Intel produce lo stesso errore segfault del compilatore GCC: ![]() E dunque il bug è nel mio codice, non in GCC. Ma intanto perché Valgrind mi indica il file mc_replace_strmem.c? Quote:
Adesso provo a sostituire le dichiarazioni dei tipi con quelli definiti in stdint.h, come suggerito da WarDuck.
|
|
|
|
|
|
|
#26 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Anche col compilatore Intel se uso l'allineamento è tutto ok:
![]() Mah! Ultima modifica di Vincenzo1968 : 05-01-2013 alle 16:51. |
|
|
|
|
|
#27 |
|
Senior Member
Iscritto dal: May 2001
Messaggi: 12883
|
Ti consiglio anche di sostituire la strcpy con strncpy, la variante che ti consente di specificare il numero massimo di bytes da scrivere nel buffer, è più sicura.
|
|
|
|
|
|
#28 | |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Quote:
Ancora non ho sostituito le dichiarazioni dei tipi con quelli in stdint.h(ho lavorato di debug con Valgrind). Faccio le sostituzioni che mi hai indicato e ti faccio sapere. |
|
|
|
|
|
|
#29 | |
|
Senior Member
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
|
Quote:
Puoi a valgrind di aprire il debugger quando incontra quell'errore, invece di continuare impunemente. Usare gdb da linea di comando non e' la cosa piu' piacevole del mondo, ma almeno dovresti poter vedere l'input al momento della chiamata e capire cosa c'e' di sbagliato negli argomenti. Nel frattempo segui il consiglio di Warduck riguardo strncpy, e aumenta la dimensione dei buffer.
__________________
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 |
|
|
|
|
|
|
#30 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Ho applicato le sostituzioni indicate da WarDuck ma il problema rimane. Resta comunque una buona pratica de seguire per la portabilità. D'ora in poi la adotterò.
Intanto ho isolato la parte di codice rognosa(grazie a Valgrind): Codice:
typedef struct nodeTypeTag
{
nodeEnum type;
enumTipo0 type0; /* T_SIMPLE, T_ARRAY */
enumTipo1 type1; /* T_INTEGER, T_REAL, T_STRING, T_BOOLEAN */
enumTipo2 type2; /* T_CONST, T_VAR */
/* union deve essere l'ultima voce in nodeType */
/* perché operNodeType può crescere dinamicamente */
union
{
PREFIX_ALIGNED constNodeType con SUFFIX_ALIGNED; /* costanti */
PREFIX_ALIGNED idNodeType id SUFFIX_ALIGNED; /* identificatori */
PREFIX_ALIGNED operatorNodeType opr SUFFIX_ALIGNED; /* operatori */
};
} nodeType;
Aho', 'sto Valgrind è favoloso! (anche da riga di comando) Non c'è una versione per Windows(o qualcosa di simile)? |
|
|
|
|
|
#31 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Risoltoooooooooooooooooooooooooooooooooo!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
![]()
|
|
|
|
|
|
#32 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Non era la union. Era quella minchia di funzione con argomenti variabili.
Ho risolto così: Questa la funzione incriminata(nel file "ast.c"): Codice:
nodeType *opr(int oper, int nops, ...)
{
va_list ap;
nodeType *p = NULL;
size_t nodeSize;
int i;
nodeSize = SIZEOF_NODETYPE + sizeof(operatorNodeType) + (nops - 1) * sizeof(nodeType*);
if ((p = (nodeType*)malloc(nodeSize)) == NULL)
{
printf("Errore: memoria insufficiente.\n");
return NULL;
}
p->type = typeOperator;
p->opr.oper = oper;
p->opr.nops = nops;
va_start(ap, nops);
for (i = 0; i < nops; i++)
p->opr.op[i] = va_arg(ap, nodeType*);
va_end(ap);
return p;
}
Codice:
nodeType *opr(int oper, int nops, nodeType *p1, nodeType *p2, nodeType *p3)
{
nodeType *p = NULL;
size_t nodeSize;
nodeSize = SIZEOF_NODETYPE + sizeof(operatorNodeType);
if ((p = (nodeType*)malloc(nodeSize)) == NULL)
{
printf("Errore ast opr: memoria insufficiente.\n");
return NULL;
}
p->type = typeOperator;
p->opr.oper = oper;
p->opr.nops = nops;
p->opr.op[0] = p1;
p->opr.op[1] = p2;
p->opr.op[2] = p3;
return p;
}
Ti meriti un bacino sulla fronte. Tie': smackkkkkkkkkkkkkk. Grazie di cuore anche a WarDuck e Cesare Stallman for president |
|
|
|
|
|
#34 |
|
Senior Member
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
|
Il link che ti avevo dato contiene riferimenti ad altri prodotti analoghi , alcuni dei quali disponibili pure per windows.
Ad esempio http://www.drmemory.org/ Pero' non li ho mai usati e non li conosco (neanche di nome).
__________________
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 |
|
|
|
|
|
#35 | |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Quote:
Minchia ti dice anche se lasci la memoria sporca perché ti sei dimenticato una free! Come ho fatto per vent'anni a non utilizzarlo? E come ho potuto rinunciare a Linux per vent'anni? Ma come sono stato pazzo? Bisogna avviarlo coi seguenti parametri: --leak-check=full --show-reachable=yes --track-origins=yes --log-file=outValgrind.txt Per esempio: Codice:
valgrind --leak-check=full --show-reachable=yes --track-origins=yes --log-file=outValgrind.txt ./Contest1732 Files/prog01.txt ![]() Edit: comunque ora provo 'sto Dr. Memory visto che è disponibile anche per Windows. Riedit: Ahi! : Dr. Memory currently targets 32-bit applications only. Ultima modifica di Vincenzo1968 : 07-01-2013 alle 16:07. |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 22:30.


























