mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-24 16:34:38 +00:00 
			
		
		
		
	docs: more on wreduce in synth starter
This commit is contained in:
		
							parent
							
								
									9f1c445fbf
								
							
						
					
					
						commit
						3e653fe4a6
					
				
					 3 changed files with 97 additions and 28 deletions
				
			
		|  | @ -301,9 +301,42 @@ yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_adffe o | ||||||
| Writing dot description to `rdata_adffe.dot'. | Writing dot description to `rdata_adffe.dot'. | ||||||
| Dumping selected parts of module fifo to page 1. | Dumping selected parts of module fifo to page 1. | ||||||
| 
 | 
 | ||||||
|  | yosys> wreduce | ||||||
|  | 
 | ||||||
|  | 16. Executing WREDUCE pass (reducing word size of cells). | ||||||
|  | Removed top 31 bits (of 32) from port B of cell fifo.$add$fifo.v:68$27 ($add). | ||||||
|  | Removed top 23 bits (of 32) from port Y of cell fifo.$add$fifo.v:68$27 ($add). | ||||||
|  | Removed top 31 bits (of 32) from port B of cell fifo.$sub$fifo.v:70$30 ($sub). | ||||||
|  | Removed top 23 bits (of 32) from port Y of cell fifo.$sub$fifo.v:70$30 ($sub). | ||||||
|  | Removed top 1 bits (of 2) from port B of cell fifo.$auto$opt_dff.cc:195:make_patterns_logic$64 ($ne). | ||||||
|  | Removed cell fifo.$flatten\fifo_writer.$procmux$53 ($mux). | ||||||
|  | Removed top 31 bits (of 32) from port B of cell fifo.$flatten\fifo_writer.$add$fifo.v:20$34 ($add). | ||||||
|  | Removed top 24 bits (of 32) from port Y of cell fifo.$flatten\fifo_writer.$add$fifo.v:20$34 ($add). | ||||||
|  | Removed cell fifo.$flatten\fifo_reader.$procmux$53 ($mux). | ||||||
|  | Removed top 31 bits (of 32) from port B of cell fifo.$flatten\fifo_reader.$add$fifo.v:20$34 ($add). | ||||||
|  | Removed top 24 bits (of 32) from port Y of cell fifo.$flatten\fifo_reader.$add$fifo.v:20$34 ($add). | ||||||
|  | Removed top 23 bits (of 32) from wire fifo.$add$fifo.v:68$27_Y. | ||||||
|  | Removed top 24 bits (of 32) from wire fifo.$flatten\fifo_reader.$add$fifo.v:20$34_Y. | ||||||
|  | Removed top 24 bits (of 32) from wire fifo.$flatten\fifo_writer.$add$fifo.v:20$34_Y. | ||||||
|  | 
 | ||||||
|  | yosys> select -set new_cells t:$add %co t:$add %d | ||||||
|  | 
 | ||||||
|  | yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_wreduce o:rdata %ci* | ||||||
|  | 
 | ||||||
|  | 17. Generating Graphviz representation of design. | ||||||
|  | Writing dot description to `rdata_wreduce.dot'. | ||||||
|  | Dumping selected parts of module fifo to page 1. | ||||||
|  | 
 | ||||||
|  | yosys> opt_clean | ||||||
|  | 
 | ||||||
|  | 18. Executing OPT_CLEAN pass (remove unused cells and wires). | ||||||
|  | Finding unused cells or wires in module \fifo.. | ||||||
|  | Removed 0 unused cells and 5 unused wires. | ||||||
|  | <suppressed ~1 debug messages> | ||||||
|  | 
 | ||||||
| yosys> memory_dff | yosys> memory_dff | ||||||
| 
 | 
 | ||||||
| 16. Executing MEMORY_DFF pass (merging $dff cells to $memrd). | 19. Executing MEMORY_DFF pass (merging $dff cells to $memrd). | ||||||
| Checking read port `\data'[0] in module `\fifo': merging output FF to cell. | Checking read port `\data'[0] in module `\fifo': merging output FF to cell. | ||||||
|     Write port 0: non-transparent. |     Write port 0: non-transparent. | ||||||
| 
 | 
 | ||||||
|  | @ -311,13 +344,13 @@ yosys> select -set new_cells t:$memrd_v2 | ||||||
| 
 | 
 | ||||||
| yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_memrdv2 o:rdata %ci* | yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_memrdv2 o:rdata %ci* | ||||||
| 
 | 
 | ||||||
| 17. Generating Graphviz representation of design. | 20. Generating Graphviz representation of design. | ||||||
| Writing dot description to `rdata_memrdv2.dot'. | Writing dot description to `rdata_memrdv2.dot'. | ||||||
| Dumping selected parts of module fifo to page 1. | Dumping selected parts of module fifo to page 1. | ||||||
| 
 | 
 | ||||||
