-
Notifications
You must be signed in to change notification settings - Fork 592
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
PDN creates ring outside of die area #6445
Comments
@gadfort are you available to look at this? |
@maliberty I believe this was intentional because openlane was inserting rings outside of the die area and then adjusting their die area. Personally I agree that the tools should not generate shapes outside of the die area and I'm happy to change the behavior to error out (it's easy to detect so should not require much to implement). If we are okay with changing this behavior to be an error, I can do that. |
It feels backwards to get a ring outside and then post-adjust the die area. @donn do you have any concerns about making this an error? @jeffng-or are you able to modify the pdn setup to avoid this issue? |
I believe this was before my time, so I'd have to figure out why with the team first. I'll get back to you. |
The SRAM flow is using the BLOCK_grid_strategy.tcl directly from the asap7 platforms area, so I'm not sure how much flexibility I have to modify it. The SRAMs are all generated using the mock area flow in megaboom, so I could look at what needs to be tweaked in order to avoid the issue. Of the fifteen SRAM types in megaboom, nine have this obstruction issue. @oharboe FYI. |
A surprising behavior.... https://en.wikipedia.org/wiki/Principle_of_least_astonishment |
Most designs in ORFS are using at least 1 micron and so don't have this issue:
|
@louiic Made the BLOCK_ and BLOCKS_ .tcl files for mock-array Later, I have been using them in test designs where there are macros built by OpenROAD and a top level. |
There is nothing wrong with the BLOCK* files - you have to use them intelligently. If you lower the core margin too much you get this problem. |
An actionable error message would be instructive. |
That is pending on Donn's response as to whether they need this behavior. |
So, we don't know what you mean by the resizing thing, probably a one-off thing in the early days, but what we do know is that we intentionally create PDN rings outside the die area regardless. This is the XOR template for the power grid for caravel user project: the I/O pins are at the edge of the die area and the rings surround the I/Os. Should PDNs outside the die area be disallowed, we would have to update a ton of layout files and configuration files so that the PDN goes inside the die area, and the pins are not laid out across the die area boundaries. Additionally, this would allow routes for the pins to be created in the new area, which we do not want to happen, so we'd have to add blockages… The drawbacks keep piling up. We do understand your concern however, as this IS surprising behavior for 99% of users. We would be okay with updating the default behavior, but with an escape hatch ( |
A flag seems like a reasonable idea to me. |
@donn how do you generate LEF abstracts for these blocks? What do they look like? The issue we saw was the obs covering the rings blocks the signal pins on other layers. |
Perhaps it would be better to compute the bounds per layer in write_lef_abstract and leave this as a warning? |
@donn ping |
We use Magic to generate the abstract LEF. Magic doesn't draw obs over pins. Instead, it uses min and max coordinates of metal shapes that don't overlap pins and creates wrapping obstructions around the pins. Since there is no metal wire outside the PR boundary, the resultant LEF allows design pin access as shown in the images |
That's interesting. We could change the LEF abstract generator to be similar. It is unnecessary to cut the obs around the pins though. From the manual
|
After discussing with @gadfort it looks like the best is to make it an error with an option to allow for eFabless' use case. |
Describe the bug
For some of some of the MegaBoom macros, PDN ends up creating the power ring outside of the die area boundary. As a result, the pins are no longer accessible to the detailed router when we are trying to route BoomTile. The power ring creates an obstruction that doesn't align with the die boundary, which effectively covers the pin shapes:
In this case of btb_128x56, the ring area is ( -72 144 ) ( 47106 25236 ) and the die area is ( 0 0 ) ( 47060 25232 )
It looks like the shapes are created outside of the die area since that the inner ring core is calculated at ( 240 456 ) ( 46794 24924 ) and then adjusted by the horizontal/vertical width calculation. The net effect is that the ring outline gets grown by 624 (x lo shifted left by 312 and x hi shifted right by 312). Since the inner ring core is starting at 240, the resulting x lo for the ring ends up at -72.
Expected Behavior
Either the ring is created within the die boundary or we error out if it isn't possible.
Environment
To Reproduce
Test case can be found at
https://drive.google.com/file/d/10UJD8IatCit-IcZ3RZsMG0kk4vgCjEhh/view?usp=drive_link
Relevant log output
No response
Screenshots
No response
Additional Context
No response
The text was updated successfully, but these errors were encountered: