2つのパスアセンブラを作るためにはyyparse()を使用していますか?
-
23-08-2019 - |
質問
私は、私が働いているカスタムマイクロコントローラ用のアセンブラを書いています。私はそれがバイナリまでの命令をアセンブルしますポイントにアセンブラを持っています。
しかし、私は今、ラベルが動作するようになっての問題を抱えています。私のアセンブラが新しいラベルに遭遇した場合、現在、それはラベルとそのが参照したメモリ位置の名前を格納します。命令は、ラベルを参照すると、アセンブラは、ラベルを検索し、適切な値でラベルを置き換えます。
これは結構なですが、ラベルには、それを参照する命令の後に定義されたものか?このため、私は私のパーサが二回、コード上で実行する必要があります。
ここに私は現在、私の主な機能を持っているものです。
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 }
私は、フレックス/バイソン設定内にこれを使用しています。
解決
それはあなたが必要とするすべてであるならば、あなたは完全な2パスアセンブラを必要としません。あなたはそれを参照するとき、ラベルが定義されていない場合は、単に出力スタンド内のアドレス($ 0000と言う)と、前方参照を持つ場所のすべてを一覧表示し、どのようなシンボルそれらが参照さのデータ構造を有しています。 (ローカルシンボルを持っている場合またはブロック)は、ファイルの終わりには、単にそのリストを通過し、アドレスをパッチます。
所属していません StackOverflow