我正在为我正在研究的自定义微控制器编写汇编程序。我已经将汇编程序组装到了将指令汇编为二进制的地步。
但是,我现在遇到了使标签生效的问题。目前,当我的汇编程序遇到新标签时,它会存储标签的名称及其引用的内存位置。当指令引用标签时,汇编器会查找标签并用适当的值替换标签。
这很好,很花哨,但如果标签是在引用它的指令后定义的呢?因此,我需要让我的解析器在代码上运行两次。
这是我目前的主要功能:
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配置中使用它。
答案 0 :(得分:8)
如果这就是你所需要的,那么你就不需要一个完整的双通道汇编程序。如果在引用标签时未定义标签,则只需输出一个替代地址(例如0x0000)并具有一个数据结构,该结构列出了所有具有前向引用的位置以及它们所引用的符号。在文件的末尾(或者如果你有本地符号则阻止),你只需浏览该列表并修补地址。