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