

5



- C (or any programming language) specifies a computation
- · Can describe spatial computation
- Underlying semantics is sequential

   Watch for unintended sequentialization
   Write C for spatial differently than you write C for processors



n ESE532 Fall 2017 -- DeHon

## Course "Hypothesis"

- C-to-gates synthesis mature enough to use to specify hardware
  - Leverage fact everyone knows C
  - (must, at least, know C to develop embedded code)
  - Avoid taking time to teach Verilog or VHDL
     Or making Verilog a pre-req.
  - Focus on teaching how to craft hardware
    - Using the C already know
    - ...may require thinking about the C differently

Penn ESE532 Fall 2017 - DeHon

n ESE532 Fall 2017 - DeHor

























| Lecture Checkpoint                                                             |                                                   |  |
|--------------------------------------------------------------------------------|---------------------------------------------------|--|
| <ul> <li>Happy with         <ul> <li>Straight-line code</li> </ul> </li> </ul> | <pre>int f(int a, int b) {     int t, c, d;</pre> |  |
| – Variables                                                                    | a=a&(0x0f);<br>b=b&(0x0f);                        |  |
| Graph for preclass f                                                           | t=b+3;<br>c=a^t;<br>t=o_2;                        |  |
| Next topic: Memory                                                             | <pre>t-a-2;<br/>d=b^t;<br/>return(d);</pre>       |  |
| Penn ESE532 Fall 2017 DeHon                                                    | }                                                 |  |





































BB0

BB2

BB1



















![](_page_8_Figure_4.jpeg)

| Preclass G                                                  |                                                                                                                                                                                                                                                       |            |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| <ul> <li>Graph for preclass G as mux-conversion?</li> </ul> | <pre>int g(int a, int b) {     int t, c, d;     // same as above     a=a&amp;(0x0f);     b=b&amp;(0x0f);     t=b+3;     c=a^t;     t=a-2;     d=b^t;     //added (not in f)     if (a<b) <="" added="" d="c;" end="" pre="" return(d);=""></b)></pre> |            |
| Penn ESE532 Fall 2017 DeHon                                 | ł                                                                                                                                                                                                                                                     | <b>5</b> 5 |

![](_page_9_Figure_1.jpeg)

![](_page_9_Figure_2.jpeg)

![](_page_9_Figure_3.jpeg)

![](_page_9_Figure_4.jpeg)

![](_page_9_Figure_5.jpeg)

![](_page_10_Figure_0.jpeg)

## Mux Conversion and Memory

- If (cond)
- \*a=0
- · Else - \*b=0
- Don't want memory operations in non-taken branch to occur.
- Conclude: cannot mux-convert blocks with memory operations (without additional care) 62

nn ESE532 Fall 2017 -- DeHon

![](_page_10_Figure_8.jpeg)

![](_page_10_Figure_9.jpeg)

![](_page_10_Figure_10.jpeg)

![](_page_10_Figure_11.jpeg)

![](_page_10_Figure_12.jpeg)

![](_page_11_Figure_0.jpeg)

![](_page_11_Figure_1.jpeg)

![](_page_11_Figure_2.jpeg)

![](_page_11_Figure_3.jpeg)

![](_page_11_Picture_4.jpeg)

![](_page_11_Picture_5.jpeg)

![](_page_12_Figure_0.jpeg)

![](_page_12_Figure_1.jpeg)

![](_page_12_Figure_2.jpeg)

![](_page_12_Figure_3.jpeg)

![](_page_12_Figure_4.jpeg)

![](_page_12_Figure_5.jpeg)

## Summary

- Language (here C) defines meaning of operations
- Dataflow connection of computations
- Sequential precedents constraints to preserve
- · Create basic blocks
- · Link together
- Optimize
  - Merge into hyperblocks with if-conversion
     Pipeline, unroll
- Result is dataflow graph
- (can schedule to registers and gates)

## Big Ideas: C (any prog lang) specifies a computation Can describe spatial computation Has some capabilities that don't make sense in hardware Shared memory pool, malloc, recursion Watch for unintended sequentialization C for spatial is coded differently from C for processor ...but can still run on processor Good for leaf functions (operations)

80

— Limiting for full task

Admin

- Reading for Wednesday on Web
   Xilinx HLS documents
- Do have lecture on Wednesday – But no homework due on Friday
- HW5 due next Friday (10/13)

Penn ESE532 Fall 2017 -- DeHon

81