-
Notifications
You must be signed in to change notification settings - Fork 25
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
Uninitialized count in pnp device count comparison #75
Comments
Whoa, I've never seen that one before. . . |
Actually, this may be a magic extraction problem. From the extracted spice file
|
I think "M=" only appears in the netlist if you use the "merge" option in ext2spice? |
Here's a test case. Covers several issues.
|
@d-m-bailey : I just pushed an update to magic that fixes the issue of merging the PNP devices. The problem is that the merge algorithm was written for FETs (and also handles resistors and capacitors), but the PNP device in the sky130 tech file is using the "msubcircuit" type which indicates that it is a FET-like device but (other than the problem with M) produces the right netlist output for the bipolar device. I have modified the ext2spice code---provisionally---to just add together the device counts for non-FET devices (in this case identified by the fact that W and L are zero, which is what causes the NaN value to appear, after doing a divide-by-zero calculation). Ultimately I need to revisit this, because all subcircuit-type devices need to have declared parameters checked so that only devices with matching parameters are merged. As written now, two bipolar devices with the same B, C, E connections but with different emitter area will be merged. I have not yet addressed the incorrect emitter area. This is most likely an issue in the tech file, not the magic source code, as the device declaration needs to specify which terminal is supposed to be measured to produce the area value. |
@RTimothyEdwards Thanks.
Right, but the magic tech file
which means the area of Currently, the |
The recognition (device) layer should be the BJT base (layer pnp). "a=area" would measure the area of that layer. "a1=area" and "a2=area" would measure the area of terminals 1 or 2, respectively. But the value |
I am now pretty sure that magic never was extracting the correct area for bipolar devices, because there is simply no code for calculating area and perimeter of a device terminal that is not in the same plane as the identifying type. I did just push a correction for the problem of "pulling values out of thin air"---the issue there was that the values were not initialized, so when a terminal failed to get area/perimeter calculations, it just output whatever value was left in the variables from the last device calculation. But that doesn't fix the underlying problem. (To clarify, all of these problems are in magic, not in netgen.) |
@d-m-bailey : This problem should be corrected now in the most recent versions of magic (8.3.402) and open_pdks (1.0.418). The area of bipolars (and diodes) had never previously been calculated correctly because there was no code to compute area and perimeter of terminals not on the same plane as the device identifier layer. Once I added that, it was also clear that the magic techfile for sky130 needed to use |
Slot-002 of mpw-3.
Will attach test case later.
The text was updated successfully, but these errors were encountered: