Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pull in the latest changes from s2n-bignum (2023-08-04) #1139

Merged
merged 6 commits into from
Aug 10, 2023

Conversation

aqjune-aws
Copy link
Contributor

Issues:

N/A

Description of changes:

This PR is splitted from #1108 and a successor of (already merged) #1114. This PR is independent from #1135.

This PR pulls in the vectorized versions of functions (which are verified) for montgomery multiplications in Graviton 2 from s2n-bignum. In consequence, this adds the following files from s2n-bignum: arm/fastmul/bignum_emontredc_8n_neon.S, arm/fastmul/bignum_kmul_16_32_neon.S, arm/fastmul/bignum_ksqr_16_32_neon.S, arm/fastmul/bignum_ksqr_16_32_neon.S, arm/fastmul/bignum_ksqr_32_64_neon.S

The commands used:
(The commands in the internal Quip document was used, with PATHS_TO_KEEP added to include the new 5 files)

TODAY=$(date +%Y-%m-%d)

git fetch upstream main  # Fetch the tip of main of AWS-LC 
git checkout -b aws-lc-s2n-bignum-update-${TODAY} upstream/main

git fetch s2n-bignum     # Fetch the tip of main of s2n-bignum
git checkout -b s2n-bignum-${TODAY} s2n-bignum/main

PATHS_TO_KEEP="./arm/p384 ./x86_att/p384 ./arm/p521 ./x86_att/p521 ./x86_att/curve25519/curve25519_x25519.S ./x86_att/curve25519/curve25519_x25519base.S ./x86_att/curve25519/curve25519_x25519_alt.S ./x86_att/curve25519/curve25519_x25519base_alt.S  ./arm/curve25519/curve25519_x25519.S ./arm/curve25519/curve25519_x25519base.S ./arm/curve25519/curve25519_x25519_alt.S ./arm/curve25519/curve25519_x25519base_alt.S ./arm/curve25519/curve25519_x25519_byte.S ./arm/curve25519/curve25519_x25519base_byte.S ./arm/curve25519/curve25519_x25519_byte_alt.S ./arm/curve25519/curve25519_x25519base_byte_alt.S ./arm/fastmul/bignum_emontredc_8n.S ./arm/fastmul/bignum_emontredc_8n_neon.S ./arm/fastmul/bignum_kmul_16_32.S ./arm/fastmul/bignum_kmul_16_32_neon.S ./arm/fastmul/bignum_kmul_32_64.S ./arm/fastmul/bignum_kmul_32_64_neon.S ./arm/fastmul/bignum_ksqr_16_32.S ./arm/fastmul/bignum_ksqr_16_32_neon.S ./arm/fastmul/bignum_ksqr_32_64.S ./arm/fastmul/bignum_ksqr_32_64_neon.S ./arm/generic/bignum_ge.S ./arm/generic/bignum_mul.S ./arm/generic/bignum_optsub.S ./arm/generic/bignum_sqr.S ./include/_internal_s2n_bignum.h"

git filter-branch -f --index-filter "git rm --ignore-unmatch --cached -qr -- . && git reset -q \$GIT_COMMIT -- $PATHS_TO_KEEP" --msg-filter 'cat; echo; echo "s2n-bignum original commit: https://github.com/awslabs/s2n-bignum/commit/$GIT_COMMIT"' --prune-empty -- HEAD

git checkout aws-lc-s2n-bignum-update-${TODAY}
git merge -s subtree -Xsubtree="third_party/s2n-bignum" s2n-bignum-${TODAY} --allow-unrelated-histories

Call-outs:

Point out areas that need special attention or support during the review process. Discuss architecture or design changes.

Testing:

How is this change tested (unit tests, fuzz tests, etc.)? Are there any testing steps to be verified by the reviewer?

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license and the ISC license.

aqjune and others added 4 commits July 27, 2023 04:52
Add NEON versions of functions for RSA 2048 and 4096
s2n-bignum original commit: awslabs/s2n-bignum@ec076f9
Adding support for SHA256 and SHA512 intrinsics
s2n-bignum original commit: awslabs/s2n-bignum@e6024ae
@aqjune-aws aqjune-aws requested a review from a team as a code owner August 4, 2023 17:32
@darylmartin100 darylmartin100 requested review from nebeid and removed request for torben-hansen August 9, 2023 19:08
@nebeid nebeid merged commit f1d3a58 into aws:main Aug 10, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants