Parsing 使用yyparse()生成两遍汇编程序?

Parsing 使用yyparse()生成两遍汇编程序?,parsing,assembly,bison,flex-lexer,Parsing,Assembly,Bison,Flex Lexer,我正在为一个定制的微控制器编写汇编程序。我已经让汇编程序能够将指令汇编成二进制 然而,我现在在让标签工作方面遇到了问题。目前,当我的汇编程序遇到一个新标签时,它会存储标签的名称及其引用的内存位置。当指令引用标签时,汇编程序查找标签并用适当的值替换标签 这很好,但是如果标签是在引用它的指令之后定义的呢?因此,我需要让解析器对代码运行两次 以下是我目前拥有的主要功能: 303 int main(int argc, char* argv[]) 304 { 305 306 if(argc &l

我正在为一个定制的微控制器编写汇编程序。我已经让汇编程序能够将指令汇编成二进制

然而,我现在在让标签工作方面遇到了问题。目前,当我的汇编程序遇到一个新标签时,它会存储标签的名称及其引用的内存位置。当指令引用标签时,汇编程序查找标签并用适当的值替换标签

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

以下是我目前拥有的主要功能:

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 }
303 int main(int argc,char*argv[]
304 {
305
306如果(argc<1 | | strcmp(argv[1],“-h”)==0 | | | 0==strcmp(argv[1],“-help”))
307     {
308//printf(“%s\n”,用法);
309返回1;
310     }
311//将stdin重定向到文件指针
312 int stdin=dup(0);
313关闭(0);
314
315//在文件上传递1
316 int fp=开启(argv[1],仅限“r”);
317DUP2(fp,0);
318
319 yyparse();
320
321 lseek(fp,SEEK_集,0);
322
323//在文件上传递2
324(如果需要)
325     {
326 fp=打开(argv[1],仅限“r”);
327dup2(fp,0);
328 yyparse();
329     }
330关闭(fp);
331
332//恢复标准
333 dup2(0,标准差);
334
335用于(int i=0;i

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

如果这就是您所需要的,您不需要一个完整的两遍汇编程序。如果引用标签时未定义标签,则只需输出一个替代地址(例如0x0000),并具有一个数据结构,其中列出了所有具有正向引用的位置以及它们引用的符号。在文件末尾(如果有本地符号,则为块),您只需浏览该列表并修补地址。

您是在询问是否需要两次通行证,还是您的代码正确?