Akademska digitalna zbirka SLovenije - logo
E-viri
Celotno besedilo
Recenzirano
  • AHA: An Agile Approach to t...
    Koul, Kalhan; Melchert, Jackson; Sreedhar, Kavya; Truong, Leonard; Nyengele, Gedeon; Zhang, Keyi; Liu, Qiaoyi; Setter, Jeff; Chen, Po-Han; Mei, Yuchen; Strange, Maxwell; Daly, Ross; Donovick, Caleb; Carsello, Alex; Kong, Taeyoung; Feng, Kathleen; Huff, Dillon; Nayak, Ankita; Setaluri, Rajsekhar; Thomas, James; Bhagdikar, Nikhil; Durst, David; Myers, Zachary; Tsiskaridze, Nestan; Richardson, Stephen; Bahr, Rick; Fatahalian, Kayvon; Hanrahan, Pat; Barrett, Clark; Horowitz, Mark; Torng, Christopher; Kjolstad, Fredrik; Raina, Priyanka

    ACM transactions on embedded computing systems, 03/2023, Letnik: 22, Številka: 2
    Journal Article

    With the slowing of Moore’s law, computer architects have turned to domain-specific hardware specialization to continue improving the performance and efficiency of computing systems. However, specialization typically entails significant modifications to the software stack to properly leverage the updated hardware. The lack of a structured approach for updating the compiler and the accelerator in tandem has impeded many attempts to systematize this procedure. We propose a new approach to enable flexible and evolvable domain-specific hardware specialization based on coarse-grained reconfigurable arrays (CGRAs). Our agile methodology employs a combination of new programming languages and formal methods to automatically generate the accelerator hardware and its compiler from a single source of truth. This enables the creation of design-space exploration frameworks that automatically generate accelerator architectures that approach the efficiencies of hand-designed accelerators, with a significantly lower design effort for both hardware and compiler generation. Our current system accelerates dense linear algebra applications but is modular and can be extended to support other domains. Our methodology has the potential to significantly improve the productivity of hardware-software engineering teams and enable quicker customization and deployment of complex accelerator-rich computing systems.