Pregunta

Estoy escribiendo un ensamblador para un controlador personalizado micro que estoy trabajando. Tengo el ensamblador a un punto en el que se reunirán las instrucciones de abajo a binario.

Sin embargo, ahora estoy teniendo problemas para obtener etiquetas para trabajar. En la actualidad, cuando mi ensamblador se encuentra con una nueva etiqueta, almacena el nombre de la etiqueta y la posición de memoria en referencia a su. Cuando una instrucción hace referencia a una etiqueta, el ensamblador busca la etiqueta y sustituye a la etiqueta con el valor apropiado.

Esto es fino y elegante, pero lo que si se define la etiqueta después de la instrucción referencia a ella? Debido a esto, necesito tener mi analizador se extienden sobre el código dos veces.

Esto es lo que tengo actualmente para mi principal función:

303 int main(int argc, char* argv[])
304 {
305 
306     if(argc < 1 || strcmp(argv[1],"-h")==0 || 0==strcmp(argv[1],"--help"))
307     {
308         //printf("%s\n", usage);
309         return 1;
310     }
311     // redirect stdin to the file pointer
312     int stdin = dup(0);
313     close(0);
314 
315     // pass 1 on the file
316     int fp = open(argv[1], O_RDONLY, "r");
317     dup2(fp, 0);
318 
319     yyparse();
320 
321     lseek(fp, SEEK_SET, 0);
322 
323     // pass 2 on the file
324     if(secondPassNeeded)
325     {
326         fp = open(argv[1], O_RDONLY, "r");
327         dup2(fp, 0);
328         yyparse();
329     }
330     close(fp);
331 
332     // restore stdin
333     dup2(0, stdin);
334 
335     for(int i = 0; i < labels.size(); i++)
336     {
337         printf("Label: %s, Loc: %d\n", labels[i].name.c_str(), labels[i].memoryLoc);
338     }
339     return 0;
340 }

Estoy usando esto dentro de una configuración de flexión / bisonte.

¿Fue útil?

Solución

Si eso es todo lo que necesita, no es necesario un ensamblador de dos pasos completa. Si la etiqueta no está definida cuando hace referencia a que, simplemente salida de un sustituto de la dirección (por ejemplo 0x0000) y tienen una estructura de datos que enumera todos los lugares con referencias hacia delante y qué símbolo que refered. Al final del archivo (o bloquear si tiene símbolos locales), sólo tiene que ir a través de esa lista y parchear las direcciones.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top