Queue register file optimization algorithm for QueueCore processor

A Canedo, B Abderazek, M Sowa - … International Symposium on …, 2007 - ieeexplore.ieee.org
19th International Symposium on Computer Architecture and High …, 2007ieeexplore.ieee.org
The queue computation model offers an attractive alternative for high-performance
embedded computing given its characteristics of short instructions and high instruction level
parallelism. A queue-based processor uses a FIFO queue to read and write operands
through hardware pointers located at the head and tail of the queue. Queue length is the
number of elements stored between the head and the tail pointers during computations. We
have found that 95% of the statements in integer applications require a queue length of less …
The queue computation model offers an attractive alternative for high-performance embedded computing given its characteristics of short instructions and high instruction level parallelism. A queue-based processor uses a FIFO queue to read and write operands through hardware pointers located at the head and tail of the queue. Queue length is the number of elements stored between the head and the tail pointers during computations. We have found that 95% of the statements in integer applications require a queue length of less than 32 words. The remaining 5% requires larger queue length sizes up to 230 queue words. In this paper we propose a compiler technique to optimize the queue utilization for the hungry statements that require a large amount of queue. We show that for SPEC CINT95 benchmarks, our technique optimizes the queue length without decreasing parallelism. However, our optimization has a penalty of a slight increase in code size.
ieeexplore.ieee.org