• 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. Ho to find top level connectivity for instances using SKILL...

Stats

  • Locked Locked
  • Replies 5
  • Subscribers 143
  • Views 14532
  • 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

Ho to find top level connectivity for instances using SKILL in Layout

Miguel V
Miguel V over 8 years ago

Hi,

I have a set of bondpads and I am trying to write a SKILL function that will display the coordinates and top level connectivity for each bondpad.  For example, I have pads labeled PWR, PWRres, GND and clk at the top level. I want the function to output something like this:  bondpad   (x,y)     PWR

I got the coordinates to display properly but still having troubling pulling the net associated with each bondpad.  I've searched quite a bit on here and other sources but I'm currently stumped.  Any ideas on how to approach this or are there other properties associated with cv~>instances that I am missing?  I've tried using inst~>conns~>net~>name but all I get are the connections at the cell level which end up being "IO" or "sub"

Thanks 

  • Cancel
  • Andrew Beckett
    Andrew Beckett over 8 years ago

    The trouble is, I don't think we can guess what your IO cells look like, what pins they have, whether there is connectivity at all (are you using VLS XL?) or on these pins.

    I suggest you contact customer support so that we can look at the data with you and figure out the best strategy. There are so many ways that people create I/Os and instantiate bandpads that any code may or may not work depending on your methodology.

    Regards,

    Andrew.

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
  • Miguel V
    Miguel V over 8 years ago
    Hi Andrew,

    Yes I am using VLS XL. There is a pin and label attached to each bondpad and at each cell/instance in the hierarchy. My current code gives me the correct PIN names for each instance, but only at the top level. I just wanted to know if there is some way of traversing the hierarchy from the top level cell to the bondpads in the lower level cells. Would flattening all instances work?
    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
  • Andrew Beckett
    Andrew Beckett over 8 years ago

    Flattening is almost certainly overkill and not a good idea - it may destroy the connectivity anyway. It's easy enough to traverse the hierarchy in SKILL (numerous examples on these forums) but I wouldn't guess what the right way to do this without seeing your data or your current code, which is why I suggested going to customer support so that somebody can advise with the correct contextual information to hand.

    Regards,

    Andrew.

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
  • Miguel V
    Miguel V over 8 years ago

    I figured as much which is why I didn't do it.  I was able to use leSearchHierarchy() to traverse the hierarchy, but the solution for me was to traverse the hierarchy and get all of the instances, then pull out the bondpads and coordinates, then use dbGetTrueOverlaps() to get overlaps of the pins over the bondpads and extract the pin names.  It wasn't until after I got it to work that I discovered the "Pad Opening Info..." option under Tools in my layout window, which does almost EXACTLY what I was trying to do...sigh.

    Miguel

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
  • RK56
    RK56 over 8 years ago

    Hi Miguel,

    I understand your feeling now. Sorry for that. May be if you had given more description on your requirement some one would have pointed you this. Sometimes we try to build a world with our little knowledge of SKILL and finally get embarrassed with an already available tool. But nothing goes waste I bet you might have sharpened your SKILL scripting when you try to reinvent the wheel.

    -Ramakrishnan

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel

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