Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

quicklogic: Avoid carry chains in division mapping #4607

Merged
merged 3 commits into from
Oct 7, 2024

Conversation

povik
Copy link
Member

@povik povik commented Sep 19, 2024

What are the reasons/motivation for this change?

The default mapping rules for division-like operations (div/divfloor/ mod/modfloor) invoke subtractions which can get mapped to carry chains in FPGA flows. Optimizations across carry chains are weak, so in practice this ends up too costly compared to implementing the division purely in soft logic.

Explain how this is achieved.

For this reason arrange for techmap.v ignoring division operations under -D NODIV, and use this mode in synth_quicklogic to avoid carry chains for divisions.

The default mapping rules for division-like operations (div/divfloor/
mod/modfloor) invoke subtractions which can get mapped to carry chains
in FPGA flows. Optimizations across carry chains are weak, so in
practice this ends up too costly compared to implementing the division
purely in soft logic.

For this reason arrange for `techmap.v` ignoring division operations
under `-D NODIV`, and use this mode in `synth_quicklogic` to avoid carry
chains for divisions.
@povik povik requested a review from nakengelhardt September 19, 2024 10:19
@povik
Copy link
Member Author

povik commented Sep 19, 2024

module top(input wire [10:0] a, input wire [10:0] b, output wire [10:0] y);
	assign y = a / b;
endmodule

compiled with synth_quicklogic -family qlf_k6n10f resulted in
before

   Number of cells:                704
     $lut                          308
     adder_carry                   396

after

   Number of cells:                125
     $lut                          125

@povik
Copy link
Member Author

povik commented Sep 19, 2024

When we merge this we should make a note to carry over (no pun intended) the change across all FPGA architectures provided we confirm this doesn't make the delay worse. I am not sure we should focus on trying to come up with a better architecture for division as it doesn't seem like an RTL operator in common use.

@Ravenslofty
Copy link
Collaborator

Perhaps include a testcase; something like the synthesis tests which check the number and type of cells.

@povik povik merged commit 6c1450f into YosysHQ:main Oct 7, 2024
22 checks passed
@povik povik deleted the ql-nodiv branch October 7, 2024 14:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants