-
Notifications
You must be signed in to change notification settings - Fork 200
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
xtest: add pkcs11_1031 for CKM_RSA_X_509 sign/verify (take 2) #762
base: master
Are you sure you want to change the base?
Conversation
Basic test on signing/verifying with raw RSA mechanism CKM_RSA_X_509. Signed-off-by: Etienne Carriere <[email protected]>
Skip the test if CFG_PKCS11_TA_RSA_X_509 is disabled. Signed-off-by: Etienne Carriere <[email protected]>
Fix missing sub-case end call in test_rsa_raw_operations(). Signed-off-by: Etienne Carriere <[email protected]>
Use a well known padding scheme (PKCS#1 v1.5) to ensure the generated signature has to expected size. With the previously implemented padding scheme I found seldom occurrences where the generated signature was 1 byte too short. Signed-off-by: Etienne Carriere <[email protected]>
94dbe5e
to
bc2a22c
Compare
Updated with a more robust message padding scheme. |
host/xtest/pkcs11_1000.c
Outdated
* key. If smaller, it is strongly recommended to inserrt padding | ||
* bytes to reach to key size. Lets's use random data and use PKCS v1.5 | ||
* padding scheme to ensure input data to be signed will generate well | ||
* szied signature. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sized
Fix inline comment typos. Signed-off-by: Etienne Carriere <[email protected]>
Sorry for these typos. |
Discard the padding used here. Whatever the message data, as long as the message has the size of the private key, the PKCS#11 should be able to generate a signature. Signed-off-by: Etienne Carriere <[email protected]>
Updated removing the padding scheme. Strong padding is not needed as far as PKCS#11 regression tests are concerned. |
Remove unused local variable. Signed-off-by: Etienne Carriere <[email protected]>
Fixed an omission in the previous fixup commit. CI test should be good now. |
I missed a constraint on the input message: it must represent a value smaller than the private key modulus. Clear the message leading bit! Fix inline comment. Remove the part testing the key attribute. RSA keys generation in the PKCS#11 TA is already tested by pkcs11_1021, pkcs1022 and pkcs11_1023. No need to test again RSA keys attributes. Wrap line wider than 80char for consistency of this source file. Signed-off-by: Etienne Carriere <[email protected]>
Fixed message leading bit + remove some useless tests on key attributes. |
Replace static test on CFG_PKCS11_TA_RSA_X_509 with a runtime test on whether or not the PKCS#11 TA supports CKM_RSA_X_509 for signature computation and verification. This change makes xtest more flexible regarding the tested embedded TA instead of requiring a specific xtest build for a given PKCS#11 TA configuration. Signed-off-by: Etienne Carriere <[email protected]>
This pull request has been marked as a stale pull request because it has been open (more than) 30 days with no activity. Remove the stale label or add a comment, otherwise this pull request will automatically be closed in 5 days. Note that you can always re-open a closed pull request at any time. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, just two misspelled words, see below.
Acked-by: Jerome Forissier <[email protected]>
Do_ADBG_BeginSubCase(c, "Sign/Verify with valid data/signature"); | ||
|
||
/* | ||
* Test C_Sign() with buffer too short, the C_Sign() operaiton should remain |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
operation
|
||
Do_ADBG_BeginSubCase(c, "Verify with altered signature/message"); | ||
|
||
/* Test signature wider than expect */ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
expected
Thanks for the review. However, this P-R cannot be merged before OP-TEE/optee_os#7179. Without this OP-TEE core fix, we way have failures with this added |
Basic test on signing/verifying with raw RSA mechanism CKM_RSA_X_509.
Replaces #757.