b9c579db6d
RSA and ECDSA will both require being able to convert ASN.1 INTEGERs to and from DER. Don't bother handling negative BIGNUMs for now. It doesn't seem necessary and saves bothering with two's-complement vs sign-and-magnitude. BUG=499653 Change-Id: I1e80052067ed528809493af73b04f82539d564ff Reviewed-on: https://boringssl-review.googlesource.com/5268 Reviewed-by: Adam Langley <agl@google.com>
79 lines
1.2 KiB
CMake
79 lines
1.2 KiB
CMake
include_directories(. .. ../../include)
|
|
|
|
if (${ARCH} STREQUAL "x86_64")
|
|
set(
|
|
BN_ARCH_SOURCES
|
|
|
|
x86_64-mont.${ASM_EXT}
|
|
x86_64-mont5.${ASM_EXT}
|
|
rsaz-x86_64.${ASM_EXT}
|
|
rsaz-avx2.${ASM_EXT}
|
|
|
|
rsaz_exp.c
|
|
)
|
|
endif()
|
|
|
|
if (${ARCH} STREQUAL "x86")
|
|
set(
|
|
BN_ARCH_SOURCES
|
|
|
|
bn-586.${ASM_EXT}
|
|
co-586.${ASM_EXT}
|
|
x86-mont.${ASM_EXT}
|
|
)
|
|
endif()
|
|
|
|
if (${ARCH} STREQUAL "arm")
|
|
set(
|
|
BN_ARCH_SOURCES
|
|
|
|
armv4-mont.${ASM_EXT}
|
|
)
|
|
endif()
|
|
|
|
add_library(
|
|
bn
|
|
|
|
OBJECT
|
|
|
|
add.c
|
|
asm/x86_64-gcc.c
|
|
asn1.c
|
|
bn.c
|
|
cmp.c
|
|
convert.c
|
|
ctx.c
|
|
div.c
|
|
exponentiation.c
|
|
generic.c
|
|
gcd.c
|
|
kronecker.c
|
|
montgomery.c
|
|
mul.c
|
|
prime.c
|
|
random.c
|
|
shift.c
|
|
sqrt.c
|
|
|
|
${BN_ARCH_SOURCES}
|
|
)
|
|
|
|
perlasm(x86_64-mont.${ASM_EXT} asm/x86_64-mont.pl)
|
|
perlasm(x86_64-mont5.${ASM_EXT} asm/x86_64-mont5.pl)
|
|
perlasm(rsaz-x86_64.${ASM_EXT} asm/rsaz-x86_64.pl)
|
|
perlasm(rsaz-avx2.${ASM_EXT} asm/rsaz-avx2.pl)
|
|
perlasm(bn-586.${ASM_EXT} asm/bn-586.pl)
|
|
perlasm(co-586.${ASM_EXT} asm/co-586.pl)
|
|
perlasm(x86-mont.${ASM_EXT} asm/x86-mont.pl)
|
|
perlasm(armv4-mont.${ASM_EXT} asm/armv4-mont.pl)
|
|
|
|
add_executable(
|
|
bn_test
|
|
|
|
bn_test.cc
|
|
|
|
$<TARGET_OBJECTS:test_support>
|
|
)
|
|
|
|
target_link_libraries(bn_test crypto)
|