Two-level pipelining in processor arrays (PAs) involves pipelining of operations across processing elements (PEs) and pipelining of operations in functional units in each PE. Although it is an attractive method for improving the throughput of PAs, existing methods for generating PAs with two-level pipelining are restricted and cannot systematically explore the entire space of feasible designs. In this paper, we extend a systematic design method, called General Parameter Method (GPM), we have developed earlier to find optimal designs of PAs with two-level pipelines. The basic idea is to add new constraints on periods of data flows to include the effect of internal functional pipelines in the PEs. As an illustration, we present pipelined PA designs for computing matrix products. For n-dimensional meshes and other symmetric problems, we provide an efficient scheme to obtain a pipelined PA from a non-pipelined PA using a reindexing transformation. This scheme is used in GPM as a pruning condition to arrive at optimal pipelined PAs efficiently. For pipelines with minimum initiation interval (MII) greater than unity, we show additional constraints that ensure correctness of the synthesized PAs.
[1]
Kumar N. Ganapathy,et al.
Optimal design of lower dimensional processor arrays for uniform recurrences
,
1992,
[1992] Proceedings of the International Conference on Application Specific Array Processors.
[2]
Kumar N. Ganapathy,et al.
Synthesizing Otimal Lower Dimensional Processor Arrays
,
1992,
ICPP.
[3]
H. T. Kung,et al.
Wafer-scale integration and two-level pipelined implementations of systolic arrays
,
1984,
J. Parallel Distributed Comput..
[4]
M. Valero-Garcia,et al.
Systematic hardware adaptation of systolic algorithms
,
1989,
ISCA '89.