| yosys> alumacc | yosys> alumacc | ||||||
| 
 | 
 | ||||||
| 18. Executing ALUMACC pass (create $alu and $macc cells). | 21. Executing ALUMACC pass (create $alu and $macc cells). | ||||||
| Extracting $alu and $macc cells in module fifo: | Extracting $alu and $macc cells in module fifo: | ||||||
|   creating $macc model for $add$fifo.v:68$27 ($add). |   creating $macc model for $add$fifo.v:68$27 ($add). | ||||||
|   creating $macc model for $flatten\fifo_reader.$add$fifo.v:20$34 ($add). |   creating $macc model for $flatten\fifo_reader.$add$fifo.v:20$34 ($add). | ||||||
|  | @ -327,70 +360,70 @@ Extracting $alu and $macc cells in module fifo: | ||||||
|   creating $alu model for $macc $flatten\fifo_writer.$add$fifo.v:20$34. |   creating $alu model for $macc $flatten\fifo_writer.$add$fifo.v:20$34. | ||||||
|   creating $alu model for $macc $flatten\fifo_reader.$add$fifo.v:20$34. |   creating $alu model for $macc $flatten\fifo_reader.$add$fifo.v:20$34. | ||||||
|   creating $alu model for $macc $add$fifo.v:68$27. |   creating $alu model for $macc $add$fifo.v:68$27. | ||||||
|   creating $alu cell for $flatten\fifo_reader.$add$fifo.v:20$34: $auto$alumacc.cc:485:replace_alu$76 |   creating $alu cell for $add$fifo.v:68$27: $auto$alumacc.cc:485:replace_alu$79 | ||||||
|   creating $alu cell for $flatten\fifo_writer.$add$fifo.v:20$34: $auto$alumacc.cc:485:replace_alu$79 |   creating $alu cell for $flatten\fifo_reader.$add$fifo.v:20$34: $auto$alumacc.cc:485:replace_alu$82 | ||||||
|   creating $alu cell for $add$fifo.v:68$27: $auto$alumacc.cc:485:replace_alu$82 |   creating $alu cell for $flatten\fifo_writer.$add$fifo.v:20$34: $auto$alumacc.cc:485:replace_alu$85 | ||||||
|   creating $alu cell for $sub$fifo.v:70$30: $auto$alumacc.cc:485:replace_alu$85 |   creating $alu cell for $sub$fifo.v:70$30: $auto$alumacc.cc:485:replace_alu$88 | ||||||
|   created 4 $alu and 0 $macc cells. |   created 4 $alu and 0 $macc cells. | ||||||
| 
 | 
 | ||||||
| yosys> select -set new_cells t:$alu t:$macc | yosys> select -set new_cells t:$alu t:$macc | ||||||
| 
 | 
 | ||||||
| yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_alumacc o:rdata %ci* | yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_alumacc o:rdata %ci* | ||||||
| 
 | 
 | ||||||
| 19. Generating Graphviz representation of design. | 22. Generating Graphviz representation of design. | ||||||
| Writing dot description to `rdata_alumacc.dot'. | Writing dot description to `rdata_alumacc.dot'. | ||||||
| Dumping selected parts of module fifo to page 1. | Dumping selected parts of module fifo to page 1. | ||||||
| 
 | 
 | ||||||
| yosys> memory -nomap | yosys> memory -nomap | ||||||
| 
 | 
 | ||||||
| 20. Executing MEMORY pass. | 23. Executing MEMORY pass. | ||||||
| 
 | 
 | ||||||
| yosys> opt_mem | yosys> opt_mem | ||||||
| 
 | 
 | ||||||
| 20.1. Executing OPT_MEM pass (optimize memories). | 23.1. Executing OPT_MEM pass (optimize memories). | ||||||
| Performed a total of 0 transformations. | Performed a total of 0 transformations. | ||||||
| 
 | 
 | ||||||
| yosys> opt_mem_priority | yosys> opt_mem_priority | ||||||
| 
 | 
 | ||||||
| 20.2. Executing OPT_MEM_PRIORITY pass (removing unnecessary memory write priority relations). | 23.2. Executing OPT_MEM_PRIORITY pass (removing unnecessary memory write priority relations). | ||||||
| Performed a total of 0 transformations. | Performed a total of 0 transformations. | ||||||
| 
 | 
 | ||||||
| yosys> opt_mem_feedback | yosys> opt_mem_feedback | ||||||
| 
 | 
 | ||||||
| 20.3. Executing OPT_MEM_FEEDBACK pass (finding memory read-to-write feedback paths). | 23.3. Executing OPT_MEM_FEEDBACK pass (finding memory read-to-write feedback paths). | ||||||
| 
 | 
 | ||||||
