Im Sommersemester 2004 galt es, wie schon viele Jahre davor, im Rahmen der Übung Übersetzerbau einen codeerzeugenden Compiler zu schreiben und zu optimieren. Ich möchte hier ein paar der von mir eingesetzten naheliegenden und weniger naheliegenden Tricks vorstellen.
Registerbelegung | |
---|---|
Etwas ist in Übersetzerbau seit Einsatz der Alpha als Plattform im wesentlichen immer gleich geblieben: die Hilfsregister! Angenehmer Weise gehen sich unsere Berechnungen alle in den zur Verfügung stehenden Registern aus, wir bräuchten uns diesbezüglich also eigentlich keinerlei Gedanken machen. Doch hier wäre ein erster Ansatzpunkt, Instruktionen einzusparen. |
Knausrig sein | |
---|---|
Man braucht nicht für jedes Ergebnis ein neues Register. Ganz im Gegenteil, meistens kann man Register recyclen. Ich möchte hier kurz eine Mini-Bibliothek zur Registerverwaltung anbringen, sie basiert im wesentlichen auf einer Idee von Wolti: 16 /* private register handling |
Beschreibung Registerbibliothek | |
---|---|
Ich hoffe, die Funktionsweise ist nicht allzu schwer zu durchschauen. Wir haben einen Pool von Registern (register_nr[]) und merken uns, ob diese noch zur Verfügung stehen, oder nicht (free_registers[]). is_work_reg() sagt uns, ob ein gegebenes Register ein Arbeitsregister ist und somit frei recyclet werden kann. Die hier nicht aufgezählten Register sind Tabu (Übergabeparameter, heap, etc.) und dürfen nicht verändert werden. alloc_register() stellt uns ein Arbeitsregister zur Verfügung, mit free_register() kann man es wieder freigeben. Da C kein Overloading überstützt, oft genug aber die Freigabe mehrerer Register erwünscht ist, gibt's auch noch free_register_2(). |
Comments - Make a comment |
The comments are owned by the poster. We are not responsible for its content.
|
AdministrativeTexts
updated by freddiemac1993, 2013-06-14
wiki
Re: adventures
created by brittdavis10, 2012-02-23 (1 rply, 3 views)
thread
Re: how to run phpwebsite...
created by alexander, 2011-08-25 (2 rpls, 3607 views)
thread
Re: Forum tags
created by HaroldFaragher, 2011-08-22 (3 rpls, 8488 views)
thread