• 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. Functional Verification
  3. VHDL source code encryption

Stats

  • Locked Locked
  • Replies 2
  • Subscribers 65
  • Views 16047
  • 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

VHDL source code encryption

PaulU
PaulU over 15 years ago

I'm in a situation where some IP written in VHDL must be sent to a customer so he can simulate it. Of course we don't want to send the source code.

Normally, what we do is sending pre-compiled libraries, where the the VHDL files are compiled using the -nodebug option of vcom. This is for ModelSim/QuestaSim.

Now we're facing a customer who does not use ModelSim. Instead, he uses a simulator by Cadence (Incisive, I suppose, or ncsim). We do not have Cadence tools.

So, what's the best way to cope with this?

The first question is whether ncvhdl has a similar option as the -nodebug option of vcom, hiding all internal signals and hierarchy. I have tried to find the manual pages of ncvhdl on www.cadence.com but the search results from that site are awful. Another question is whether I as a non-Cadence customer can compile VHDL using Cadence tools.

Second thought is using the new VHDL-2008 `PROTECT keyword and create encrypted VHDL that can be compiled at the customer site.. A data sheet on the Incisive simulator however does not mention any 2008 support. Is this correct?

 Are there other options?

  • Cancel
  • Mickey
    Mickey over 15 years ago
    Hi Paul, What I would recommend doing is to encrypt the file using ncprotect . The default protection mechanism utilizes a Cadence proprietary encryption algorithm and doesn't require a license. Cadence also supports the IEEE encryption mechanism (Draft IEEE P1076/D2.11, May 20, 2006). However to invoke the IEEE encryption a license is required. To encrypt the file you'll need to download and install the IUS simulator toolset. 1) download and install the IUS simulator by going to downloads.cadence.com and choose the latest IUS82 hotfix from within the appropriate O/S tab. 2) once you have the tool installed execute ncprotect with your vhdl file(s) and include -autoprotect : ncvhdl myfile.vhd -autoprotect the above will result in a complete encryption (ports, names, hierarachy, etc...) of the file with the resulting file having the same name as the input file, except with a .vhdp extension. Btw, feel free to email me (jrodrig@cadence.com) offline if you have any questions regarding the download and/or install procedure. Hope that helps. Best regards, Mickey
    • Cancel
    • Vote Up 0 Vote Down
    • Cancel
  • PaulU
    PaulU over 15 years ago

    Mickey,

    Thanks for the quick response.  I will look into this later. If I need help, I will contact you offline.

    Best regards,

    Paul. 

    • 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