## syn\_generic

- Optimization of datapath components (adders, multipliers, shifters, etc.) to meet the required performance goal
- Using enable conditions in the fanin of registers to implement clock-gating logic and thus reducing power
- Stops the clocks for individual blocks when those blocks are inactive --> disabling functionality of those blocks.



## Commands

- Start from Pg 106 of Synthesis Low power guide
- set\_attribute lp\_insert\_clock\_gating true
- set\_attribute leakage\_power\_effort medium #before the elaborate command
- set\_attribute lp\_clock\_gating\_exceptions\_aware true --> if multiple flip-flops have different types of clock gating requirements
- Syn\_opt -incr --> optimises and generates reports in increments
- report\_clock\_gating -gated\_ff > reports/clk-gatingtiming.txt
- Check power after optimisation using report\_power
- gui\_show to see the clock gated instance

## Example

 Try this optimisation on an FSM design or any other sequential design with flip-flops in the middle of the data path