Skip to main content
Log in

Provably-correct hardware compilation tools based on pass separation techniques

  • Published:
Formal Aspects of Computing

Abstract

This paper presents a framework for verifying compilation tools for parametrised hardware designs with placement information. The framework involves Pebble, a simple declarative language based on Structural VHDL which supports the use of placement information to guide circuit layout; such information often leads to efficient designs that are particularly important for hardware libraries. Relative placement information enables control of circuit layout at a higher level of abstraction than placement information in the form of explicit coordinates. An approach based on pass separation techniques is adopted for specifying and verifying two Pebble abstraction mechanisms: a flattening procedure and a relative placement method. For the flattening procedure, which takes a set of parametrised blocks and unfolds the circuit description into a netlist, we provide semantic descriptions of both the hierarchical and the flattened Pebble languages to prove its functional correctness. For the relative placement method, we specify the compilation procedure from Pebble programs with relative placement information to Pebble programs with explicit coordinate expressions, often in the form of symbolic placement constraints. This compilation procedure can be used in conjunction with partial evaluation to optimise the size and speed of parametrised circuit descriptions using relative placement, without flattening the original hierarchical descriptions. Our approach has been used for optimising a pattern matcher design, which results in a 33% reduction in resource usage. For DES encryption, our method can reduce the size of a DES design by 60%.

This is a preview of subscription content, log in via an institution to check access.

Access this article

Price excludes VAT (USA)
Tax calculation will be finalised during checkout.

Instant access to the full article PDF.

Similar content being viewed by others

Author information

Authors and Affiliations

Authors

Corresponding author

Correspondence to Steve McKeever.

Additional information

Received July 2004

Revised September 2005

Accepted September 2005 by M. J. Butler

Rights and permissions

Reprints and permissions

About this article

Cite this article

McKeever, S., Luk, W. Provably-correct hardware compilation tools based on pass separation techniques. Form Asp Comp 18, 120–142 (2006). https://doi.org/10.1007/s00165-005-0075-8

Download citation

  • Published:

  • Issue Date:

  • DOI: https://doi.org/10.1007/s00165-005-0075-8

Keywords

Navigation