Automatic Hardware Pragma Insertion in High-Level Synthesis: A Non-Linear Programming Approach
St\'ephane Pouget, Louis-No\"el Pouchet, Jason Cong

TL;DR
This paper presents an automated framework for inserting pragmas in high-level synthesis to optimize hardware design, using a non-linear programming model to efficiently explore vast configuration spaces and improve performance.
Contribution
It introduces a novel non-linear programming approach to automatically determine optimal pragma configurations in HLS, significantly reducing exploration time.
Findings
Effectively manipulates billions of design configurations in seconds to minutes.
Provides a lower bound on performance after HLS.
Supports pipelining, unit replication, and data caching in loop-based programs.
Abstract
High-Level Synthesis enables the rapid prototyping of hardware accelerators, by combining a high-level description of the functional behavior of a kernel with a set of micro-architecture optimizations as inputs. Such optimizations can be described by inserting pragmas e.g. pipelining and replication of units, or even higher level transformations for HLS such as automatic data caching using the AMD/Xilinx Merlin compiler. Selecting the best combination of pragmas, even within a restricted set, remains particularly challenging and the typical state-of-practice uses design-space exploration to navigate this space. But due to the highly irregular performance distribution of pragma configurations, typical DSE approaches are either extremely time consuming, or operating on a severely restricted search space. This work proposes a framework to automatically insert HLS pragmas in regular…
Peer Reviews
No public reviews on file for this paper yet. If you reviewed it on a platform where reviews are public (OpenReview, ICLR, NeurIPS, ICML), you can paste yours below so the community can read it here.
Videos
No videos yet. Explain this paper in a talk, walkthrough, or lecture? Add one.
