| Not available or is heavily handicapped       |                                                                                         | egend      |            | ols 8      | ۰                                         | VivadoHLS, LegUp, Catapult, Synphony, HercuLeS, OpenCL, MaxJ                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------|-----------------------------------------------------------------------------------------|------------|------------|------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ✓ Mostly available                            | ✓ Mostly available but also with noticeable limitations                                 |            | 40         | 012        | 306                                       | DFiant                                                                                                                                                                                                                                                                                                                                                                                                   |
| ✓ Mostly available with almost no limitations |                                                                                         |            | `\         | and        |                                           | Chisel, SpinalHDL, PyRTL, Migen, MyHDL, Bluespec, Cx, JHDL                                                                                                                                                                                                                                                                                                                                               |
| ✓+ Exemplary capabilities                     |                                                                                         |            |            |            |                                           | VHDL, Verilog, SystemVerilog                                                                                                                                                                                                                                                                                                                                                                             |
| Property<br>Group                             | Properties                                                                              | A.         | 2/2        | 704,14     | A. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. | Comments                                                                                                                                                                                                                                                                                                                                                                                                 |
| Hardware<br>Design<br>Fundamentals            | Concurrent Semantics                                                                    |            | ✓          | <b>✓</b>   | ✓                                         | RTL semantics are based on clock-scheduled concurrency. HL-RTL semantics describe hardware construction and are therefore concurrent. DF-HDL semantics are dataflow-based which means that independent paths are concurrent and dependent paths are sequenced together. Most HLS languages are inherently sequential, and special pragmas and tooling allow concurrent and pipelined synthesis.          |
|                                               | Bit Accurate Type Safety                                                                | <b>←</b>   | <b>√</b> + | <b>✓</b>   | ✓                                         | Some HLS languages do not support bit accurate types. DFiant is embedded in Scala which is a type-safe language. DFiant has implemented special type-level macros reflect bit-accurate type errors to the Scala presentation compiler, which in turn provides error positions and messages to the editor. This provides an immediate visible indication of most errors, and thus increases productivity. |
|                                               | Clear Synthesizability                                                                  | ×          | ✓          | <b>✓</b>   | ×                                         | RTL and HLS languages were developed for simulation and software development, respectively, and only later were adopted for hardware synthesis. Consequently, these languages include significant unsynthesizable syntax that confuses hardware developers. Contrarily, DFiant and many HL-RTL languages focus on hardware construction syntax that is inherently synthesizable.                         |
|                                               | Hierarchy, Composition, IO<br>Ports, Connectivity, RTL<br>Blackbox Interface,Top Design | <b>←</b>   | <b>√</b> + | <b>√</b> + | ✓                                         | HLS languages offer only limited connectivity and are not designed for top-level hardware description. DFiant and Some HL-RTL languages surpass the capabilities of RTLs by allowing direct connection between sibling components and even between ports at different hierarchy levels.                                                                                                                  |
|                                               | Combinational/Sequential Expressions                                                    | <b>≠</b>   | ✓          | ✓          | <b>✓</b>                                  | HLS is sometimes too high-level to allow direct developer control over combinational and sequential paths. However, such a control is rarely required in HLS application domains.                                                                                                                                                                                                                        |
|                                               | Clock and Reset Management                                                              | 4          | <b>←</b>   | <b>V</b>   | <b>✓</b>                                  | HLS offers very limited clock and reset management capabilities due to its abstraction. We have yet to implement multiple-clock domains capabilities in DFiant, but we see no limitation to have equivalent RTL-control with the proper constraints.                                                                                                                                                     |
| Design<br>Abstraction &<br>Automation         | State Abstraction                                                                       | <b>✓</b>   | <b>√</b> + | ×          | ×                                         | RTLs and HL-RTLs express a state as a register. HLS languages abstract over registers and provide a construct to express a global/static variable which is considered a state. DFiant also abstracts over registers, but also abstracts over explicit state declaration. Thanks to its dataflow ordered semantics, DFiant generates a state only if the developer accesses a stream's token history.     |
|                                               | Time Abstraction                                                                        | ×          | <b>≠</b>   | ×          | ×                                         | HLS rarely provides time abstraction (e.g., no UART is written in HLS). DF-HDLs have Timer constructs that provide the necessary abstraction, but we have yet to implement them in DFiant.                                                                                                                                                                                                               |
|                                               | Auto-Balanced Manual<br>Pipelining                                                      | <b>✓</b>   | ✓          | ×          | ×                                         | DFiant supports manual user pipelining constraint tag to be applied on selective junctions in the design. The DFiant compiler will make sure that all joined/forked paths are properly balanced.                                                                                                                                                                                                         |
|                                               | Automatic Pipelining                                                                    | √+         | <b>✓</b>   | ×          | ×                                         | HLS and DFiant support automatic pipelining and automatic flow control. However, DFiant is an                                                                                                                                                                                                                                                                                                            |
|                                               | Automatic Flow-Control                                                                  | <b>√</b> + | <b>✓</b>   | <b>√</b>   |                                           | HDL and does support control loops. Instead, control loops are explicitly described as state machines                                                                                                                                                                                                                                                                                                    |
|                                               | Control Loop Pipelining                                                                 | <b>√</b> + | ×          | ×          | ×                                         | and therefore manually scheduled for better performance.                                                                                                                                                                                                                                                                                                                                                 |
| B# - 4 -                                      | Conditional & Looped Gen.                                                               | <b>V</b>   | <b>√</b>   | <b>√</b>   | <b>√</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                          |
| Meta-                                         | Recursive Construction                                                                  | <b>√</b>   | <b>√</b> + | <b>V</b>   | ×                                         |                                                                                                                                                                                                                                                                                                                                                                                                          |
| Programming                                   | Inheritance/Typeclasses Polymorphic Interfaces                                          | <b>∀</b>   | V ./       | <b>V</b>   | <b>x</b> ✓                                |                                                                                                                                                                                                                                                                                                                                                                                                          |
| Post-Design                                   | Legible RTL Output                                                                      |            | <u> </u>   | •          |                                           |                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                               | Simulation                                                                              | <b>/</b>   | 4          |            |                                           |                                                                                                                                                                                                                                                                                                                                                                                                          |
| _                                             | Verification                                                                            | <b>√</b>   |            |            |                                           |                                                                                                                                                                                                                                                                                                                                                                                                          |
| -                                             | Debugging                                                                               |            | <b>✓</b>   |            |                                           |                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                               | Open Source                                                                             | ×          | <b>V</b>   | <b>√</b>   | <b>√</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                               | Maturity                                                                                | <b>✓</b>   | ×          | <b>✓</b>   | <b>√</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                          |
| Properties                                    | Documentation                                                                           | <b>✓</b>   | ×          | <b>✓</b>   | <b>√</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                               | Familiar Ergonomics                                                                     | <b>✓</b>   | <b>✓</b>   | <b>✓</b>   | <b>√</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                          |