| yosys> memory_bmux2rom | yosys> memory_bmux2rom | ||||||
| 
 | 
 | ||||||
| 20.4. Executing MEMORY_BMUX2ROM pass (converting muxes to ROMs). | 23.4. Executing MEMORY_BMUX2ROM pass (converting muxes to ROMs). | ||||||
| 
 | 
 | ||||||
| yosys> memory_dff | yosys> memory_dff | ||||||
| 
 | 
 | ||||||
| 20.5. Executing MEMORY_DFF pass (merging $dff cells to $memrd). | 23.5. Executing MEMORY_DFF pass (merging $dff cells to $memrd). | ||||||
| 
 | 
 | ||||||
| yosys> opt_clean | yosys> opt_clean | ||||||
| 
 | 
 | ||||||
| 20.6. Executing OPT_CLEAN pass (remove unused cells and wires). | 23.6. Executing OPT_CLEAN pass (remove unused cells and wires). | ||||||
| Finding unused cells or wires in module \fifo.. | Finding unused cells or wires in module \fifo.. | ||||||
| Removed 3 unused cells and 11 unused wires. | Removed 1 unused cells and 9 unused wires. | ||||||
| <suppressed ~4 debug messages> | <suppressed ~2 debug messages> | ||||||
| 
 | 
 | ||||||
| yosys> memory_share | yosys> memory_share | ||||||
| 
 | 
 | ||||||
| 20.7. Executing MEMORY_SHARE pass (consolidating $memrd/$memwr cells). | 23.7. Executing MEMORY_SHARE pass (consolidating $memrd/$memwr cells). | ||||||
| 
 | 
 | ||||||
| yosys> opt_mem_widen | yosys> opt_mem_widen | ||||||
| 
 | 
 | ||||||
| 20.8. Executing OPT_MEM_WIDEN pass (optimize memories where all ports are wide). | 23.8. Executing OPT_MEM_WIDEN pass (optimize memories where all ports are wide). | ||||||
| Performed a total of 0 transformations. | Performed a total of 0 transformations. | ||||||
| 
 | 
 | ||||||
| yosys> opt_clean | yosys> opt_clean | ||||||
| 
 | 
 | ||||||
| 20.9. Executing OPT_CLEAN pass (remove unused cells and wires). | 23.9. Executing OPT_CLEAN pass (remove unused cells and wires). | ||||||
| Finding unused cells or wires in module \fifo.. | Finding unused cells or wires in module \fifo.. | ||||||
| 
 | 
 | ||||||
| yosys> memory_collect | yosys> memory_collect | ||||||
| 
 | 
 | ||||||
| 20.10. Executing MEMORY_COLLECT pass (generating $mem cells). | 23.10. Executing MEMORY_COLLECT pass (generating $mem cells). | ||||||
| 
 | 
 | ||||||
| yosys> select -set new_cells t:$mem_v2 | yosys> select -set new_cells t:$mem_v2 | ||||||
| 
 | 
 | ||||||
|  | @ -398,6 +431,6 @@ yosys> select -set rdata_path @new_cells %ci*:-$mem_v2[WR_DATA,WR_ADDR,WR_EN] @n | ||||||
| 
 | 
 | ||||||
| yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_coarse @rdata_path | yosys> show -color maroon3 @new_cells -notitle -format dot -prefix rdata_coarse @rdata_path | ||||||
| 
 | 
 | ||||||
| 21. Generating Graphviz representation of design. | 24. Generating Graphviz representation of design. | ||||||
| Writing dot description to `rdata_coarse.dot'. | Writing dot description to `rdata_coarse.dot'. | ||||||
| Dumping selected parts of module fifo to page 1. | Dumping selected parts of module fifo to page 1. | ||||||
|  |  | ||||||
|  | @ -44,6 +44,15 @@ show -color maroon3 @new_cells -notitle -format dot -prefix rdata_adffe o:rdata | ||||||
| 
 | 
 | ||||||
| # ======================================================== | # ======================================================== | ||||||
| 
 | 
 | ||||||
|  | wreduce | ||||||
|  | select -set new_cells t:$add %co t:$add %d | ||||||
|  | show -color maroon3 @new_cells -notitle -format dot -prefix rdata_wreduce o:rdata %ci* | ||||||
|  | 
 | ||||||
|  | # unclear if this is necessary or only because of bug(s) | ||||||
|  | opt_clean | ||||||
|  | 
 | ||||||
|  | # ======================================================== | ||||||
|  | 
 | ||||||
| memory_dff | memory_dff | ||||||
| select -set new_cells t:$memrd_v2 | select -set new_cells t:$memrd_v2 | ||||||
| show -color maroon3 @new_cells -notitle -format dot -prefix rdata_memrdv2 o:rdata %ci* | show -color maroon3 @new_cells -notitle -format dot -prefix rdata_memrdv2 o:rdata %ci* | ||||||
|  | @ -57,6 +66,10 @@ show -color maroon3 @new_cells -notitle -format dot -prefix rdata_alumacc o:rdat | ||||||
| # ======================================================== | # ======================================================== | ||||||
| 
 | 
 | ||||||
