• 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. "Hidden" parameters in Pcell

Stats

  • Locked Locked
  • Replies 6
  • Subscribers 144
  • Views 2555
  • 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

"Hidden" parameters in Pcell

RVERP
RVERP over 12 years ago

Hello,

 When I generate a Pcell using a function and it's arguments, my pcells do not generate correctly.

 I understand why, once the pcell is compiled, he has unknown variables, the one that where passed by the function.  IfI replace this variables with a parameter of the pcell, the functions arguments are stored and the pcell compiles.

I don't want to use variables for this to prevent having a long list.

Is there another way of doing this, some sort of hidden parameter or property?

 

So this doesn't work:

procedure( makeAcell(arg1 arg2)

pcDefinePcell(
 ...
 ...
w = arg1*arg2

))

 

This does work, but it's not what I want:

procedure( makeAcell(arg1 arg2)
 ...
;PCELL PARAMETERS
((Arg1 int arg1) (Arg2 int arg2))
 ...
))

 

  • Cancel
Parents
  • RVERP
    RVERP over 12 years ago

    Ok, thanks, this seems to work, with one exception.  If I use backquotes in a for loop, this doesn't seem to work.

     example:

     procedure(makeACell(arg1 arg2)
    eval(`pcDefinePCell(
      ...
      ...
      w=,arg1*,arg2
    for( n 1 ,arg1
    do something
    ) ;for
    ) ;pcDefinePCell
    ) ; eval
    ) ; procedure

    It looks like that he still needs the arg1 in the for loop.

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
Reply
  • RVERP
    RVERP over 12 years ago

    Ok, thanks, this seems to work, with one exception.  If I use backquotes in a for loop, this doesn't seem to work.

     example:

     procedure(makeACell(arg1 arg2)
    eval(`pcDefinePCell(
      ...
      ...
      w=,arg1*,arg2
    for( n 1 ,arg1
    do something
    ) ;for
    ) ;pcDefinePCell
    ) ; eval
    ) ; procedure

    It looks like that he still needs the arg1 in the for loop.

    • 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