Abstract
之前討論的都是在Windows版的NC-Verilog執行Verilog PLI,若要在Linux版的NC-Verilog執行PLI,有些地方不太一樣‧IntroductionWindows版與Linux版的NC-Verilog有兩點不一樣,第一:Windows版使用Visual C++ 6.0編譯,Linux版使用gcc編譯;第二:Windows與Linux設定路徑方面不太一樣,不過很慶幸的是,若你是用標準的C語言去寫PLI,則可一行code都不改從Windows porting到Linux‧
編譯器方面:Visual C++編譯成*.dll,gcc編譯成*.so,所幸Cadence在Windows與Linux提供了相同GUI的PLI Wizard,讓我們只要下一步下一步的設定,就可以自動呼叫Visual C++或gcc產生*.dll或*.so‧
設定路徑方面:Windows版只要將*.dll放在目前的路徑,或者放在C:\Program Files\Cadence Design Systems\IUS\tools\bin\,NC-Verilog就可以自動抓的到;但Linux版不能如此,必須透過設定環境變數的方式,若希望*.so放在目前的目錄下,則必須以下設定:
setenv LD_LIBRARY_PATH .:$LD_LIBRARY_PATH
Cadence的tool都會依賴LD_LIBRARY_PATH這個環境變數,所以加上 . 表示目前目錄,後面加上:$LD_LIBRARY_PATH表示接上原來LD_LIBRARY_PATH的設定,這樣NC-Verilog就是順利的抓到自己寫的*.so‧