ePrints@IIScePrints@IISc Home | About | Browse | Latest Additions | Advanced Search | Contact | Help

An incremental basic block instruction scheduler

Venugopal, R and Srikant, YN (1998) An incremental basic block instruction scheduler. In: Journal of Systems Architecture, 45 (3). pp. 179-203.

[img] PDF
An_incremental_basic_block.pdf - Published Version
Restricted to Registered users only

Download (541kB) | Request a copy
Official URL: http://www.sciencedirect.com/science?_ob=ArticleUR...


Incremental methods for the earlier phases of compilation such as lexical analysis, parsing, semantic analysis and machine independent optimization have been well studied. In this paper, we describe an approach towards incremental machine dependent optimization, in particular, basic block instruction scheduling. First we describe a simple algorithm for the incremental construction of the dependency directed acyclic graph (DDAG). We then target basic block scheduling based on the longest path length criterion. In this context, we apply an existing incremental shortest path algorithm for computing the lengths of the longest paths incrementally. The techniques described have been implemented in the form of an incremental basic block instruction scheduler for the IBM RISC System/6000 processor. Compile-time measurements on a few sample programs indicate that this approach results in significant reduction in the time taken for instruction scheduling when compared with that taken by the non-incremental approach.

Item Type: Journal Article
Publication: Journal of Systems Architecture
Publisher: Elsevier Science
Additional Information: Copyright of this article belongs to Elsevier Science.
Keywords: Integrated programming environments;Incremental compilation; Instruction scheduling;Compiler optimization.
Department/Centre: Division of Electrical Sciences > Computer Science & Automation
Date Deposited: 21 Aug 2009 06:14
Last Modified: 19 Sep 2010 04:59
URI: http://eprints.iisc.ac.in/id/eprint/18022

Actions (login required)

View Item View Item