• Skip to main content
  • Skip to search
  • Skip to footer
Cadence Home
  • This search text may be transcribed, used, stored, or accessed by our third-party service providers per our Cookie Policy and Privacy Policy.

  1. Community Forums
  2. Custom IC SKILL
  3. Overlapping Pin layers not triggering abutment.

Stats

  • Locked Locked
  • Replies 4
  • Subscribers 143
  • Views 15053
  • Members are here 0
This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Overlapping Pin layers not triggering abutment.

snee
snee over 8 years ago

I have created a PCell of a traditional transistor. Both the Source and Drain is their own ROD object. I have setup the abutment properties according to documentation, however when overlapping one cells source with the others drain the auto abutment function (MosAbutFunc) is never called and the shapes never snap.

The following is how I attach abutment options to the respective Diff layers.

leftObj = leftDrain->dbId
net_id = dbMakeNet( pcCellView "S" )
term_id = dbCreateTerm( net_id "S" "inputOutput" )
pin_id = dbCreatePin( net_id leftObj "leftDiff")
dbReplaceProp(leftObj "abutFunction" "string" "MosAbutFunc")
dbReplaceProp(leftObj "abutAccessDir" "list" list("left"))
dbReplaceProp(leftObj "abutClass" "string" "diffs")
dbReplaceProp(leftObj "vxlInstSpacingDir" "list" list("left") )
dbReplaceProp(leftObj "vxlInstSpacingRule" "float" 2.0)

rightObj = rightDrain->dbId
net_id = dbMakeNet( pcCellView "D" )
term_id = dbCreateTerm( net_id "D" "inputOutput" )
pin_id = dbCreatePin( net_id rightObj "rightDiff")
dbReplaceProp(rightObj "abutFunction" "string" "MosAbutFunc")
dbReplaceProp(rightObj "abutAccessDir" "list" list("right"))
dbReplaceProp(rightObj "abutClass" "string" "diffs")
dbReplaceProp(rightObj "vxlInstSpacingDir" "list" list("right") )
dbReplaceProp(rightObj "vxlInstSpacingRule" "float" 2.0)

  • Cancel
Parents
  • snee
    snee over 8 years ago
    The issue is, I can abut ME1 Drawing layers, but I cannot abut any other layer.

    For example, if I create a MOS device, whos Source/Drain are rod-objects of layer "Diff drawing", abutment will not work. However, if I change the layer in my PCell to "ME1 drawing", for experimentation, abutment works correctly.

    The issue is the Diff layer. What would cause one layer to be abutable, but others not to work?

    Again, this is the same PCell code, just the layers for S/D are redefined.
    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
Reply
  • snee
    snee over 8 years ago
    The issue is, I can abut ME1 Drawing layers, but I cannot abut any other layer.

    For example, if I create a MOS device, whos Source/Drain are rod-objects of layer "Diff drawing", abutment will not work. However, if I change the layer in my PCell to "ME1 drawing", for experimentation, abutment works correctly.

    The issue is the Diff layer. What would cause one layer to be abutable, but others not to work?

    Again, this is the same PCell code, just the layers for S/D are redefined.
    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
Children
No Data

Community Guidelines

The Cadence Design Communities support Cadence users and technologists interacting to exchange ideas, news, technical information, and best practices to solve problems and get the most from Cadence technology. The community is open to everyone, and to provide the most value, we require participants to follow our Community Guidelines that facilitate a quality exchange of ideas and information. By accessing, contributing, using or downloading any materials from the site, you agree to be bound by the full Community Guidelines.

© 2025 Cadence Design Systems, Inc. All Rights Reserved.

  • Terms of Use
  • Privacy
  • Cookie Policy
  • US Trademarks
  • Do Not Sell or Share My Personal Information