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

macc: Stop using the B port #4817

Merged
merged 1 commit into from
Jan 8, 2025
Merged

macc: Stop using the B port #4817

merged 1 commit into from
Jan 8, 2025

Conversation

povik
Copy link
Member

@povik povik commented Dec 13, 2024

What are the reasons/motivation for this change?
Explain how this is achieved.

The B port is for single-bit summands. These can just as well be represented as an additional summand on the A port (which supports summands of arbitrary width). An upcoming $macc_v2 cell won't be special-casing single-bit summands in any way.

In preparation, make the following changes:

  • remove the bit_ports field from the Macc helper (instead add any single-bit summands to ports next to other summands)

  • leave B empty on cells emitted from Macc::to_cell

If applicable, please suggest to reviewers how they can test the change.

An included test makes sure we interpret the B port on existing RTLIL exports.

@povik povik mentioned this pull request Dec 13, 2024
14 tasks
@widlarizer
Copy link
Collaborator

I think some theoretical merit was mentioned in the past to the B port when techmapping to primitives that only support single-bit summands. Since I have no actual evidence of that being used by anyone, it's just something to keep in mind. Otherwise I'm in favor of the idea

The B port is for single-bit summands. These can just as well be
represented as an additional summand on the A port (which supports
summands of arbitrary width). An upcoming `$macc_v2` cell won't be
special-casing single-bit summands in any way.

In preparation, make the following changes:

 * remove the `bit_ports` field from the `Macc` helper (instead add any
   single-bit summands to `ports` next to other summands)

 * leave `B` empty on cells emitted from `Macc::to_cell`
for (auto &port : macc.ports) {
summand_t this_summand;
if (GetSize(port.in_b)) {
this_summand.first = module->addWire(NEW_ID, width);
module->addMul(NEW_ID, port.in_a, port.in_b, this_summand.first, port.is_signed);
} else if (GetSize(port.in_a) == 1 && GetSize(port.in_b) == 0 && !port.is_signed && !port.do_subtract) {
// Mimic old 'bit_ports' treatment in case it's relevant for performance,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice!

@povik povik merged commit ca0ace6 into YosysHQ:main Jan 8, 2025
26 checks passed
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.

2 participants