| memory -nomap | memory -nomap | ||||||
|  | # or use the following commands: | ||||||
|  | # design -reset | ||||||
|  | # read_verilog fifo.v | ||||||
|  | # synth_ice40 -top fifo -run begin:map_ram | ||||||
| select -set new_cells t:$mem_v2 | select -set new_cells t:$mem_v2 | ||||||
| select -set rdata_path @new_cells %ci*:-$mem_v2[WR_DATA,WR_ADDR,WR_EN] @new_cells %co* %% | select -set rdata_path @new_cells %ci*:-$mem_v2[WR_DATA,WR_ADDR,WR_EN] @new_cells %co* %% | ||||||
| show -color maroon3 @new_cells -notitle -format dot -prefix rdata_coarse @rdata_path | show -color maroon3 @new_cells -notitle -format dot -prefix rdata_coarse @rdata_path | ||||||
|  |  | ||||||
|  | @ -369,6 +369,8 @@ options is able to fold one of the ``$mux`` cells into the ``$adff`` to form an | ||||||
| Part 2 | Part 2 | ||||||
| ^^^^^^ | ^^^^^^ | ||||||
| 
 | 
 | ||||||
|  | The next group of commands performs a series of optimizations: | ||||||
|  | 
 | ||||||
| .. literalinclude:: /cmd/synth_ice40.rst | .. literalinclude:: /cmd/synth_ice40.rst | ||||||
|    :language: yoscrypt |    :language: yoscrypt | ||||||
|    :start-at: wreduce |    :start-at: wreduce | ||||||
|  | @ -377,12 +379,33 @@ Part 2 | ||||||
|    :caption: ``coarse`` section (part 2) |    :caption: ``coarse`` section (part 2) | ||||||
|    :name: synth_coarse2 |    :name: synth_coarse2 | ||||||
| 
 | 
 | ||||||
| The next three (new) commands are :doc:`/cmd/wreduce`, :doc:`/cmd/peepopt`, and | First up is :doc:`/cmd/wreduce`.  If we run this we get the following: | ||||||
| :doc:`/cmd/share`.  None of these affect our design either, so let's skip over | 
 | ||||||
| them.  :yoscrypt:`techmap -map +/cmp2lut.v -D LUT_WIDTH=4` optimizes certain | .. literalinclude:: /code_examples/fifo/fifo.out | ||||||
| comparison operators by converting them to LUTs instead.  The usage of |    :language: doscon | ||||||
| :cmd:ref:`techmap` is explored more in |    :start-at: yosys> wreduce | ||||||
| :doc:`/using_yosys/synthesis/techmap_synth`. |    :end-before: yosys> select | ||||||
|  |    :caption: output of :cmd:ref:`wreduce` | ||||||
|  | 
 | ||||||
|  | Looking at the data path for ``rdata``, the most relevant of these width | ||||||
|  | reductions are the ones affecting ``fifo.$flatten\fifo_reader.$add$fifo.v``. | ||||||
|  | That is the ``$add`` cell incrementing the fifo_reader address.  We can look at | ||||||
|  | the schematic and see the output of that cell has now changed. | ||||||
|  | 
 | ||||||
|  | .. TODO:: pending bugfix in :cmd:ref:`wreduce` and/or :cmd:ref:`opt_clean` | ||||||
|  | 
 | ||||||
|  | .. figure:: /_images/code_examples/fifo/rdata_wreduce.* | ||||||
|  |    :class: width-helper | ||||||
|  |    :name: rdata_wreduce | ||||||
|  | 
 | ||||||
|  |    ``rdata`` output after :cmd:ref:`wreduce` | ||||||
|  | 
 | ||||||
|  | The next two (new) commands are :doc:`/cmd/peepopt` and :doc:`/cmd/share`. | ||||||
|  | Neither of these affect our design, and they're explored in more detail in | ||||||
|  | :doc:`/using_yosys/synthesis/opt`, so let's skip over them.  :yoscrypt:`techmap | ||||||
|  | -map +/cmp2lut.v -D LUT_WIDTH=4` optimizes certain comparison operators by | ||||||
|  | converting them to LUTs instead.  The usage of :cmd:ref:`techmap` is explored | ||||||
|  | more in :doc:`/using_yosys/synthesis/techmap_synth`. | ||||||
| 
 | 
 | ||||||
| Our next command to run is | Our next command to run is | ||||||
| :doc:`/cmd/memory_dff`. | :doc:`/cmd/memory_dff`. | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue