2つのパスアセンブラを作るためにはyyparse()を使用していますか?

StackOverflow https://stackoverflow.com/questions/717848

質問

私は、私が働いているカスタムマイクロコントローラ用のアセンブラを書いています。私はそれがバイナリまでの命令をアセンブルしますポイントにアセンブラを持っています。

しかし、私は今、ラベルが動作するようになっての問題を抱えています。私のアセンブラが新しいラベルに遭遇した場合、現在、それはラベルとそのが参照したメモリ位置の名前を格納します。命令は、ラベルを参照すると、アセンブラは、ラベルを検索し、適切な値でラベルを置き換えます。

これは結構なですが、ラベルには、それを参照する命令の後に定義されたものか?このため、私は私のパーサが二回、コード上で実行する必要があります。

ここに私は現在、私の主な機能を持っているものです。

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と言う)と、前方参照を持つ場所のすべてを一覧表示し、どのようなシンボルそれらが参照さのデータ構造を有しています。 (ローカルシンボルを持っている場合またはブロック)は、ファイルの終わりには、単にそのリストを通過し、アドレスをパッチます。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top