newhope代码在vs2019的编译
1安裝openssl
windows版本的網址
點進去下載以下這個
按照提示安裝即可,最后可以在終端使用openssl就可以了
2在vs中使用第三方庫
新建一個項目,在源代碼中選一個放進去去,比如我選的是Optimized_Implementation中的crypto_kem\newhope512cca
把x86改成x64(之前一直用x86不行,但是現在突然可以了不知道是不是這個原因)。然后點擊項目名右鍵屬性,在包含目錄和庫目錄中分別添加你自己的openssl的include和lib的地址。
然后在連接器-輸入中添加如圖兩個附加依賴項。
最后把下載的openssl中bin文件夾的如下兩個dll文件放在項目文件中,可能名字不太一樣但是差不多太多。
3修改一些小地方
newhope源代碼中還有一些小問題
首先在PQCgenKAT_kem中頂部添加
#define _CRT_SECURE_NO_WARNINGS
可以避免fopen報錯。
然后在poly.h中修改poly結構體的定義,因為微軟有自己的一套東西
__declspec(align(32)) typedef struct {
uint16_t coeffs[NEWHOPE_N];
} poly;
接下來是一個詭異的東西了,在verify.c中的verify函數定義了一個無符號整數r但是后面又在前面加了個負號,我姑且先刪掉負號叭。
4完成
按道理這樣子應該已經完成了,編譯之后項目文件夾就會多了兩個文件,存放公私鑰等信息。
如果還是編譯錯誤很有可能還是第三方庫openssl用不了。(到時候再說吧~我盡力了)
總結
以上是生活随笔為你收集整理的newhope代码在vs2019的编译的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: git git git
- 下一篇: IDA pro 使用笔记