• 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 15051
  • 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
  • skillUser
    skillUser over 8 years ago
    Hi Shane,

    Are you operating in Virtuoso Layout Suite XL? And do you have the Options -> Editor "Abut Server" turned on, and the XL Options, Generation, "Abut transistors" option turned on? You must be in XL for abutment to work, though unabutment can work in 'L'. Which version are you using? The latest versions have a PCell development mode in Virtuoso that might be helpful in debugging.

    I hope this helps.

    Regards,

    Lawrence.
    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
Reply
  • skillUser
    skillUser over 8 years ago
    Hi Shane,

    Are you operating in Virtuoso Layout Suite XL? And do you have the Options -> Editor "Abut Server" turned on, and the XL Options, Generation, "Abut transistors" option turned on? You must be in XL for abutment to work, though unabutment can work in 'L'. Which version are you using? The latest versions have a PCell development mode in Virtuoso that might be helpful in debugging.

    I hope this helps.

    Regards,

    Lawrence.
    • 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