我正在尝试编译boringssl的库包装。根据命令判断,我已经编译了肯定包含符号AES_set_encrypt_key
的crypto.lib文件:
nm crypto.lib --demangle
然后我生成了一个声明该符号的FFI文件:
use std::os::raw::{c_char, c_int, c_uchar, c_uint, c_void};
#[repr(C)]
pub struct aes_key_st {
pub rd_key: [u32; 60usize],
pub rounds: c_uint,
}
pub type AES_KEY = aes_key_st;
extern "C" {
pub fn AES_set_encrypt_key(key: *const u8, bits: c_uint, aeskey: *mut AES_KEY) -> c_int;
pub fn foo() -> c_int;
}
这是原始的C声明:
struct aes_key_st {
uint32_t rd_key[4 * (AES_MAXNR + 1)];
unsigned rounds;
};
typedef struct aes_key_st AES_KEY;
OPENSSL_EXPORT int AES_set_encrypt_key(const uint8_t *key, unsigned bits, AES_KEY *aeskey);
build.rs:
fn main() {
let out_dir = "<path_to_lib>"
println!("cargo:rustc-link-search=native={}", out_dir);
println!("cargo:rustc-link-lib=static=crypto");
}
编译此代码时出现LNK2019 (unresolved external symbol)
错误。
为什么会这样?
答案 0 :(得分:0)
我用32位版本的MSVC编译了我的库,但是Rust用64位版本的程序编译了程序。这就是为什么发生冲突。