diff options
Diffstat (limited to 'lib/assembler.c')
-rw-r--r-- | lib/assembler.c | 234 |
1 files changed, 68 insertions, 166 deletions
diff --git a/lib/assembler.c b/lib/assembler.c index 0beb2df..0acf738 100644 --- a/lib/assembler.c +++ b/lib/assembler.c @@ -176,9 +176,7 @@ static bytestream_t *pushdword(unsigned long int d, expression_t * e) bytestream_t *s; if ((segment < 0) || (segment > 1)) { - exception(1, - _ - ("You have to be into the .text or the .data segment to define a value.")); + exception(1, _("You have to be into the .text or the .data segment to define a value.")); } s = pushuninit(1); @@ -267,9 +265,7 @@ static void pushstring(char *s) static void pushstart(void) { if (segment != SEG_TEXT) { - exception(1, - _ - ("You can't have the startpoint elsewhere than the .text segment")); + exception(1, _("You can't have the startpoint elsewhere than the .text segment")); } pushlabel("__start__"); } @@ -282,9 +278,7 @@ static void look4pattern(pattern_t * patterns, expression_t * expression) for (patterns = patterns->next; patterns; patterns = patterns->next) { for (i = 0; i < patterns->nbr; i++) { - if (! - (patterns->expr[i]->type - || patterns->expr[i]->string || !patterns->expr[i]->name)) { + if (!(patterns->expr[i]->type || patterns->expr[i]->string || !patterns->expr[i]->name)) { if (!strcasecmp(patterns->expr[i]->name, expression->symbol)) { expression->e_subtype = E_PATTERN; expression->pattern = patterns; @@ -661,8 +655,7 @@ static void evaluate(expression_t * e) if (!e->child->e_subtype == E_VALUE) { exception(1, _("Error: unable to compute the immediate value")); } - e->avalue = - (e->op == OP_MOINS_UNARY) ? -e->child->avalue : e->child->avalue; + e->avalue = (e->op == OP_MOINS_UNARY) ? -e->child->avalue : e->child->avalue; free(e->child); e->child = NULL; e->e_type = e->e_subtype = E_VALUE; @@ -696,8 +689,7 @@ static void evaluate(expression_t * e) if (e->child->next->child->e_subtype == E_LABEL) { exception(1, _("Addresses operations not allowed")); } - if (e->child->next->child->e_subtype == - e->child->next->child->next->e_subtype) { + if (e->child->next->child->e_subtype == e->child->next->child->next->e_subtype) { exception(1, _("Expression too complex or invalid")); } /* On veut obtenir quelque chose sous la forme LABEL[VALUE + PATTERN] */ @@ -808,9 +800,7 @@ static void evaluate(expression_t * e) et si c'est le cas, il ne faut pas que ce soit - C. Sinon nous ne devons pas avoir de labels pour B ou C */ - if ( - (e->child->child->next->child->next->e_subtype == - E_PATTERN) + if ((e->child->child->next->child->next->e_subtype == E_PATTERN) && (e->child->child->next->op == OP_MOINS)) { exception(1, _("Address type not supported")); } @@ -823,18 +813,14 @@ static void evaluate(expression_t * e) if (e->child->child->next->child->e_subtype == e->child->child->next->child->next->e_subtype) { - exception(1, - _("Expression too complex or invalid")); + exception(1, _("Expression too complex or invalid")); } /* Ok, si notre expression a réussi à franchir toutes ses étapes, c'est qu'elle est correcte.... Enfin j'espère :) Je vais modifier l'expression de sorte a ce qu'elle ait la forme [LABEL + (VALEUR +- PATTERN)] */ - if ( - (t = - e->child->child->next->child)->e_subtype == - E_PATTERN) { + if ((t = e->child->child->next->child)->e_subtype == E_PATTERN) { t->prev = t->next; t->next = NULL; t->prev->next = t; @@ -851,15 +837,12 @@ static void evaluate(expression_t * e) et si c'est le cas, il ne faut pas que ce soit - C. Sinon nous ne devons pas avoir de patterns pour B ou C. */ - if ( - (e->child->child->next->child->next->e_subtype == - E_LABEL) + if ((e->child->child->next->child->next->e_subtype == E_LABEL) && (e->child->child->next->op == OP_MOINS)) { exception(1, _("Address type not supported")); } - if (e->child->child->next->child->e_subtype == - E_PATTERN) { + if (e->child->child->next->child->e_subtype == E_PATTERN) { exception(1, _("Expression invalid")); } @@ -867,8 +850,7 @@ static void evaluate(expression_t * e) if (e->child->child->next->child->e_subtype == e->child->child->next->child->next->e_subtype) { - exception(1, - _("Expression too complex or invalid")); + exception(1, _("Expression too complex or invalid")); } /* Ok, si notre expression a réussi à franchir toutes ses étapes, c'est qu'elle @@ -876,10 +858,7 @@ static void evaluate(expression_t * e) qu'elle ait la forme [LABEL + (VALEUR +- PATTERN)] */ /* Pas mal de boulot ici... */ - if ( - (t = - e->child->child->next->child)->e_subtype == - E_LABEL) { + if ((t = e->child->child->next->child)->e_subtype == E_LABEL) { /* Nous avons [PATTERN + (LABEL +- VALEUR)], on inverse LABEL et VALEUR */ t->prev = t->next; t->next = NULL; @@ -918,8 +897,7 @@ static void evaluate(expression_t * e) if (e->child->child->next->op == OP_MOINS) { exception(1, _("Expression invalid")); } - e->child->child->avalue += - e->child->child->next->child->avalue; + e->child->child->avalue += e->child->child->next->child->avalue; t = e->child->child->next; e->child->child->next = t->child->next; free_expr(t); @@ -927,15 +905,12 @@ static void evaluate(expression_t * e) On va pas s'embeter, on va réévaluer la chose :) */ evaluate(e); return; - } else if (e->child->child->next->child-> - next->e_subtype == E_VALUE) { + } else if (e->child->child->next->child->next->e_subtype == E_VALUE) { /* Quasiment la même chose qu'au dessus... */ if (e->child->child->next->op == OP_MOINS) { - e->child->child->avalue - -= e->child->child->next->child->avalue; + e->child->child->avalue -= e->child->child->next->child->avalue; } else { - e->child->child->avalue - += e->child->child->next->child->avalue; + e->child->child->avalue += e->child->child->next->child->avalue; } t = e->child->child->next; e->child->child->next = t->child; @@ -947,9 +922,7 @@ static void evaluate(expression_t * e) if (e->child->child->next->child->e_subtype == e->child->child->next->child->next->e_subtype) { - exception(1, - _ - ("Expression too complex or invalid")); + exception(1, _("Expression too complex or invalid")); } /* Ok, si notre expression a réussi à franchir toutes ses étapes, c'est qu'elle @@ -957,10 +930,7 @@ static void evaluate(expression_t * e) qu'elle ait la forme [LABEL + (VALEUR +- PATTERN)] */ /* Pas mal de boulot ici... */ - if ( - (t = - e->child->child->next->child)->e_subtype == - E_PATTERN) { + if ((t = e->child->child->next->child)->e_subtype == E_PATTERN) { /* Nous avons [VALEUR + (PATTERN + LABEL)], on inverse LABEL et PATTERN */ t->prev = t->next; t->next = NULL; @@ -1254,8 +1224,7 @@ static int islabel(expression_t * e) /* Cette fonction cherche une instruction pouvant correspondre à l'expression. */ -static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, - expression_t * e) +static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, expression_t * e) { char *stringtolook = e->symbol; expression_t *t; @@ -1281,8 +1250,7 @@ static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, go_out = 0; for (i = 0; (!go_out) && (i < instructs->nbexplicit); i++) { if (!instructs->strings[i]) { - if (strcasecmp - (instructs->names[i], i ? t->symbol : stringtolook)) { + if (strcasecmp(instructs->names[i], i ? t->symbol : stringtolook)) { go_out = 1; } } else { @@ -1291,9 +1259,8 @@ static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, if (!t->pattern) { go_out = 1; } else { - if (strcasecmp - (instructs->strings[i] + 1, - t->pattern->name)) go_out = 1; + if (strcasecmp(instructs->strings[i] + 1, t->pattern->name)) + go_out = 1; } break; case 'C': @@ -1323,9 +1290,7 @@ static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, /* C'est le cas le plus simple ou presque, il suffit de tout prendre */ break; default: - exception(1, - _ - ("Unknow predefined string into the meta language")); + exception(1, _("Unknow predefined string into the meta language")); } } @@ -1347,10 +1312,8 @@ static instruct_t *e_match_i(phon_t * phons, instruct_t * instructs, for (i = 0; i < instructs->nbexplicit; i++) { fprintf(stderr, " + %s <= %s (type %s)\n", instructs->names[i], - instructs-> - strings[i] ? instructs->strings[i] : - "Pas de chaîne associée", - instructs->etypes[i] ? "prédéfinit" : "direct"); + instructs->strings[i] ? instructs->strings[i] : + "Pas de chaîne associée", instructs->etypes[i] ? "prédéfinit" : "direct"); } fprintf(stderr, " => Champs implicites.\n"); for (i = 0; i < instructs->nbimplicit; i++) { @@ -1394,8 +1357,7 @@ static void evaluate_pattern(_TableauVariable * it, expression_t * e) if (m->string) { if (m->type) { if (strcmp(m->name, "I")) { - exception(1, - _("Unknow constant type in the meta language")); + exception(1, _("Unknow constant type in the meta language")); } if (e->e_subtype == E_VALUE) { pushdword(e->avalue, NULL); @@ -1428,9 +1390,7 @@ static void evaluate_pattern(_TableauVariable * it, expression_t * e) if (m->type) { if (strcmp(m->name, "I") || strcmp(m->string, "O")) { - exception(1, - _ - ("Unknow constant type in the meta language")); + exception(1, _("Unknow constant type in the meta language")); } tv = 0; if (e->child->next->e_subtype == E_VALUE) { @@ -1660,9 +1620,7 @@ void asm_eol(void) if (!e_current) break; if (segment != SEG_TEXT) { - exception(1, - _ - ("You can only have an instruction into a .text segment")); + exception(1, _("You can only have an instruction into a .text segment")); } if (!(instr = e_match_i(phons, instructs, e_current))) { exception(1, _("Unmatched instruction")); @@ -1686,14 +1644,10 @@ void asm_eol(void) pushdword(0, e_current); } } else { - exception(1, - _ - ("Unknow constant type in the meta language")); + exception(1, _("Unknow constant type in the meta language")); } } else { - InsererVarDansTab(&it, - CreerElement - (instr->names[i], e_current)); + InsererVarDansTab(&it, CreerElement(instr->names[i], e_current)); } break; case 'O': @@ -1705,9 +1659,7 @@ void asm_eol(void) pushdword(0, e_current); } } else { - exception(1, - _ - ("Unknow constant type in the meta language")); + exception(1, _("Unknow constant type in the meta language")); } } break; @@ -1719,19 +1671,14 @@ void asm_eol(void) t->child = t->next = NULL; t->pattern = NULL; t->symbol = NULL; - InsererVarDansTab(&it, - CreerElement(instr->names[i], t)); + InsererVarDansTab(&it, CreerElement(instr->names[i], t)); #ifdef DEBUG - fprintf(stderr, - "On a %s qui vaut %i\n", - instr->names[i], e_current->index); + fprintf(stderr, "On a %s qui vaut %i\n", instr->names[i], e_current->index); #endif evaluate_pattern(&it, e_current); break; default: - exception(1, - _ - ("Unknow constant type in the meta language")); + exception(1, _("Unknow constant type in the meta language")); } } @@ -1756,11 +1703,9 @@ void asm_eol(void) t->symbol = NULL; } #ifdef DEBUG - fprintf(stderr, "On a %s qui vaut %i\n", - instr->implicits[i], t->avalue); + fprintf(stderr, "On a %s qui vaut %i\n", instr->implicits[i], t->avalue); #endif - InsererVarDansTab(&it, - CreerElement(instr->implicits[i], t)); + InsererVarDansTab(&it, CreerElement(instr->implicits[i], t)); break; case 1: /* type prédéfinit */ t = (expression_t *) @@ -1774,11 +1719,9 @@ void asm_eol(void) t->pattern = NULL; t->symbol = NULL; #ifdef DEBUG - fprintf(stderr, "On a %s qui vaut %i\n", - instr->implicits[i], t->avalue); + fprintf(stderr, "On a %s qui vaut %i\n", instr->implicits[i], t->avalue); #endif - InsererVarDansTab(&it, - CreerElement(instr->implicits[i], t)); + InsererVarDansTab(&it, CreerElement(instr->implicits[i], t)); break; case 2: /* type valeur */ t = (expression_t *) @@ -1789,11 +1732,9 @@ void asm_eol(void) t->pattern = NULL; t->symbol = NULL; #ifdef DEBUG - fprintf(stderr, "On a %s qui vaut %i\n", - instr->implicits[i], t->avalue); + fprintf(stderr, "On a %s qui vaut %i\n", instr->implicits[i], t->avalue); #endif - InsererVarDansTab(&it, - CreerElement(instr->implicits[i], t)); + InsererVarDansTab(&it, CreerElement(instr->implicits[i], t)); break; } } @@ -1952,9 +1893,7 @@ void asm_eof(FILE * f) if ((ttext->Expr->child->e_subtype == E_LABEL) && (ttext->Expr->child->next->e_subtype == E_VALUE)) { #ifdef DEBUG - fprintf(stderr, - "Symbole externe %s\n", - ttext->Expr->child->symbol); + fprintf(stderr, "Symbole externe %s\n", ttext->Expr->child->symbol); #endif a = ttext->Expr->child->next->avalue; nbsymbols++; @@ -1970,35 +1909,28 @@ void asm_eof(FILE * f) if (((ttext->Expr->child->e_subtype == E_LABEL) && (ttext->Expr->child->next->e_subtype == E_VALUE)) || ((ttext->Expr->child->e_subtype == E_VALUE) - && (ttext->Expr->child->next->e_subtype == - E_LABEL))) { + && (ttext->Expr->child->next->e_subtype == E_LABEL))) { if (ttext->Expr->child->e_subtype == E_LABEL) { #ifdef DEBUG - fprintf(stderr, - "Symbole externe %s\n", - ttext->Expr->child->symbol); + fprintf(stderr, "Symbole externe %s\n", ttext->Expr->child->symbol); #endif a = ttext->Expr->child->next->avalue; nbsymbols++; writeword(1, f2, 1); writeword(ttext->offset, f2, 1); - writeword(strlen - (ttext->Expr->child->symbol), f2, 1); + writeword(strlen(ttext->Expr->child->symbol), f2, 1); writestring(ttext->Expr->child->symbol, f2); nbe++; } else { #ifdef DEBUG fprintf(stderr, - "Symbole externe %s\n", - ttext->Expr->child->next->symbol); + "Symbole externe %s\n", ttext->Expr->child->next->symbol); #endif a = ttext->Expr->child->avalue; nbsymbols++; writeword(1, f2, 1); writeword(ttext->offset, f2, 1); - writeword(strlen - (ttext->Expr->child->next->symbol), f2, - 1); + writeword(strlen(ttext->Expr->child->next->symbol), f2, 1); writestring(ttext->Expr->child->next->symbol, f2); nbe++; } @@ -2006,42 +1938,28 @@ void asm_eof(FILE * f) } } if (ttext->Expr->op != OP_FUNC_CALL) { - exception(1, - _ - ("Can't evaluate expression for a direct value")); + exception(1, _("Can't evaluate expression for a direct value")); } if (strcmp(ttext->Expr->symbol, "diff")) { - exception(1, - _ - ("Can't evaluate expression for a direct value")); + exception(1, _("Can't evaluate expression for a direct value")); } if ((ttext->Expr->child->e_subtype != E_LABEL) || (ttext->Expr->child->next->e_subtype != E_LABEL)) { - exception(1, - _ - ("Can only use the diff() function onto labels")); + exception(1, _("Can only use the diff() function onto labels")); } - t = - (bytestream_t *) NomVarToVar(ttext->Expr->child->symbol, - labels, &trouve); + t = (bytestream_t *) NomVarToVar(ttext->Expr->child->symbol, labels, &trouve); if (!trouve) { - exception(1, - _("Can only evaluate a diff on local symbols")); + exception(1, _("Can only evaluate a diff on local symbols")); } - u = - (bytestream_t *) - NomVarToVar(ttext->Expr->child->next->symbol, labels, - &trouve); + u = (bytestream_t *) + NomVarToVar(ttext->Expr->child->next->symbol, labels, &trouve); if (!trouve) { - exception(1, - _("Can only evaluate a diff on local symbols")); + exception(1, _("Can only evaluate a diff on local symbols")); } if (t->segment != u->segment) { - exception(1, - _ - ("Can only evaluate a diff on symbols from the same segment")); + exception(1, _("Can only evaluate a diff on symbols from the same segment")); } a = t->offset - u->offset; @@ -2099,8 +2017,7 @@ void asm_eof(FILE * f) case E_LABEL: a = tdata->Expr->avalue; #ifdef DEBUG - fprintf(stderr, "Symbole externe %s\n", - tdata->Expr->child->symbol); + fprintf(stderr, "Symbole externe %s\n", tdata->Expr->child->symbol); #endif nbsymbols++; writeword(3, f2, 1); @@ -2111,42 +2028,28 @@ void asm_eof(FILE * f) break; case E_OPERATION: if (tdata->Expr->op != OP_FUNC_CALL) { - exception(1, - _ - ("Can't evaluate expression for a direct value")); + exception(1, _("Can't evaluate expression for a direct value")); } if (strcmp(tdata->Expr->symbol, "diff")) { - exception(1, - _ - ("Can't evaluate expression for a direct value")); + exception(1, _("Can't evaluate expression for a direct value")); } if ((tdata->Expr->child->e_subtype != E_LABEL) || (tdata->Expr->child->next->e_subtype != E_LABEL)) { - exception(1, - _ - ("Can only use the diff() function onto labels")); + exception(1, _("Can only use the diff() function onto labels")); } - t = - (bytestream_t *) NomVarToVar(tdata->Expr->child->symbol, - labels, &trouve); + t = (bytestream_t *) NomVarToVar(tdata->Expr->child->symbol, labels, &trouve); if (!trouve) { - exception(1, - _("Can only evaluate a diff on local symbols")); + exception(1, _("Can only evaluate a diff on local symbols")); } - u = - (bytestream_t *) - NomVarToVar(tdata->Expr->child->next->symbol, labels, - &trouve); + u = (bytestream_t *) + NomVarToVar(tdata->Expr->child->next->symbol, labels, &trouve); if (!trouve) { - exception(1, - _("Can only evaluate a diff on local symbols")); + exception(1, _("Can only evaluate a diff on local symbols")); } if (t->segment != u->segment) { - exception(1, - _ - ("Can only evaluate a diff on symbols from the same segment")); + exception(1, _("Can only evaluate a diff on symbols from the same segment")); } a = t->offset - u->offset; @@ -2209,7 +2112,7 @@ void asm_eof(FILE * f) popcontext(); writeword(0x4f424e4e, f, 1); - writeword(ftell(f2) + s_data + s_text + 7, f, 1); + writeword((ftell(f2) >> 2)+ s_data + s_text + 7, f, 1); t = (bytestream_t *) NomVarToVar("__start__", labels, &trouve); if (trouve) { writeword(t->offset, f, 1); @@ -2220,7 +2123,7 @@ void asm_eof(FILE * f) writeword(s_text, f, 1); writeword(s_data, f, 1); writeword(s_bss, f, 1); - writeword(ftell(f2) + 1, f, 1); + writeword((ftell(f2) >> 2) + 1, f, 1); fclose(f2); writeword(nbsymbols, f, 1); @@ -2256,8 +2159,7 @@ void assembler_flush(void) delete_bytestream(data); delete_bytestream(bss); } -/* Fonction générique qui va traiter un fichier entier */ static int -process_file(char *name) +/* Fonction générique qui va traiter un fichier entier */ static int process_file(char *name) { FILE *f; char buf[BUFSIZ], errctx[BUFSIZ], *p; |