使用yyparse()创建一个两遍汇编程序?

时间:2009-04-04 21:26:00

标签: parsing assembly bison flex-lexer

我正在为我正在研究的自定义微控制器编写汇编程序。我已经将汇编程序组装到了将指令汇编为二进制的地步。

但是,我现在遇到了使标签生效的问题。目前,当我的汇编程序遇到新标签时,它会存储标签的名称及其引用的内存位置。当指令引用标签时,汇编器会查找标签并用适当的值替换标签。

这很好,很花哨,但如果标签是在引用它的指令后定义的呢?因此,我需要让我的解析器在代码上运行两次。

这是我目前的主要功能:

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 }

我在flex / bison配置中使用它。

1 个答案:

答案 0 :(得分:8)

如果这就是你所需要的,那么你就不需要一个完整的双通道汇编程序。如果在引用标签时未定义标签,则只需输出一个替代地址(例如0x0000)并具有一个数据结构,该结构列出了所有具有前向引用的位置以及它们所引用的符号。在文件的末尾(或者如果你有本地符号则阻止),你只需浏览该列表并修补地址。