Abstract

Reconfigurable computing architectures allow the adaptation of the underlying datapath to the algorithm. The granularity of the datapath elements and data width determines the granularity of the architecture and its programming flexibility. Coarse-grained architectures have shown the right balance between programmability and performance. This paper provides an overview of coarse-grained reconfigurable architectures and describes Versat, a Coarse-Grained Reconfigurable Array (CGRA) with self-generated partial reconfiguration, presented as a case study for better understanding these architectures. Unlike most of the existing approaches, which mainly use pre-compiled configurations, a Versat program can generate and apply myriads of on-the-fly configurations. Partial reconfiguration plays a central role in this approach, as it speeds up the generation of incrementally different configurations. The reconfigurable array has a complete graph topology, which yields unprecedented programmability, including assembly programming. Besides being useful for optimising programs, assembly programming is invaluable for working around post-silicon hardware, software, or compiler issues. Results on core area, frequency, power, and performance running different codes are presented and compared to other implementations.

Highlights

  • Versat has some distinctive features, which cannot be found in other architectures: (1) it has a small number of functional units (FUs) organised in a full mesh structure; (2) it has a fully addressable configuration register combined with a configuration memory to support partial self-configuration; (3) it has a dedicated and minimal controller for reconfiguration, direct memory access (DMA) management and simple algorithm control—no RISC [3] or VLIW [4] processors are used

  • A novel Coarse-Grained Reconfigurable Array (CGRA) architecture called Versat has been presented as a case study of CGRAs architectures

  • A detailed description of the CGRA architecture has been presented for a better understanding of the subject

Read more

Summary

Introduction

Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations. FPGAs integrate programmable coarse-grained blocks (like functional units, memory blocks, memory interfaces, and even processors) to alleviate the fine-level reconfigurability logic’s burden fabric. This practice improves performance and reduces energy consumption but reduces flexibility. CGRAs are generally used to accelerate program loops whose bodies contain array operations; the parts of the program which do not contain loops run on a classical processor. For this reason, CGRA architectures typically feature a processor core [3,4]. Versat architecture is described, analysed, and experimental results are presented

Coarse-Grained Reconfigurable Architectures
Versat: A Coarse-Grained Reconfigurable Architecture for Embedded Systems
Versat Architecture
Data Engine
DE Structure
Address Generation
ALU Functions
Multipliers and Barrel Shifter
Functional Unit Latencies
Data Engine Control
Configuration Module
Controller
Qualitative Comparison with Other Architectures
Programming
Basic Programming
Self and Partial Reconfiguration
Results
Integrated Circuit Implementation Results
Performance and Energy Consumption Results for Simple Kernels
Performance and Energy Consumption Results for Complex Kernels
Performance Comparison with Other CGRAs
Conclusions
Full Text
Paper version not known

Talk to us

Join us for a 30 min session where you can share your feedback and ask us any queries you have

Schedule a call

Disclaimer: All third-party content on this website/platform is and will remain the property of their respective owners and is provided on "as is" basis without any warranties, express or implied. Use of third-party content does not indicate any affiliation, sponsorship with or endorsement by them. Any references to third-party content is to identify the corresponding services and shall be considered fair use under The CopyrightLaw.