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