• 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. Set UNIX environment variable through in Cadence environment...

Stats

  • Locked Locked
  • Replies 11
  • Subscribers 143
  • Views 28907
  • 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

Set UNIX environment variable through in Cadence environment through skill

rajs
rajs over 9 years ago

Cadence version using=IC616.

Hi ,

I have two questions which i have listed below

a)Not able to set PVDIR variable in unix through skill command.

system("setenv PVDIR /home/data/")

error message in unix terminal: sh: setenv: command not found

b)I want to streamout the gds and then execute skill code sequentially, if the error not exist in streamout or else terminate with error message.

   1)How to wait till streamout is done & How to check for error message. There is a user defined function "xstOutOnCompletion()", How to use 

         along with procedure.

envSetVal("xstream" "xstShowCompletionMsgBox" 'boolean nil)

xstSetField("library" libname)
xstSetField("topCell" cellname)
xstSetField("strmFile" strcat(cellname ".gds"))
xstSetField("attachTechFileOfLib" "tsmc90_tech")
xstSetField("view" "layout")
xstSetField("runDir" path)
xstSetField("summaryFile" "strmOut.sum")
xstSetField("virtualMemory" "true")
xstSetField("logFile" "strmOut.log")
xstOutDoTranslate()

 

Thanks,

rajs

  • Cancel
Parents
  • Andrew Beckett
    Andrew Beckett over 9 years ago

    The first approach wouldn't work for two reasons. First of all "setenv" is a "csh" command, not a "sh" command. Anyway, even if that had worked or you'd use an appropriate command ("export VAR=value", say), then this would not have helped because it environment variables are only inherited in child processes, not in the parent process. What you want to use is setShellEnvVar("VAR=value").

    The documentation explains how to write xstOutOnCompletion - and even gives an example. You don't wait for it to return - instead, you have a callback that is triggered when it completes and this callback receives the status information. You can then do any subsequent actions  you need from within your xstOutOnCompletion definition.

    Regards,

    Andrew.

    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
Reply
  • Andrew Beckett
    Andrew Beckett over 9 years ago

    The first approach wouldn't work for two reasons. First of all "setenv" is a "csh" command, not a "sh" command. Anyway, even if that had worked or you'd use an appropriate command ("export VAR=value", say), then this would not have helped because it environment variables are only inherited in child processes, not in the parent process. What you want to use is setShellEnvVar("VAR=value").

    The documentation explains how to write xstOutOnCompletion - and even gives an example. You don't wait for it to return - instead, you have a callback that is triggered when it completes and this callback receives the status information. You can then do any subsequent actions  you need from within your xstOutOnCompletion definition.

    Regards,

    Andrew.

    • 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