From 7affeef725d4b924950f108e2aea4c9bdd6546f3 Mon Sep 17 00:00:00 2001 From: Valerio Setti Date: Tue, 9 Apr 2024 12:28:39 +0200 Subject: [PATCH] generate_test_keys: use keys from asymmetric_key_data.py asymmetric_key_data.py already provides EC/RSA key pair values that are suitable for generate_test_keys.py. So instead of re-generating the keys using gen_key program, we use those keys. This commit also: - extends asymmetric_key_data.py to introduce RSA bit sizes that are used in test_suite_pk but were missing from asymmetric_key_data.py. - updates test_keys.h with new keys. Signed-off-by: Valerio Setti --- scripts/mbedtls_dev/asymmetric_key_data.py | 80 ++ tests/scripts/check-python-files.sh | 1 + tests/scripts/generate_test_keys.py | 115 +- tests/src/test_keys.h | 1319 ++++++++++---------- tests/suites/test_suite_pk.function | 172 +-- 5 files changed, 905 insertions(+), 782 deletions(-) diff --git a/scripts/mbedtls_dev/asymmetric_key_data.py b/scripts/mbedtls_dev/asymmetric_key_data.py index 8ca6758782..4287be2d49 100644 --- a/scripts/mbedtls_dev/asymmetric_key_data.py +++ b/scripts/mbedtls_dev/asymmetric_key_data.py @@ -136,6 +136,54 @@ ASYMMETRIC_KEY_DATA = construct_asymmetric_key_data({ 308189 02818100af057d396ee84fb75fdbb5c2b13c7fe5a654aa8aa2470b541ee1feb0b12d25c79711531249e1129628042dbbb6c120d1443524ef4c0e6e1d8956eeb2077af12349ddeee54483bc06c2c61948cd02b202e796aebd94d3a7cbf859c2c1819c324cb82b9cd34ede263a2abffe4733f077869e8660f7d6834da53d690ef7985f6bc3 0203010001 +"""), + 1026: (""" +3082025e + 020100 + 02818102d09661fc74224ba7be7907abef4f5e8bcc264a802c978f7eaa5855ada05436d75db768d20f68595dbcc3d725b138e80b247e44a4163a0542fab612acbbde45f2e93894aa253bddef6a7becdc9cc29a99bacf48dc6e38db7a33e9ac924c520fc6be7d6e5646c1d67fb8b2b97ac60beecc3bb8e75bed8315aa3fe46f748a66d6ef + 0203010001 + 0281806a4a346beba97f655fe834647d2944f5f40815e7302caf02ed179893c2d989395d5e877cacbf24a77a079d3db71580ccdbf63023d00f80e52f5c1a0716b323b7bfcbdc8a1781c44c4153e3da228d17b2dc78eb1f44cff60fe1150808a6e38ba2470aee2e948a6898ddadea56d9470927aca8d94a0338c11a8e95715b5f94e011 + 024101f5418534c36236fc9fd38934d7c06dfed3829151ccab56b6330c641f7796a71924cf8119ca26e186ecd3068d6607a05260db4857651980436891adde9eb92ab7 + 02410170042fbdbaba1e102b7f7f1dc9d940cfdcd85dd0ea65f543c6432e9c5480724bb49b1e5f80ca2b9f84cd6644bfb2e3d0968090b89f534dc2951e606db909dd89 + 0241014b6c1aeb1c14a04ec04e5975fb015cb914984c054dd22bef24299939c514733f88bb3a9d16b04685b3a883b8923190ab672715d9d31add57b4983de1e8087e59 + 02410117bf76f308b0560e00a2c864427dcd50b5161c2aa523a00f46f4e6c79b4c90958fd2a282028aac227477169888085a38c34f33b3c41934f1071db23b75ff53d1 + 02410120a428b4e0c4a6f202920fd49cc9886e6b6719d40a3ad0604f5d5efd5ef6973a573ab324f38ecb8e669a69341597081e240b6ae4e2714887dd78dadaeb0b9216 +""", """ +308189 + 02818102d09661fc74224ba7be7907abef4f5e8bcc264a802c978f7eaa5855ada05436d75db768d20f68595dbcc3d725b138e80b247e44a4163a0542fab612acbbde45f2e93894aa253bddef6a7becdc9cc29a99bacf48dc6e38db7a33e9ac924c520fc6be7d6e5646c1d67fb8b2b97ac60beecc3bb8e75bed8315aa3fe46f748a66d6ef + 0203010001 +"""), + 1028: (""" +3082025e + 020100 + 0281810e62a76f0e0b59683a7ebf7cbfd37b1d1781d8f1b900604b507f0f04c72a3d340d067bcd53bea3caff4e4ae694f0b6d8f591a4167fbf7f372ab57e83a69a3f26f447bcf582bc9621a30a3b44d6b43e986d1a867b07489e4f9bfcadaa82a2782dc2729a631fb1fb9ffb794b4e53c76239e04d4a8f80352588db29462dde18237cf5 + 0203010001 + 02818101cfa0422e3bb60c15ef2e96db4499e789f5d634ea64567b2cdd6e2bdd121f85edccdee9b4ed178c5f33816101a7c371518b3e23f9fdc71b90242cd310b6b31428b0b64eb9596be0cc044cc85048982f90b706e66ccdd39ad5a1a7b64cf034eac0c35d7ace93f2bcd3ce243bd8f83b46f509ca2f805063002af2bb2d88b6ee36a9 + 024103f0886d2977526f3f3f6a075600232ce3008517276dd3721dee08fd6c999fc976b9e8dd2bc143385fa4b48735ce81c66b501d7129ee7860cfbef23b5da91e6c2d + 024103a6c8734aace59d5f386f97de450f8a12d63ae6ac15d336e010c9fcf03a32f0611881ac6cd8b3f989925c0f025af26cf26aebd7d9b04eb503048dca2f503c28e9 + 0241019b300451c3b47866f113e9a9c6a490c87c8dc6c2eca42902caea1f6907b97e0a4a02072aafc1185ae66c34345bddcd683361cda1aaf8a98009f9f8fa56d97081 + 02401bcca849173d38e1e50ec48872ab54a2dcc621a80a7a1e8ea951287988718d5e85d90d64ab4926e9a575a168a385c421ad765813fc3f4af8cd00de7b6bba6e49 + 0241036dcf69f6e548c8acfb536fb6cd186f8b8f20d313361d0447c1b5e380f4113e578b31e867dda47d44ad3761e793f725031b8d379f389de277a9a0137651df548a +""", """ +308189 + 0281810e62a76f0e0b59683a7ebf7cbfd37b1d1781d8f1b900604b507f0f04c72a3d340d067bcd53bea3caff4e4ae694f0b6d8f591a4167fbf7f372ab57e83a69a3f26f447bcf582bc9621a30a3b44d6b43e986d1a867b07489e4f9bfcadaa82a2782dc2729a631fb1fb9ffb794b4e53c76239e04d4a8f80352588db29462dde18237cf5 + 0203010001 +"""), + 1030: (""" +3082025f + 020100 + 0281812b7cd197f5796d1f8e576b2b37723fd9210814ef1c1995f9899d50058f379d239c66878e922f34c6ae3672c8598fcd5d47b764d2ec156e134d03cf6a94d38d2ea8bc76dbbc60c4b974219090eaf287497d7dcf7f119cfa867496f7e91c12b5d552e1d1461a80dbe9a59db3b016c6c0141c3b2a0e226089b855cb88ef656408bd89 + 0203010001 + 0281810210d5ff531cacb22f8cf7dd1fd9fb0376f3647f2e9ab3df9c89b9ad3c98e68b89adeb29901dd2f2cf2ac1f817726278830ec8a8d0fdd19d496ec6bc683671174786b7d6a8e822fa71d65ad35abbdf0e6e55ff2c1821b62bc630192160e5c9b3dcafc65ae6b2a088fbc5591da58a45dd7a30960f7d3def75b80cdf73247360e8fb + 0241072e371a3ba861e78e3eb9313065faab0a97216e9544bfc2d5b403844b43273705755a85aa0baf7114770cfeca20bca17ac19bc4cbba106a33b3dddca0fb535f33 + 0241060e6af37ab4ea11f52b9344e7160eb2a53f1075e1229a7f10a301de3359f53e981ea0e17df0fb380f089e5c37dd40daa29eefd205f5c87b38f8fef636b57ba053 + 0241023a5dd09ef83540b30b554d24f64f9c28d212068cfc62ffe26d53b605e05557a632ee9e90cfc56531f36aadd82be63bb8aa405a04d8bbe5281bc45883fed7b4af + 0241041de6dbad4caf5417a9504965201c4b99827de8f369f7456a84b3ef5c4ec9238c7a3d782a8915ebec643a698b5bee0af0c243592bce0042aadeaf49a4b4c6dd9b + 024105d32dee952b503b536fcecf19ec08236a9cd945c49551bf99f15b674fc21aa199f4c4211f0f0007c417c1fb4155326a2142fca454bbd38d6dbc6caa7ac335a17c +""", """ +308189 + 0281812b7cd197f5796d1f8e576b2b37723fd9210814ef1c1995f9899d50058f379d239c66878e922f34c6ae3672c8598fcd5d47b764d2ec156e134d03cf6a94d38d2ea8bc76dbbc60c4b974219090eaf287497d7dcf7f119cfa867496f7e91c12b5d552e1d1461a80dbe9a59db3b016c6c0141c3b2a0e226089b855cb88ef656408bd89 + 0203010001 """), 1536: (""" 3082037b @@ -152,6 +200,38 @@ ASYMMETRIC_KEY_DATA = construct_asymmetric_key_data({ 3081c9 0281c100c870feb6ca6b1d2bd9f2dd99e20f1fe2d7e5192de662229dbe162bd1ba66336a7182903ca0b72796cd441c83d24bcdc3e9a2f5e4399c8a043f1c3ddf04754a66d4cfe7b3671a37dd31a9b4c13bfe06ee90f9d94ddaa06de67a52ac863e68f756736ceb014405a6160579640f831dddccc34ad0b05070e3f9954a58d1815813e1b83bcadba814789c87f1ef2ba5d738b793ec456a67360eea1b5faf1c7cc7bf24f3b2a9d0f8958b1096e0f0c335f8888d0c63a51c3c0337214fa3f5efdf6dcc35 0203010001 +"""), + 2048: (""" +308204a3 + 020100 + 0282010100f7bb6b8eab40491cd64455ec04d4ed8db5051a9738fc7af73ff3b097511cce40aaf76537b1353504427986b7b2b53a964a6937b558ec0d1dea274af2b8fff2f094c243fa577266a79db0c26ffe30416d23ef05dd5fecab413ebbb4f8526ae720a94584226b37d92ef463fc736cb38e530e7488d9162f5726807bc543138a2d258adb4d680221c2532381ccfa81bc89bc3d7b84039c2df41ce3ec8db91c2380e781ba3aa9e23b74ed9973d4908efca47aa8d9b7b0a4423297a404427c3f3cd6e0782e4553880f06ba39a64f4a7b0eef921a6050a207cefadcf07394a3e18ea915dc8497e7ae61fc3162f62f5065a692af077266f7360c2076cebeaf14cb22c1ed + 0203010001 + 0282010000b8962dce604bc62e7678f48ca80cfff456ad36e2f6d329cc911a42ba7cf5b9b8f5aae1005e4a06f6e591279038d8508f2b62badfa5223da3cc94fa8360d5556f6d6852be75ea08135cac1834da719a4e7837e166d1d2c6c816b64661c10766b02f705cc4489f947428255835a909214341c21335ae12181dd81e611d59b1db70667bebd7e92b71e1d388318d3ec14d616f72c231f6727a183e6818285bd65f6572cadc9012248821b2d0ae6cedd30ca440d4d34cd77e2cf6b40ed2c7d856b30d474733fce0fb695c3e6530c079aed955e4073055f2655d4b671e291fde400f2f06d0b33f87d261e0ad3dae48a913841b34cfed03790fcaee00de2e90fb9621 + 02818100fcbe89cd1aa319e49ef4f72149bf06da57dcc64d3de605e9ff3e76fc66f4b1e2878245ffd71990511b17e97f33818889a8c21b5527fd181327affe88f9bba670c4e6f1e6309bd0323074e4cbcf23dce3c19b8d5495f56a93059ba7414f28ed1ec906ad18c63de1148abcfe9be7986000f425e580b70e43e48e24fa9d51aaae4d + 02818100faec5a7bed2e53cfca1e167db4641db5a00fe2c328125423d594789f3ec072c623e7afbdee0089fd26307651f6d3611a88af28c34585d5cb713a650c35933f58944db9bd15ba9fc28b07e6705b7b3ef1ccb48d21a53569c8b84c444b61ea5c6e67b54f0afd852ffb8c92a111fab8677263eeb80cf1a3403b4a9a209776947221 + 0281802ff99afeabc7b9ea83a1cc272d706d4494d8fb6b3e0ca3a2bf28843d74ed8db68a3258472ff5524792f4ff057e296059810717591ab61813cabcc57c0aab6bf48bebaa8f1f3af45212909dbd721c449996ee87ed3e69cf49090f7ab812e699dbf61ca64ec592895ef4d6db1d8ce08798a6bf6ac8fbf6613cc91e8bd3c0e4bd21 + 02818100b29b34590bddb308afecb4c3ab78abf1114add755e7b956aa0677b6896a933c937db7dabaad2b565fd1df7caa5ef9629e5eb100fd6d7c9f372d846fee6cfb6025e25e934df57a4ca3c5e5637d9d6235ac80428852f6c92acae0a937e38e731fde0521d3e4c70d653ae9edc89c8b623e4379fbf606f4b6db8068528f7c70f2921 + 0281800ed47ae05b275a23a7dfe3ffb727e3a268e626a59d401d2d846de26954ff54fc9ed93a9af33fac2c967a18e0f86145083e39923454bc10da5f4937e836b99851956bffb301ce9e06789786693213fcde6d5f2933d52bb29dc340ea011257788d3c5775eb6569230aafbf08752d40a8419de71b01d4927e27c1079caada0568b1 + """, """ +3081010a + 0282010100f7bb6b8eab40491cd64455ec04d4ed8db5051a9738fc7af73ff3b097511cce40aaf76537b1353504427986b7b2b53a964a6937b558ec0d1dea274af2b8fff2f094c243fa577266a79db0c26ffe30416d23ef05dd5fecab413ebbb4f8526ae720a94584226b37d92ef463fc736cb38e530e7488d9162f5726807bc543138a2d258adb4d680221c2532381ccfa81bc89bc3d7b84039c2df41ce3ec8db91c2380e781ba3aa9e23b74ed9973d4908efca47aa8d9b7b0a4423297a404427c3f3cd6e0782e4553880f06ba39a64f4a7b0eef921a6050a207cefadcf07394a3e18ea915dc8497e7ae61fc3162f62f5065a692af077266f7360c2076cebeaf14cb22c1ed + 0203010001 +"""), + 4096: (""" +30820929 + 020100 + 0282020100cc8725f6b38d5d01aeeb07d36e03de4d31a0261ce74fe11a895ecfd13d168aee932af135ffbb849877273897081f3f7593c14ae82bc266c10544f726ae1ccf133d8a4018d380dfa25251c011107b7513a943346aa0e0dec11d8d7fa25644653c118daabce6d41f066f6621768801478055780e91b68ea3c95856d172a89032b39c824e8b7dc1a3f8aee4f6b368baa3cd68f50d52680117e9b913d7f8c852a0d1008e8b87a5c97e37afc11a080550557b8b4dcbd8e192ed3366d83a09d27c77e150f66855b5dcfdb2df151bd7f444250eaf6fe3f236826c81fa848101bfaad535ffb522d6ff97c9dd1e43b82cce2921d153c15450c4724ffd3efdca578e013650a03a5cf501fc58600fb5c860c0ef0cfe0ac0712d441313dca41a4d7d411e6c83b2151749d28be4692f62373db07e4a79051c5682ec20d491c4cfc7bc140f35fa15e5a1fa756d65b8ef93addf4c47c4a35b184f22a1ef089948f946f6faeb6470f26746e658cf9b4177417842e6d373558089aff721b930e9ec61b4f6a02c052c6924d39a5bbb15ed1106c4010f4dd69c79d042c8b31661b1ee486bc69db5f2f07a50d85b20699d601315625bb869629c7f4c5d48b211d097f438acec95973a38d421090af0f13484e4e94b8cb5efc18507f4b931df39987ffb2830293e4da381aaf70b3292952ef934e2b40fdebba3d9701b76e1be548274b2602d888537482d + 0203010001 + 028202001a943e9c0089f0aa0116048a96abb486321a86916f82fb352460789fcfb1400550853e5afedc9ad6e877259cc4feb093c24b968534f89abb5f48aed8ad3c4bb1cba7cd7c1c724d3dae36770010b5068a334f2b3ee720c9f9ed320001f3f587f5662f939e605df519343d60c0635ccd32b188bc55f5d434173c9e6db2199341af833990e50246f99cddf79dd2c35babe14c103a76b8d2d98d73528f98c249b0a1f09155b31f599fc833542422a2342623bbbef4ac7ee605e2cdecf01fea25683bd4f66ca924ccef00418adff730c4714f66ffa2af0da3e5df7f539c634289fc12bc24093ec8f0ec180af0907cec1ebec911fa180fb5f3c80ed852896ad6e6b3eccb44de62193d52118cab2b171071d5fdaa7c4288fc7766d57774f4be46151bb90ace7c10c215f62ed26e52e6122436f532bd54fc08272adb216a2db433d5699c40ad58faa2660898ffccfc98002f8bb0361b4cf9ed6e93c1ca96d34a1ef40460f85918cfde4a8193b51ecea4b3903cae924a8fad5f8308954c9f19a7597bf0a75126a557e49f8bbd31fc4e8556f230640bf36204c6cf3d56dca5a41d860307ba6705a698681100a327f91739c486c470ba71d03d285314b0d7d04008e03f2a2b85e7c243d6fd9b97a02168c069ec572d3f0ca15ebcb1739f3a0b3c147a88e0b74f45a007ae927d6f822bf50b87b1e93fe7d9180bc6bc12bde6c8070d10c97331 + 0282010100f50ebceac9d3c64482a8c265d6365461aa4a31a6a7633a24c8e34794ecdfcab1d6b52fb6a5f38055cc32d6a61b889550de27b3d0bd68b6d4fda041598ab98887143988576806b1c48720794902952ebe1bf0def65a0e6f94067056e6864fa2882e3a16f246282093d037639078182dd0a6eb21d3bad0637901a268b14c632c9d0b1690ed88abdde03f528247aa2e41557d0865ad34e53ff53ae0e5dea195d93fe65c25871f6f23adf34b6e960c2978f2b7475dafce6cbb26a53934d26c193d67f32de91035eeb89022beb7d5df784ac20ca6ab91bf6b775b6c9416f605b4841736cbfbd22ad98ab2e8428457e0793f5af40e550b48765d59e6e1b4a4a1f571f1 + 0282010100d5a91d4d44bb9b73c1fe0248925e2c0ec1de51390bd8a73b453da51ae29325ae7657089fd4ee4a2fd96e345b57f672d7d484fde99189ab0a6365bf2b38680d6bb947f4b217be660323c26b86d643ae686d82e36ec00cfd038942443caa04a0f91e68ec717935b45e790311be56440d7176949594688ed1dd5c9103c57c158d05e4c37b98d81898030744a64f6ebdbf750aab79757e34dac422163ea7c0f42b97710c861978b24100385aad727e5f3836a74ea4bf1d36ef2a5edf9c9e8f996ef3191348450ea9f1d4a63db29cb06f63e5badb18e4d40f5112b658d1cc23cb65388aca03d141a6bc5fbd9429fe33d340d3e85bfa848908d60b562f894e8a337dfd + 0282010100c4950f0d95dc51d791ad094d223b3113abc49af1e2a361f83242c8a07a28c8744315d3f1c44c82edd0c21398eacb75648ae1f48885f92379d6ffa08cd11126a99d9acd79b8946e3486659185f511718ec5e1432b02714426cdc77e9eacade36735161a643dcd60dcd2922c47af5f4e196c5d8124555f67fca148048dfe062cbaca334f0d8daeb96d73be9f8e17c1c55d6bd0b9a7e99fe1dfba5cc16a07dbaa8c6d220c64c9dda114a0f029052b3a75b0d73fe3b2ed7821e5cd7307a1a95fd1f7ba8760c8454b7c38fbf65c88b01cd273ba2c55c3b477e426ae025a2cffc4a095f2ba4e0779a24b765b85489f2a0e79b95fc0c38e2a91f12ef65ca749ce369431 + 028201002aa48e0c95e33bab66d4637048863314deec9819629be30499552c56a951e4fb64f309ed9c79d2a4aa28ac9a6e7be97fda1290fac4e94d11cdb4c8eabf5f450e72f4418a29e2fe493221e3840dcf8447a353b440ae63e93b83718e5ced31ef4ec91af7d5cdf3420478f27be019278be7515b665f305f10d3b55ddbfad64116dc4e4415aef3b234e4a5d6b5bab4c77a26c9f25f536bd4f0b4a478fc184f126c80d53742ac62c270e6b258a6b56b3365ecc28797a9ed12c1b91b265603ef751807bcc1747313f22729e1e3fe79f75cc3fb5dc7ccb81efacf9b847945a6109ecf9cf156505cbb55a3d317eb325661d18fe6bb416046837318053b365199334c03a1 + 0282010100ee63706030a4ece9fe3bddcfc49f5a83f37f63ebcb29dbdc999f6ff54b596f115cf1eca09990108a439518e996f689fdde89b2c67edc04bf8e366734c2ae3017ec14e042050e7c656840146ca048394dcebe90dd2195349bbad306569031b2ef6e9171d2ae7797c8844e548394ca3b768d8496e99ef63abb59b0ff7fc70eb53153dd0f59018a275acba701f2c76a15c894f53461fedf65bc25c2c5cec396e556a1a919bc7a056393d50644126dcdef9256642e65a6043cbce9497e192cf2cb33648e117f41dbf01900acb93b0c78ddf31f381f4db3f9ccbbb69093dabf2e89dbbc0cb72f20c005a2519e3a874146495d7aacf3416a422e560986f22f39456e7f + """, """ +3082020a + 0282020100cc8725f6b38d5d01aeeb07d36e03de4d31a0261ce74fe11a895ecfd13d168aee932af135ffbb849877273897081f3f7593c14ae82bc266c10544f726ae1ccf133d8a4018d380dfa25251c011107b7513a943346aa0e0dec11d8d7fa25644653c118daabce6d41f066f6621768801478055780e91b68ea3c95856d172a89032b39c824e8b7dc1a3f8aee4f6b368baa3cd68f50d52680117e9b913d7f8c852a0d1008e8b87a5c97e37afc11a080550557b8b4dcbd8e192ed3366d83a09d27c77e150f66855b5dcfdb2df151bd7f444250eaf6fe3f236826c81fa848101bfaad535ffb522d6ff97c9dd1e43b82cce2921d153c15450c4724ffd3efdca578e013650a03a5cf501fc58600fb5c860c0ef0cfe0ac0712d441313dca41a4d7d411e6c83b2151749d28be4692f62373db07e4a79051c5682ec20d491c4cfc7bc140f35fa15e5a1fa756d65b8ef93addf4c47c4a35b184f22a1ef089948f946f6faeb6470f26746e658cf9b4177417842e6d373558089aff721b930e9ec61b4f6a02c052c6924d39a5bbb15ed1106c4010f4dd69c79d042c8b31661b1ee486bc69db5f2f07a50d85b20699d601315625bb869629c7f4c5d48b211d097f438acec95973a38d421090af0f13484e4e94b8cb5efc18507f4b931df39987ffb2830293e4da381aaf70b3292952ef934e2b40fdebba3d9701b76e1be548274b2602d888537482d + 0203010001 """), }, }) diff --git a/tests/scripts/check-python-files.sh b/tests/scripts/check-python-files.sh index 51e80792b0..cf1f87ab12 100755 --- a/tests/scripts/check-python-files.sh +++ b/tests/scripts/check-python-files.sh @@ -62,6 +62,7 @@ $PYTHON -m pylint scripts/mbedtls_dev/*.py scripts/*.py tests/scripts/*.py || { echo echo 'Running mypy ...' +export MYPYPATH="../../scripts" $PYTHON -m mypy scripts/*.py tests/scripts/*.py || ret=1 diff --git a/tests/scripts/generate_test_keys.py b/tests/scripts/generate_test_keys.py index 23bc9a19e8..630ab05ac1 100755 --- a/tests/scripts/generate_test_keys.py +++ b/tests/scripts/generate_test_keys.py @@ -8,94 +8,85 @@ generating the required key at run time. This helps speeding up testing.""" import os import sys -import subprocess +# pylint: disable=wrong-import-position +SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__)) + "/" +sys.path.append(SCRIPT_DIR + "../../scripts/") +from mbedtls_dev.asymmetric_key_data import ASYMMETRIC_KEY_DATA -KEY_GEN = "./programs/pkey/gen_key" -TMP_DER_FILE = "tmp_key.der" -OUTPUT_HEADER_FILE = "./tests/src/test_keys.h" +OUTPUT_HEADER_FILE = SCRIPT_DIR + "../src/test_keys.h" BYTES_PER_LINE = 12 KEYS = { # RSA keys - 'test_rsa_1024': ['rsa', '1024'], - 'test_rsa_1026': ['rsa', '1026'], - 'test_rsa_1028': ['rsa', '1028'], - 'test_rsa_1030': ['rsa', '1030'], - 'test_rsa_2048': ['rsa', '2048'], - 'test_rsa_4096': ['rsa', '4096'], + 'test_rsa_1024': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 1024], + 'test_rsa_1026': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 1026], + 'test_rsa_1028': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 1028], + 'test_rsa_1030': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 1030], + 'test_rsa_2048': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 2048], + 'test_rsa_4096': ['PSA_KEY_TYPE_RSA_KEY_PAIR', 4096], # EC keys - 'test_ec_secp192r1': ['ec', 'secp192r1'], - 'test_ec_secp224r1': ['ec', 'secp224r1'], - 'test_ec_secp256r1': ['ec', 'secp256r1'], - 'test_ec_secp384r1': ['ec', 'secp384r1'], - 'test_ec_secp521r1': ['ec', 'secp521r1'], - 'test_ec_bp256r1': ['ec', 'brainpoolP256r1'], - 'test_ec_bp384r1': ['ec', 'brainpoolP384r1'], - 'test_ec_bp512r1': ['ec', 'brainpoolP512r1'], - 'test_ec_curve25519': ['ec', 'x25519'], - 'test_ec_secp192k1': ['ec', 'secp192k1'], - 'test_ec_secp256k1': ['ec', 'secp256k1'], - 'test_ec_curve448': ['ec', 'x448'], + 'test_ec_secp192r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1)', 192], + 'test_ec_secp192r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_R1)', 192], + 'test_ec_secp224r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1)', 224], + 'test_ec_secp224r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_R1)', 224], + 'test_ec_secp256r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1)', 256], + 'test_ec_secp256r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_R1)', 256], + 'test_ec_secp384r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1)', 384], + 'test_ec_secp384r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_R1)', 384], + 'test_ec_secp521r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1)', 521], + 'test_ec_secp521r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_R1)', 521], + 'test_ec_bp256r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 256], + 'test_ec_bp256r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 256], + 'test_ec_bp384r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 384], + 'test_ec_bp384r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 384], + 'test_ec_bp512r1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 512], + 'test_ec_bp512r1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_BRAINPOOL_P_R1)', 512], + 'test_ec_secp192k1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_K1)', 192], + 'test_ec_secp192k1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_K1)', 192], + 'test_ec_secp256k1_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_K1)', 256], + 'test_ec_secp256k1_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_SECP_K1)', 256], + 'test_ec_curve25519_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_MONTGOMERY)', 255], + 'test_ec_curve25519_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_MONTGOMERY)', 255], + 'test_ec_curve448_priv': ['PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_MONTGOMERY)', 448], + 'test_ec_curve448_pub': ['PSA_KEY_TYPE_ECC_PUBLIC_KEY(PSA_ECC_FAMILY_MONTGOMERY)', 448], } -def generate_der_file(curve_type: str, curve_or_bits: str): - if not os.path.exists(KEY_GEN): - raise Exception(KEY_GEN + " does not exist. Please build it before running this script.") - if curve_type == 'ec': - cob_param = 'ec_curve=' + curve_or_bits - else: - cob_param = 'rsa_keysize=' + curve_or_bits - - subprocess.run([KEY_GEN, 'type=' + curve_type, cob_param, - 'format=der', 'filename=' + TMP_DER_FILE], check=True) - -def convert_der_to_c(array_name: str) -> str: - """Convert a DER file content to a C array. The name of such array is - provided as input parameter. The file to be converted is the temporary - TMP_DER_FILE.""" +def convert_der_to_c(array_name: str, key_data: bytearray) -> str: + """Convert a DER content to a C array.""" output_text = "const unsigned char {}[] = {{\n".format(array_name) - with open(TMP_DER_FILE, 'rb') as input_file: - data_block = input_file.read(BYTES_PER_LINE) - while data_block: - new_line = ' ' + ', '.join(['{:#04x}'.format(b) for b in data_block]) - output_text = output_text + new_line + ",\n" - data_block = input_file.read(BYTES_PER_LINE) + def get_data_chunk(data): + for index in range(0, len(data), BYTES_PER_LINE): + yield data[index : index + BYTES_PER_LINE] - output_text = output_text + "};\n" + for bytes_chunk in get_data_chunk(key_data): + new_line = ' ' + ', '.join(['{:#04x}'.format(b) for b in bytes_chunk]) + output_text = output_text + new_line + ",\n" + + output_text = output_text + "};" return output_text def main(): - # Remove intermediate and output files if already existing. + # Remove output file if already existing. if os.path.exists(OUTPUT_HEADER_FILE): os.remove(OUTPUT_HEADER_FILE) - if os.path.exists(TMP_DER_FILE): - os.remove(TMP_DER_FILE) output_file = open(OUTPUT_HEADER_FILE, 'at') output_file.write( "/*********************************************************************************\n" + " * This file was automatically generated from tests/scripts/generate_test_keys.py.\n" + " * Please do not edit it manually.\n" + - " *********************************************************************************/\n" + - "\n" + " *********************************************************************************/\n" ) - add_newline = False for key in KEYS: - # Use gen_key tool to generate the desired key (in DER format) and save - # it into a temporary file. - generate_der_file(KEYS[key][0], KEYS[key][1]) - # Convert the key from binary format to a C array and append the result - # to the output header file. - if add_newline: - output_file.write("\n") - c_data = convert_der_to_c(key) - output_file.write(c_data) - # Remove the temporary key file. - os.remove(TMP_DER_FILE) - add_newline = True + key_type = KEYS[key][0] + key_bitsize = KEYS[key][1] + c_array = convert_der_to_c(key, ASYMMETRIC_KEY_DATA[key_type][key_bitsize]) + output_file.write("\n") + output_file.write(c_array) + output_file.write("\n") if __name__ == '__main__': sys.exit(main()) diff --git a/tests/src/test_keys.h b/tests/src/test_keys.h index 197e142ddd..694bee55fb 100644 --- a/tests/src/test_keys.h +++ b/tests/src/test_keys.h @@ -4,690 +4,717 @@ *********************************************************************************/ const unsigned char test_rsa_1024[] = { - 0x30, 0x82, 0x02, 0x5b, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x00, 0x96, - 0xbf, 0x20, 0x0e, 0x0b, 0xab, 0xff, 0x46, 0x3d, 0xd8, 0xc4, 0x25, 0x71, - 0x78, 0x27, 0xe4, 0x27, 0xfd, 0x9c, 0x38, 0x26, 0x25, 0xc2, 0x05, 0xb2, - 0x9a, 0x73, 0x04, 0x99, 0xa8, 0x75, 0x00, 0x98, 0x6b, 0x28, 0xec, 0xe9, - 0x87, 0x6c, 0x92, 0xf8, 0xdd, 0x6e, 0x3b, 0x0a, 0xae, 0x79, 0x79, 0xa1, - 0xbc, 0x39, 0xc2, 0x3e, 0x2d, 0x46, 0xad, 0x09, 0xff, 0xec, 0x3a, 0x2b, - 0xf5, 0xaf, 0x87, 0xaa, 0x69, 0x25, 0xa3, 0x71, 0xa1, 0xe0, 0x43, 0x13, - 0x63, 0xac, 0x0d, 0x54, 0x62, 0x5b, 0xd3, 0x1b, 0x36, 0x0e, 0x6d, 0x26, - 0x80, 0x56, 0xd3, 0x10, 0xf2, 0x21, 0xd4, 0xac, 0x96, 0x3e, 0xe6, 0x66, - 0x7a, 0xea, 0x02, 0x14, 0x02, 0x28, 0x0f, 0x92, 0x46, 0x82, 0x23, 0x06, - 0xd6, 0xef, 0xcc, 0x69, 0x3b, 0x58, 0x82, 0xb0, 0xd7, 0x26, 0x9f, 0x10, - 0x7c, 0x68, 0x5c, 0x4c, 0x91, 0x0c, 0x27, 0x02, 0x03, 0x01, 0x00, 0x01, - 0x02, 0x81, 0x80, 0x15, 0xb8, 0x8f, 0x62, 0xb1, 0x62, 0xd9, 0xf8, 0x61, - 0xe3, 0xfb, 0x36, 0x01, 0x4e, 0x14, 0xc2, 0xbc, 0x27, 0xbf, 0xb1, 0x45, - 0x7f, 0x38, 0xf5, 0x94, 0xe1, 0x20, 0x03, 0xeb, 0x2c, 0xc9, 0xed, 0xc9, - 0x33, 0x33, 0xa5, 0x43, 0x6c, 0x57, 0x2e, 0xd6, 0xe6, 0x22, 0x6d, 0x26, - 0x77, 0xb2, 0x70, 0x33, 0x67, 0x9e, 0xe8, 0xf2, 0xb2, 0xed, 0x15, 0x4a, - 0x34, 0xbd, 0x47, 0x3a, 0x85, 0xff, 0x01, 0xc9, 0x8e, 0xa9, 0x3d, 0x65, - 0xaa, 0x62, 0xcb, 0xf7, 0x33, 0xdd, 0xfb, 0x69, 0x67, 0xa4, 0xc6, 0xda, - 0x3e, 0xc9, 0x5a, 0x00, 0xaa, 0xb7, 0xde, 0x01, 0x45, 0x15, 0xfb, 0x8b, - 0x87, 0x68, 0x40, 0xa7, 0xf1, 0xe3, 0xc2, 0xeb, 0xa1, 0x9a, 0xcd, 0x49, - 0xf8, 0x19, 0xae, 0x61, 0x5a, 0x8e, 0x2d, 0x8f, 0x49, 0x85, 0x09, 0x64, - 0x48, 0x29, 0x4a, 0x2c, 0x1a, 0x12, 0x51, 0x33, 0xbe, 0xc0, 0x0d, 0x02, - 0x41, 0x00, 0xc7, 0x67, 0x6c, 0xc0, 0xb8, 0x44, 0x65, 0x5c, 0xd1, 0xfd, - 0xb3, 0x36, 0x91, 0xf5, 0xb4, 0xf9, 0x51, 0x55, 0x18, 0x9a, 0x42, 0x68, - 0xe5, 0xd0, 0x73, 0xe9, 0xdd, 0xf0, 0x91, 0x49, 0xa8, 0x2b, 0x3f, 0x8a, - 0xfc, 0xc5, 0x43, 0x9a, 0xa8, 0x4a, 0xe7, 0xe8, 0xf3, 0xdd, 0x3d, 0x9f, - 0x9c, 0xb8, 0xa7, 0xab, 0xeb, 0xd8, 0xc0, 0xa3, 0xae, 0xde, 0x1d, 0x46, - 0x38, 0x87, 0x2d, 0x96, 0x3b, 0x4d, 0x02, 0x41, 0x00, 0xc1, 0x88, 0x48, - 0x0c, 0xb2, 0x5e, 0x24, 0x09, 0x11, 0x93, 0xbc, 0xaa, 0x8d, 0x27, 0x14, - 0x47, 0x4e, 0x59, 0xae, 0x53, 0xfc, 0x75, 0x02, 0x56, 0xa5, 0x10, 0x33, - 0x92, 0x72, 0xa5, 0xbe, 0x95, 0xbc, 0x4e, 0x19, 0x85, 0x89, 0xd1, 0xc2, - 0xe4, 0xf4, 0x64, 0x1d, 0xe0, 0x7e, 0xa7, 0x2d, 0x7b, 0x6d, 0xb0, 0xb0, - 0x2a, 0x1b, 0xad, 0xc6, 0x6c, 0xf5, 0x64, 0x53, 0x31, 0xaa, 0xb4, 0x23, - 0x43, 0x02, 0x40, 0x64, 0xb0, 0x77, 0xfc, 0xf4, 0xcf, 0x2c, 0xb3, 0xeb, - 0x21, 0x85, 0x8e, 0x47, 0xb3, 0xdf, 0xb7, 0x89, 0x77, 0x43, 0xde, 0x19, - 0x2c, 0xa8, 0xe7, 0x52, 0xb0, 0xc4, 0x2e, 0x46, 0xde, 0xff, 0xb9, 0x1e, - 0xf4, 0x0a, 0xe1, 0x7d, 0x5a, 0xaa, 0x22, 0x70, 0xea, 0x73, 0xc1, 0xc2, - 0xed, 0x47, 0x11, 0x03, 0x31, 0xcf, 0xfc, 0xfa, 0x81, 0x6c, 0xba, 0xa1, - 0xe3, 0xa4, 0x85, 0xb5, 0xe2, 0x47, 0x7d, 0x02, 0x40, 0x13, 0xcb, 0x4b, - 0x8b, 0x38, 0xe7, 0x16, 0x0a, 0x73, 0x68, 0xc7, 0xe0, 0x2d, 0xc5, 0xb4, - 0x76, 0x42, 0x96, 0x3b, 0x95, 0x4d, 0x79, 0xee, 0x3e, 0x4c, 0x6d, 0xa6, - 0xc8, 0xb0, 0xbf, 0x31, 0x0a, 0x01, 0x93, 0x7f, 0x5a, 0xc0, 0x28, 0xdb, - 0x25, 0x2d, 0xb5, 0xdb, 0xb4, 0x6d, 0x5f, 0xcd, 0xf0, 0x14, 0xdd, 0x00, - 0x77, 0x9e, 0x13, 0x1c, 0xfb, 0x61, 0xf1, 0xdb, 0xec, 0x75, 0x88, 0x2d, - 0x1f, 0x02, 0x40, 0x21, 0x0a, 0xa0, 0x87, 0x82, 0x23, 0x01, 0xe9, 0x8b, - 0xcc, 0x29, 0xb3, 0x47, 0x69, 0xfe, 0x37, 0x65, 0x90, 0x79, 0xaa, 0x36, - 0x9b, 0x6c, 0x58, 0xd4, 0x62, 0x08, 0x6c, 0xfe, 0x1f, 0xec, 0x89, 0xbb, - 0x85, 0x9e, 0x27, 0xd2, 0x0d, 0x97, 0xaa, 0x3d, 0x2c, 0x00, 0xee, 0x60, - 0x95, 0x77, 0x6e, 0x5d, 0xc4, 0xe2, 0x49, 0x3f, 0x79, 0x38, 0x78, 0xc8, - 0x48, 0xa3, 0xe3, 0x80, 0x46, 0xcb, 0x22, + 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x00, 0xaf, + 0x05, 0x7d, 0x39, 0x6e, 0xe8, 0x4f, 0xb7, 0x5f, 0xdb, 0xb5, 0xc2, 0xb1, + 0x3c, 0x7f, 0xe5, 0xa6, 0x54, 0xaa, 0x8a, 0xa2, 0x47, 0x0b, 0x54, 0x1e, + 0xe1, 0xfe, 0xb0, 0xb1, 0x2d, 0x25, 0xc7, 0x97, 0x11, 0x53, 0x12, 0x49, + 0xe1, 0x12, 0x96, 0x28, 0x04, 0x2d, 0xbb, 0xb6, 0xc1, 0x20, 0xd1, 0x44, + 0x35, 0x24, 0xef, 0x4c, 0x0e, 0x6e, 0x1d, 0x89, 0x56, 0xee, 0xb2, 0x07, + 0x7a, 0xf1, 0x23, 0x49, 0xdd, 0xee, 0xe5, 0x44, 0x83, 0xbc, 0x06, 0xc2, + 0xc6, 0x19, 0x48, 0xcd, 0x02, 0xb2, 0x02, 0xe7, 0x96, 0xae, 0xbd, 0x94, + 0xd3, 0xa7, 0xcb, 0xf8, 0x59, 0xc2, 0xc1, 0x81, 0x9c, 0x32, 0x4c, 0xb8, + 0x2b, 0x9c, 0xd3, 0x4e, 0xde, 0x26, 0x3a, 0x2a, 0xbf, 0xfe, 0x47, 0x33, + 0xf0, 0x77, 0x86, 0x9e, 0x86, 0x60, 0xf7, 0xd6, 0x83, 0x4d, 0xa5, 0x3d, + 0x69, 0x0e, 0xf7, 0x98, 0x5f, 0x6b, 0xc3, 0x02, 0x03, 0x01, 0x00, 0x01, + 0x02, 0x81, 0x81, 0x00, 0x87, 0x4b, 0xf0, 0xff, 0xc2, 0xf2, 0xa7, 0x1d, + 0x14, 0x67, 0x1d, 0xdd, 0x01, 0x71, 0xc9, 0x54, 0xd7, 0xfd, 0xbf, 0x50, + 0x28, 0x1e, 0x4f, 0x6d, 0x99, 0xea, 0x0e, 0x1e, 0xbc, 0xf8, 0x2f, 0xaa, + 0x58, 0xe7, 0xb5, 0x95, 0xff, 0xb2, 0x93, 0xd1, 0xab, 0xe1, 0x7f, 0x11, + 0x0b, 0x37, 0xc4, 0x8c, 0xc0, 0xf3, 0x6c, 0x37, 0xe8, 0x4d, 0x87, 0x66, + 0x21, 0xd3, 0x27, 0xf6, 0x4b, 0xbe, 0x08, 0x45, 0x7d, 0x3e, 0xc4, 0x09, + 0x8b, 0xa2, 0xfa, 0x0a, 0x31, 0x9f, 0xba, 0x41, 0x1c, 0x28, 0x41, 0xed, + 0x7b, 0xe8, 0x31, 0x96, 0xa8, 0xcd, 0xf9, 0xda, 0xa5, 0xd0, 0x06, 0x94, + 0xbc, 0x33, 0x5f, 0xc4, 0xc3, 0x22, 0x17, 0xfe, 0x04, 0x88, 0xbc, 0xe9, + 0xcb, 0x72, 0x02, 0xe5, 0x94, 0x68, 0xb1, 0xea, 0xd1, 0x19, 0x00, 0x04, + 0x77, 0xdb, 0x2c, 0xa7, 0x97, 0xfa, 0xc1, 0x9e, 0xda, 0x3f, 0x58, 0xc1, + 0x02, 0x41, 0x00, 0xe2, 0xab, 0x76, 0x08, 0x41, 0xbb, 0x9d, 0x30, 0xa8, + 0x1d, 0x22, 0x2d, 0xe1, 0xeb, 0x73, 0x81, 0xd8, 0x22, 0x14, 0x40, 0x7f, + 0x1b, 0x97, 0x5c, 0xbb, 0xfe, 0x4e, 0x1a, 0x94, 0x67, 0xfd, 0x98, 0xad, + 0xbd, 0x78, 0xf6, 0x07, 0x83, 0x6c, 0xa5, 0xbe, 0x19, 0x28, 0xb9, 0xd1, + 0x60, 0xd9, 0x7f, 0xd4, 0x5c, 0x12, 0xd6, 0xb5, 0x2e, 0x2c, 0x98, 0x71, + 0xa1, 0x74, 0xc6, 0x6b, 0x48, 0x81, 0x13, 0x02, 0x41, 0x00, 0xc5, 0xab, + 0x27, 0x60, 0x21, 0x59, 0xae, 0x7d, 0x6f, 0x20, 0xc3, 0xc2, 0xee, 0x85, + 0x1e, 0x46, 0xdc, 0x11, 0x2e, 0x68, 0x9e, 0x28, 0xd5, 0xfc, 0xbb, 0xf9, + 0x90, 0xa9, 0x9e, 0xf8, 0xa9, 0x0b, 0x8b, 0xb4, 0x4f, 0xd3, 0x64, 0x67, + 0xe7, 0xfc, 0x17, 0x89, 0xce, 0xb6, 0x63, 0xab, 0xda, 0x33, 0x86, 0x52, + 0xc3, 0xc7, 0x3f, 0x11, 0x17, 0x74, 0x90, 0x2e, 0x84, 0x05, 0x65, 0x92, + 0x70, 0x91, 0x02, 0x41, 0x00, 0xb6, 0xcd, 0xbd, 0x35, 0x4f, 0x7d, 0xf5, + 0x79, 0xa6, 0x3b, 0x48, 0xb3, 0x64, 0x3e, 0x35, 0x3b, 0x84, 0x89, 0x87, + 0x77, 0xb4, 0x8b, 0x15, 0xf9, 0x4e, 0x0b, 0xfc, 0x05, 0x67, 0xa6, 0xae, + 0x59, 0x11, 0xd5, 0x7a, 0xd6, 0x40, 0x9c, 0xf7, 0x64, 0x7b, 0xf9, 0x62, + 0x64, 0xe9, 0xbd, 0x87, 0xeb, 0x95, 0xe2, 0x63, 0xb7, 0x11, 0x0b, 0x9a, + 0x1f, 0x9f, 0x94, 0xac, 0xce, 0xd0, 0xfa, 0xfa, 0x4d, 0x02, 0x40, 0x71, + 0x19, 0x5e, 0xec, 0x37, 0xe8, 0xd2, 0x57, 0xde, 0xcf, 0xc6, 0x72, 0xb0, + 0x7a, 0xe6, 0x39, 0xf1, 0x0c, 0xbb, 0x9b, 0x0c, 0x73, 0x9d, 0x0c, 0x80, + 0x99, 0x68, 0xd6, 0x44, 0xa9, 0x4e, 0x3f, 0xd6, 0xed, 0x92, 0x87, 0x07, + 0x7a, 0x14, 0x58, 0x3f, 0x37, 0x90, 0x58, 0xf7, 0x6a, 0x8a, 0xec, 0xd4, + 0x3c, 0x62, 0xdc, 0x8c, 0x0f, 0x41, 0x76, 0x66, 0x50, 0xd7, 0x25, 0x27, + 0x5a, 0xc4, 0xa1, 0x02, 0x41, 0x00, 0xbb, 0x32, 0xd1, 0x33, 0xed, 0xc2, + 0xe0, 0x48, 0xd4, 0x63, 0x38, 0x8b, 0x7b, 0xe9, 0xcb, 0x4b, 0xe2, 0x9f, + 0x4b, 0x62, 0x50, 0xbe, 0x60, 0x3e, 0x70, 0xe3, 0x64, 0x75, 0x01, 0xc9, + 0x7d, 0xdd, 0xe2, 0x0a, 0x4e, 0x71, 0xbe, 0x95, 0xfd, 0x5e, 0x71, 0x78, + 0x4e, 0x25, 0xac, 0xa4, 0xba, 0xf2, 0x5b, 0xe5, 0x73, 0x8a, 0xae, 0x59, + 0xbb, 0xfe, 0x1c, 0x99, 0x77, 0x81, 0x44, 0x7a, 0x2b, 0x24, }; const unsigned char test_rsa_1026[] = { - 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x02, 0xae, - 0x9a, 0x65, 0x51, 0x54, 0x10, 0x29, 0xa3, 0x7a, 0x5f, 0xa3, 0x1b, 0x9d, - 0xf3, 0x0e, 0x24, 0xdb, 0x1f, 0xd8, 0x4e, 0x12, 0x43, 0x49, 0x00, 0x31, - 0xf8, 0x03, 0x88, 0x04, 0x87, 0x8f, 0xc9, 0x95, 0x66, 0x34, 0xb3, 0xcf, - 0x0a, 0xf1, 0x2e, 0x47, 0xd3, 0x8c, 0x3b, 0x41, 0xff, 0x32, 0x60, 0xd8, - 0x17, 0x7e, 0xad, 0x83, 0x4c, 0x37, 0x6d, 0x6b, 0xc5, 0x49, 0x6f, 0x36, - 0x84, 0xb8, 0x59, 0xa5, 0x5a, 0x03, 0xbf, 0xd7, 0xbe, 0xca, 0x9c, 0x09, - 0x1c, 0xf5, 0x20, 0xd3, 0x3a, 0x0e, 0x2f, 0xd3, 0x08, 0xa3, 0x9a, 0x65, - 0x54, 0x26, 0xa6, 0x78, 0x35, 0x7a, 0xd9, 0x70, 0x0d, 0x4d, 0xb9, 0xf7, - 0x76, 0xfd, 0x6e, 0xf5, 0xe4, 0x00, 0xe6, 0xcb, 0x60, 0xec, 0xc6, 0x38, - 0x24, 0x9e, 0x9b, 0xe6, 0x69, 0x81, 0xe0, 0xc3, 0xc9, 0x10, 0xef, 0x73, - 0xe4, 0x22, 0x52, 0x3d, 0x8c, 0x16, 0xc3, 0x02, 0x03, 0x01, 0x00, 0x01, - 0x02, 0x81, 0x80, 0x54, 0x28, 0x86, 0x9c, 0xb6, 0x62, 0x18, 0xc8, 0x79, - 0xfa, 0x79, 0x02, 0xac, 0x94, 0x9b, 0x3a, 0x37, 0x45, 0xaa, 0xfc, 0xbe, - 0xce, 0x52, 0x87, 0x5c, 0x98, 0x9a, 0xce, 0x34, 0x47, 0xed, 0x7e, 0xf6, - 0xfa, 0x05, 0x21, 0xb9, 0x12, 0x0d, 0x47, 0xef, 0xf3, 0xe5, 0x2f, 0x6a, - 0x42, 0x7e, 0x89, 0x52, 0x53, 0x66, 0xea, 0x9b, 0xba, 0x5e, 0xdc, 0xe1, - 0xa5, 0xd7, 0xff, 0x72, 0xbe, 0x47, 0xde, 0x06, 0x0b, 0x48, 0xf9, 0xf4, - 0xb7, 0xa8, 0x06, 0x76, 0xfd, 0xd2, 0x4c, 0xbf, 0xe4, 0x4a, 0x1c, 0x7f, - 0xf8, 0x71, 0xc6, 0x9f, 0x80, 0xfa, 0x97, 0xca, 0xc3, 0xf6, 0x70, 0xe3, - 0x5e, 0x8c, 0x2d, 0x02, 0xe0, 0x3a, 0x91, 0xbd, 0xa2, 0x12, 0xa4, 0xa5, - 0x7c, 0x9d, 0x6a, 0xdd, 0x00, 0xfe, 0x28, 0x60, 0xbf, 0x7e, 0x5f, 0x4f, - 0xb3, 0xf5, 0xd2, 0x0f, 0x8c, 0x69, 0x0b, 0xf0, 0x2c, 0x60, 0x81, 0x02, - 0x41, 0x01, 0xc4, 0x95, 0xb4, 0x0c, 0xf6, 0xfe, 0x28, 0xe5, 0xdc, 0x63, - 0xeb, 0x33, 0x06, 0xc1, 0xe6, 0x34, 0xa9, 0x68, 0x73, 0x2d, 0xff, 0x72, - 0x3c, 0xde, 0x74, 0xf7, 0xbb, 0x79, 0xde, 0x85, 0x20, 0x55, 0xa4, 0xe4, - 0x8b, 0x94, 0x82, 0x5b, 0x63, 0xe0, 0xdc, 0xba, 0x3d, 0x95, 0x43, 0x86, - 0xe6, 0xfd, 0x9b, 0x13, 0x75, 0xf7, 0xd2, 0xf1, 0xf5, 0x99, 0xd5, 0x9c, - 0xdf, 0x38, 0x93, 0xdc, 0x4e, 0x03, 0x02, 0x41, 0x01, 0x84, 0x5e, 0xbe, - 0xe1, 0x62, 0x47, 0x50, 0xfc, 0x17, 0xff, 0xc7, 0x15, 0x16, 0x25, 0xef, - 0x6b, 0xd0, 0xb6, 0xdb, 0x13, 0xcb, 0x65, 0x7e, 0xce, 0x4f, 0xab, 0x76, - 0xe0, 0x8b, 0xe8, 0xc0, 0xe4, 0xc0, 0x49, 0xac, 0xb7, 0x2a, 0x97, 0xad, - 0xaa, 0xe1, 0x31, 0xba, 0xd7, 0x02, 0x52, 0xfa, 0xfa, 0x03, 0xd3, 0xc3, - 0x9b, 0x3e, 0x2d, 0x32, 0xea, 0x9f, 0xb2, 0x8b, 0x66, 0x1b, 0xc4, 0x18, - 0x41, 0x02, 0x41, 0x01, 0xa3, 0x23, 0xd9, 0x69, 0xa0, 0x5c, 0xe5, 0x57, - 0x6b, 0x72, 0x05, 0xe2, 0x6d, 0xc1, 0xa9, 0x06, 0xe0, 0x55, 0x61, 0x46, - 0x1a, 0x2a, 0x9c, 0x00, 0x91, 0x66, 0xd4, 0x73, 0x1b, 0x07, 0x43, 0x58, - 0xcd, 0xaa, 0xf3, 0x31, 0x88, 0x40, 0x47, 0x11, 0x7a, 0x99, 0xe8, 0x6a, - 0x91, 0xed, 0x1f, 0x83, 0x82, 0xd8, 0xd5, 0x09, 0xbc, 0x8c, 0x64, 0x9e, - 0x21, 0x5c, 0x74, 0xc6, 0x1a, 0xf9, 0x8e, 0x2d, 0x02, 0x41, 0x00, 0xd1, - 0x4f, 0xa2, 0xfe, 0xa3, 0xd2, 0x1d, 0xe2, 0x90, 0x28, 0xa9, 0x2a, 0x43, - 0x32, 0x94, 0xd3, 0xfd, 0xbb, 0xdf, 0x5c, 0xce, 0xbd, 0x57, 0xd7, 0x67, - 0x76, 0xd8, 0xed, 0xf2, 0x59, 0xb2, 0x44, 0x57, 0x22, 0x1d, 0xf4, 0xe5, - 0xfe, 0xb3, 0x79, 0xaa, 0x3e, 0xfc, 0x1c, 0xcf, 0x42, 0xdb, 0xc3, 0x0d, - 0x76, 0xff, 0x30, 0x57, 0x15, 0x53, 0x20, 0xc2, 0x8b, 0x1e, 0xb8, 0x1c, - 0x74, 0xd6, 0x41, 0x02, 0x41, 0x00, 0x94, 0x24, 0x23, 0x0b, 0x45, 0x3a, - 0xef, 0xf3, 0x41, 0x19, 0x11, 0xba, 0xf6, 0xca, 0xab, 0x72, 0x9e, 0xc0, - 0xa4, 0xc2, 0x9e, 0x52, 0xf8, 0x36, 0xf4, 0xe8, 0xed, 0x5d, 0xa7, 0x5f, - 0x68, 0x46, 0xf4, 0x91, 0x17, 0x9c, 0xe8, 0x1b, 0x31, 0x50, 0xd7, 0x42, - 0x25, 0xc5, 0x67, 0x6a, 0xf8, 0xc2, 0x1f, 0x28, 0xe3, 0xdc, 0x52, 0x79, - 0x7b, 0xf6, 0x68, 0xdc, 0x60, 0xc6, 0xdc, 0xcc, 0xcd, 0x1d, + 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x02, 0xd0, + 0x96, 0x61, 0xfc, 0x74, 0x22, 0x4b, 0xa7, 0xbe, 0x79, 0x07, 0xab, 0xef, + 0x4f, 0x5e, 0x8b, 0xcc, 0x26, 0x4a, 0x80, 0x2c, 0x97, 0x8f, 0x7e, 0xaa, + 0x58, 0x55, 0xad, 0xa0, 0x54, 0x36, 0xd7, 0x5d, 0xb7, 0x68, 0xd2, 0x0f, + 0x68, 0x59, 0x5d, 0xbc, 0xc3, 0xd7, 0x25, 0xb1, 0x38, 0xe8, 0x0b, 0x24, + 0x7e, 0x44, 0xa4, 0x16, 0x3a, 0x05, 0x42, 0xfa, 0xb6, 0x12, 0xac, 0xbb, + 0xde, 0x45, 0xf2, 0xe9, 0x38, 0x94, 0xaa, 0x25, 0x3b, 0xdd, 0xef, 0x6a, + 0x7b, 0xec, 0xdc, 0x9c, 0xc2, 0x9a, 0x99, 0xba, 0xcf, 0x48, 0xdc, 0x6e, + 0x38, 0xdb, 0x7a, 0x33, 0xe9, 0xac, 0x92, 0x4c, 0x52, 0x0f, 0xc6, 0xbe, + 0x7d, 0x6e, 0x56, 0x46, 0xc1, 0xd6, 0x7f, 0xb8, 0xb2, 0xb9, 0x7a, 0xc6, + 0x0b, 0xee, 0xcc, 0x3b, 0xb8, 0xe7, 0x5b, 0xed, 0x83, 0x15, 0xaa, 0x3f, + 0xe4, 0x6f, 0x74, 0x8a, 0x66, 0xd6, 0xef, 0x02, 0x03, 0x01, 0x00, 0x01, + 0x02, 0x81, 0x80, 0x6a, 0x4a, 0x34, 0x6b, 0xeb, 0xa9, 0x7f, 0x65, 0x5f, + 0xe8, 0x34, 0x64, 0x7d, 0x29, 0x44, 0xf5, 0xf4, 0x08, 0x15, 0xe7, 0x30, + 0x2c, 0xaf, 0x02, 0xed, 0x17, 0x98, 0x93, 0xc2, 0xd9, 0x89, 0x39, 0x5d, + 0x5e, 0x87, 0x7c, 0xac, 0xbf, 0x24, 0xa7, 0x7a, 0x07, 0x9d, 0x3d, 0xb7, + 0x15, 0x80, 0xcc, 0xdb, 0xf6, 0x30, 0x23, 0xd0, 0x0f, 0x80, 0xe5, 0x2f, + 0x5c, 0x1a, 0x07, 0x16, 0xb3, 0x23, 0xb7, 0xbf, 0xcb, 0xdc, 0x8a, 0x17, + 0x81, 0xc4, 0x4c, 0x41, 0x53, 0xe3, 0xda, 0x22, 0x8d, 0x17, 0xb2, 0xdc, + 0x78, 0xeb, 0x1f, 0x44, 0xcf, 0xf6, 0x0f, 0xe1, 0x15, 0x08, 0x08, 0xa6, + 0xe3, 0x8b, 0xa2, 0x47, 0x0a, 0xee, 0x2e, 0x94, 0x8a, 0x68, 0x98, 0xdd, + 0xad, 0xea, 0x56, 0xd9, 0x47, 0x09, 0x27, 0xac, 0xa8, 0xd9, 0x4a, 0x03, + 0x38, 0xc1, 0x1a, 0x8e, 0x95, 0x71, 0x5b, 0x5f, 0x94, 0xe0, 0x11, 0x02, + 0x41, 0x01, 0xf5, 0x41, 0x85, 0x34, 0xc3, 0x62, 0x36, 0xfc, 0x9f, 0xd3, + 0x89, 0x34, 0xd7, 0xc0, 0x6d, 0xfe, 0xd3, 0x82, 0x91, 0x51, 0xcc, 0xab, + 0x56, 0xb6, 0x33, 0x0c, 0x64, 0x1f, 0x77, 0x96, 0xa7, 0x19, 0x24, 0xcf, + 0x81, 0x19, 0xca, 0x26, 0xe1, 0x86, 0xec, 0xd3, 0x06, 0x8d, 0x66, 0x07, + 0xa0, 0x52, 0x60, 0xdb, 0x48, 0x57, 0x65, 0x19, 0x80, 0x43, 0x68, 0x91, + 0xad, 0xde, 0x9e, 0xb9, 0x2a, 0xb7, 0x02, 0x41, 0x01, 0x70, 0x04, 0x2f, + 0xbd, 0xba, 0xba, 0x1e, 0x10, 0x2b, 0x7f, 0x7f, 0x1d, 0xc9, 0xd9, 0x40, + 0xcf, 0xdc, 0xd8, 0x5d, 0xd0, 0xea, 0x65, 0xf5, 0x43, 0xc6, 0x43, 0x2e, + 0x9c, 0x54, 0x80, 0x72, 0x4b, 0xb4, 0x9b, 0x1e, 0x5f, 0x80, 0xca, 0x2b, + 0x9f, 0x84, 0xcd, 0x66, 0x44, 0xbf, 0xb2, 0xe3, 0xd0, 0x96, 0x80, 0x90, + 0xb8, 0x9f, 0x53, 0x4d, 0xc2, 0x95, 0x1e, 0x60, 0x6d, 0xb9, 0x09, 0xdd, + 0x89, 0x02, 0x41, 0x01, 0x4b, 0x6c, 0x1a, 0xeb, 0x1c, 0x14, 0xa0, 0x4e, + 0xc0, 0x4e, 0x59, 0x75, 0xfb, 0x01, 0x5c, 0xb9, 0x14, 0x98, 0x4c, 0x05, + 0x4d, 0xd2, 0x2b, 0xef, 0x24, 0x29, 0x99, 0x39, 0xc5, 0x14, 0x73, 0x3f, + 0x88, 0xbb, 0x3a, 0x9d, 0x16, 0xb0, 0x46, 0x85, 0xb3, 0xa8, 0x83, 0xb8, + 0x92, 0x31, 0x90, 0xab, 0x67, 0x27, 0x15, 0xd9, 0xd3, 0x1a, 0xdd, 0x57, + 0xb4, 0x98, 0x3d, 0xe1, 0xe8, 0x08, 0x7e, 0x59, 0x02, 0x41, 0x01, 0x17, + 0xbf, 0x76, 0xf3, 0x08, 0xb0, 0x56, 0x0e, 0x00, 0xa2, 0xc8, 0x64, 0x42, + 0x7d, 0xcd, 0x50, 0xb5, 0x16, 0x1c, 0x2a, 0xa5, 0x23, 0xa0, 0x0f, 0x46, + 0xf4, 0xe6, 0xc7, 0x9b, 0x4c, 0x90, 0x95, 0x8f, 0xd2, 0xa2, 0x82, 0x02, + 0x8a, 0xac, 0x22, 0x74, 0x77, 0x16, 0x98, 0x88, 0x08, 0x5a, 0x38, 0xc3, + 0x4f, 0x33, 0xb3, 0xc4, 0x19, 0x34, 0xf1, 0x07, 0x1d, 0xb2, 0x3b, 0x75, + 0xff, 0x53, 0xd1, 0x02, 0x41, 0x01, 0x20, 0xa4, 0x28, 0xb4, 0xe0, 0xc4, + 0xa6, 0xf2, 0x02, 0x92, 0x0f, 0xd4, 0x9c, 0xc9, 0x88, 0x6e, 0x6b, 0x67, + 0x19, 0xd4, 0x0a, 0x3a, 0xd0, 0x60, 0x4f, 0x5d, 0x5e, 0xfd, 0x5e, 0xf6, + 0x97, 0x3a, 0x57, 0x3a, 0xb3, 0x24, 0xf3, 0x8e, 0xcb, 0x8e, 0x66, 0x9a, + 0x69, 0x34, 0x15, 0x97, 0x08, 0x1e, 0x24, 0x0b, 0x6a, 0xe4, 0xe2, 0x71, + 0x48, 0x87, 0xdd, 0x78, 0xda, 0xda, 0xeb, 0x0b, 0x92, 0x16, }; const unsigned char test_rsa_1028[] = { - 0x30, 0x82, 0x02, 0x5f, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x0c, 0x48, - 0x52, 0xeb, 0x3d, 0x96, 0x7a, 0x6c, 0x68, 0xa7, 0x10, 0x15, 0x4b, 0xc4, - 0x8b, 0x32, 0xa8, 0xb1, 0xd5, 0xdf, 0xbf, 0xb1, 0x11, 0xfd, 0x50, 0xac, - 0xc9, 0x27, 0x99, 0xd6, 0xfe, 0x34, 0x6d, 0x0c, 0xd2, 0x2b, 0x4e, 0xc7, - 0x1b, 0xbf, 0xc2, 0x85, 0x04, 0x99, 0x50, 0x13, 0xa2, 0x60, 0x02, 0x67, - 0x94, 0xcf, 0xe7, 0x84, 0xc7, 0xb2, 0x03, 0x81, 0xb8, 0x60, 0xfa, 0xaf, - 0xc0, 0xcd, 0x30, 0xf0, 0xe6, 0xdb, 0xd0, 0x3a, 0x3d, 0x1d, 0x3c, 0x8e, - 0x0d, 0xb1, 0x86, 0xc3, 0xba, 0xa1, 0x35, 0x47, 0xae, 0x6e, 0x43, 0x23, - 0x4a, 0x61, 0xfc, 0xc5, 0x1e, 0xa6, 0xe8, 0x74, 0x38, 0x3b, 0x4c, 0x79, - 0x4a, 0x94, 0x66, 0x1a, 0x44, 0x23, 0x0a, 0x96, 0x86, 0x5d, 0xf6, 0x43, - 0x5a, 0xa7, 0x03, 0x46, 0x81, 0x9f, 0xe9, 0xf4, 0xaa, 0xa3, 0x03, 0xe1, - 0xea, 0x21, 0xf1, 0xae, 0x2d, 0x06, 0xf7, 0x02, 0x03, 0x01, 0x00, 0x01, - 0x02, 0x81, 0x81, 0x01, 0x1f, 0xa6, 0xb2, 0x4d, 0x9e, 0x94, 0x11, 0x91, - 0xdb, 0x62, 0xbd, 0xc8, 0x02, 0x31, 0x87, 0xcf, 0x66, 0x01, 0x7e, 0x68, - 0x2f, 0x7f, 0x49, 0x50, 0xd5, 0x95, 0xcb, 0x71, 0x27, 0xf9, 0x76, 0x7b, - 0x59, 0x76, 0x6a, 0xae, 0xd8, 0xc9, 0x41, 0x98, 0x3e, 0x8a, 0x06, 0xaa, - 0x8c, 0x39, 0x49, 0x16, 0x3f, 0x3a, 0x9e, 0x70, 0x7c, 0x35, 0xb6, 0xa3, - 0xda, 0x7c, 0xaf, 0x26, 0x8f, 0xe8, 0x8f, 0xfc, 0x5b, 0x7c, 0xda, 0x94, - 0x57, 0x8d, 0x03, 0x5c, 0xed, 0x66, 0xfe, 0x9c, 0x6e, 0xaa, 0xcc, 0xa1, - 0x05, 0x48, 0xc4, 0x11, 0xbc, 0xf7, 0xdf, 0xaa, 0xeb, 0x65, 0xb6, 0xaf, - 0xce, 0x45, 0x0c, 0x7f, 0x3a, 0x84, 0x0a, 0x85, 0x28, 0xf0, 0xa4, 0xd6, - 0x39, 0x9e, 0xc3, 0xc6, 0x47, 0x24, 0x6f, 0xbe, 0x20, 0x45, 0x19, 0x84, - 0x29, 0x0d, 0x12, 0x9a, 0x12, 0xc9, 0x03, 0x96, 0xf0, 0x26, 0x11, 0x49, - 0x02, 0x41, 0x03, 0x9a, 0xb4, 0xe9, 0x07, 0xe1, 0xe0, 0x69, 0xc7, 0x0c, - 0x5c, 0x71, 0x1b, 0x21, 0x31, 0x66, 0x5b, 0x5d, 0x0d, 0x3c, 0x51, 0x64, - 0xda, 0xb4, 0xfe, 0x14, 0xb1, 0x27, 0xa6, 0x97, 0x36, 0x58, 0xb2, 0xa0, - 0x17, 0xa9, 0x28, 0x33, 0x19, 0x6b, 0xee, 0x6f, 0x6c, 0x17, 0x50, 0x8c, - 0x01, 0x78, 0xfb, 0xfe, 0xed, 0xab, 0xf6, 0x71, 0xd9, 0x85, 0xc8, 0x96, - 0x63, 0x7c, 0x10, 0x3c, 0xf0, 0x54, 0x09, 0x02, 0x41, 0x03, 0x68, 0x60, - 0x30, 0x2c, 0xc9, 0xcc, 0x20, 0x7e, 0x1e, 0xd3, 0xb0, 0x04, 0x3f, 0xde, - 0xef, 0x53, 0x2f, 0x3b, 0xf6, 0x77, 0x01, 0x41, 0x41, 0xa8, 0xc1, 0x5a, - 0x21, 0x30, 0xf4, 0xdc, 0x5c, 0xeb, 0xbe, 0x75, 0x3f, 0xf2, 0x8a, 0xa0, - 0x35, 0xd2, 0xed, 0x23, 0xbc, 0xfc, 0x24, 0x53, 0xde, 0x64, 0x88, 0x72, - 0xef, 0x43, 0xbd, 0x2d, 0x0f, 0x2d, 0x71, 0xb1, 0xe2, 0xbf, 0xe9, 0xe7, - 0x42, 0xff, 0x02, 0x41, 0x03, 0x3c, 0xb3, 0x36, 0x87, 0xa9, 0xca, 0x4f, - 0xb6, 0x41, 0xd7, 0xd4, 0x8d, 0xb5, 0x26, 0x14, 0xf4, 0x01, 0x82, 0x9d, - 0xa5, 0xcc, 0x9a, 0xd0, 0xeb, 0x51, 0xd2, 0x39, 0xf6, 0x58, 0xe0, 0xaa, - 0x90, 0xe3, 0x4f, 0xdc, 0xd1, 0x09, 0xf3, 0xcf, 0x07, 0xfa, 0x72, 0x6e, - 0x0e, 0x1d, 0x70, 0x45, 0x24, 0xae, 0x34, 0xef, 0xb9, 0x0b, 0x4f, 0x7d, - 0xe4, 0x45, 0x8d, 0x5c, 0x23, 0x89, 0x57, 0x9f, 0x61, 0x02, 0x41, 0x02, - 0xa7, 0xde, 0x86, 0xcc, 0xf0, 0xfb, 0xff, 0xba, 0xaa, 0xc5, 0xa9, 0x60, - 0xb6, 0x72, 0x44, 0xab, 0xdc, 0x9c, 0xeb, 0xa8, 0xb5, 0x36, 0xa9, 0x38, - 0x1e, 0x6f, 0xe2, 0x7c, 0x27, 0xe8, 0x71, 0x16, 0x5c, 0x99, 0x3e, 0x1c, - 0x04, 0xc3, 0x75, 0x0f, 0x0c, 0x37, 0x14, 0xfa, 0xa0, 0x49, 0x28, 0x81, - 0xcb, 0x01, 0x5f, 0xcc, 0xb7, 0xeb, 0x1c, 0xef, 0xfa, 0xb2, 0x7a, 0x97, - 0xbc, 0x6f, 0xb9, 0xfb, 0x02, 0x41, 0x01, 0x60, 0x60, 0x57, 0x31, 0x7d, - 0xbe, 0xac, 0xd2, 0x64, 0xb9, 0x26, 0x52, 0x4f, 0x20, 0xda, 0xde, 0xd3, - 0x27, 0x38, 0x97, 0xea, 0xb4, 0xf4, 0xcd, 0x83, 0xfa, 0xeb, 0x51, 0x47, - 0x5b, 0x78, 0x24, 0x53, 0x17, 0xf8, 0x26, 0xee, 0xf7, 0x92, 0x25, 0x14, - 0xcd, 0xb6, 0x86, 0xe7, 0x06, 0xb3, 0xd7, 0xee, 0x8b, 0x42, 0x31, 0xb4, - 0x49, 0x95, 0x4e, 0x8c, 0x11, 0x57, 0x7f, 0x44, 0x36, 0x22, 0x64, + 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x0e, 0x62, + 0xa7, 0x6f, 0x0e, 0x0b, 0x59, 0x68, 0x3a, 0x7e, 0xbf, 0x7c, 0xbf, 0xd3, + 0x7b, 0x1d, 0x17, 0x81, 0xd8, 0xf1, 0xb9, 0x00, 0x60, 0x4b, 0x50, 0x7f, + 0x0f, 0x04, 0xc7, 0x2a, 0x3d, 0x34, 0x0d, 0x06, 0x7b, 0xcd, 0x53, 0xbe, + 0xa3, 0xca, 0xff, 0x4e, 0x4a, 0xe6, 0x94, 0xf0, 0xb6, 0xd8, 0xf5, 0x91, + 0xa4, 0x16, 0x7f, 0xbf, 0x7f, 0x37, 0x2a, 0xb5, 0x7e, 0x83, 0xa6, 0x9a, + 0x3f, 0x26, 0xf4, 0x47, 0xbc, 0xf5, 0x82, 0xbc, 0x96, 0x21, 0xa3, 0x0a, + 0x3b, 0x44, 0xd6, 0xb4, 0x3e, 0x98, 0x6d, 0x1a, 0x86, 0x7b, 0x07, 0x48, + 0x9e, 0x4f, 0x9b, 0xfc, 0xad, 0xaa, 0x82, 0xa2, 0x78, 0x2d, 0xc2, 0x72, + 0x9a, 0x63, 0x1f, 0xb1, 0xfb, 0x9f, 0xfb, 0x79, 0x4b, 0x4e, 0x53, 0xc7, + 0x62, 0x39, 0xe0, 0x4d, 0x4a, 0x8f, 0x80, 0x35, 0x25, 0x88, 0xdb, 0x29, + 0x46, 0x2d, 0xde, 0x18, 0x23, 0x7c, 0xf5, 0x02, 0x03, 0x01, 0x00, 0x01, + 0x02, 0x81, 0x81, 0x01, 0xcf, 0xa0, 0x42, 0x2e, 0x3b, 0xb6, 0x0c, 0x15, + 0xef, 0x2e, 0x96, 0xdb, 0x44, 0x99, 0xe7, 0x89, 0xf5, 0xd6, 0x34, 0xea, + 0x64, 0x56, 0x7b, 0x2c, 0xdd, 0x6e, 0x2b, 0xdd, 0x12, 0x1f, 0x85, 0xed, + 0xcc, 0xde, 0xe9, 0xb4, 0xed, 0x17, 0x8c, 0x5f, 0x33, 0x81, 0x61, 0x01, + 0xa7, 0xc3, 0x71, 0x51, 0x8b, 0x3e, 0x23, 0xf9, 0xfd, 0xc7, 0x1b, 0x90, + 0x24, 0x2c, 0xd3, 0x10, 0xb6, 0xb3, 0x14, 0x28, 0xb0, 0xb6, 0x4e, 0xb9, + 0x59, 0x6b, 0xe0, 0xcc, 0x04, 0x4c, 0xc8, 0x50, 0x48, 0x98, 0x2f, 0x90, + 0xb7, 0x06, 0xe6, 0x6c, 0xcd, 0xd3, 0x9a, 0xd5, 0xa1, 0xa7, 0xb6, 0x4c, + 0xf0, 0x34, 0xea, 0xc0, 0xc3, 0x5d, 0x7a, 0xce, 0x93, 0xf2, 0xbc, 0xd3, + 0xce, 0x24, 0x3b, 0xd8, 0xf8, 0x3b, 0x46, 0xf5, 0x09, 0xca, 0x2f, 0x80, + 0x50, 0x63, 0x00, 0x2a, 0xf2, 0xbb, 0x2d, 0x88, 0xb6, 0xee, 0x36, 0xa9, + 0x02, 0x41, 0x03, 0xf0, 0x88, 0x6d, 0x29, 0x77, 0x52, 0x6f, 0x3f, 0x3f, + 0x6a, 0x07, 0x56, 0x00, 0x23, 0x2c, 0xe3, 0x00, 0x85, 0x17, 0x27, 0x6d, + 0xd3, 0x72, 0x1d, 0xee, 0x08, 0xfd, 0x6c, 0x99, 0x9f, 0xc9, 0x76, 0xb9, + 0xe8, 0xdd, 0x2b, 0xc1, 0x43, 0x38, 0x5f, 0xa4, 0xb4, 0x87, 0x35, 0xce, + 0x81, 0xc6, 0x6b, 0x50, 0x1d, 0x71, 0x29, 0xee, 0x78, 0x60, 0xcf, 0xbe, + 0xf2, 0x3b, 0x5d, 0xa9, 0x1e, 0x6c, 0x2d, 0x02, 0x41, 0x03, 0xa6, 0xc8, + 0x73, 0x4a, 0xac, 0xe5, 0x9d, 0x5f, 0x38, 0x6f, 0x97, 0xde, 0x45, 0x0f, + 0x8a, 0x12, 0xd6, 0x3a, 0xe6, 0xac, 0x15, 0xd3, 0x36, 0xe0, 0x10, 0xc9, + 0xfc, 0xf0, 0x3a, 0x32, 0xf0, 0x61, 0x18, 0x81, 0xac, 0x6c, 0xd8, 0xb3, + 0xf9, 0x89, 0x92, 0x5c, 0x0f, 0x02, 0x5a, 0xf2, 0x6c, 0xf2, 0x6a, 0xeb, + 0xd7, 0xd9, 0xb0, 0x4e, 0xb5, 0x03, 0x04, 0x8d, 0xca, 0x2f, 0x50, 0x3c, + 0x28, 0xe9, 0x02, 0x41, 0x01, 0x9b, 0x30, 0x04, 0x51, 0xc3, 0xb4, 0x78, + 0x66, 0xf1, 0x13, 0xe9, 0xa9, 0xc6, 0xa4, 0x90, 0xc8, 0x7c, 0x8d, 0xc6, + 0xc2, 0xec, 0xa4, 0x29, 0x02, 0xca, 0xea, 0x1f, 0x69, 0x07, 0xb9, 0x7e, + 0x0a, 0x4a, 0x02, 0x07, 0x2a, 0xaf, 0xc1, 0x18, 0x5a, 0xe6, 0x6c, 0x34, + 0x34, 0x5b, 0xdd, 0xcd, 0x68, 0x33, 0x61, 0xcd, 0xa1, 0xaa, 0xf8, 0xa9, + 0x80, 0x09, 0xf9, 0xf8, 0xfa, 0x56, 0xd9, 0x70, 0x81, 0x02, 0x40, 0x1b, + 0xcc, 0xa8, 0x49, 0x17, 0x3d, 0x38, 0xe1, 0xe5, 0x0e, 0xc4, 0x88, 0x72, + 0xab, 0x54, 0xa2, 0xdc, 0xc6, 0x21, 0xa8, 0x0a, 0x7a, 0x1e, 0x8e, 0xa9, + 0x51, 0x28, 0x79, 0x88, 0x71, 0x8d, 0x5e, 0x85, 0xd9, 0x0d, 0x64, 0xab, + 0x49, 0x26, 0xe9, 0xa5, 0x75, 0xa1, 0x68, 0xa3, 0x85, 0xc4, 0x21, 0xad, + 0x76, 0x58, 0x13, 0xfc, 0x3f, 0x4a, 0xf8, 0xcd, 0x00, 0xde, 0x7b, 0x6b, + 0xba, 0x6e, 0x49, 0x02, 0x41, 0x03, 0x6d, 0xcf, 0x69, 0xf6, 0xe5, 0x48, + 0xc8, 0xac, 0xfb, 0x53, 0x6f, 0xb6, 0xcd, 0x18, 0x6f, 0x8b, 0x8f, 0x20, + 0xd3, 0x13, 0x36, 0x1d, 0x04, 0x47, 0xc1, 0xb5, 0xe3, 0x80, 0xf4, 0x11, + 0x3e, 0x57, 0x8b, 0x31, 0xe8, 0x67, 0xdd, 0xa4, 0x7d, 0x44, 0xad, 0x37, + 0x61, 0xe7, 0x93, 0xf7, 0x25, 0x03, 0x1b, 0x8d, 0x37, 0x9f, 0x38, 0x9d, + 0xe2, 0x77, 0xa9, 0xa0, 0x13, 0x76, 0x51, 0xdf, 0x54, 0x8a, }; const unsigned char test_rsa_1030[] = { - 0x30, 0x82, 0x02, 0x5f, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x29, 0x32, - 0x4b, 0xbf, 0x78, 0x5a, 0xf5, 0x4f, 0x0a, 0x61, 0xd5, 0x99, 0x29, 0xf2, - 0x3d, 0x39, 0x68, 0x3b, 0xab, 0x41, 0x30, 0x1e, 0x2c, 0x87, 0xca, 0x33, - 0xa3, 0x2f, 0x31, 0x23, 0x9a, 0xe1, 0xca, 0x5b, 0x75, 0xf0, 0xc3, 0x84, - 0x9c, 0x52, 0xe7, 0xf9, 0x67, 0xa8, 0xa6, 0x2b, 0x7c, 0x43, 0xa9, 0x5f, - 0xd7, 0x25, 0x64, 0x43, 0xa9, 0x02, 0xa7, 0x7d, 0x97, 0x24, 0x26, 0x7d, - 0x89, 0x5d, 0x20, 0x8a, 0xb8, 0x6c, 0xcc, 0xcb, 0x18, 0x65, 0x9c, 0xbe, - 0x1a, 0xd8, 0x47, 0xa2, 0xeb, 0xc2, 0xe2, 0x88, 0x26, 0x4f, 0xfc, 0x77, - 0x08, 0x6c, 0x5a, 0x82, 0x30, 0xbe, 0x84, 0xa6, 0xaa, 0x67, 0x41, 0xbd, - 0xe5, 0x1e, 0x87, 0x23, 0x33, 0xbd, 0x59, 0x6d, 0x41, 0xb5, 0x94, 0xc8, - 0xcb, 0xc3, 0xc6, 0x4d, 0xe7, 0x3e, 0x79, 0x6e, 0x9a, 0x8e, 0x54, 0xa7, - 0x1c, 0x64, 0x97, 0x69, 0xc8, 0xc2, 0xdf, 0x02, 0x03, 0x01, 0x00, 0x01, - 0x02, 0x81, 0x81, 0x05, 0x40, 0xdf, 0x5d, 0x50, 0xab, 0xc8, 0xbc, 0x86, - 0x46, 0x68, 0xf1, 0x59, 0xe2, 0xaf, 0x8c, 0x07, 0xe4, 0x14, 0x0d, 0x56, - 0xba, 0xd7, 0xa8, 0x39, 0x50, 0xd1, 0xc3, 0xcd, 0x85, 0xb7, 0x7f, 0xde, - 0x48, 0xeb, 0x86, 0xad, 0xbd, 0x80, 0xc7, 0x27, 0x18, 0x81, 0x9a, 0x30, - 0x16, 0x90, 0xdc, 0xd0, 0x01, 0xe3, 0x73, 0x11, 0x3b, 0x7a, 0x42, 0x01, - 0xb9, 0xdc, 0xf1, 0x99, 0xe1, 0x9d, 0xb2, 0xbb, 0x89, 0xc5, 0xbe, 0x87, - 0x6c, 0x5e, 0xcd, 0xc3, 0xaf, 0x18, 0x4e, 0x42, 0x69, 0xac, 0x26, 0x5b, - 0x24, 0x15, 0xdb, 0x69, 0x88, 0x6d, 0x74, 0x91, 0xe3, 0x4a, 0xb7, 0x5f, - 0x64, 0xa7, 0xdf, 0xc3, 0xff, 0x12, 0xac, 0x29, 0xc0, 0x9d, 0x8a, 0x13, - 0x56, 0xdc, 0xec, 0x8c, 0x77, 0xad, 0xa3, 0xf7, 0xcb, 0x28, 0x06, 0x90, - 0x59, 0x6e, 0x2f, 0x22, 0x14, 0xa7, 0x1a, 0xc0, 0xc0, 0x19, 0xc2, 0x81, - 0x02, 0x41, 0x06, 0xf9, 0x78, 0x16, 0xa4, 0xf4, 0xd3, 0x30, 0x26, 0xbe, - 0x99, 0xa1, 0xe1, 0x2a, 0x8d, 0x07, 0xb2, 0xf7, 0x2a, 0xfc, 0x76, 0x6a, - 0x4c, 0x2d, 0x97, 0x48, 0x70, 0x64, 0xda, 0xb4, 0x62, 0xb6, 0x3f, 0xa7, - 0x1a, 0x95, 0x78, 0xb4, 0xab, 0xfd, 0xd2, 0x84, 0xbf, 0x98, 0x22, 0xfe, - 0xbe, 0x34, 0x26, 0x1d, 0x96, 0x06, 0x20, 0x6b, 0x19, 0x31, 0xb9, 0x08, - 0x8c, 0x8e, 0x21, 0x6d, 0x19, 0xe2, 0xf3, 0x02, 0x41, 0x05, 0xe8, 0x1f, - 0xe6, 0x01, 0xed, 0x9a, 0xd4, 0xab, 0x84, 0x1e, 0xc8, 0x1f, 0xd0, 0xa2, - 0x33, 0xb1, 0x49, 0xe2, 0xac, 0x40, 0x80, 0x06, 0x04, 0x4b, 0xe3, 0x6e, - 0xd4, 0x35, 0x42, 0x45, 0x98, 0x77, 0x42, 0xb2, 0x56, 0xd9, 0x1b, 0xce, - 0x28, 0xdf, 0x96, 0xd0, 0xc1, 0x2e, 0x06, 0x5a, 0x7a, 0x62, 0x76, 0x3e, - 0xb4, 0xe7, 0xcc, 0x7e, 0xa6, 0x1d, 0xb5, 0x7a, 0x9e, 0x2f, 0x3e, 0x09, - 0x23, 0x65, 0x02, 0x41, 0x06, 0x97, 0x5d, 0x56, 0x89, 0x2e, 0x97, 0x27, - 0xba, 0x76, 0x06, 0xdb, 0x65, 0xe0, 0xc0, 0xc7, 0xb5, 0xea, 0xc1, 0x45, - 0x36, 0xe3, 0xde, 0x7a, 0x77, 0xae, 0x8e, 0x09, 0xc2, 0x67, 0x17, 0xa3, - 0x05, 0x24, 0xf7, 0x8a, 0xab, 0x38, 0x94, 0x12, 0x9d, 0x11, 0xb7, 0xc0, - 0x1f, 0xd2, 0x80, 0x0e, 0xe8, 0xb6, 0xad, 0x41, 0xbd, 0x01, 0x7a, 0x1d, - 0xf3, 0xb0, 0x90, 0xa5, 0x02, 0x12, 0x09, 0x94, 0xe1, 0x02, 0x41, 0x04, - 0xdc, 0x69, 0x13, 0xf2, 0xd6, 0x45, 0xab, 0x6b, 0x93, 0x89, 0x79, 0x8c, - 0xa5, 0x38, 0x37, 0x6e, 0x59, 0xad, 0xcf, 0xb0, 0x2d, 0x2b, 0xc6, 0x71, - 0x65, 0xb4, 0x19, 0xb3, 0xd2, 0xdc, 0x4f, 0x83, 0x26, 0x42, 0x7a, 0x32, - 0xa6, 0x2d, 0x5d, 0x79, 0xd4, 0x35, 0xec, 0x25, 0x22, 0x59, 0x67, 0x8a, - 0x8c, 0x61, 0x42, 0xa3, 0xd8, 0xa9, 0x09, 0xb0, 0x3d, 0x5f, 0xb1, 0xba, - 0x93, 0x45, 0x15, 0xf9, 0x02, 0x41, 0x06, 0x5e, 0x0f, 0x28, 0x69, 0x63, - 0x78, 0xfa, 0x87, 0xbf, 0x45, 0x62, 0x02, 0xca, 0x84, 0x34, 0xea, 0x1b, - 0x30, 0xb2, 0x3b, 0x04, 0xb3, 0x1c, 0xb4, 0x61, 0xfd, 0x9f, 0xba, 0xb5, - 0xdb, 0x88, 0x65, 0x6b, 0x4c, 0x36, 0xc5, 0x6c, 0x2d, 0x9a, 0xce, 0x06, - 0x8d, 0x4c, 0xc2, 0x64, 0x48, 0x74, 0x4e, 0x6e, 0xb6, 0x09, 0xa8, 0x18, - 0x25, 0xce, 0x86, 0x27, 0x61, 0x02, 0x16, 0x32, 0xe2, 0xae, 0x41, + 0x30, 0x82, 0x02, 0x5f, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81, 0x2b, 0x7c, + 0xd1, 0x97, 0xf5, 0x79, 0x6d, 0x1f, 0x8e, 0x57, 0x6b, 0x2b, 0x37, 0x72, + 0x3f, 0xd9, 0x21, 0x08, 0x14, 0xef, 0x1c, 0x19, 0x95, 0xf9, 0x89, 0x9d, + 0x50, 0x05, 0x8f, 0x37, 0x9d, 0x23, 0x9c, 0x66, 0x87, 0x8e, 0x92, 0x2f, + 0x34, 0xc6, 0xae, 0x36, 0x72, 0xc8, 0x59, 0x8f, 0xcd, 0x5d, 0x47, 0xb7, + 0x64, 0xd2, 0xec, 0x15, 0x6e, 0x13, 0x4d, 0x03, 0xcf, 0x6a, 0x94, 0xd3, + 0x8d, 0x2e, 0xa8, 0xbc, 0x76, 0xdb, 0xbc, 0x60, 0xc4, 0xb9, 0x74, 0x21, + 0x90, 0x90, 0xea, 0xf2, 0x87, 0x49, 0x7d, 0x7d, 0xcf, 0x7f, 0x11, 0x9c, + 0xfa, 0x86, 0x74, 0x96, 0xf7, 0xe9, 0x1c, 0x12, 0xb5, 0xd5, 0x52, 0xe1, + 0xd1, 0x46, 0x1a, 0x80, 0xdb, 0xe9, 0xa5, 0x9d, 0xb3, 0xb0, 0x16, 0xc6, + 0xc0, 0x14, 0x1c, 0x3b, 0x2a, 0x0e, 0x22, 0x60, 0x89, 0xb8, 0x55, 0xcb, + 0x88, 0xef, 0x65, 0x64, 0x08, 0xbd, 0x89, 0x02, 0x03, 0x01, 0x00, 0x01, + 0x02, 0x81, 0x81, 0x02, 0x10, 0xd5, 0xff, 0x53, 0x1c, 0xac, 0xb2, 0x2f, + 0x8c, 0xf7, 0xdd, 0x1f, 0xd9, 0xfb, 0x03, 0x76, 0xf3, 0x64, 0x7f, 0x2e, + 0x9a, 0xb3, 0xdf, 0x9c, 0x89, 0xb9, 0xad, 0x3c, 0x98, 0xe6, 0x8b, 0x89, + 0xad, 0xeb, 0x29, 0x90, 0x1d, 0xd2, 0xf2, 0xcf, 0x2a, 0xc1, 0xf8, 0x17, + 0x72, 0x62, 0x78, 0x83, 0x0e, 0xc8, 0xa8, 0xd0, 0xfd, 0xd1, 0x9d, 0x49, + 0x6e, 0xc6, 0xbc, 0x68, 0x36, 0x71, 0x17, 0x47, 0x86, 0xb7, 0xd6, 0xa8, + 0xe8, 0x22, 0xfa, 0x71, 0xd6, 0x5a, 0xd3, 0x5a, 0xbb, 0xdf, 0x0e, 0x6e, + 0x55, 0xff, 0x2c, 0x18, 0x21, 0xb6, 0x2b, 0xc6, 0x30, 0x19, 0x21, 0x60, + 0xe5, 0xc9, 0xb3, 0xdc, 0xaf, 0xc6, 0x5a, 0xe6, 0xb2, 0xa0, 0x88, 0xfb, + 0xc5, 0x59, 0x1d, 0xa5, 0x8a, 0x45, 0xdd, 0x7a, 0x30, 0x96, 0x0f, 0x7d, + 0x3d, 0xef, 0x75, 0xb8, 0x0c, 0xdf, 0x73, 0x24, 0x73, 0x60, 0xe8, 0xfb, + 0x02, 0x41, 0x07, 0x2e, 0x37, 0x1a, 0x3b, 0xa8, 0x61, 0xe7, 0x8e, 0x3e, + 0xb9, 0x31, 0x30, 0x65, 0xfa, 0xab, 0x0a, 0x97, 0x21, 0x6e, 0x95, 0x44, + 0xbf, 0xc2, 0xd5, 0xb4, 0x03, 0x84, 0x4b, 0x43, 0x27, 0x37, 0x05, 0x75, + 0x5a, 0x85, 0xaa, 0x0b, 0xaf, 0x71, 0x14, 0x77, 0x0c, 0xfe, 0xca, 0x20, + 0xbc, 0xa1, 0x7a, 0xc1, 0x9b, 0xc4, 0xcb, 0xba, 0x10, 0x6a, 0x33, 0xb3, + 0xdd, 0xdc, 0xa0, 0xfb, 0x53, 0x5f, 0x33, 0x02, 0x41, 0x06, 0x0e, 0x6a, + 0xf3, 0x7a, 0xb4, 0xea, 0x11, 0xf5, 0x2b, 0x93, 0x44, 0xe7, 0x16, 0x0e, + 0xb2, 0xa5, 0x3f, 0x10, 0x75, 0xe1, 0x22, 0x9a, 0x7f, 0x10, 0xa3, 0x01, + 0xde, 0x33, 0x59, 0xf5, 0x3e, 0x98, 0x1e, 0xa0, 0xe1, 0x7d, 0xf0, 0xfb, + 0x38, 0x0f, 0x08, 0x9e, 0x5c, 0x37, 0xdd, 0x40, 0xda, 0xa2, 0x9e, 0xef, + 0xd2, 0x05, 0xf5, 0xc8, 0x7b, 0x38, 0xf8, 0xfe, 0xf6, 0x36, 0xb5, 0x7b, + 0xa0, 0x53, 0x02, 0x41, 0x02, 0x3a, 0x5d, 0xd0, 0x9e, 0xf8, 0x35, 0x40, + 0xb3, 0x0b, 0x55, 0x4d, 0x24, 0xf6, 0x4f, 0x9c, 0x28, 0xd2, 0x12, 0x06, + 0x8c, 0xfc, 0x62, 0xff, 0xe2, 0x6d, 0x53, 0xb6, 0x05, 0xe0, 0x55, 0x57, + 0xa6, 0x32, 0xee, 0x9e, 0x90, 0xcf, 0xc5, 0x65, 0x31, 0xf3, 0x6a, 0xad, + 0xd8, 0x2b, 0xe6, 0x3b, 0xb8, 0xaa, 0x40, 0x5a, 0x04, 0xd8, 0xbb, 0xe5, + 0x28, 0x1b, 0xc4, 0x58, 0x83, 0xfe, 0xd7, 0xb4, 0xaf, 0x02, 0x41, 0x04, + 0x1d, 0xe6, 0xdb, 0xad, 0x4c, 0xaf, 0x54, 0x17, 0xa9, 0x50, 0x49, 0x65, + 0x20, 0x1c, 0x4b, 0x99, 0x82, 0x7d, 0xe8, 0xf3, 0x69, 0xf7, 0x45, 0x6a, + 0x84, 0xb3, 0xef, 0x5c, 0x4e, 0xc9, 0x23, 0x8c, 0x7a, 0x3d, 0x78, 0x2a, + 0x89, 0x15, 0xeb, 0xec, 0x64, 0x3a, 0x69, 0x8b, 0x5b, 0xee, 0x0a, 0xf0, + 0xc2, 0x43, 0x59, 0x2b, 0xce, 0x00, 0x42, 0xaa, 0xde, 0xaf, 0x49, 0xa4, + 0xb4, 0xc6, 0xdd, 0x9b, 0x02, 0x41, 0x05, 0xd3, 0x2d, 0xee, 0x95, 0x2b, + 0x50, 0x3b, 0x53, 0x6f, 0xce, 0xcf, 0x19, 0xec, 0x08, 0x23, 0x6a, 0x9c, + 0xd9, 0x45, 0xc4, 0x95, 0x51, 0xbf, 0x99, 0xf1, 0x5b, 0x67, 0x4f, 0xc2, + 0x1a, 0xa1, 0x99, 0xf4, 0xc4, 0x21, 0x1f, 0x0f, 0x00, 0x07, 0xc4, 0x17, + 0xc1, 0xfb, 0x41, 0x55, 0x32, 0x6a, 0x21, 0x42, 0xfc, 0xa4, 0x54, 0xbb, + 0xd3, 0x8d, 0x6d, 0xbc, 0x6c, 0xaa, 0x7a, 0xc3, 0x35, 0xa1, 0x7c, }; const unsigned char test_rsa_2048[] = { - 0x30, 0x82, 0x04, 0xa4, 0x02, 0x01, 0x00, 0x02, 0x82, 0x01, 0x01, 0x00, - 0xd3, 0x67, 0x70, 0x8d, 0x0a, 0x25, 0x6c, 0x81, 0xb1, 0x25, 0xae, 0xf9, - 0xcb, 0x57, 0x0f, 0xb5, 0xb1, 0x14, 0xa3, 0xc7, 0x91, 0xfd, 0xee, 0x13, - 0x63, 0x96, 0xd5, 0x56, 0x17, 0x2b, 0xa1, 0xea, 0xf1, 0x25, 0x29, 0xb1, - 0xac, 0x7f, 0x56, 0xcb, 0xdc, 0x6d, 0x1b, 0x21, 0x2b, 0x4d, 0xee, 0x0d, - 0xd0, 0xff, 0x3b, 0xdc, 0x5d, 0x08, 0x37, 0x5e, 0xf0, 0x33, 0x84, 0x11, - 0x0e, 0x0d, 0xe9, 0x3a, 0xda, 0x65, 0xfa, 0xd6, 0xd7, 0x22, 0x4a, 0x6e, - 0xa8, 0xf7, 0x49, 0x4b, 0x6f, 0xbe, 0xc2, 0x2f, 0xb8, 0xa0, 0x86, 0xdc, - 0x7a, 0xe6, 0xcf, 0x9b, 0x9e, 0x9a, 0xa3, 0xbd, 0x25, 0x29, 0x38, 0x17, - 0x60, 0x31, 0x81, 0x84, 0x3b, 0xbb, 0x6d, 0xa6, 0x62, 0xf8, 0xee, 0x8f, - 0x27, 0xd3, 0x26, 0x29, 0xb8, 0xc0, 0xef, 0x84, 0x18, 0x5a, 0xaa, 0x5a, - 0x35, 0x80, 0x9a, 0x78, 0x8c, 0x3a, 0x45, 0x32, 0xd0, 0x67, 0xcf, 0x0c, - 0x02, 0xdb, 0x26, 0x15, 0x66, 0x97, 0x78, 0x68, 0xe1, 0x28, 0x7c, 0x15, - 0xb5, 0xe9, 0x73, 0x38, 0xf3, 0x5c, 0x9f, 0xcc, 0xf7, 0x5b, 0x76, 0xef, - 0x77, 0xa0, 0xbf, 0xd2, 0x1c, 0x06, 0x91, 0xd2, 0xaf, 0x1d, 0xa2, 0x1f, - 0x27, 0xd4, 0xd9, 0x8d, 0x59, 0x13, 0x7e, 0xed, 0xe3, 0x04, 0x50, 0xb9, - 0xb2, 0x53, 0x90, 0x8b, 0xaa, 0x73, 0xc1, 0x1e, 0x5e, 0x7b, 0x76, 0x3a, - 0x3e, 0x5c, 0xf4, 0x5e, 0xbb, 0xc4, 0xb8, 0x41, 0xb5, 0x22, 0x79, 0x42, - 0x76, 0x6b, 0x04, 0xee, 0x70, 0x6e, 0x6d, 0xfd, 0x1a, 0x34, 0x96, 0x9b, - 0xc4, 0x8f, 0x19, 0xd1, 0xc3, 0xcd, 0x9e, 0x57, 0xfd, 0x08, 0x83, 0xbb, - 0xe1, 0x9f, 0x76, 0xa7, 0x17, 0xa6, 0x3c, 0x74, 0x63, 0x90, 0x4c, 0x77, - 0xb8, 0x7f, 0xa0, 0x50, 0xbc, 0x3c, 0xfe, 0x51, 0x6e, 0xd0, 0x3d, 0x39, - 0x0e, 0xe4, 0x07, 0x3f, 0x02, 0x03, 0x01, 0x00, 0x01, 0x02, 0x82, 0x01, - 0x00, 0x13, 0x5c, 0x5b, 0xd0, 0x6e, 0xe7, 0x72, 0x82, 0x86, 0x28, 0xbf, - 0x57, 0x9d, 0x29, 0xc2, 0x04, 0x8f, 0xcd, 0x26, 0x1a, 0xb6, 0xe2, 0x1c, - 0x95, 0xa5, 0xff, 0x40, 0x56, 0x7c, 0x14, 0xc0, 0xe5, 0x75, 0x64, 0x43, - 0xe7, 0x43, 0xb6, 0xfd, 0xc9, 0xf9, 0xcb, 0xfc, 0x3a, 0x13, 0x6f, 0x35, - 0xa8, 0x0a, 0x45, 0xf5, 0xc3, 0x7e, 0xb9, 0xab, 0xe8, 0x83, 0xf3, 0x13, - 0xdb, 0x44, 0x00, 0x3e, 0x25, 0xe7, 0xae, 0x83, 0x44, 0x7d, 0xbb, 0x64, - 0x39, 0xb2, 0x3b, 0xc3, 0x78, 0xa7, 0x29, 0x3f, 0x3b, 0x83, 0x9b, 0x1f, - 0xfe, 0xbd, 0x3a, 0xba, 0x34, 0xb4, 0x57, 0xd1, 0x3b, 0x17, 0x56, 0x29, - 0x0e, 0xea, 0xfe, 0x5d, 0xb0, 0x30, 0x90, 0x3f, 0xc0, 0x87, 0x3b, 0xe9, - 0x0d, 0x2f, 0x46, 0x85, 0x2e, 0x38, 0xff, 0x62, 0x70, 0x24, 0x92, 0xd9, - 0x1b, 0x1d, 0xdf, 0x43, 0x46, 0x5b, 0x01, 0x53, 0x28, 0xe3, 0x86, 0x4a, - 0xfc, 0x50, 0x65, 0xe5, 0xa1, 0x41, 0x5b, 0xef, 0x0c, 0xf5, 0xd1, 0x82, - 0x81, 0xa4, 0xbb, 0x07, 0xf7, 0x34, 0xbe, 0x94, 0xaa, 0x84, 0x38, 0x13, - 0x28, 0x86, 0xc0, 0x61, 0x9d, 0xd9, 0xc0, 0xc0, 0x62, 0x23, 0x3b, 0x1c, - 0x2e, 0x8e, 0x2e, 0x00, 0xc4, 0x73, 0xc3, 0x7d, 0xa7, 0xb4, 0xae, 0xc1, - 0x97, 0x60, 0x36, 0x38, 0xa5, 0xe9, 0xae, 0xe6, 0xef, 0x44, 0x69, 0x47, - 0x28, 0xd9, 0x44, 0xe5, 0x14, 0x5a, 0xd9, 0x2a, 0x03, 0xb0, 0x71, 0x14, - 0x28, 0x28, 0x0d, 0x43, 0x97, 0x90, 0x35, 0xaf, 0x23, 0xca, 0x7a, 0x5f, - 0x5f, 0x4b, 0xe9, 0x1c, 0xc6, 0xbe, 0x86, 0x04, 0x1c, 0xa5, 0x23, 0x44, - 0x91, 0xa2, 0xec, 0x6d, 0xcb, 0x95, 0x18, 0x75, 0x6d, 0xf5, 0xe4, 0xa7, - 0x33, 0x7a, 0xa0, 0x9b, 0x5c, 0x0b, 0xcf, 0x10, 0x85, 0x30, 0xbd, 0xa6, - 0xcc, 0x35, 0x6d, 0x6e, 0xf1, 0x02, 0x81, 0x81, 0x00, 0xf4, 0xf2, 0xbf, - 0xf3, 0x44, 0xa0, 0x29, 0x23, 0xe7, 0x07, 0x5c, 0x81, 0x46, 0xb5, 0x6a, - 0xbc, 0xf9, 0x1c, 0x8e, 0x16, 0x70, 0x21, 0x5d, 0x27, 0xe1, 0x46, 0x12, - 0x09, 0x12, 0x46, 0xea, 0x52, 0x35, 0xbf, 0x9c, 0x50, 0xab, 0xe5, 0x0f, - 0xc4, 0x6b, 0xb0, 0x17, 0x5d, 0x35, 0x8c, 0x8e, 0x9e, 0x91, 0xd4, 0xe5, - 0xfe, 0xae, 0x95, 0x0c, 0xd7, 0xd5, 0xc8, 0xfd, 0x8a, 0x19, 0x2c, 0xba, - 0xe9, 0x7f, 0x9f, 0x15, 0x33, 0xbf, 0xec, 0x2f, 0xe9, 0x45, 0x5f, 0x80, - 0xa9, 0xf4, 0x96, 0xf5, 0x89, 0xbb, 0x94, 0x42, 0x10, 0x00, 0x46, 0x2a, - 0x6e, 0x1f, 0xee, 0xfd, 0xe8, 0x78, 0xae, 0xf7, 0x2a, 0xa5, 0x22, 0x5f, - 0x77, 0xae, 0x1a, 0x08, 0xd6, 0x35, 0x5e, 0xdb, 0x38, 0x4a, 0xd1, 0x60, - 0xb5, 0xf9, 0xd9, 0x95, 0x00, 0x26, 0x6f, 0xf7, 0x12, 0x52, 0x5b, 0x1d, - 0x09, 0x28, 0xdd, 0x21, 0xbb, 0x02, 0x81, 0x81, 0x00, 0xdc, 0xf1, 0x3d, - 0xbb, 0x87, 0xf7, 0xae, 0x69, 0xe8, 0x18, 0x94, 0x51, 0x2c, 0x78, 0xaf, - 0x1c, 0x8b, 0x77, 0x22, 0x49, 0xce, 0xd2, 0x1a, 0xc2, 0xbc, 0x0f, 0xca, - 0x63, 0x1d, 0x92, 0x1e, 0x98, 0x94, 0x5b, 0xda, 0x57, 0xcd, 0x98, 0xa6, - 0x6a, 0x54, 0x8f, 0x43, 0x93, 0x7f, 0x0f, 0xca, 0xe5, 0x2e, 0xf5, 0x50, - 0x06, 0x43, 0x0e, 0xbf, 0xec, 0x08, 0x53, 0xba, 0x04, 0x8f, 0x54, 0x35, - 0xa3, 0x21, 0x9e, 0xf9, 0xfc, 0x53, 0x37, 0xf3, 0xb5, 0x3a, 0x95, 0x7a, - 0x60, 0x89, 0xc9, 0x53, 0xaf, 0xf4, 0x2e, 0x39, 0x83, 0x15, 0x67, 0x38, - 0x7f, 0x65, 0x4f, 0xce, 0xcd, 0x42, 0x0b, 0x84, 0x83, 0xdf, 0xe0, 0xf3, - 0x59, 0x1f, 0x62, 0xef, 0x64, 0xc3, 0xbc, 0xe8, 0x56, 0xff, 0x20, 0xcd, - 0xe4, 0xfb, 0xa3, 0x50, 0xa3, 0xca, 0xfb, 0xd8, 0xbe, 0x96, 0x94, 0x06, - 0x9a, 0x02, 0x1b, 0x86, 0x4d, 0x02, 0x81, 0x81, 0x00, 0xa0, 0xb7, 0x05, - 0xaa, 0x9f, 0xc4, 0x56, 0x39, 0xf0, 0x43, 0xac, 0x36, 0x46, 0x26, 0x92, - 0x3a, 0x1b, 0x58, 0xd9, 0x01, 0x6f, 0xe0, 0xf4, 0x36, 0x4e, 0x60, 0xa3, - 0x44, 0xc0, 0x71, 0x37, 0x1d, 0x69, 0x96, 0xa7, 0x01, 0x67, 0x47, 0x8b, - 0xe8, 0xdc, 0x9f, 0x55, 0x35, 0x1b, 0x05, 0x76, 0x2e, 0x24, 0x91, 0x03, - 0xb6, 0xee, 0xe5, 0x6c, 0xdf, 0xd0, 0xad, 0x67, 0x6d, 0x4c, 0xc7, 0x44, - 0x7c, 0x1f, 0xf8, 0x48, 0xf9, 0x03, 0x5b, 0xfc, 0xb3, 0x99, 0x88, 0xe7, - 0xea, 0x9b, 0x48, 0xd1, 0x21, 0xe5, 0xa9, 0x89, 0x0e, 0xe6, 0x9f, 0x23, - 0x07, 0xce, 0x7c, 0x08, 0xac, 0x97, 0x42, 0x75, 0x79, 0xcd, 0x8f, 0x98, - 0x03, 0xf6, 0x7f, 0xae, 0x7c, 0x9d, 0xd7, 0xf7, 0x0e, 0x20, 0x48, 0xf0, - 0xa3, 0x75, 0xa3, 0x85, 0x57, 0xeb, 0xe0, 0x5a, 0xc3, 0xf2, 0xb5, 0x45, - 0x7f, 0xd5, 0x08, 0x02, 0x31, 0x02, 0x81, 0x80, 0x6b, 0x9f, 0xc7, 0xe6, - 0x75, 0xd1, 0x1c, 0xd0, 0xd2, 0x12, 0x47, 0x0d, 0x53, 0x90, 0x66, 0x1c, - 0x8d, 0x83, 0x36, 0xdc, 0xa5, 0x36, 0x8b, 0x7a, 0x98, 0x89, 0x48, 0x99, - 0x07, 0x6a, 0x8a, 0x24, 0xe0, 0xff, 0xed, 0x58, 0x1f, 0xfa, 0x5f, 0xf6, - 0x23, 0xc2, 0xb5, 0xb4, 0x3f, 0x8c, 0xbd, 0xd4, 0xee, 0x0e, 0xe9, 0x30, - 0x63, 0xb1, 0xe7, 0xa3, 0x5e, 0x5b, 0x0a, 0x9d, 0xf6, 0x03, 0x9b, 0x2d, - 0x1f, 0xcf, 0x85, 0x0e, 0x78, 0xab, 0x24, 0xb7, 0xff, 0x15, 0x99, 0x4b, - 0x35, 0x53, 0x30, 0xc4, 0xe1, 0x39, 0x33, 0x22, 0xbb, 0x66, 0x50, 0x8b, - 0x1e, 0x1a, 0xc6, 0x2e, 0x0e, 0x21, 0xf6, 0x27, 0x17, 0x03, 0x49, 0x06, - 0xfc, 0xd7, 0x00, 0xae, 0x20, 0xfb, 0x00, 0x62, 0x80, 0x5c, 0xc6, 0x6e, - 0xe8, 0x75, 0x21, 0x6e, 0xe8, 0x0d, 0xce, 0x02, 0xe8, 0xee, 0xaa, 0x58, - 0x92, 0xf6, 0x3d, 0x71, 0x02, 0x81, 0x81, 0x00, 0x84, 0x6e, 0x5b, 0x4e, - 0x97, 0xdd, 0xef, 0xaa, 0x17, 0x06, 0xe8, 0xa0, 0x9b, 0x00, 0x49, 0x1f, - 0xaa, 0x50, 0x28, 0x35, 0x04, 0xae, 0xf1, 0x74, 0xdf, 0xcc, 0x60, 0xfc, - 0xe2, 0x97, 0x7d, 0x81, 0xdc, 0x91, 0x11, 0xbc, 0xb4, 0x9e, 0x84, 0x87, - 0xf7, 0xd8, 0xf7, 0x4f, 0xa4, 0x76, 0x5f, 0x86, 0xec, 0x26, 0x7f, 0xb3, - 0x3c, 0x37, 0x15, 0xc4, 0x43, 0xda, 0x51, 0x54, 0xf7, 0x10, 0x05, 0x25, - 0x24, 0x11, 0x92, 0xa8, 0xb9, 0x41, 0x1a, 0xd2, 0x01, 0xd5, 0x52, 0xac, - 0x99, 0x07, 0x59, 0xdc, 0xcf, 0x8d, 0x7f, 0x7d, 0x5f, 0x01, 0xa6, 0x77, - 0xe5, 0x83, 0xfd, 0x6a, 0x1f, 0x7b, 0xcb, 0x38, 0x29, 0xfc, 0xd0, 0x6f, - 0x6b, 0x86, 0xd5, 0xcd, 0x1c, 0x63, 0x7f, 0xb0, 0x58, 0xda, 0x43, 0xc7, - 0x2f, 0x81, 0xd0, 0x3f, 0xd5, 0x8f, 0xa1, 0xda, 0xf1, 0x75, 0xda, 0x4c, - 0x5b, 0x4f, 0x2c, 0x20, + 0x30, 0x82, 0x04, 0xa3, 0x02, 0x01, 0x00, 0x02, 0x82, 0x01, 0x01, 0x00, + 0xf7, 0xbb, 0x6b, 0x8e, 0xab, 0x40, 0x49, 0x1c, 0xd6, 0x44, 0x55, 0xec, + 0x04, 0xd4, 0xed, 0x8d, 0xb5, 0x05, 0x1a, 0x97, 0x38, 0xfc, 0x7a, 0xf7, + 0x3f, 0xf3, 0xb0, 0x97, 0x51, 0x1c, 0xce, 0x40, 0xaa, 0xf7, 0x65, 0x37, + 0xb1, 0x35, 0x35, 0x04, 0x42, 0x79, 0x86, 0xb7, 0xb2, 0xb5, 0x3a, 0x96, + 0x4a, 0x69, 0x37, 0xb5, 0x58, 0xec, 0x0d, 0x1d, 0xea, 0x27, 0x4a, 0xf2, + 0xb8, 0xff, 0xf2, 0xf0, 0x94, 0xc2, 0x43, 0xfa, 0x57, 0x72, 0x66, 0xa7, + 0x9d, 0xb0, 0xc2, 0x6f, 0xfe, 0x30, 0x41, 0x6d, 0x23, 0xef, 0x05, 0xdd, + 0x5f, 0xec, 0xab, 0x41, 0x3e, 0xbb, 0xb4, 0xf8, 0x52, 0x6a, 0xe7, 0x20, + 0xa9, 0x45, 0x84, 0x22, 0x6b, 0x37, 0xd9, 0x2e, 0xf4, 0x63, 0xfc, 0x73, + 0x6c, 0xb3, 0x8e, 0x53, 0x0e, 0x74, 0x88, 0xd9, 0x16, 0x2f, 0x57, 0x26, + 0x80, 0x7b, 0xc5, 0x43, 0x13, 0x8a, 0x2d, 0x25, 0x8a, 0xdb, 0x4d, 0x68, + 0x02, 0x21, 0xc2, 0x53, 0x23, 0x81, 0xcc, 0xfa, 0x81, 0xbc, 0x89, 0xbc, + 0x3d, 0x7b, 0x84, 0x03, 0x9c, 0x2d, 0xf4, 0x1c, 0xe3, 0xec, 0x8d, 0xb9, + 0x1c, 0x23, 0x80, 0xe7, 0x81, 0xba, 0x3a, 0xa9, 0xe2, 0x3b, 0x74, 0xed, + 0x99, 0x73, 0xd4, 0x90, 0x8e, 0xfc, 0xa4, 0x7a, 0xa8, 0xd9, 0xb7, 0xb0, + 0xa4, 0x42, 0x32, 0x97, 0xa4, 0x04, 0x42, 0x7c, 0x3f, 0x3c, 0xd6, 0xe0, + 0x78, 0x2e, 0x45, 0x53, 0x88, 0x0f, 0x06, 0xba, 0x39, 0xa6, 0x4f, 0x4a, + 0x7b, 0x0e, 0xef, 0x92, 0x1a, 0x60, 0x50, 0xa2, 0x07, 0xce, 0xfa, 0xdc, + 0xf0, 0x73, 0x94, 0xa3, 0xe1, 0x8e, 0xa9, 0x15, 0xdc, 0x84, 0x97, 0xe7, + 0xae, 0x61, 0xfc, 0x31, 0x62, 0xf6, 0x2f, 0x50, 0x65, 0xa6, 0x92, 0xaf, + 0x07, 0x72, 0x66, 0xf7, 0x36, 0x0c, 0x20, 0x76, 0xce, 0xbe, 0xaf, 0x14, + 0xcb, 0x22, 0xc1, 0xed, 0x02, 0x03, 0x01, 0x00, 0x01, 0x02, 0x82, 0x01, + 0x00, 0x00, 0xb8, 0x96, 0x2d, 0xce, 0x60, 0x4b, 0xc6, 0x2e, 0x76, 0x78, + 0xf4, 0x8c, 0xa8, 0x0c, 0xff, 0xf4, 0x56, 0xad, 0x36, 0xe2, 0xf6, 0xd3, + 0x29, 0xcc, 0x91, 0x1a, 0x42, 0xba, 0x7c, 0xf5, 0xb9, 0xb8, 0xf5, 0xaa, + 0xe1, 0x00, 0x5e, 0x4a, 0x06, 0xf6, 0xe5, 0x91, 0x27, 0x90, 0x38, 0xd8, + 0x50, 0x8f, 0x2b, 0x62, 0xba, 0xdf, 0xa5, 0x22, 0x3d, 0xa3, 0xcc, 0x94, + 0xfa, 0x83, 0x60, 0xd5, 0x55, 0x6f, 0x6d, 0x68, 0x52, 0xbe, 0x75, 0xea, + 0x08, 0x13, 0x5c, 0xac, 0x18, 0x34, 0xda, 0x71, 0x9a, 0x4e, 0x78, 0x37, + 0xe1, 0x66, 0xd1, 0xd2, 0xc6, 0xc8, 0x16, 0xb6, 0x46, 0x61, 0xc1, 0x07, + 0x66, 0xb0, 0x2f, 0x70, 0x5c, 0xc4, 0x48, 0x9f, 0x94, 0x74, 0x28, 0x25, + 0x58, 0x35, 0xa9, 0x09, 0x21, 0x43, 0x41, 0xc2, 0x13, 0x35, 0xae, 0x12, + 0x18, 0x1d, 0xd8, 0x1e, 0x61, 0x1d, 0x59, 0xb1, 0xdb, 0x70, 0x66, 0x7b, + 0xeb, 0xd7, 0xe9, 0x2b, 0x71, 0xe1, 0xd3, 0x88, 0x31, 0x8d, 0x3e, 0xc1, + 0x4d, 0x61, 0x6f, 0x72, 0xc2, 0x31, 0xf6, 0x72, 0x7a, 0x18, 0x3e, 0x68, + 0x18, 0x28, 0x5b, 0xd6, 0x5f, 0x65, 0x72, 0xca, 0xdc, 0x90, 0x12, 0x24, + 0x88, 0x21, 0xb2, 0xd0, 0xae, 0x6c, 0xed, 0xd3, 0x0c, 0xa4, 0x40, 0xd4, + 0xd3, 0x4c, 0xd7, 0x7e, 0x2c, 0xf6, 0xb4, 0x0e, 0xd2, 0xc7, 0xd8, 0x56, + 0xb3, 0x0d, 0x47, 0x47, 0x33, 0xfc, 0xe0, 0xfb, 0x69, 0x5c, 0x3e, 0x65, + 0x30, 0xc0, 0x79, 0xae, 0xd9, 0x55, 0xe4, 0x07, 0x30, 0x55, 0xf2, 0x65, + 0x5d, 0x4b, 0x67, 0x1e, 0x29, 0x1f, 0xde, 0x40, 0x0f, 0x2f, 0x06, 0xd0, + 0xb3, 0x3f, 0x87, 0xd2, 0x61, 0xe0, 0xad, 0x3d, 0xae, 0x48, 0xa9, 0x13, + 0x84, 0x1b, 0x34, 0xcf, 0xed, 0x03, 0x79, 0x0f, 0xca, 0xee, 0x00, 0xde, + 0x2e, 0x90, 0xfb, 0x96, 0x21, 0x02, 0x81, 0x81, 0x00, 0xfc, 0xbe, 0x89, + 0xcd, 0x1a, 0xa3, 0x19, 0xe4, 0x9e, 0xf4, 0xf7, 0x21, 0x49, 0xbf, 0x06, + 0xda, 0x57, 0xdc, 0xc6, 0x4d, 0x3d, 0xe6, 0x05, 0xe9, 0xff, 0x3e, 0x76, + 0xfc, 0x66, 0xf4, 0xb1, 0xe2, 0x87, 0x82, 0x45, 0xff, 0xd7, 0x19, 0x90, + 0x51, 0x1b, 0x17, 0xe9, 0x7f, 0x33, 0x81, 0x88, 0x89, 0xa8, 0xc2, 0x1b, + 0x55, 0x27, 0xfd, 0x18, 0x13, 0x27, 0xaf, 0xfe, 0x88, 0xf9, 0xbb, 0xa6, + 0x70, 0xc4, 0xe6, 0xf1, 0xe6, 0x30, 0x9b, 0xd0, 0x32, 0x30, 0x74, 0xe4, + 0xcb, 0xcf, 0x23, 0xdc, 0xe3, 0xc1, 0x9b, 0x8d, 0x54, 0x95, 0xf5, 0x6a, + 0x93, 0x05, 0x9b, 0xa7, 0x41, 0x4f, 0x28, 0xed, 0x1e, 0xc9, 0x06, 0xad, + 0x18, 0xc6, 0x3d, 0xe1, 0x14, 0x8a, 0xbc, 0xfe, 0x9b, 0xe7, 0x98, 0x60, + 0x00, 0xf4, 0x25, 0xe5, 0x80, 0xb7, 0x0e, 0x43, 0xe4, 0x8e, 0x24, 0xfa, + 0x9d, 0x51, 0xaa, 0xae, 0x4d, 0x02, 0x81, 0x81, 0x00, 0xfa, 0xec, 0x5a, + 0x7b, 0xed, 0x2e, 0x53, 0xcf, 0xca, 0x1e, 0x16, 0x7d, 0xb4, 0x64, 0x1d, + 0xb5, 0xa0, 0x0f, 0xe2, 0xc3, 0x28, 0x12, 0x54, 0x23, 0xd5, 0x94, 0x78, + 0x9f, 0x3e, 0xc0, 0x72, 0xc6, 0x23, 0xe7, 0xaf, 0xbd, 0xee, 0x00, 0x89, + 0xfd, 0x26, 0x30, 0x76, 0x51, 0xf6, 0xd3, 0x61, 0x1a, 0x88, 0xaf, 0x28, + 0xc3, 0x45, 0x85, 0xd5, 0xcb, 0x71, 0x3a, 0x65, 0x0c, 0x35, 0x93, 0x3f, + 0x58, 0x94, 0x4d, 0xb9, 0xbd, 0x15, 0xba, 0x9f, 0xc2, 0x8b, 0x07, 0xe6, + 0x70, 0x5b, 0x7b, 0x3e, 0xf1, 0xcc, 0xb4, 0x8d, 0x21, 0xa5, 0x35, 0x69, + 0xc8, 0xb8, 0x4c, 0x44, 0x4b, 0x61, 0xea, 0x5c, 0x6e, 0x67, 0xb5, 0x4f, + 0x0a, 0xfd, 0x85, 0x2f, 0xfb, 0x8c, 0x92, 0xa1, 0x11, 0xfa, 0xb8, 0x67, + 0x72, 0x63, 0xee, 0xb8, 0x0c, 0xf1, 0xa3, 0x40, 0x3b, 0x4a, 0x9a, 0x20, + 0x97, 0x76, 0x94, 0x72, 0x21, 0x02, 0x81, 0x80, 0x2f, 0xf9, 0x9a, 0xfe, + 0xab, 0xc7, 0xb9, 0xea, 0x83, 0xa1, 0xcc, 0x27, 0x2d, 0x70, 0x6d, 0x44, + 0x94, 0xd8, 0xfb, 0x6b, 0x3e, 0x0c, 0xa3, 0xa2, 0xbf, 0x28, 0x84, 0x3d, + 0x74, 0xed, 0x8d, 0xb6, 0x8a, 0x32, 0x58, 0x47, 0x2f, 0xf5, 0x52, 0x47, + 0x92, 0xf4, 0xff, 0x05, 0x7e, 0x29, 0x60, 0x59, 0x81, 0x07, 0x17, 0x59, + 0x1a, 0xb6, 0x18, 0x13, 0xca, 0xbc, 0xc5, 0x7c, 0x0a, 0xab, 0x6b, 0xf4, + 0x8b, 0xeb, 0xaa, 0x8f, 0x1f, 0x3a, 0xf4, 0x52, 0x12, 0x90, 0x9d, 0xbd, + 0x72, 0x1c, 0x44, 0x99, 0x96, 0xee, 0x87, 0xed, 0x3e, 0x69, 0xcf, 0x49, + 0x09, 0x0f, 0x7a, 0xb8, 0x12, 0xe6, 0x99, 0xdb, 0xf6, 0x1c, 0xa6, 0x4e, + 0xc5, 0x92, 0x89, 0x5e, 0xf4, 0xd6, 0xdb, 0x1d, 0x8c, 0xe0, 0x87, 0x98, + 0xa6, 0xbf, 0x6a, 0xc8, 0xfb, 0xf6, 0x61, 0x3c, 0xc9, 0x1e, 0x8b, 0xd3, + 0xc0, 0xe4, 0xbd, 0x21, 0x02, 0x81, 0x81, 0x00, 0xb2, 0x9b, 0x34, 0x59, + 0x0b, 0xdd, 0xb3, 0x08, 0xaf, 0xec, 0xb4, 0xc3, 0xab, 0x78, 0xab, 0xf1, + 0x11, 0x4a, 0xdd, 0x75, 0x5e, 0x7b, 0x95, 0x6a, 0xa0, 0x67, 0x7b, 0x68, + 0x96, 0xa9, 0x33, 0xc9, 0x37, 0xdb, 0x7d, 0xab, 0xaa, 0xd2, 0xb5, 0x65, + 0xfd, 0x1d, 0xf7, 0xca, 0xa5, 0xef, 0x96, 0x29, 0xe5, 0xeb, 0x10, 0x0f, + 0xd6, 0xd7, 0xc9, 0xf3, 0x72, 0xd8, 0x46, 0xfe, 0xe6, 0xcf, 0xb6, 0x02, + 0x5e, 0x25, 0xe9, 0x34, 0xdf, 0x57, 0xa4, 0xca, 0x3c, 0x5e, 0x56, 0x37, + 0xd9, 0xd6, 0x23, 0x5a, 0xc8, 0x04, 0x28, 0x85, 0x2f, 0x6c, 0x92, 0xac, + 0xae, 0x0a, 0x93, 0x7e, 0x38, 0xe7, 0x31, 0xfd, 0xe0, 0x52, 0x1d, 0x3e, + 0x4c, 0x70, 0xd6, 0x53, 0xae, 0x9e, 0xdc, 0x89, 0xc8, 0xb6, 0x23, 0xe4, + 0x37, 0x9f, 0xbf, 0x60, 0x6f, 0x4b, 0x6d, 0xb8, 0x06, 0x85, 0x28, 0xf7, + 0xc7, 0x0f, 0x29, 0x21, 0x02, 0x81, 0x80, 0x0e, 0xd4, 0x7a, 0xe0, 0x5b, + 0x27, 0x5a, 0x23, 0xa7, 0xdf, 0xe3, 0xff, 0xb7, 0x27, 0xe3, 0xa2, 0x68, + 0xe6, 0x26, 0xa5, 0x9d, 0x40, 0x1d, 0x2d, 0x84, 0x6d, 0xe2, 0x69, 0x54, + 0xff, 0x54, 0xfc, 0x9e, 0xd9, 0x3a, 0x9a, 0xf3, 0x3f, 0xac, 0x2c, 0x96, + 0x7a, 0x18, 0xe0, 0xf8, 0x61, 0x45, 0x08, 0x3e, 0x39, 0x92, 0x34, 0x54, + 0xbc, 0x10, 0xda, 0x5f, 0x49, 0x37, 0xe8, 0x36, 0xb9, 0x98, 0x51, 0x95, + 0x6b, 0xff, 0xb3, 0x01, 0xce, 0x9e, 0x06, 0x78, 0x97, 0x86, 0x69, 0x32, + 0x13, 0xfc, 0xde, 0x6d, 0x5f, 0x29, 0x33, 0xd5, 0x2b, 0xb2, 0x9d, 0xc3, + 0x40, 0xea, 0x01, 0x12, 0x57, 0x78, 0x8d, 0x3c, 0x57, 0x75, 0xeb, 0x65, + 0x69, 0x23, 0x0a, 0xaf, 0xbf, 0x08, 0x75, 0x2d, 0x40, 0xa8, 0x41, 0x9d, + 0xe7, 0x1b, 0x01, 0xd4, 0x92, 0x7e, 0x27, 0xc1, 0x07, 0x9c, 0xaa, 0xda, + 0x05, 0x68, 0xb1, }; const unsigned char test_rsa_4096[] = { 0x30, 0x82, 0x09, 0x29, 0x02, 0x01, 0x00, 0x02, 0x82, 0x02, 0x01, 0x00, - 0xf2, 0x60, 0xe5, 0x99, 0x5a, 0xb8, 0xcf, 0xbc, 0xd2, 0x19, 0xf9, 0x31, - 0x3a, 0x3f, 0x2a, 0xda, 0x81, 0xe1, 0x19, 0x3f, 0x21, 0x44, 0x12, 0x88, - 0x1d, 0x29, 0xa9, 0xdb, 0x33, 0x9b, 0x64, 0x11, 0x25, 0xb3, 0x6a, 0x51, - 0x66, 0xfd, 0x08, 0x29, 0xa4, 0x08, 0x2d, 0x93, 0xe8, 0x5f, 0xe8, 0xb4, - 0xc7, 0x9b, 0xac, 0x6a, 0x76, 0xfb, 0xaa, 0x28, 0x7f, 0x8c, 0xd6, 0xc9, - 0x2a, 0x45, 0x6d, 0x38, 0x1a, 0xf2, 0x31, 0xf5, 0xb4, 0xd6, 0x94, 0x6c, - 0x22, 0xee, 0x9d, 0xcf, 0x39, 0x97, 0xe0, 0x72, 0x29, 0x9b, 0x46, 0x95, - 0x1a, 0x44, 0x5f, 0xd5, 0xf2, 0x69, 0xa7, 0x0d, 0xcd, 0xab, 0x00, 0x0c, - 0xa5, 0xe4, 0xee, 0x43, 0x73, 0x05, 0x98, 0x6f, 0x0b, 0x37, 0x52, 0x33, - 0x31, 0x87, 0x9c, 0x7d, 0x1c, 0xfa, 0xf1, 0x96, 0x4a, 0x2a, 0x2d, 0xd4, - 0x0c, 0x50, 0x0e, 0x49, 0x8d, 0x21, 0x2a, 0xbf, 0x19, 0x98, 0xfb, 0x68, - 0x3f, 0x06, 0x61, 0xce, 0x6c, 0x5a, 0x8b, 0xbe, 0x2b, 0x45, 0x00, 0xb3, - 0x3f, 0xc1, 0x9e, 0xca, 0xa1, 0x13, 0xa6, 0x2b, 0x2a, 0xf2, 0x59, 0xdf, - 0xb0, 0x7d, 0xcc, 0xfd, 0x39, 0x19, 0xfc, 0xd1, 0x7e, 0xdc, 0xe0, 0x07, - 0x44, 0xd4, 0xf3, 0x63, 0x88, 0x58, 0x3d, 0xd4, 0xe3, 0x64, 0x46, 0x08, - 0x7c, 0xc1, 0x19, 0x5a, 0xab, 0x56, 0xea, 0xd0, 0x6f, 0x6f, 0xf0, 0x6b, - 0x26, 0x64, 0x15, 0x39, 0xfb, 0xff, 0x36, 0xce, 0xd6, 0x3c, 0x4b, 0xba, - 0xda, 0x62, 0x3a, 0x03, 0x22, 0x0e, 0x2b, 0xe1, 0xf4, 0xa5, 0xbd, 0x9d, - 0x99, 0x2d, 0x57, 0xbc, 0xf7, 0x3f, 0x44, 0x70, 0xf2, 0xd5, 0xa8, 0x5c, - 0x08, 0xea, 0x68, 0x99, 0xaf, 0xe5, 0xc2, 0xc7, 0xeb, 0x51, 0x2f, 0x5b, - 0x53, 0xd4, 0xbd, 0x87, 0x67, 0xc1, 0xb7, 0xa8, 0xeb, 0x64, 0x67, 0x03, - 0xd5, 0x00, 0xd2, 0xd6, 0xa7, 0x42, 0x43, 0x7f, 0x0e, 0xdd, 0x2c, 0x11, - 0x0a, 0x25, 0xc9, 0xd3, 0xc6, 0x40, 0x79, 0x20, 0x0c, 0x27, 0xea, 0x70, - 0xfe, 0x3a, 0x17, 0x22, 0xa9, 0x07, 0x77, 0x6a, 0x1f, 0x4d, 0x9d, 0x85, - 0x46, 0xba, 0xad, 0x92, 0x4e, 0x2a, 0x23, 0xc8, 0x26, 0x0d, 0x8c, 0xb8, - 0xbc, 0xaf, 0x88, 0x3a, 0xe2, 0x92, 0x94, 0xe5, 0x7d, 0x23, 0xd1, 0x42, - 0xd3, 0x6b, 0xff, 0x6e, 0x07, 0xc5, 0xde, 0xb2, 0x2c, 0x07, 0xfc, 0x15, - 0xef, 0xd8, 0x86, 0x1e, 0xee, 0x7f, 0x85, 0x10, 0x08, 0x29, 0x7a, 0xd1, - 0xd0, 0x6f, 0x22, 0xc8, 0x3e, 0x17, 0xef, 0xe5, 0xf8, 0x27, 0x97, 0x40, - 0xeb, 0x75, 0xd6, 0xe3, 0x00, 0xde, 0x80, 0xd1, 0x69, 0xe7, 0x2b, 0xe1, - 0xb1, 0x81, 0xbd, 0x8e, 0x47, 0x2d, 0x47, 0xd5, 0xea, 0x48, 0x4c, 0x05, - 0xda, 0x52, 0x68, 0xc3, 0x36, 0xe6, 0x45, 0xff, 0x84, 0x3e, 0xd6, 0x9d, - 0xa9, 0x4e, 0xf8, 0xc2, 0x43, 0x80, 0x7d, 0xa9, 0x1d, 0x68, 0xa8, 0x3a, - 0xf2, 0x93, 0x4c, 0x08, 0x56, 0x44, 0x4a, 0xf4, 0xce, 0xb8, 0xa2, 0x05, - 0x18, 0x2b, 0xf6, 0x86, 0x29, 0x0e, 0x25, 0x8f, 0x7b, 0x7a, 0x01, 0xfa, - 0xd8, 0x81, 0xcc, 0x7b, 0x9c, 0x38, 0x81, 0xc1, 0xc7, 0x3f, 0x2c, 0x4e, - 0xb0, 0x86, 0x4c, 0xca, 0xdb, 0xaf, 0x49, 0x1c, 0x14, 0x15, 0x50, 0x98, - 0x29, 0x50, 0xeb, 0x3f, 0xbe, 0x20, 0x96, 0x3f, 0x7c, 0xd3, 0x5c, 0xdc, - 0x58, 0xa9, 0x00, 0x70, 0x0f, 0x7b, 0x2b, 0xf0, 0xfa, 0x26, 0x9c, 0x2b, - 0x52, 0x3f, 0x0c, 0x0b, 0xb3, 0xc6, 0xe1, 0xa4, 0xb0, 0xee, 0xa1, 0x4f, - 0x95, 0x17, 0x5d, 0xf2, 0xda, 0x2a, 0xe5, 0xd1, 0x8f, 0xf1, 0x68, 0x8e, - 0x50, 0x29, 0x20, 0xfe, 0xa8, 0x34, 0xf3, 0x99, 0x4f, 0xce, 0x0b, 0x78, - 0xb4, 0xad, 0x51, 0xe2, 0x85, 0xeb, 0xfd, 0xe1, 0x02, 0x03, 0x01, 0x00, - 0x01, 0x02, 0x82, 0x02, 0x00, 0x1a, 0x49, 0x73, 0x85, 0x49, 0x0f, 0x53, - 0xaa, 0x6f, 0x1f, 0xf5, 0x84, 0x87, 0x04, 0x6c, 0x4d, 0xa3, 0xf9, 0xe9, - 0x8e, 0xcc, 0xf9, 0x10, 0xc8, 0x75, 0xdf, 0x3b, 0xa6, 0x84, 0x27, 0x95, - 0x77, 0xfd, 0x9e, 0x82, 0x88, 0x9f, 0x12, 0x90, 0xc4, 0xd1, 0x5f, 0x38, - 0xb0, 0x3a, 0xaa, 0xd2, 0x36, 0x6f, 0x12, 0x9d, 0x65, 0xb3, 0x8f, 0x52, - 0x52, 0x4f, 0x99, 0x12, 0xff, 0x60, 0xc8, 0x04, 0x53, 0x2a, 0x2a, 0xfb, - 0xcb, 0xa1, 0xe8, 0x06, 0xd3, 0x5e, 0x8b, 0x82, 0x0e, 0x84, 0x38, 0xca, - 0x55, 0x1f, 0x59, 0x91, 0x93, 0x60, 0xb4, 0xab, 0x2f, 0x2d, 0x3a, 0x13, - 0xad, 0xdd, 0xd1, 0x2e, 0xb1, 0x70, 0x79, 0x8e, 0x74, 0xbe, 0xc0, 0x0b, - 0xda, 0xf9, 0x3c, 0xaf, 0xfb, 0xd0, 0xe2, 0x9c, 0x10, 0x7e, 0xa8, 0xe1, - 0xb4, 0x32, 0xc9, 0x75, 0xcc, 0x72, 0x64, 0x69, 0x54, 0x45, 0x4b, 0xe4, - 0x52, 0xb3, 0x00, 0x42, 0x3d, 0xf9, 0x5d, 0xe4, 0x14, 0x2a, 0xf0, 0xbc, - 0x08, 0xad, 0x31, 0x2f, 0xe5, 0x00, 0xe4, 0x6b, 0x28, 0x1f, 0x45, 0x9e, - 0x07, 0x3f, 0x02, 0x67, 0x48, 0x69, 0x20, 0x0f, 0xb0, 0x23, 0xf6, 0x03, - 0x53, 0x26, 0x3e, 0xe6, 0xc6, 0x2b, 0x0b, 0x2c, 0x75, 0x6e, 0x47, 0x61, - 0xb7, 0x59, 0xcd, 0x19, 0x82, 0x58, 0xa3, 0x69, 0xb0, 0x49, 0x76, 0x65, - 0x03, 0xa3, 0x9e, 0x60, 0x95, 0x02, 0x66, 0x26, 0xde, 0x31, 0xcc, 0x29, - 0x61, 0xcf, 0xde, 0xdc, 0xb8, 0xc0, 0x70, 0x18, 0x4a, 0x18, 0x32, 0xb0, - 0xc4, 0x32, 0x10, 0x1a, 0xab, 0x41, 0xbe, 0x66, 0xee, 0x5d, 0xe3, 0x5c, - 0xf5, 0x22, 0x05, 0x15, 0x9c, 0x1b, 0xb4, 0x6e, 0x91, 0x42, 0x80, 0x38, - 0xfa, 0x8d, 0x35, 0x32, 0x1d, 0x65, 0xcf, 0x64, 0x19, 0xd0, 0x21, 0x34, - 0x9d, 0xcb, 0x9f, 0xc9, 0x43, 0x63, 0x61, 0xd2, 0x3b, 0xd3, 0x01, 0x7f, - 0xae, 0x3f, 0x77, 0xd5, 0x5f, 0x45, 0x52, 0x9a, 0x71, 0xe8, 0xa8, 0x41, - 0xc4, 0x95, 0x96, 0xdf, 0x42, 0x3d, 0xcb, 0xb7, 0x38, 0x28, 0x73, 0x8c, - 0x11, 0xa8, 0x1f, 0xd9, 0xe3, 0x8d, 0xe1, 0x97, 0xa0, 0x74, 0xc4, 0xbe, - 0x45, 0x3e, 0x61, 0x77, 0xdd, 0x19, 0xdd, 0xcc, 0x2f, 0x75, 0xeb, 0xa7, - 0x07, 0xbe, 0x58, 0xc4, 0x41, 0x54, 0x0f, 0xd3, 0x8e, 0xcf, 0x36, 0xe7, - 0x43, 0xdc, 0xc9, 0x9a, 0xdf, 0x6e, 0x58, 0x64, 0xe0, 0xce, 0x40, 0x1f, - 0xcc, 0x43, 0x38, 0x25, 0xac, 0x4c, 0x64, 0xc8, 0xcf, 0xd3, 0x05, 0x89, - 0x34, 0x41, 0x12, 0x2b, 0xb2, 0xf5, 0x57, 0x3f, 0xe7, 0x0e, 0xf5, 0x6a, - 0x7f, 0x90, 0xdb, 0xfa, 0x97, 0xf8, 0xc2, 0xf5, 0xd9, 0xa4, 0xce, 0x07, - 0x5b, 0x09, 0xb0, 0x71, 0x17, 0xf3, 0x76, 0xc6, 0x5b, 0xc9, 0xb7, 0x73, - 0xd1, 0x07, 0xb2, 0x72, 0x71, 0xe0, 0xdc, 0x5d, 0x50, 0xa0, 0x38, 0x89, - 0xfa, 0x82, 0xb8, 0x62, 0x69, 0xcf, 0x81, 0xa1, 0x60, 0x9c, 0x33, 0x4e, - 0x5a, 0xa5, 0x9a, 0x76, 0x54, 0x1a, 0x40, 0xa1, 0xba, 0x63, 0xd0, 0xde, - 0x1c, 0x23, 0xbf, 0xed, 0x9b, 0x12, 0xc8, 0xc1, 0x41, 0x3e, 0x07, 0xe0, - 0xc8, 0xbf, 0x04, 0x73, 0xe3, 0x3a, 0xce, 0xbe, 0x54, 0x5d, 0x9d, 0x97, - 0xb9, 0xe8, 0xc9, 0x69, 0xd3, 0xc2, 0x0a, 0x1e, 0x65, 0x80, 0xa2, 0xeb, - 0x0c, 0x11, 0x77, 0x07, 0xe8, 0x09, 0xba, 0x92, 0x3d, 0xe9, 0x10, 0x77, - 0xf4, 0x8b, 0x7b, 0x8f, 0x9e, 0x1d, 0xe9, 0x97, 0x76, 0x94, 0x6a, 0x91, - 0x13, 0xb7, 0x42, 0x2d, 0xdf, 0x70, 0x3c, 0x5c, 0xb6, 0x8f, 0xb5, 0x7c, - 0x21, 0x55, 0x23, 0x72, 0xe7, 0x45, 0xba, 0xb2, 0xf6, 0x3a, 0x30, 0x0f, - 0x51, 0x52, 0x08, 0x13, 0x56, 0x1e, 0x7c, 0x4d, 0x52, 0x60, 0x1c, 0x79, - 0xd5, 0x02, 0x82, 0x01, 0x01, 0x00, 0xfb, 0xfe, 0x82, 0xfc, 0x4e, 0x1f, - 0x85, 0x7e, 0x0f, 0xf0, 0x55, 0x93, 0x9c, 0xf9, 0x0c, 0x64, 0xc9, 0xe1, - 0xbb, 0xa9, 0x69, 0xae, 0x17, 0x07, 0x72, 0x25, 0x8d, 0x99, 0x19, 0x43, - 0xc1, 0x29, 0x96, 0xcf, 0x27, 0x01, 0x85, 0x55, 0xca, 0x10, 0xcb, 0xf6, - 0xfe, 0x31, 0x82, 0x66, 0x23, 0xfb, 0xf0, 0xf7, 0xb1, 0x2c, 0x07, 0x5f, - 0xeb, 0x9c, 0xf0, 0xb8, 0xf1, 0x01, 0xc8, 0x7b, 0xde, 0xa2, 0x5e, 0x7f, - 0x03, 0x25, 0x73, 0x49, 0x27, 0x57, 0x30, 0x7f, 0x55, 0x55, 0x58, 0x15, - 0x16, 0x13, 0x70, 0x75, 0x69, 0x86, 0xc0, 0xf9, 0x5c, 0xd7, 0x35, 0x38, - 0xf9, 0xa2, 0xed, 0x0a, 0xa4, 0xe1, 0x57, 0xcf, 0x1c, 0x1c, 0x75, 0x78, - 0xbc, 0xb0, 0x88, 0x13, 0x35, 0x19, 0x7c, 0x58, 0x1a, 0xec, 0x7a, 0x0f, - 0x8b, 0x77, 0xf3, 0x4f, 0xaa, 0xa8, 0xcc, 0xd8, 0x06, 0x5c, 0x1e, 0x9a, - 0x3f, 0x52, 0x66, 0x96, 0x44, 0x0c, 0xfd, 0x9c, 0xdd, 0xc7, 0xef, 0x87, - 0x4c, 0xb4, 0xa3, 0xd3, 0xf0, 0xaf, 0x0b, 0x02, 0x5a, 0xcb, 0xc0, 0xce, - 0xda, 0xd3, 0xba, 0xdc, 0x7e, 0xca, 0xd8, 0xfa, 0x80, 0xf1, 0xe5, 0x40, - 0xcd, 0x42, 0xa6, 0x32, 0x81, 0x49, 0x3f, 0x81, 0x02, 0xab, 0xa1, 0x6d, - 0x3a, 0x33, 0x04, 0x89, 0xb9, 0x48, 0xff, 0xa1, 0x02, 0x1b, 0x6c, 0x75, - 0x50, 0x47, 0x30, 0x51, 0x56, 0x27, 0x8b, 0xec, 0x17, 0x8f, 0x13, 0x9e, - 0x99, 0x18, 0x32, 0x54, 0x35, 0x2c, 0xd1, 0xc3, 0x6b, 0x96, 0xed, 0xcb, - 0xc0, 0x86, 0xeb, 0x68, 0x3e, 0xf5, 0x4b, 0x6a, 0x85, 0xf2, 0xcc, 0x3e, - 0x87, 0x0c, 0x24, 0x94, 0x34, 0x76, 0xe0, 0xee, 0x90, 0x30, 0x00, 0xdc, - 0x41, 0xf4, 0x1b, 0xad, 0x81, 0x08, 0xf7, 0x05, 0x06, 0x6e, 0x4b, 0x5b, - 0x7b, 0xc3, 0x2d, 0xaa, 0x1f, 0x37, 0xb1, 0xe1, 0x5a, 0x65, 0x02, 0x82, - 0x01, 0x01, 0x00, 0xf6, 0x3b, 0x41, 0x17, 0x76, 0x3a, 0x48, 0xca, 0x82, - 0x34, 0x61, 0xc8, 0x4f, 0x98, 0x5b, 0x90, 0xea, 0xc1, 0x1d, 0x43, 0x22, - 0x7b, 0x85, 0xa7, 0x29, 0x50, 0x8e, 0x91, 0xab, 0xf3, 0x5e, 0x1f, 0x34, - 0x72, 0xc9, 0x8b, 0xe6, 0x21, 0x94, 0x1b, 0xfa, 0x5f, 0xce, 0x7b, 0xa3, - 0xd1, 0xf9, 0xab, 0xd4, 0x13, 0x75, 0x53, 0xb7, 0x63, 0x4b, 0xb5, 0x33, - 0x09, 0xf1, 0x6e, 0xe9, 0x63, 0xca, 0x06, 0xd0, 0x92, 0x16, 0x84, 0x5f, - 0xa5, 0x09, 0x12, 0x0f, 0x06, 0x07, 0x49, 0x45, 0x03, 0x68, 0x08, 0x3c, - 0x02, 0x6e, 0xb0, 0x0a, 0x3d, 0x39, 0xce, 0x58, 0x17, 0x1d, 0xb9, 0x9e, - 0x10, 0xd1, 0xe2, 0x4b, 0x68, 0x64, 0x9b, 0xc4, 0x1a, 0x9b, 0x3e, 0x1d, - 0x7c, 0x4e, 0x36, 0x83, 0x67, 0x9d, 0x68, 0x9c, 0xe4, 0x7d, 0x39, 0x6e, - 0x6f, 0x82, 0xea, 0x7b, 0x5f, 0x06, 0x4a, 0x71, 0x89, 0xd3, 0x42, 0x76, - 0x22, 0xd5, 0x2d, 0x83, 0xb9, 0x75, 0x9c, 0xa1, 0xb4, 0xb1, 0x0c, 0x8e, - 0x11, 0x4a, 0x6e, 0x1e, 0x36, 0x59, 0x01, 0xf3, 0x4d, 0x3b, 0x88, 0xd4, - 0x34, 0x03, 0xb1, 0x6c, 0xae, 0xd7, 0xd2, 0x90, 0x5b, 0xf7, 0xb2, 0x97, - 0x40, 0xee, 0x38, 0x08, 0x98, 0x3d, 0x85, 0xa5, 0x44, 0xa7, 0x84, 0xee, - 0xfc, 0xfe, 0x94, 0xfa, 0x44, 0x3c, 0x8e, 0xbb, 0x83, 0x46, 0x07, 0xb3, - 0x68, 0xae, 0xb0, 0x72, 0xa9, 0x0e, 0xaf, 0x87, 0x32, 0x1a, 0xa5, 0x52, - 0xc3, 0x67, 0x40, 0xc7, 0xe9, 0x13, 0x73, 0x98, 0x77, 0x61, 0x3d, 0xae, - 0x19, 0xa9, 0x86, 0x07, 0x5c, 0x95, 0x62, 0x4d, 0x36, 0x8c, 0xa6, 0x36, - 0x57, 0xd1, 0x41, 0x1b, 0x47, 0x73, 0x98, 0x46, 0x5c, 0xf5, 0x4e, 0x1a, - 0xf2, 0xa7, 0x7b, 0x1e, 0xee, 0x03, 0xdc, 0xf2, 0x68, 0x1f, 0x05, 0xd7, - 0xbf, 0x5b, 0x98, 0x20, 0xfc, 0xff, 0xcd, 0x02, 0x82, 0x01, 0x01, 0x00, - 0x99, 0x2a, 0x17, 0x3f, 0x77, 0xd4, 0x9c, 0xf5, 0x04, 0x87, 0x15, 0xdc, - 0xc4, 0xfa, 0x73, 0x58, 0x07, 0x85, 0x16, 0xe5, 0x60, 0x00, 0x9a, 0xaa, - 0xc1, 0xec, 0xa5, 0x66, 0x3a, 0xfe, 0xfd, 0xb7, 0x63, 0x9c, 0xc1, 0x9e, - 0xa1, 0x06, 0x85, 0xed, 0x33, 0xac, 0x0a, 0xd0, 0xd8, 0xeb, 0x70, 0x4f, - 0xc0, 0x25, 0x2d, 0x21, 0x0f, 0xd2, 0x73, 0x89, 0x4e, 0x9f, 0x7a, 0x8d, - 0x94, 0xe8, 0x05, 0x68, 0x37, 0x7b, 0x87, 0xd4, 0x09, 0x80, 0x9b, 0x52, - 0xd9, 0x7d, 0x6b, 0xc6, 0x95, 0xe5, 0x2b, 0x27, 0xe1, 0xa0, 0xdb, 0xe5, - 0x36, 0x01, 0xdb, 0x36, 0x4b, 0x79, 0x37, 0xf2, 0x99, 0x95, 0x70, 0xa6, - 0x2f, 0x13, 0x09, 0x89, 0x1a, 0xb5, 0xaa, 0x2a, 0xba, 0x6a, 0xc2, 0x49, - 0x9d, 0x54, 0x87, 0xf8, 0xd8, 0x2f, 0xfe, 0x9b, 0x87, 0xde, 0x12, 0x62, - 0xcb, 0x2f, 0x3a, 0x9e, 0x5f, 0x53, 0x6d, 0xcd, 0x8d, 0xe1, 0x23, 0xb7, - 0xa9, 0xa6, 0xe0, 0xfe, 0x97, 0x4e, 0x6b, 0x87, 0x18, 0x54, 0xc7, 0xe3, - 0xfd, 0x13, 0x0f, 0x50, 0xec, 0xfe, 0x4d, 0xef, 0x87, 0x92, 0x61, 0xd6, - 0xb5, 0x8f, 0x7d, 0x34, 0x8a, 0x1d, 0x9b, 0x25, 0x39, 0x93, 0x55, 0x15, - 0xca, 0x6d, 0x85, 0xcc, 0x00, 0x30, 0x3d, 0xc1, 0xa8, 0xae, 0x75, 0x5a, - 0x33, 0x56, 0x0f, 0xcb, 0xcf, 0x5e, 0x76, 0xce, 0xee, 0x45, 0x61, 0xd2, - 0x63, 0xaf, 0xba, 0x9a, 0x12, 0x58, 0xc1, 0xc0, 0xfd, 0x46, 0x45, 0x93, - 0xda, 0x63, 0xa7, 0x4f, 0x73, 0x75, 0xf6, 0xad, 0x8b, 0x04, 0x2f, 0xd0, - 0x34, 0x68, 0xa8, 0xc5, 0xec, 0xf2, 0xcc, 0x6e, 0xcb, 0x04, 0xf1, 0xe6, - 0x97, 0xcd, 0x29, 0x02, 0xa4, 0x63, 0x3c, 0x0b, 0x3d, 0x8f, 0x75, 0xf0, - 0x97, 0x04, 0x0c, 0xe6, 0x99, 0x13, 0x1f, 0xe4, 0x80, 0x2a, 0xf9, 0x12, - 0x87, 0x21, 0xec, 0x29, 0x02, 0x82, 0x01, 0x00, 0x57, 0xc6, 0x33, 0xa3, - 0xeb, 0x6f, 0x47, 0x77, 0x79, 0x06, 0xb7, 0x3c, 0xb2, 0xb2, 0xfb, 0x21, - 0x23, 0xae, 0x07, 0x82, 0x61, 0x0e, 0x6b, 0x4c, 0x75, 0x7b, 0xd3, 0xf6, - 0xb5, 0xb7, 0x21, 0x7c, 0x3a, 0x34, 0x19, 0x08, 0x97, 0xd6, 0xac, 0x77, - 0x74, 0xbf, 0x26, 0x5a, 0x08, 0xc1, 0xd7, 0x20, 0x9b, 0x8e, 0xfc, 0x2a, - 0x05, 0x9b, 0x8d, 0xe7, 0x5f, 0xf4, 0x51, 0x6e, 0x5a, 0x20, 0x4a, 0x6a, - 0x37, 0x7b, 0x7c, 0x2f, 0x5f, 0xf0, 0xf2, 0xd4, 0xcf, 0x2a, 0x34, 0xfa, - 0xb7, 0x71, 0x49, 0x6a, 0x76, 0x09, 0xdf, 0xef, 0x3d, 0x17, 0x2a, 0x3e, - 0x16, 0x44, 0xd7, 0x41, 0xcd, 0xc8, 0xed, 0x28, 0x9f, 0xfc, 0xec, 0xb0, - 0x62, 0x2d, 0xa1, 0xdd, 0x78, 0xa1, 0x51, 0x38, 0x39, 0x8b, 0x7c, 0x1f, - 0x48, 0x9e, 0x62, 0xcd, 0x50, 0x42, 0xcc, 0x06, 0x4e, 0x48, 0x47, 0x73, - 0xce, 0x19, 0x75, 0x87, 0xa1, 0x99, 0x35, 0x28, 0xee, 0x65, 0xf4, 0x39, - 0x0b, 0xa3, 0xdf, 0xe1, 0x3b, 0xdb, 0x8a, 0x0e, 0xcb, 0x12, 0x50, 0x94, - 0x53, 0x68, 0xda, 0xaa, 0x22, 0x0b, 0x10, 0xad, 0xf4, 0xb2, 0x37, 0x19, - 0x46, 0x80, 0xa2, 0x41, 0xb5, 0x8d, 0x5d, 0xdd, 0xf7, 0xa2, 0x5d, 0x7c, - 0x00, 0xb8, 0x02, 0x87, 0x6e, 0xb2, 0x1d, 0x06, 0x7a, 0x58, 0x4c, 0xc6, - 0x0c, 0xad, 0xf5, 0x0e, 0xd5, 0xb3, 0xa1, 0x62, 0x20, 0xdd, 0x86, 0xf0, - 0xa7, 0x5f, 0x03, 0x04, 0xa0, 0x06, 0x2c, 0x0e, 0x79, 0xb4, 0xea, 0x4c, - 0x30, 0xb3, 0x8d, 0xa4, 0x71, 0x25, 0x90, 0xba, 0xc8, 0x71, 0x06, 0x87, - 0x6e, 0x42, 0xdd, 0xcc, 0x7a, 0x5e, 0xbf, 0xa7, 0x57, 0xd4, 0x16, 0xae, - 0xd7, 0x96, 0x57, 0x93, 0xaa, 0x23, 0x89, 0xf4, 0x67, 0xc8, 0x2c, 0xf4, - 0x5c, 0x2d, 0x25, 0xb1, 0xed, 0x80, 0xb7, 0x63, 0xf9, 0x8e, 0x76, 0x99, - 0x02, 0x82, 0x01, 0x01, 0x00, 0xb9, 0xf8, 0x0f, 0x4d, 0xbb, 0xd4, 0xe4, - 0x25, 0x05, 0xa3, 0x17, 0x4c, 0x37, 0x62, 0x02, 0x14, 0x3e, 0xc0, 0x72, - 0xe8, 0xea, 0x3d, 0x8a, 0x1a, 0xc1, 0x6e, 0x6a, 0xdd, 0x27, 0xc6, 0xc2, - 0x4c, 0xd6, 0x1a, 0x09, 0xe6, 0x08, 0xc9, 0xf1, 0x5f, 0x91, 0x32, 0x66, - 0x97, 0xbb, 0x3d, 0xaf, 0x19, 0x57, 0x9f, 0x7b, 0x49, 0x99, 0x2f, 0x46, - 0x62, 0xb7, 0xcc, 0xde, 0xec, 0x8f, 0x30, 0x2d, 0xe1, 0x21, 0xad, 0x8e, - 0xf4, 0x38, 0xf6, 0xc0, 0x1f, 0x45, 0x60, 0x5e, 0x5f, 0xac, 0x65, 0x9c, - 0x8e, 0xc6, 0xa0, 0xd2, 0xa6, 0x4f, 0xf8, 0x67, 0xc0, 0x1f, 0x70, 0xcc, - 0x9f, 0x29, 0x5f, 0x9c, 0x42, 0x9c, 0xa9, 0x1e, 0x5e, 0x97, 0x61, 0x11, - 0x11, 0xd3, 0x88, 0x4a, 0xd8, 0xc2, 0xee, 0xab, 0x6a, 0xde, 0x6c, 0x20, - 0xbb, 0x1d, 0xa4, 0xc5, 0x49, 0xdb, 0xb4, 0x7c, 0x8f, 0x1f, 0xad, 0x4d, - 0xc3, 0x24, 0x7d, 0x77, 0x0b, 0x2e, 0x9f, 0x94, 0xe5, 0x48, 0xe1, 0x69, - 0x15, 0xac, 0xc6, 0x96, 0x9a, 0x5b, 0x62, 0xcb, 0x73, 0x45, 0x27, 0x43, - 0xd3, 0xd4, 0x49, 0x99, 0x3e, 0x69, 0xfd, 0x63, 0x59, 0x2b, 0x73, 0x94, - 0x56, 0x20, 0x39, 0x0c, 0x97, 0xbc, 0x85, 0x8d, 0xfe, 0xe6, 0x4b, 0x84, - 0xf7, 0x6d, 0x9d, 0x64, 0x34, 0x06, 0xee, 0x4c, 0x4f, 0x61, 0x66, 0x9c, - 0xaf, 0xd0, 0x98, 0x4d, 0x19, 0x66, 0xa6, 0x67, 0x25, 0x8d, 0xa3, 0x93, - 0xe3, 0xe5, 0x45, 0x10, 0xf5, 0x88, 0xb6, 0xd8, 0x53, 0x68, 0x77, 0x99, - 0xd0, 0x84, 0x9c, 0x78, 0x69, 0x85, 0xe2, 0xb6, 0x15, 0x3c, 0xdc, 0xff, - 0x52, 0xd6, 0x44, 0xfe, 0xa7, 0x9e, 0x83, 0x60, 0x7f, 0x63, 0xde, 0x59, - 0xe2, 0x7c, 0xf9, 0xfd, 0x9a, 0xb3, 0x38, 0xf0, 0xfb, 0x26, 0x6a, 0x67, - 0xcb, 0xab, 0xc9, 0x9e, 0xac, 0xb0, 0x1e, 0x0b, 0x5e, + 0xcc, 0x87, 0x25, 0xf6, 0xb3, 0x8d, 0x5d, 0x01, 0xae, 0xeb, 0x07, 0xd3, + 0x6e, 0x03, 0xde, 0x4d, 0x31, 0xa0, 0x26, 0x1c, 0xe7, 0x4f, 0xe1, 0x1a, + 0x89, 0x5e, 0xcf, 0xd1, 0x3d, 0x16, 0x8a, 0xee, 0x93, 0x2a, 0xf1, 0x35, + 0xff, 0xbb, 0x84, 0x98, 0x77, 0x27, 0x38, 0x97, 0x08, 0x1f, 0x3f, 0x75, + 0x93, 0xc1, 0x4a, 0xe8, 0x2b, 0xc2, 0x66, 0xc1, 0x05, 0x44, 0xf7, 0x26, + 0xae, 0x1c, 0xcf, 0x13, 0x3d, 0x8a, 0x40, 0x18, 0xd3, 0x80, 0xdf, 0xa2, + 0x52, 0x51, 0xc0, 0x11, 0x10, 0x7b, 0x75, 0x13, 0xa9, 0x43, 0x34, 0x6a, + 0xa0, 0xe0, 0xde, 0xc1, 0x1d, 0x8d, 0x7f, 0xa2, 0x56, 0x44, 0x65, 0x3c, + 0x11, 0x8d, 0xaa, 0xbc, 0xe6, 0xd4, 0x1f, 0x06, 0x6f, 0x66, 0x21, 0x76, + 0x88, 0x01, 0x47, 0x80, 0x55, 0x78, 0x0e, 0x91, 0xb6, 0x8e, 0xa3, 0xc9, + 0x58, 0x56, 0xd1, 0x72, 0xa8, 0x90, 0x32, 0xb3, 0x9c, 0x82, 0x4e, 0x8b, + 0x7d, 0xc1, 0xa3, 0xf8, 0xae, 0xe4, 0xf6, 0xb3, 0x68, 0xba, 0xa3, 0xcd, + 0x68, 0xf5, 0x0d, 0x52, 0x68, 0x01, 0x17, 0xe9, 0xb9, 0x13, 0xd7, 0xf8, + 0xc8, 0x52, 0xa0, 0xd1, 0x00, 0x8e, 0x8b, 0x87, 0xa5, 0xc9, 0x7e, 0x37, + 0xaf, 0xc1, 0x1a, 0x08, 0x05, 0x50, 0x55, 0x7b, 0x8b, 0x4d, 0xcb, 0xd8, + 0xe1, 0x92, 0xed, 0x33, 0x66, 0xd8, 0x3a, 0x09, 0xd2, 0x7c, 0x77, 0xe1, + 0x50, 0xf6, 0x68, 0x55, 0xb5, 0xdc, 0xfd, 0xb2, 0xdf, 0x15, 0x1b, 0xd7, + 0xf4, 0x44, 0x25, 0x0e, 0xaf, 0x6f, 0xe3, 0xf2, 0x36, 0x82, 0x6c, 0x81, + 0xfa, 0x84, 0x81, 0x01, 0xbf, 0xaa, 0xd5, 0x35, 0xff, 0xb5, 0x22, 0xd6, + 0xff, 0x97, 0xc9, 0xdd, 0x1e, 0x43, 0xb8, 0x2c, 0xce, 0x29, 0x21, 0xd1, + 0x53, 0xc1, 0x54, 0x50, 0xc4, 0x72, 0x4f, 0xfd, 0x3e, 0xfd, 0xca, 0x57, + 0x8e, 0x01, 0x36, 0x50, 0xa0, 0x3a, 0x5c, 0xf5, 0x01, 0xfc, 0x58, 0x60, + 0x0f, 0xb5, 0xc8, 0x60, 0xc0, 0xef, 0x0c, 0xfe, 0x0a, 0xc0, 0x71, 0x2d, + 0x44, 0x13, 0x13, 0xdc, 0xa4, 0x1a, 0x4d, 0x7d, 0x41, 0x1e, 0x6c, 0x83, + 0xb2, 0x15, 0x17, 0x49, 0xd2, 0x8b, 0xe4, 0x69, 0x2f, 0x62, 0x37, 0x3d, + 0xb0, 0x7e, 0x4a, 0x79, 0x05, 0x1c, 0x56, 0x82, 0xec, 0x20, 0xd4, 0x91, + 0xc4, 0xcf, 0xc7, 0xbc, 0x14, 0x0f, 0x35, 0xfa, 0x15, 0xe5, 0xa1, 0xfa, + 0x75, 0x6d, 0x65, 0xb8, 0xef, 0x93, 0xad, 0xdf, 0x4c, 0x47, 0xc4, 0xa3, + 0x5b, 0x18, 0x4f, 0x22, 0xa1, 0xef, 0x08, 0x99, 0x48, 0xf9, 0x46, 0xf6, + 0xfa, 0xeb, 0x64, 0x70, 0xf2, 0x67, 0x46, 0xe6, 0x58, 0xcf, 0x9b, 0x41, + 0x77, 0x41, 0x78, 0x42, 0xe6, 0xd3, 0x73, 0x55, 0x80, 0x89, 0xaf, 0xf7, + 0x21, 0xb9, 0x30, 0xe9, 0xec, 0x61, 0xb4, 0xf6, 0xa0, 0x2c, 0x05, 0x2c, + 0x69, 0x24, 0xd3, 0x9a, 0x5b, 0xbb, 0x15, 0xed, 0x11, 0x06, 0xc4, 0x01, + 0x0f, 0x4d, 0xd6, 0x9c, 0x79, 0xd0, 0x42, 0xc8, 0xb3, 0x16, 0x61, 0xb1, + 0xee, 0x48, 0x6b, 0xc6, 0x9d, 0xb5, 0xf2, 0xf0, 0x7a, 0x50, 0xd8, 0x5b, + 0x20, 0x69, 0x9d, 0x60, 0x13, 0x15, 0x62, 0x5b, 0xb8, 0x69, 0x62, 0x9c, + 0x7f, 0x4c, 0x5d, 0x48, 0xb2, 0x11, 0xd0, 0x97, 0xf4, 0x38, 0xac, 0xec, + 0x95, 0x97, 0x3a, 0x38, 0xd4, 0x21, 0x09, 0x0a, 0xf0, 0xf1, 0x34, 0x84, + 0xe4, 0xe9, 0x4b, 0x8c, 0xb5, 0xef, 0xc1, 0x85, 0x07, 0xf4, 0xb9, 0x31, + 0xdf, 0x39, 0x98, 0x7f, 0xfb, 0x28, 0x30, 0x29, 0x3e, 0x4d, 0xa3, 0x81, + 0xaa, 0xf7, 0x0b, 0x32, 0x92, 0x95, 0x2e, 0xf9, 0x34, 0xe2, 0xb4, 0x0f, + 0xde, 0xbb, 0xa3, 0xd9, 0x70, 0x1b, 0x76, 0xe1, 0xbe, 0x54, 0x82, 0x74, + 0xb2, 0x60, 0x2d, 0x88, 0x85, 0x37, 0x48, 0x2d, 0x02, 0x03, 0x01, 0x00, + 0x01, 0x02, 0x82, 0x02, 0x00, 0x1a, 0x94, 0x3e, 0x9c, 0x00, 0x89, 0xf0, + 0xaa, 0x01, 0x16, 0x04, 0x8a, 0x96, 0xab, 0xb4, 0x86, 0x32, 0x1a, 0x86, + 0x91, 0x6f, 0x82, 0xfb, 0x35, 0x24, 0x60, 0x78, 0x9f, 0xcf, 0xb1, 0x40, + 0x05, 0x50, 0x85, 0x3e, 0x5a, 0xfe, 0xdc, 0x9a, 0xd6, 0xe8, 0x77, 0x25, + 0x9c, 0xc4, 0xfe, 0xb0, 0x93, 0xc2, 0x4b, 0x96, 0x85, 0x34, 0xf8, 0x9a, + 0xbb, 0x5f, 0x48, 0xae, 0xd8, 0xad, 0x3c, 0x4b, 0xb1, 0xcb, 0xa7, 0xcd, + 0x7c, 0x1c, 0x72, 0x4d, 0x3d, 0xae, 0x36, 0x77, 0x00, 0x10, 0xb5, 0x06, + 0x8a, 0x33, 0x4f, 0x2b, 0x3e, 0xe7, 0x20, 0xc9, 0xf9, 0xed, 0x32, 0x00, + 0x01, 0xf3, 0xf5, 0x87, 0xf5, 0x66, 0x2f, 0x93, 0x9e, 0x60, 0x5d, 0xf5, + 0x19, 0x34, 0x3d, 0x60, 0xc0, 0x63, 0x5c, 0xcd, 0x32, 0xb1, 0x88, 0xbc, + 0x55, 0xf5, 0xd4, 0x34, 0x17, 0x3c, 0x9e, 0x6d, 0xb2, 0x19, 0x93, 0x41, + 0xaf, 0x83, 0x39, 0x90, 0xe5, 0x02, 0x46, 0xf9, 0x9c, 0xdd, 0xf7, 0x9d, + 0xd2, 0xc3, 0x5b, 0xab, 0xe1, 0x4c, 0x10, 0x3a, 0x76, 0xb8, 0xd2, 0xd9, + 0x8d, 0x73, 0x52, 0x8f, 0x98, 0xc2, 0x49, 0xb0, 0xa1, 0xf0, 0x91, 0x55, + 0xb3, 0x1f, 0x59, 0x9f, 0xc8, 0x33, 0x54, 0x24, 0x22, 0xa2, 0x34, 0x26, + 0x23, 0xbb, 0xbe, 0xf4, 0xac, 0x7e, 0xe6, 0x05, 0xe2, 0xcd, 0xec, 0xf0, + 0x1f, 0xea, 0x25, 0x68, 0x3b, 0xd4, 0xf6, 0x6c, 0xa9, 0x24, 0xcc, 0xef, + 0x00, 0x41, 0x8a, 0xdf, 0xf7, 0x30, 0xc4, 0x71, 0x4f, 0x66, 0xff, 0xa2, + 0xaf, 0x0d, 0xa3, 0xe5, 0xdf, 0x7f, 0x53, 0x9c, 0x63, 0x42, 0x89, 0xfc, + 0x12, 0xbc, 0x24, 0x09, 0x3e, 0xc8, 0xf0, 0xec, 0x18, 0x0a, 0xf0, 0x90, + 0x7c, 0xec, 0x1e, 0xbe, 0xc9, 0x11, 0xfa, 0x18, 0x0f, 0xb5, 0xf3, 0xc8, + 0x0e, 0xd8, 0x52, 0x89, 0x6a, 0xd6, 0xe6, 0xb3, 0xec, 0xcb, 0x44, 0xde, + 0x62, 0x19, 0x3d, 0x52, 0x11, 0x8c, 0xab, 0x2b, 0x17, 0x10, 0x71, 0xd5, + 0xfd, 0xaa, 0x7c, 0x42, 0x88, 0xfc, 0x77, 0x66, 0xd5, 0x77, 0x74, 0xf4, + 0xbe, 0x46, 0x15, 0x1b, 0xb9, 0x0a, 0xce, 0x7c, 0x10, 0xc2, 0x15, 0xf6, + 0x2e, 0xd2, 0x6e, 0x52, 0xe6, 0x12, 0x24, 0x36, 0xf5, 0x32, 0xbd, 0x54, + 0xfc, 0x08, 0x27, 0x2a, 0xdb, 0x21, 0x6a, 0x2d, 0xb4, 0x33, 0xd5, 0x69, + 0x9c, 0x40, 0xad, 0x58, 0xfa, 0xa2, 0x66, 0x08, 0x98, 0xff, 0xcc, 0xfc, + 0x98, 0x00, 0x2f, 0x8b, 0xb0, 0x36, 0x1b, 0x4c, 0xf9, 0xed, 0x6e, 0x93, + 0xc1, 0xca, 0x96, 0xd3, 0x4a, 0x1e, 0xf4, 0x04, 0x60, 0xf8, 0x59, 0x18, + 0xcf, 0xde, 0x4a, 0x81, 0x93, 0xb5, 0x1e, 0xce, 0xa4, 0xb3, 0x90, 0x3c, + 0xae, 0x92, 0x4a, 0x8f, 0xad, 0x5f, 0x83, 0x08, 0x95, 0x4c, 0x9f, 0x19, + 0xa7, 0x59, 0x7b, 0xf0, 0xa7, 0x51, 0x26, 0xa5, 0x57, 0xe4, 0x9f, 0x8b, + 0xbd, 0x31, 0xfc, 0x4e, 0x85, 0x56, 0xf2, 0x30, 0x64, 0x0b, 0xf3, 0x62, + 0x04, 0xc6, 0xcf, 0x3d, 0x56, 0xdc, 0xa5, 0xa4, 0x1d, 0x86, 0x03, 0x07, + 0xba, 0x67, 0x05, 0xa6, 0x98, 0x68, 0x11, 0x00, 0xa3, 0x27, 0xf9, 0x17, + 0x39, 0xc4, 0x86, 0xc4, 0x70, 0xba, 0x71, 0xd0, 0x3d, 0x28, 0x53, 0x14, + 0xb0, 0xd7, 0xd0, 0x40, 0x08, 0xe0, 0x3f, 0x2a, 0x2b, 0x85, 0xe7, 0xc2, + 0x43, 0xd6, 0xfd, 0x9b, 0x97, 0xa0, 0x21, 0x68, 0xc0, 0x69, 0xec, 0x57, + 0x2d, 0x3f, 0x0c, 0xa1, 0x5e, 0xbc, 0xb1, 0x73, 0x9f, 0x3a, 0x0b, 0x3c, + 0x14, 0x7a, 0x88, 0xe0, 0xb7, 0x4f, 0x45, 0xa0, 0x07, 0xae, 0x92, 0x7d, + 0x6f, 0x82, 0x2b, 0xf5, 0x0b, 0x87, 0xb1, 0xe9, 0x3f, 0xe7, 0xd9, 0x18, + 0x0b, 0xc6, 0xbc, 0x12, 0xbd, 0xe6, 0xc8, 0x07, 0x0d, 0x10, 0xc9, 0x73, + 0x31, 0x02, 0x82, 0x01, 0x01, 0x00, 0xf5, 0x0e, 0xbc, 0xea, 0xc9, 0xd3, + 0xc6, 0x44, 0x82, 0xa8, 0xc2, 0x65, 0xd6, 0x36, 0x54, 0x61, 0xaa, 0x4a, + 0x31, 0xa6, 0xa7, 0x63, 0x3a, 0x24, 0xc8, 0xe3, 0x47, 0x94, 0xec, 0xdf, + 0xca, 0xb1, 0xd6, 0xb5, 0x2f, 0xb6, 0xa5, 0xf3, 0x80, 0x55, 0xcc, 0x32, + 0xd6, 0xa6, 0x1b, 0x88, 0x95, 0x50, 0xde, 0x27, 0xb3, 0xd0, 0xbd, 0x68, + 0xb6, 0xd4, 0xfd, 0xa0, 0x41, 0x59, 0x8a, 0xb9, 0x88, 0x87, 0x14, 0x39, + 0x88, 0x57, 0x68, 0x06, 0xb1, 0xc4, 0x87, 0x20, 0x79, 0x49, 0x02, 0x95, + 0x2e, 0xbe, 0x1b, 0xf0, 0xde, 0xf6, 0x5a, 0x0e, 0x6f, 0x94, 0x06, 0x70, + 0x56, 0xe6, 0x86, 0x4f, 0xa2, 0x88, 0x2e, 0x3a, 0x16, 0xf2, 0x46, 0x28, + 0x20, 0x93, 0xd0, 0x37, 0x63, 0x90, 0x78, 0x18, 0x2d, 0xd0, 0xa6, 0xeb, + 0x21, 0xd3, 0xba, 0xd0, 0x63, 0x79, 0x01, 0xa2, 0x68, 0xb1, 0x4c, 0x63, + 0x2c, 0x9d, 0x0b, 0x16, 0x90, 0xed, 0x88, 0xab, 0xdd, 0xe0, 0x3f, 0x52, + 0x82, 0x47, 0xaa, 0x2e, 0x41, 0x55, 0x7d, 0x08, 0x65, 0xad, 0x34, 0xe5, + 0x3f, 0xf5, 0x3a, 0xe0, 0xe5, 0xde, 0xa1, 0x95, 0xd9, 0x3f, 0xe6, 0x5c, + 0x25, 0x87, 0x1f, 0x6f, 0x23, 0xad, 0xf3, 0x4b, 0x6e, 0x96, 0x0c, 0x29, + 0x78, 0xf2, 0xb7, 0x47, 0x5d, 0xaf, 0xce, 0x6c, 0xbb, 0x26, 0xa5, 0x39, + 0x34, 0xd2, 0x6c, 0x19, 0x3d, 0x67, 0xf3, 0x2d, 0xe9, 0x10, 0x35, 0xee, + 0xb8, 0x90, 0x22, 0xbe, 0xb7, 0xd5, 0xdf, 0x78, 0x4a, 0xc2, 0x0c, 0xa6, + 0xab, 0x91, 0xbf, 0x6b, 0x77, 0x5b, 0x6c, 0x94, 0x16, 0xf6, 0x05, 0xb4, + 0x84, 0x17, 0x36, 0xcb, 0xfb, 0xd2, 0x2a, 0xd9, 0x8a, 0xb2, 0xe8, 0x42, + 0x84, 0x57, 0xe0, 0x79, 0x3f, 0x5a, 0xf4, 0x0e, 0x55, 0x0b, 0x48, 0x76, + 0x5d, 0x59, 0xe6, 0xe1, 0xb4, 0xa4, 0xa1, 0xf5, 0x71, 0xf1, 0x02, 0x82, + 0x01, 0x01, 0x00, 0xd5, 0xa9, 0x1d, 0x4d, 0x44, 0xbb, 0x9b, 0x73, 0xc1, + 0xfe, 0x02, 0x48, 0x92, 0x5e, 0x2c, 0x0e, 0xc1, 0xde, 0x51, 0x39, 0x0b, + 0xd8, 0xa7, 0x3b, 0x45, 0x3d, 0xa5, 0x1a, 0xe2, 0x93, 0x25, 0xae, 0x76, + 0x57, 0x08, 0x9f, 0xd4, 0xee, 0x4a, 0x2f, 0xd9, 0x6e, 0x34, 0x5b, 0x57, + 0xf6, 0x72, 0xd7, 0xd4, 0x84, 0xfd, 0xe9, 0x91, 0x89, 0xab, 0x0a, 0x63, + 0x65, 0xbf, 0x2b, 0x38, 0x68, 0x0d, 0x6b, 0xb9, 0x47, 0xf4, 0xb2, 0x17, + 0xbe, 0x66, 0x03, 0x23, 0xc2, 0x6b, 0x86, 0xd6, 0x43, 0xae, 0x68, 0x6d, + 0x82, 0xe3, 0x6e, 0xc0, 0x0c, 0xfd, 0x03, 0x89, 0x42, 0x44, 0x3c, 0xaa, + 0x04, 0xa0, 0xf9, 0x1e, 0x68, 0xec, 0x71, 0x79, 0x35, 0xb4, 0x5e, 0x79, + 0x03, 0x11, 0xbe, 0x56, 0x44, 0x0d, 0x71, 0x76, 0x94, 0x95, 0x94, 0x68, + 0x8e, 0xd1, 0xdd, 0x5c, 0x91, 0x03, 0xc5, 0x7c, 0x15, 0x8d, 0x05, 0xe4, + 0xc3, 0x7b, 0x98, 0xd8, 0x18, 0x98, 0x03, 0x07, 0x44, 0xa6, 0x4f, 0x6e, + 0xbd, 0xbf, 0x75, 0x0a, 0xab, 0x79, 0x75, 0x7e, 0x34, 0xda, 0xc4, 0x22, + 0x16, 0x3e, 0xa7, 0xc0, 0xf4, 0x2b, 0x97, 0x71, 0x0c, 0x86, 0x19, 0x78, + 0xb2, 0x41, 0x00, 0x38, 0x5a, 0xad, 0x72, 0x7e, 0x5f, 0x38, 0x36, 0xa7, + 0x4e, 0xa4, 0xbf, 0x1d, 0x36, 0xef, 0x2a, 0x5e, 0xdf, 0x9c, 0x9e, 0x8f, + 0x99, 0x6e, 0xf3, 0x19, 0x13, 0x48, 0x45, 0x0e, 0xa9, 0xf1, 0xd4, 0xa6, + 0x3d, 0xb2, 0x9c, 0xb0, 0x6f, 0x63, 0xe5, 0xba, 0xdb, 0x18, 0xe4, 0xd4, + 0x0f, 0x51, 0x12, 0xb6, 0x58, 0xd1, 0xcc, 0x23, 0xcb, 0x65, 0x38, 0x8a, + 0xca, 0x03, 0xd1, 0x41, 0xa6, 0xbc, 0x5f, 0xbd, 0x94, 0x29, 0xfe, 0x33, + 0xd3, 0x40, 0xd3, 0xe8, 0x5b, 0xfa, 0x84, 0x89, 0x08, 0xd6, 0x0b, 0x56, + 0x2f, 0x89, 0x4e, 0x8a, 0x33, 0x7d, 0xfd, 0x02, 0x82, 0x01, 0x01, 0x00, + 0xc4, 0x95, 0x0f, 0x0d, 0x95, 0xdc, 0x51, 0xd7, 0x91, 0xad, 0x09, 0x4d, + 0x22, 0x3b, 0x31, 0x13, 0xab, 0xc4, 0x9a, 0xf1, 0xe2, 0xa3, 0x61, 0xf8, + 0x32, 0x42, 0xc8, 0xa0, 0x7a, 0x28, 0xc8, 0x74, 0x43, 0x15, 0xd3, 0xf1, + 0xc4, 0x4c, 0x82, 0xed, 0xd0, 0xc2, 0x13, 0x98, 0xea, 0xcb, 0x75, 0x64, + 0x8a, 0xe1, 0xf4, 0x88, 0x85, 0xf9, 0x23, 0x79, 0xd6, 0xff, 0xa0, 0x8c, + 0xd1, 0x11, 0x26, 0xa9, 0x9d, 0x9a, 0xcd, 0x79, 0xb8, 0x94, 0x6e, 0x34, + 0x86, 0x65, 0x91, 0x85, 0xf5, 0x11, 0x71, 0x8e, 0xc5, 0xe1, 0x43, 0x2b, + 0x02, 0x71, 0x44, 0x26, 0xcd, 0xc7, 0x7e, 0x9e, 0xac, 0xad, 0xe3, 0x67, + 0x35, 0x16, 0x1a, 0x64, 0x3d, 0xcd, 0x60, 0xdc, 0xd2, 0x92, 0x2c, 0x47, + 0xaf, 0x5f, 0x4e, 0x19, 0x6c, 0x5d, 0x81, 0x24, 0x55, 0x5f, 0x67, 0xfc, + 0xa1, 0x48, 0x04, 0x8d, 0xfe, 0x06, 0x2c, 0xba, 0xca, 0x33, 0x4f, 0x0d, + 0x8d, 0xae, 0xb9, 0x6d, 0x73, 0xbe, 0x9f, 0x8e, 0x17, 0xc1, 0xc5, 0x5d, + 0x6b, 0xd0, 0xb9, 0xa7, 0xe9, 0x9f, 0xe1, 0xdf, 0xba, 0x5c, 0xc1, 0x6a, + 0x07, 0xdb, 0xaa, 0x8c, 0x6d, 0x22, 0x0c, 0x64, 0xc9, 0xdd, 0xa1, 0x14, + 0xa0, 0xf0, 0x29, 0x05, 0x2b, 0x3a, 0x75, 0xb0, 0xd7, 0x3f, 0xe3, 0xb2, + 0xed, 0x78, 0x21, 0xe5, 0xcd, 0x73, 0x07, 0xa1, 0xa9, 0x5f, 0xd1, 0xf7, + 0xba, 0x87, 0x60, 0xc8, 0x45, 0x4b, 0x7c, 0x38, 0xfb, 0xf6, 0x5c, 0x88, + 0xb0, 0x1c, 0xd2, 0x73, 0xba, 0x2c, 0x55, 0xc3, 0xb4, 0x77, 0xe4, 0x26, + 0xae, 0x02, 0x5a, 0x2c, 0xff, 0xc4, 0xa0, 0x95, 0xf2, 0xba, 0x4e, 0x07, + 0x79, 0xa2, 0x4b, 0x76, 0x5b, 0x85, 0x48, 0x9f, 0x2a, 0x0e, 0x79, 0xb9, + 0x5f, 0xc0, 0xc3, 0x8e, 0x2a, 0x91, 0xf1, 0x2e, 0xf6, 0x5c, 0xa7, 0x49, + 0xce, 0x36, 0x94, 0x31, 0x02, 0x82, 0x01, 0x00, 0x2a, 0xa4, 0x8e, 0x0c, + 0x95, 0xe3, 0x3b, 0xab, 0x66, 0xd4, 0x63, 0x70, 0x48, 0x86, 0x33, 0x14, + 0xde, 0xec, 0x98, 0x19, 0x62, 0x9b, 0xe3, 0x04, 0x99, 0x55, 0x2c, 0x56, + 0xa9, 0x51, 0xe4, 0xfb, 0x64, 0xf3, 0x09, 0xed, 0x9c, 0x79, 0xd2, 0xa4, + 0xaa, 0x28, 0xac, 0x9a, 0x6e, 0x7b, 0xe9, 0x7f, 0xda, 0x12, 0x90, 0xfa, + 0xc4, 0xe9, 0x4d, 0x11, 0xcd, 0xb4, 0xc8, 0xea, 0xbf, 0x5f, 0x45, 0x0e, + 0x72, 0xf4, 0x41, 0x8a, 0x29, 0xe2, 0xfe, 0x49, 0x32, 0x21, 0xe3, 0x84, + 0x0d, 0xcf, 0x84, 0x47, 0xa3, 0x53, 0xb4, 0x40, 0xae, 0x63, 0xe9, 0x3b, + 0x83, 0x71, 0x8e, 0x5c, 0xed, 0x31, 0xef, 0x4e, 0xc9, 0x1a, 0xf7, 0xd5, + 0xcd, 0xf3, 0x42, 0x04, 0x78, 0xf2, 0x7b, 0xe0, 0x19, 0x27, 0x8b, 0xe7, + 0x51, 0x5b, 0x66, 0x5f, 0x30, 0x5f, 0x10, 0xd3, 0xb5, 0x5d, 0xdb, 0xfa, + 0xd6, 0x41, 0x16, 0xdc, 0x4e, 0x44, 0x15, 0xae, 0xf3, 0xb2, 0x34, 0xe4, + 0xa5, 0xd6, 0xb5, 0xba, 0xb4, 0xc7, 0x7a, 0x26, 0xc9, 0xf2, 0x5f, 0x53, + 0x6b, 0xd4, 0xf0, 0xb4, 0xa4, 0x78, 0xfc, 0x18, 0x4f, 0x12, 0x6c, 0x80, + 0xd5, 0x37, 0x42, 0xac, 0x62, 0xc2, 0x70, 0xe6, 0xb2, 0x58, 0xa6, 0xb5, + 0x6b, 0x33, 0x65, 0xec, 0xc2, 0x87, 0x97, 0xa9, 0xed, 0x12, 0xc1, 0xb9, + 0x1b, 0x26, 0x56, 0x03, 0xef, 0x75, 0x18, 0x07, 0xbc, 0xc1, 0x74, 0x73, + 0x13, 0xf2, 0x27, 0x29, 0xe1, 0xe3, 0xfe, 0x79, 0xf7, 0x5c, 0xc3, 0xfb, + 0x5d, 0xc7, 0xcc, 0xb8, 0x1e, 0xfa, 0xcf, 0x9b, 0x84, 0x79, 0x45, 0xa6, + 0x10, 0x9e, 0xcf, 0x9c, 0xf1, 0x56, 0x50, 0x5c, 0xbb, 0x55, 0xa3, 0xd3, + 0x17, 0xeb, 0x32, 0x56, 0x61, 0xd1, 0x8f, 0xe6, 0xbb, 0x41, 0x60, 0x46, + 0x83, 0x73, 0x18, 0x05, 0x3b, 0x36, 0x51, 0x99, 0x33, 0x4c, 0x03, 0xa1, + 0x02, 0x82, 0x01, 0x01, 0x00, 0xee, 0x63, 0x70, 0x60, 0x30, 0xa4, 0xec, + 0xe9, 0xfe, 0x3b, 0xdd, 0xcf, 0xc4, 0x9f, 0x5a, 0x83, 0xf3, 0x7f, 0x63, + 0xeb, 0xcb, 0x29, 0xdb, 0xdc, 0x99, 0x9f, 0x6f, 0xf5, 0x4b, 0x59, 0x6f, + 0x11, 0x5c, 0xf1, 0xec, 0xa0, 0x99, 0x90, 0x10, 0x8a, 0x43, 0x95, 0x18, + 0xe9, 0x96, 0xf6, 0x89, 0xfd, 0xde, 0x89, 0xb2, 0xc6, 0x7e, 0xdc, 0x04, + 0xbf, 0x8e, 0x36, 0x67, 0x34, 0xc2, 0xae, 0x30, 0x17, 0xec, 0x14, 0xe0, + 0x42, 0x05, 0x0e, 0x7c, 0x65, 0x68, 0x40, 0x14, 0x6c, 0xa0, 0x48, 0x39, + 0x4d, 0xce, 0xbe, 0x90, 0xdd, 0x21, 0x95, 0x34, 0x9b, 0xba, 0xd3, 0x06, + 0x56, 0x90, 0x31, 0xb2, 0xef, 0x6e, 0x91, 0x71, 0xd2, 0xae, 0x77, 0x97, + 0xc8, 0x84, 0x4e, 0x54, 0x83, 0x94, 0xca, 0x3b, 0x76, 0x8d, 0x84, 0x96, + 0xe9, 0x9e, 0xf6, 0x3a, 0xbb, 0x59, 0xb0, 0xff, 0x7f, 0xc7, 0x0e, 0xb5, + 0x31, 0x53, 0xdd, 0x0f, 0x59, 0x01, 0x8a, 0x27, 0x5a, 0xcb, 0xa7, 0x01, + 0xf2, 0xc7, 0x6a, 0x15, 0xc8, 0x94, 0xf5, 0x34, 0x61, 0xfe, 0xdf, 0x65, + 0xbc, 0x25, 0xc2, 0xc5, 0xce, 0xc3, 0x96, 0xe5, 0x56, 0xa1, 0xa9, 0x19, + 0xbc, 0x7a, 0x05, 0x63, 0x93, 0xd5, 0x06, 0x44, 0x12, 0x6d, 0xcd, 0xef, + 0x92, 0x56, 0x64, 0x2e, 0x65, 0xa6, 0x04, 0x3c, 0xbc, 0xe9, 0x49, 0x7e, + 0x19, 0x2c, 0xf2, 0xcb, 0x33, 0x64, 0x8e, 0x11, 0x7f, 0x41, 0xdb, 0xf0, + 0x19, 0x00, 0xac, 0xb9, 0x3b, 0x0c, 0x78, 0xdd, 0xf3, 0x1f, 0x38, 0x1f, + 0x4d, 0xb3, 0xf9, 0xcc, 0xbb, 0xb6, 0x90, 0x93, 0xda, 0xbf, 0x2e, 0x89, + 0xdb, 0xbc, 0x0c, 0xb7, 0x2f, 0x20, 0xc0, 0x05, 0xa2, 0x51, 0x9e, 0x3a, + 0x87, 0x41, 0x46, 0x49, 0x5d, 0x7a, 0xac, 0xf3, 0x41, 0x6a, 0x42, 0x2e, + 0x56, 0x09, 0x86, 0xf2, 0x2f, 0x39, 0x45, 0x6e, 0x7f, }; -const unsigned char test_ec_secp192r1[] = { - 0x30, 0x5f, 0x02, 0x01, 0x01, 0x04, 0x18, 0xeb, 0x6a, 0x83, 0xe7, 0x5b, - 0xa1, 0x5e, 0x13, 0x8b, 0xea, 0x23, 0x89, 0x4a, 0xf9, 0xa6, 0xd9, 0x9e, - 0x1b, 0xba, 0x51, 0xf7, 0xa9, 0xf3, 0xa8, 0xa0, 0x0a, 0x06, 0x08, 0x2a, - 0x86, 0x48, 0xce, 0x3d, 0x03, 0x01, 0x01, 0xa1, 0x34, 0x03, 0x32, 0x00, - 0x04, 0xb4, 0x64, 0x38, 0xcb, 0xf9, 0x1b, 0x96, 0x35, 0x67, 0xbd, 0x99, - 0x1b, 0xc0, 0x57, 0xf8, 0xb8, 0xc9, 0x53, 0xa5, 0x81, 0x04, 0xe4, 0x69, - 0xec, 0x55, 0xdd, 0x0e, 0x25, 0x90, 0xa4, 0xe7, 0x47, 0x66, 0x94, 0x3b, - 0x98, 0x68, 0xb8, 0x1b, 0xd9, 0x8e, 0x92, 0x2f, 0x48, 0x56, 0x60, 0x07, - 0xea, +const unsigned char test_ec_secp192r1_priv[] = { + 0xd8, 0x3b, 0x57, 0xa5, 0x9c, 0x51, 0x35, 0x8d, 0x9c, 0x8b, 0xbb, 0x89, + 0x8a, 0xff, 0x50, 0x7f, 0x44, 0xdd, 0x14, 0xcf, 0x16, 0x91, 0x71, 0x90, }; -const unsigned char test_ec_secp224r1[] = { - 0x30, 0x68, 0x02, 0x01, 0x01, 0x04, 0x1c, 0x1e, 0xec, 0x90, 0x48, 0xba, - 0x1e, 0x64, 0xf1, 0x21, 0x61, 0x28, 0xb7, 0x96, 0xa5, 0xd8, 0x5a, 0x4e, - 0x1c, 0x99, 0x6b, 0xd8, 0x2a, 0xcd, 0x8d, 0x04, 0x52, 0x08, 0xcc, 0xa0, - 0x07, 0x06, 0x05, 0x2b, 0x81, 0x04, 0x00, 0x21, 0xa1, 0x3c, 0x03, 0x3a, - 0x00, 0x04, 0xc2, 0xf0, 0x4f, 0x21, 0x05, 0xb4, 0x59, 0xa2, 0xba, 0x90, - 0x37, 0x4f, 0x7b, 0x1d, 0x63, 0x96, 0xb4, 0x39, 0xa0, 0x6f, 0x00, 0x44, - 0xdc, 0xc5, 0xe1, 0x85, 0x05, 0x3b, 0x58, 0xde, 0xbf, 0x9e, 0xb6, 0xe4, - 0x1e, 0x25, 0x96, 0xef, 0x90, 0x53, 0x1e, 0x86, 0x42, 0xa0, 0x64, 0x55, - 0x42, 0x3a, 0x76, 0x05, 0xfc, 0x6c, 0x01, 0xc3, 0x98, 0xbb, +const unsigned char test_ec_secp192r1_pub[] = { + 0x04, 0xe3, 0x5f, 0xcb, 0xee, 0x11, 0xce, 0xc3, 0x15, 0x4f, 0x80, 0xa1, + 0xa6, 0x1d, 0xf7, 0xd7, 0x61, 0x2d, 0xe4, 0xf2, 0xfd, 0x70, 0xc5, 0x60, + 0x8d, 0x0e, 0xe3, 0xa4, 0xa1, 0xa5, 0x71, 0x94, 0x71, 0xad, 0xb3, 0x39, + 0x66, 0xdd, 0x9b, 0x03, 0x5f, 0xdb, 0x77, 0x4f, 0xee, 0xba, 0x94, 0xb0, + 0x4c, }; -const unsigned char test_ec_secp256r1[] = { - 0x30, 0x77, 0x02, 0x01, 0x01, 0x04, 0x20, 0xed, 0x96, 0xc5, 0x3c, 0x6c, - 0xde, 0x36, 0x87, 0x3c, 0xfa, 0x5c, 0xe5, 0xa7, 0x0d, 0x52, 0x05, 0x66, - 0x9d, 0xf5, 0xf0, 0x59, 0x40, 0x68, 0x9a, 0x6a, 0xe6, 0x6e, 0x04, 0xa9, - 0x15, 0x30, 0x36, 0xa0, 0x0a, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d, - 0x03, 0x01, 0x07, 0xa1, 0x44, 0x03, 0x42, 0x00, 0x04, 0x2c, 0x8d, 0x41, - 0xbf, 0x8b, 0xfc, 0xde, 0x64, 0xd9, 0xa7, 0x06, 0x4c, 0xe9, 0xe0, 0xe8, - 0xe7, 0x50, 0x62, 0x51, 0x9c, 0x68, 0xc3, 0x26, 0x2e, 0xd4, 0x86, 0xc2, - 0xbc, 0xc2, 0xa8, 0x44, 0x4b, 0x4e, 0xcb, 0xde, 0x33, 0xe1, 0xd3, 0x72, - 0x87, 0xe1, 0x18, 0xaa, 0x32, 0x36, 0xa3, 0x05, 0x4f, 0x2c, 0x47, 0x27, - 0x17, 0x60, 0x37, 0x31, 0x60, 0x28, 0x19, 0x8a, 0xeb, 0x05, 0x1e, 0x7b, - 0x60, +const unsigned char test_ec_secp224r1_priv[] = { + 0x87, 0x2f, 0x20, 0x3b, 0x3a, 0xd3, 0x5b, 0x7f, 0x2e, 0xcc, 0x80, 0x3c, + 0x3a, 0x0e, 0x1e, 0x0b, 0x1e, 0xd6, 0x1c, 0xc1, 0xaf, 0xe7, 0x1b, 0x18, + 0x9c, 0xd4, 0xc9, 0x95, }; -const unsigned char test_ec_secp384r1[] = { - 0x30, 0x81, 0xa4, 0x02, 0x01, 0x01, 0x04, 0x30, 0xa8, 0x88, 0x45, 0xb7, - 0x52, 0x1d, 0x21, 0x2c, 0x2c, 0x20, 0x48, 0x48, 0x51, 0x19, 0xf1, 0x09, - 0x5d, 0x1a, 0x55, 0x78, 0x06, 0x59, 0x71, 0xea, 0xfd, 0x17, 0x41, 0x82, - 0x49, 0x63, 0x9e, 0x62, 0xe1, 0x9c, 0xcc, 0x22, 0x69, 0xeb, 0xbb, 0x90, - 0x7e, 0xa0, 0x50, 0x65, 0xfd, 0x4b, 0xa1, 0x0c, 0xa0, 0x07, 0x06, 0x05, - 0x2b, 0x81, 0x04, 0x00, 0x22, 0xa1, 0x64, 0x03, 0x62, 0x00, 0x04, 0x74, - 0xa4, 0x5a, 0xa5, 0xb2, 0xfb, 0xb9, 0x21, 0x79, 0x0f, 0xa5, 0x91, 0xe5, - 0x31, 0x36, 0x28, 0x9d, 0xbf, 0x7e, 0x10, 0xae, 0x1b, 0x71, 0xd5, 0x84, - 0xd4, 0x5b, 0xb4, 0xca, 0x84, 0xa3, 0x7d, 0xbd, 0x0a, 0xa5, 0x71, 0xda, - 0x24, 0xad, 0x87, 0xa9, 0xaf, 0x72, 0x3c, 0xb7, 0x8e, 0x51, 0xa5, 0x15, - 0x8d, 0x9b, 0x92, 0xa8, 0xd1, 0x86, 0x86, 0xd2, 0x1a, 0x5a, 0x68, 0x4c, - 0x0a, 0x9c, 0x36, 0x04, 0x9e, 0xba, 0xa1, 0xc5, 0x98, 0x86, 0x07, 0x59, - 0xec, 0x63, 0xbe, 0x8f, 0x2a, 0x3a, 0xde, 0x15, 0x59, 0xfa, 0x55, 0xc7, - 0x92, 0xcd, 0x4f, 0xa4, 0x8a, 0xcc, 0x1e, 0xa7, 0x14, 0x9b, 0x73, +const unsigned char test_ec_secp224r1_pub[] = { + 0x04, 0x6f, 0x00, 0xea, 0xda, 0xa9, 0x49, 0xfe, 0xe3, 0xe9, 0xe1, 0xc7, + 0xfa, 0x12, 0x47, 0xee, 0xce, 0xc8, 0x6a, 0x0d, 0xce, 0x46, 0x41, 0x8b, + 0x9b, 0xd3, 0x11, 0x7b, 0x98, 0x1d, 0x4b, 0xd0, 0xae, 0x7a, 0x99, 0x0d, + 0xe9, 0x12, 0xf9, 0xd0, 0x60, 0xd6, 0xcb, 0x53, 0x1a, 0x42, 0xd2, 0x2e, + 0x39, 0x4a, 0xc2, 0x9e, 0x81, 0x80, 0x4b, 0xf1, 0x60, }; -const unsigned char test_ec_secp521r1[] = { - 0x30, 0x81, 0xdc, 0x02, 0x01, 0x01, 0x04, 0x42, 0x00, 0x13, 0x96, 0x0c, - 0x56, 0xec, 0x80, 0x5d, 0x78, 0x63, 0x67, 0x4c, 0xbd, 0xdc, 0xef, 0x69, - 0xc8, 0x74, 0xd6, 0xbe, 0x94, 0xb4, 0x36, 0x2f, 0xe5, 0x7b, 0x67, 0x1e, - 0x09, 0x74, 0xc4, 0x2b, 0xfd, 0x5a, 0xd7, 0xca, 0xec, 0xb7, 0x8e, 0xb1, - 0x09, 0xb8, 0xe1, 0xcf, 0x57, 0xd7, 0xe3, 0x6a, 0x57, 0xef, 0x84, 0xd7, - 0xf7, 0x4d, 0xaa, 0xf4, 0xd3, 0x53, 0x78, 0x1c, 0x95, 0xf7, 0x63, 0x1f, - 0xb1, 0x98, 0xa0, 0x07, 0x06, 0x05, 0x2b, 0x81, 0x04, 0x00, 0x23, 0xa1, - 0x81, 0x89, 0x03, 0x81, 0x86, 0x00, 0x04, 0x01, 0x20, 0xa9, 0xc9, 0x35, - 0x18, 0x71, 0x4b, 0x54, 0xb0, 0xd7, 0x2f, 0xcc, 0xdd, 0x7d, 0xec, 0x25, - 0x04, 0xa7, 0x2e, 0xda, 0x76, 0x8f, 0xb3, 0x77, 0xd6, 0xa5, 0xf8, 0x9e, - 0xea, 0x10, 0x58, 0xc4, 0x2c, 0xdb, 0xae, 0x78, 0xc3, 0x79, 0x04, 0x91, - 0xb4, 0x35, 0xa5, 0x26, 0xa5, 0x93, 0x2b, 0xda, 0x7a, 0xb1, 0xcf, 0x2f, - 0xc9, 0x66, 0xc7, 0xad, 0x89, 0x22, 0x49, 0xc6, 0x95, 0xcd, 0x66, 0xea, - 0x36, 0x01, 0xc5, 0x06, 0x75, 0xb0, 0xc7, 0x27, 0xa7, 0xa7, 0x89, 0xdc, - 0x97, 0x53, 0xa3, 0x74, 0xf8, 0xb7, 0xa7, 0xba, 0x25, 0x0d, 0x45, 0xa7, - 0x82, 0x5d, 0x8a, 0xb9, 0x3e, 0x43, 0x22, 0x34, 0xdf, 0x49, 0x23, 0x06, - 0xc3, 0xa5, 0x55, 0x45, 0xef, 0xdf, 0xaf, 0x68, 0x70, 0x69, 0x4f, 0x65, - 0x0a, 0xfb, 0xe8, 0xa8, 0xd9, 0xd1, 0x4c, 0x8b, 0x13, 0x7d, 0x43, 0xc5, - 0x8a, 0x87, 0x3d, 0x93, 0x5a, 0x66, 0xd5, +const unsigned char test_ec_secp256r1_priv[] = { + 0x49, 0xc9, 0xa8, 0xc1, 0x8c, 0x4b, 0x88, 0x56, 0x38, 0xc4, 0x31, 0xcf, + 0x1d, 0xf1, 0xc9, 0x94, 0x13, 0x16, 0x09, 0xb5, 0x80, 0xd4, 0xfd, 0x43, + 0xa0, 0xca, 0xb1, 0x7d, 0xb2, 0xf1, 0x3e, 0xee, }; -const unsigned char test_ec_bp256r1[] = { - 0x30, 0x78, 0x02, 0x01, 0x01, 0x04, 0x20, 0x4c, 0xb1, 0x0d, 0x0f, 0x90, - 0xe3, 0xae, 0x71, 0x43, 0x7a, 0xc8, 0x3a, 0x6d, 0x6f, 0x51, 0x35, 0x19, - 0xa4, 0x42, 0xe2, 0x47, 0x61, 0x4d, 0xfe, 0x1f, 0xe8, 0xf9, 0x61, 0x56, - 0x88, 0x87, 0x82, 0xa0, 0x0b, 0x06, 0x09, 0x2b, 0x24, 0x03, 0x03, 0x02, - 0x08, 0x01, 0x01, 0x07, 0xa1, 0x44, 0x03, 0x42, 0x00, 0x04, 0x04, 0x7e, - 0xaa, 0x53, 0x65, 0x4c, 0x1b, 0x46, 0x7c, 0x10, 0x89, 0x58, 0xb8, 0xd8, - 0xd7, 0xaa, 0x09, 0x4f, 0xe4, 0x65, 0xc8, 0x03, 0xa0, 0x6f, 0x1a, 0xf0, - 0x4e, 0x95, 0xa4, 0xe0, 0x6c, 0xaf, 0x82, 0x8f, 0x2b, 0xa7, 0x32, 0xca, - 0x77, 0x7c, 0x60, 0xed, 0xc1, 0x02, 0x33, 0x35, 0xec, 0x0f, 0x7b, 0x92, - 0x0b, 0xfa, 0x8e, 0x4f, 0x25, 0xd4, 0x6d, 0xd9, 0x5c, 0xa9, 0x65, 0x22, - 0x3d, 0x38, +const unsigned char test_ec_secp256r1_pub[] = { + 0x04, 0x77, 0x72, 0x65, 0x6f, 0x81, 0x4b, 0x39, 0x92, 0x79, 0xd5, 0xe1, + 0xf1, 0x78, 0x1f, 0xac, 0x6f, 0x09, 0x9a, 0x3c, 0x5c, 0xa1, 0xb0, 0xe3, + 0x53, 0x51, 0x83, 0x4b, 0x08, 0xb6, 0x5e, 0x0b, 0x57, 0x25, 0x90, 0xcd, + 0xaf, 0x8f, 0x76, 0x93, 0x61, 0xbc, 0xf3, 0x4a, 0xcf, 0xc1, 0x1e, 0x5e, + 0x07, 0x4e, 0x84, 0x26, 0xbd, 0xde, 0x04, 0xbe, 0x6e, 0x65, 0x39, 0x45, + 0x44, 0x96, 0x17, 0xde, 0x45, }; -const unsigned char test_ec_bp384r1[] = { - 0x30, 0x81, 0xa8, 0x02, 0x01, 0x01, 0x04, 0x30, 0x25, 0xe5, 0x2b, 0x86, - 0xfe, 0xd0, 0x4b, 0xac, 0x1e, 0x91, 0x10, 0x8e, 0xe4, 0xb7, 0x22, 0xe5, - 0xa8, 0xcc, 0x9a, 0x3a, 0xe7, 0x54, 0x04, 0x08, 0xda, 0x45, 0x0b, 0xf4, - 0x2f, 0x7a, 0x9b, 0x04, 0xa9, 0xcf, 0x37, 0x1b, 0xf4, 0x6c, 0x98, 0x79, - 0xd6, 0x8e, 0x8c, 0x8e, 0x39, 0x9d, 0x09, 0x31, 0xa0, 0x0b, 0x06, 0x09, - 0x2b, 0x24, 0x03, 0x03, 0x02, 0x08, 0x01, 0x01, 0x0b, 0xa1, 0x64, 0x03, - 0x62, 0x00, 0x04, 0x1f, 0xf8, 0x30, 0xb5, 0x6e, 0x08, 0xa2, 0xf8, 0xc1, - 0x19, 0x86, 0xb1, 0x64, 0x9b, 0xd0, 0x68, 0x84, 0x3c, 0x7a, 0x40, 0xe3, - 0x56, 0x95, 0xa1, 0x24, 0x49, 0x7a, 0x36, 0xb8, 0x6a, 0x4d, 0x55, 0x61, - 0x04, 0x82, 0x5b, 0xfd, 0xe0, 0xf1, 0x2c, 0x88, 0x84, 0xed, 0xfb, 0x37, - 0x8a, 0x07, 0xf7, 0x89, 0xfa, 0x95, 0x07, 0x21, 0xbb, 0x66, 0x44, 0x46, - 0x63, 0x80, 0x61, 0x09, 0x06, 0xfd, 0x7e, 0xfd, 0x41, 0xae, 0x86, 0x98, - 0xa9, 0x05, 0xb2, 0x31, 0x49, 0xca, 0xad, 0x14, 0x8b, 0xb5, 0x8c, 0x7c, - 0x2b, 0x16, 0x66, 0x1e, 0x18, 0x7b, 0xa3, 0x52, 0xbc, 0x5d, 0x26, 0x1e, - 0x70, 0xdb, 0x11, +const unsigned char test_ec_secp384r1_priv[] = { + 0x3f, 0x5d, 0x8d, 0x9b, 0xe2, 0x80, 0xb5, 0x69, 0x6c, 0xc5, 0xcc, 0x9f, + 0x94, 0xcf, 0x8a, 0xf7, 0xe6, 0xb6, 0x1d, 0xd6, 0x59, 0x2b, 0x2a, 0xb2, + 0xb3, 0xa4, 0xc6, 0x07, 0x45, 0x04, 0x17, 0xec, 0x32, 0x7d, 0xcd, 0xca, + 0xed, 0x7c, 0x10, 0x05, 0x3d, 0x71, 0x9a, 0x05, 0x74, 0xf0, 0xa7, 0x6a, }; -const unsigned char test_ec_bp512r1[] = { - 0x30, 0x81, 0xda, 0x02, 0x01, 0x01, 0x04, 0x40, 0x92, 0xcd, 0x27, 0xe6, - 0x7a, 0xdc, 0x76, 0x4e, 0xb0, 0x70, 0xb5, 0xae, 0x1e, 0xf2, 0x2a, 0x0e, - 0x8b, 0xc0, 0xa6, 0x42, 0x2e, 0x23, 0xd8, 0xc1, 0x65, 0x3b, 0x45, 0x95, - 0xf2, 0xd0, 0xed, 0xeb, 0x48, 0x8a, 0x9c, 0x32, 0xcf, 0xb0, 0x03, 0x66, - 0x65, 0xf9, 0xed, 0x60, 0x39, 0x06, 0xff, 0x8e, 0x9d, 0xd3, 0x39, 0xa7, - 0x49, 0x7e, 0xf7, 0xd1, 0xe2, 0xb9, 0xb0, 0x6c, 0x48, 0x76, 0x01, 0xb8, - 0xa0, 0x0b, 0x06, 0x09, 0x2b, 0x24, 0x03, 0x03, 0x02, 0x08, 0x01, 0x01, - 0x0d, 0xa1, 0x81, 0x85, 0x03, 0x81, 0x82, 0x00, 0x04, 0x30, 0xb4, 0xb1, - 0x4d, 0xea, 0xed, 0xf9, 0x32, 0xff, 0xe1, 0xdb, 0x96, 0xd7, 0x34, 0xd4, - 0x6b, 0x3e, 0xad, 0xf5, 0xfa, 0x0b, 0xdd, 0x5d, 0x41, 0x56, 0xfd, 0x2d, - 0x8e, 0x2b, 0x84, 0x2f, 0xc0, 0xe4, 0xba, 0xed, 0x53, 0x2c, 0x4c, 0xeb, - 0x14, 0xe3, 0x89, 0x92, 0x66, 0xdc, 0x61, 0x3a, 0xda, 0xb9, 0xb9, 0x8c, - 0xc7, 0x41, 0x74, 0xba, 0x40, 0x54, 0xef, 0xce, 0x38, 0xc9, 0x0a, 0xeb, - 0x70, 0x01, 0x30, 0xf8, 0x18, 0x7e, 0x8c, 0x39, 0x16, 0xfc, 0xef, 0x10, - 0x7f, 0x16, 0xe2, 0x52, 0xba, 0x8f, 0x37, 0xdf, 0x23, 0x72, 0xe2, 0xd9, - 0x90, 0x7a, 0x51, 0xc3, 0x44, 0x8a, 0x6e, 0x92, 0x79, 0x7b, 0x66, 0x22, - 0xa9, 0x7e, 0xef, 0xef, 0x8d, 0x10, 0x23, 0x95, 0x97, 0xd7, 0x28, 0x28, - 0x4c, 0x89, 0xcb, 0x14, 0xe2, 0x89, 0x09, 0xe8, 0x05, 0x07, 0x0f, 0x6a, - 0x3f, 0xad, 0x84, 0xb3, 0x0b, +const unsigned char test_ec_secp384r1_pub[] = { + 0x04, 0xd9, 0xc6, 0x62, 0xb5, 0x0b, 0xa2, 0x9c, 0xa4, 0x79, 0x90, 0x45, + 0x0e, 0x04, 0x3a, 0xea, 0xf4, 0xf0, 0xc6, 0x9b, 0x15, 0x67, 0x6d, 0x11, + 0x2f, 0x62, 0x2a, 0x71, 0xc9, 0x30, 0x59, 0xaf, 0x99, 0x96, 0x91, 0xc5, + 0x68, 0x0d, 0x2b, 0x44, 0xd1, 0x11, 0x57, 0x9d, 0xb1, 0x2f, 0x4a, 0x41, + 0x3a, 0x2e, 0xd5, 0xc4, 0x5f, 0xcf, 0xb6, 0x7b, 0x5b, 0x63, 0xe0, 0x0b, + 0x91, 0xeb, 0xe5, 0x9d, 0x09, 0xa6, 0xb1, 0xac, 0x2c, 0x0c, 0x42, 0x82, + 0xaa, 0x12, 0x31, 0x7e, 0xd5, 0x91, 0x4f, 0x99, 0x9b, 0xc4, 0x88, 0xbb, + 0x13, 0x2e, 0x83, 0x42, 0xcc, 0x36, 0xf2, 0xca, 0x5e, 0x33, 0x79, 0xc7, + 0x47, }; -const unsigned char test_ec_curve25519[] = { - 0x30, 0x2e, 0x02, 0x01, 0x00, 0x30, 0x05, 0x06, 0x03, 0x2b, 0x65, 0x6e, - 0x04, 0x22, 0x04, 0x20, 0xf0, 0x29, 0x67, 0x44, 0x79, 0x87, 0xc0, 0x63, - 0xe1, 0x20, 0xd5, 0x6f, 0x45, 0xc5, 0x94, 0x3a, 0xd1, 0x75, 0x2a, 0x77, - 0xa1, 0x86, 0x98, 0x65, 0xdd, 0xab, 0x63, 0x88, 0xe1, 0x2a, 0x66, 0x6e, +const unsigned char test_ec_secp521r1_priv[] = { + 0x01, 0xb1, 0xb6, 0xad, 0x07, 0xbb, 0x79, 0xe7, 0x32, 0x0d, 0xa5, 0x98, + 0x60, 0xea, 0x28, 0xe0, 0x55, 0x28, 0x4f, 0x60, 0x58, 0xf2, 0x79, 0xde, + 0x66, 0x6e, 0x06, 0xd4, 0x35, 0xd2, 0xaf, 0x7b, 0xda, 0x28, 0xd9, 0x9f, + 0xa4, 0x7b, 0x7d, 0xd0, 0x96, 0x3e, 0x16, 0xb0, 0x07, 0x30, 0x78, 0xee, + 0x8b, 0x8a, 0x38, 0xd9, 0x66, 0xa5, 0x82, 0xf4, 0x6d, 0x19, 0xff, 0x95, + 0xdf, 0x3a, 0xd9, 0x68, 0x5a, 0xae, }; -const unsigned char test_ec_secp192k1[] = { - 0x30, 0x5c, 0x02, 0x01, 0x01, 0x04, 0x18, 0x30, 0xaa, 0xb8, 0xb2, 0x51, - 0x9e, 0xf6, 0x8e, 0xf5, 0xbe, 0x41, 0xbc, 0x2d, 0x2d, 0x1f, 0x96, 0x30, - 0xd8, 0x5f, 0x62, 0x9c, 0xca, 0x51, 0xca, 0xa0, 0x07, 0x06, 0x05, 0x2b, - 0x81, 0x04, 0x00, 0x1f, 0xa1, 0x34, 0x03, 0x32, 0x00, 0x04, 0xf5, 0x88, - 0xa8, 0x31, 0x0c, 0x1f, 0xf2, 0xdf, 0xeb, 0x70, 0x69, 0xd7, 0x8c, 0x42, - 0xe1, 0xaa, 0x20, 0x66, 0x5e, 0x49, 0x74, 0x7f, 0xb5, 0xa5, 0x6b, 0x96, - 0x75, 0xc6, 0xa2, 0xda, 0xf0, 0x5d, 0xa2, 0x8e, 0xbd, 0x54, 0x94, 0xf5, - 0x4d, 0x31, 0x1e, 0x6c, 0x70, 0xa3, 0xd2, 0x29, 0xda, 0x4d, +const unsigned char test_ec_secp521r1_pub[] = { + 0x04, 0x00, 0x1d, 0xe1, 0x42, 0xd5, 0x4f, 0x69, 0xeb, 0x03, 0x8e, 0xe4, + 0xb7, 0xaf, 0x9d, 0x3c, 0xa0, 0x77, 0x36, 0xfd, 0x9c, 0xf7, 0x19, 0xeb, + 0x35, 0x4d, 0x69, 0x87, 0x9e, 0xe7, 0xf3, 0xc1, 0x36, 0xfb, 0x0f, 0xbf, + 0x9f, 0x08, 0xf8, 0x6b, 0xe5, 0xfa, 0x12, 0x8e, 0xc1, 0xa0, 0x51, 0xd3, + 0xe6, 0xc6, 0x43, 0xe8, 0x5a, 0xda, 0x8f, 0xfa, 0xcf, 0x36, 0x63, 0xc2, + 0x60, 0xbd, 0x2c, 0x84, 0x4b, 0x6f, 0x56, 0x00, 0xce, 0xe8, 0xe4, 0x8a, + 0x9e, 0x65, 0xd0, 0x9c, 0xad, 0xd8, 0x9f, 0x23, 0x5d, 0xee, 0x05, 0xf3, + 0xb8, 0xa6, 0x46, 0xbe, 0x71, 0x5f, 0x1f, 0x67, 0xd5, 0xb4, 0x34, 0xe0, + 0xff, 0x23, 0xa1, 0xfc, 0x07, 0xef, 0x77, 0x40, 0x19, 0x3e, 0x40, 0xee, + 0xff, 0x6f, 0x3b, 0xcd, 0xfd, 0x76, 0x5a, 0xa9, 0x15, 0x50, 0x33, 0x52, + 0x4f, 0xe4, 0xf2, 0x05, 0xf5, 0x44, 0x4e, 0x29, 0x2c, 0x4c, 0x2f, 0x6a, + 0xc1, }; -const unsigned char test_ec_secp256k1[] = { - 0x30, 0x74, 0x02, 0x01, 0x01, 0x04, 0x20, 0xda, 0x1f, 0xf8, 0xe8, 0xb9, - 0x1f, 0x45, 0xd8, 0xc3, 0xfe, 0x3e, 0x5d, 0x50, 0x56, 0xc3, 0xe8, 0xad, - 0x87, 0xb0, 0x91, 0x71, 0xcd, 0xca, 0x80, 0xa7, 0xdf, 0x49, 0xd6, 0xa5, - 0xc6, 0x9f, 0x97, 0xa0, 0x07, 0x06, 0x05, 0x2b, 0x81, 0x04, 0x00, 0x0a, - 0xa1, 0x44, 0x03, 0x42, 0x00, 0x04, 0xef, 0x76, 0x2f, 0x4f, 0x6a, 0x7d, - 0x0a, 0xec, 0xef, 0x78, 0x0b, 0xa1, 0xba, 0x57, 0x0f, 0x41, 0x76, 0x76, - 0xf1, 0x4f, 0x7e, 0x91, 0x8b, 0x18, 0xba, 0xab, 0xd9, 0xd7, 0xcc, 0x2c, - 0xe2, 0x1e, 0x92, 0x6d, 0xfd, 0x53, 0xcc, 0xa4, 0x62, 0xab, 0xe4, 0xc0, - 0xaf, 0xaf, 0xc9, 0xd0, 0x10, 0x1a, 0x89, 0x86, 0x6d, 0x6f, 0x24, 0x71, - 0xa3, 0xe2, 0x70, 0xe2, 0x02, 0xe5, 0x96, 0x48, 0xd5, 0x03, +const unsigned char test_ec_bp256r1_priv[] = { + 0x21, 0x61, 0xd6, 0xf2, 0xdb, 0x76, 0x52, 0x6f, 0xa6, 0x2c, 0x16, 0xf3, + 0x56, 0xa8, 0x0f, 0x01, 0xf3, 0x2f, 0x77, 0x67, 0x84, 0xb3, 0x6a, 0xa9, + 0x97, 0x99, 0xa8, 0xb7, 0x66, 0x20, 0x80, 0xff, }; -const unsigned char test_ec_curve448[] = { - 0x30, 0x46, 0x02, 0x01, 0x00, 0x30, 0x05, 0x06, 0x03, 0x2b, 0x65, 0x6f, - 0x04, 0x3a, 0x04, 0x38, 0xe4, 0xd9, 0x04, 0xba, 0x83, 0x93, 0xa5, 0x69, - 0x14, 0x17, 0xab, 0x9d, 0xfd, 0xc9, 0xf2, 0x0d, 0x57, 0x6f, 0xe7, 0x1a, - 0xe6, 0xac, 0xb7, 0x76, 0xdc, 0xe2, 0x76, 0x68, 0x34, 0xd9, 0x45, 0x11, - 0xff, 0x73, 0x24, 0x03, 0xe1, 0x49, 0x6a, 0x65, 0x1d, 0x89, 0xd3, 0x2f, - 0xbc, 0xfe, 0x49, 0xa8, 0xc1, 0xba, 0xbf, 0x46, 0x4b, 0x4c, 0x25, 0xef, +const unsigned char test_ec_bp256r1_pub[] = { + 0x04, 0x76, 0x8c, 0x8c, 0xae, 0x4a, 0xbc, 0xa6, 0x30, 0x6d, 0xb0, 0xed, + 0x81, 0xb0, 0xc4, 0xa6, 0x21, 0x5c, 0x37, 0x80, 0x66, 0xec, 0x6d, 0x61, + 0x6c, 0x14, 0x6e, 0x13, 0xf1, 0xc7, 0xdf, 0x80, 0x9b, 0x96, 0xab, 0x69, + 0x11, 0xc2, 0x7d, 0x8a, 0x02, 0x33, 0x9f, 0x09, 0x26, 0x84, 0x0e, 0x55, + 0x23, 0x6d, 0x3d, 0x1e, 0xfb, 0xe2, 0x66, 0x9d, 0x09, 0x0e, 0x4c, 0x4c, + 0x66, 0x0f, 0xad, 0xa9, 0x1d, +}; + +const unsigned char test_ec_bp384r1_priv[] = { + 0x3d, 0xd9, 0x2e, 0x75, 0x0d, 0x90, 0xd7, 0xd3, 0x9f, 0xc1, 0x88, 0x5c, + 0xd8, 0xad, 0x12, 0xea, 0x94, 0x41, 0xf2, 0x2b, 0x93, 0x34, 0xb4, 0xd9, + 0x65, 0x20, 0x2a, 0xdb, 0x14, 0x48, 0xce, 0x24, 0xc5, 0x80, 0x8a, 0x85, + 0xdd, 0x9a, 0xfc, 0x22, 0x9a, 0xf0, 0xa3, 0x12, 0x4f, 0x75, 0x5b, 0xcb, +}; + +const unsigned char test_ec_bp384r1_pub[] = { + 0x04, 0x71, 0x9f, 0x9d, 0x09, 0x3a, 0x62, 0x7e, 0x0d, 0x35, 0x03, 0x85, + 0xc6, 0x61, 0xce, 0xbf, 0x00, 0xc6, 0x19, 0x23, 0x56, 0x6f, 0xe9, 0x00, + 0x6a, 0x31, 0x07, 0xaf, 0x1d, 0x87, 0x1b, 0xc6, 0xbb, 0x68, 0x98, 0x5f, + 0xd7, 0x22, 0xea, 0x32, 0xbe, 0x31, 0x6f, 0x8e, 0x78, 0x3b, 0x7c, 0xd1, + 0x95, 0x77, 0x85, 0xf6, 0x6c, 0xfc, 0x0c, 0xb1, 0x95, 0xdd, 0x5c, 0x99, + 0xa8, 0xe7, 0xab, 0xaa, 0x84, 0x85, 0x53, 0xa5, 0x84, 0xdf, 0xd2, 0xb4, + 0x8e, 0x76, 0xd4, 0x45, 0xfe, 0x00, 0xdd, 0x8b, 0xe5, 0x90, 0x96, 0xd8, + 0x77, 0xd4, 0x69, 0x6d, 0x23, 0xb4, 0xbc, 0x8d, 0xb1, 0x47, 0x24, 0xe6, + 0x6a, +}; + +const unsigned char test_ec_bp512r1_priv[] = { + 0x37, 0x2c, 0x97, 0x78, 0xf6, 0x9f, 0x72, 0x6c, 0xbc, 0xa3, 0xf4, 0xa2, + 0x68, 0xf1, 0x6b, 0x4d, 0x61, 0x7d, 0x10, 0x28, 0x0d, 0x79, 0xa6, 0xa0, + 0x29, 0xcd, 0x51, 0x87, 0x9f, 0xe1, 0x01, 0x29, 0x34, 0xdf, 0xe5, 0x39, + 0x54, 0x55, 0x33, 0x7d, 0xf6, 0x90, 0x6d, 0xc7, 0xd6, 0xd2, 0xee, 0xa4, + 0xdb, 0xb2, 0x06, 0x5c, 0x02, 0x28, 0xf7, 0x3b, 0x3e, 0xd7, 0x16, 0x48, + 0x0e, 0x7d, 0x71, 0xd2, +}; + +const unsigned char test_ec_bp512r1_pub[] = { + 0x04, 0x38, 0xb7, 0xec, 0x92, 0xb6, 0x1c, 0x5c, 0x6c, 0x7f, 0xbc, 0x28, + 0xa4, 0xec, 0x75, 0x9d, 0x48, 0xfc, 0xd4, 0xe2, 0xe3, 0x74, 0xde, 0xfd, + 0x5c, 0x49, 0x68, 0xa5, 0x4d, 0xbe, 0xf7, 0x51, 0x0e, 0x51, 0x78, 0x86, + 0xfb, 0xfc, 0x38, 0xea, 0x39, 0xaa, 0x52, 0x93, 0x59, 0xd7, 0x0a, 0x71, + 0x56, 0xc3, 0x5d, 0x3c, 0xba, 0xc7, 0xce, 0x77, 0x6b, 0xdb, 0x25, 0x1d, + 0xd6, 0x4b, 0xce, 0x71, 0x23, 0x44, 0x24, 0xee, 0x70, 0x49, 0xee, 0xd0, + 0x72, 0xf0, 0xdb, 0xc4, 0xd7, 0x99, 0x96, 0xe1, 0x75, 0xd5, 0x57, 0xe2, + 0x63, 0x76, 0x3a, 0xe9, 0x70, 0x95, 0xc0, 0x81, 0xe7, 0x3e, 0x7d, 0xb2, + 0xe3, 0x8a, 0xdc, 0x3d, 0x4c, 0x9a, 0x04, 0x87, 0xb1, 0xed, 0xe8, 0x76, + 0xdc, 0x1f, 0xca, 0x61, 0xc9, 0x02, 0xe9, 0xa1, 0xd8, 0x72, 0x2b, 0x86, + 0x12, 0x92, 0x8f, 0x18, 0xa2, 0x48, 0x45, 0x59, 0x1a, +}; + +const unsigned char test_ec_secp192k1_priv[] = { + 0x29, 0x7a, 0xc1, 0x72, 0x2c, 0xca, 0xc7, 0x58, 0x9e, 0xcb, 0x24, 0x0d, + 0xc7, 0x19, 0x84, 0x25, 0x38, 0xca, 0x97, 0x4b, 0xeb, 0x79, 0xf2, 0x28, +}; + +const unsigned char test_ec_secp192k1_pub[] = { + 0x04, 0x26, 0xb7, 0xbb, 0x38, 0xda, 0x64, 0x9a, 0xc2, 0x13, 0x8f, 0xc0, + 0x50, 0xc6, 0x54, 0x8b, 0x32, 0x55, 0x3d, 0xab, 0x68, 0xaf, 0xeb, 0xc3, + 0x61, 0x05, 0xd3, 0x25, 0xb7, 0x55, 0x38, 0xc1, 0x23, 0x23, 0xcb, 0x07, + 0x64, 0x78, 0x9e, 0xcb, 0x99, 0x26, 0x71, 0xbe, 0xb2, 0xb6, 0xbe, 0xf2, + 0xf5, +}; + +const unsigned char test_ec_secp256k1_priv[] = { + 0x7f, 0xa0, 0x6f, 0xa0, 0x2d, 0x0e, 0x91, 0x1b, 0x9a, 0x47, 0xfd, 0xc1, + 0x7d, 0x2d, 0x96, 0x2c, 0xa0, 0x1e, 0x2f, 0x31, 0xd6, 0x0c, 0x62, 0x12, + 0xd0, 0xed, 0x7e, 0x3b, 0xba, 0x23, 0xa7, 0xb9, +}; + +const unsigned char test_ec_secp256k1_pub[] = { + 0x04, 0x5c, 0x39, 0x15, 0x45, 0x79, 0xef, 0xd6, 0x67, 0xad, 0xc7, 0x3a, + 0x81, 0x01, 0x5a, 0x79, 0x7d, 0x2c, 0x86, 0x82, 0xcd, 0xfb, 0xd3, 0xc3, + 0x55, 0x3c, 0x4a, 0x18, 0x5d, 0x48, 0x1c, 0xdc, 0x50, 0xe4, 0x2a, 0x0e, + 0x1c, 0xbc, 0x3c, 0xa2, 0x9a, 0x32, 0xa6, 0x45, 0xe9, 0x27, 0xf5, 0x4b, + 0xea, 0xed, 0x14, 0xc9, 0xdb, 0xbf, 0x82, 0x79, 0xd7, 0x25, 0xf5, 0x49, + 0x5c, 0xa9, 0x24, 0xb2, 0x4d, +}; + +const unsigned char test_ec_curve25519_priv[] = { + 0x70, 0x07, 0x6d, 0x0a, 0x73, 0x18, 0xa5, 0x7d, 0x3c, 0x16, 0xc1, 0x72, + 0x51, 0xb2, 0x66, 0x45, 0xdf, 0x4c, 0x2f, 0x87, 0xeb, 0xc0, 0x99, 0x2a, + 0xb1, 0x77, 0xfb, 0xa5, 0x1d, 0xb9, 0x2c, 0x6a, +}; + +const unsigned char test_ec_curve25519_pub[] = { + 0x85, 0x20, 0xf0, 0x09, 0x89, 0x30, 0xa7, 0x54, 0x74, 0x8b, 0x7d, 0xdc, + 0xb4, 0x3e, 0xf7, 0x5a, 0x0d, 0xbf, 0x3a, 0x0d, 0x26, 0x38, 0x1a, 0xf4, + 0xeb, 0xa4, 0xa9, 0x8e, 0xaa, 0x9b, 0x4e, 0x6a, +}; + +const unsigned char test_ec_curve448_priv[] = { + 0xe4, 0xe4, 0x9f, 0x52, 0x68, 0x6f, 0x9e, 0xe3, 0xb6, 0x38, 0x52, 0x8f, + 0x72, 0x1f, 0x15, 0x96, 0x19, 0x6f, 0xfd, 0x0a, 0x1c, 0xdd, 0xb6, 0x4c, + 0x3f, 0x21, 0x6f, 0x06, 0x54, 0x18, 0x05, 0xcf, 0xeb, 0x1a, 0x28, 0x6d, + 0xc7, 0x80, 0x18, 0x09, 0x5c, 0xdf, 0xec, 0x05, 0x0e, 0x80, 0x07, 0xb5, + 0xf4, 0x90, 0x89, 0x62, 0xba, 0x20, 0xd6, 0xc1, +}; + +const unsigned char test_ec_curve448_pub[] = { + 0xc0, 0xd3, 0xa5, 0xa2, 0xb4, 0x16, 0xa5, 0x73, 0xdc, 0x99, 0x09, 0xf9, + 0x2f, 0x13, 0x4a, 0xc0, 0x13, 0x23, 0xab, 0x8f, 0x8e, 0x36, 0x80, 0x4e, + 0x57, 0x85, 0x88, 0xba, 0x2d, 0x09, 0xfe, 0x7c, 0x3e, 0x73, 0x7f, 0x77, + 0x1c, 0xa1, 0x12, 0x82, 0x5b, 0x54, 0x8a, 0x0f, 0xfd, 0xed, 0x6d, 0x6a, + 0x2f, 0xd0, 0x9a, 0x3e, 0x77, 0xde, 0xc3, 0x0e, }; diff --git a/tests/suites/test_suite_pk.function b/tests/suites/test_suite_pk.function index 5e9e4d6d2f..5e63214d33 100644 --- a/tests/suites/test_suite_pk.function +++ b/tests/suites/test_suite_pk.function @@ -189,37 +189,56 @@ struct key_lut_element { int curve_or_keybits; const unsigned char *key; size_t key_len; + const unsigned char *pub_key; + size_t pub_key_len; }; struct key_lut_element keys_lut[] = { - { 1024, test_rsa_1024, sizeof(test_rsa_1024) }, - { 1026, test_rsa_1026, sizeof(test_rsa_1026) }, - { 1028, test_rsa_1028, sizeof(test_rsa_1028) }, - { 1030, test_rsa_1030, sizeof(test_rsa_1030) }, - { 2048, test_rsa_2048, sizeof(test_rsa_2048) }, - { 4096, test_rsa_4096, sizeof(test_rsa_4096) }, - { MBEDTLS_ECP_DP_SECP192R1, test_ec_secp192r1, sizeof(test_ec_secp192r1) }, - { MBEDTLS_ECP_DP_SECP224R1, test_ec_secp224r1, sizeof(test_ec_secp224r1) }, - { MBEDTLS_ECP_DP_SECP256R1, test_ec_secp256r1, sizeof(test_ec_secp256r1) }, - { MBEDTLS_ECP_DP_SECP384R1, test_ec_secp384r1, sizeof(test_ec_secp384r1) }, - { MBEDTLS_ECP_DP_SECP521R1, test_ec_secp521r1, sizeof(test_ec_secp521r1) }, - { MBEDTLS_ECP_DP_BP256R1, test_ec_bp256r1, sizeof(test_ec_bp256r1) }, - { MBEDTLS_ECP_DP_BP384R1, test_ec_bp384r1, sizeof(test_ec_bp384r1) }, - { MBEDTLS_ECP_DP_BP512R1, test_ec_bp512r1, sizeof(test_ec_bp512r1) }, - { MBEDTLS_ECP_DP_CURVE25519, test_ec_curve25519, sizeof(test_ec_curve25519) }, - { MBEDTLS_ECP_DP_SECP192K1, test_ec_secp192k1, sizeof(test_ec_secp192k1) }, - { MBEDTLS_ECP_DP_SECP256K1, test_ec_secp256k1, sizeof(test_ec_secp256k1) }, - { MBEDTLS_ECP_DP_CURVE448, test_ec_curve448, sizeof(test_ec_curve448) }, + { 1024, test_rsa_1024, sizeof(test_rsa_1024), NULL, 0 }, + { 1026, test_rsa_1026, sizeof(test_rsa_1026), NULL, 0 }, + { 1028, test_rsa_1028, sizeof(test_rsa_1028), NULL, 0 }, + { 1030, test_rsa_1030, sizeof(test_rsa_1030), NULL, 0 }, + { 2048, test_rsa_2048, sizeof(test_rsa_2048), NULL, 0 }, + { 4096, test_rsa_4096, sizeof(test_rsa_4096), NULL, 0 }, + { MBEDTLS_ECP_DP_SECP192R1, test_ec_secp192r1_priv, sizeof(test_ec_secp192r1_priv), + test_ec_secp192r1_pub, sizeof(test_ec_secp192r1_pub) }, + { MBEDTLS_ECP_DP_SECP224R1, test_ec_secp224r1_priv, sizeof(test_ec_secp224r1_priv), + test_ec_secp224r1_pub, sizeof(test_ec_secp224r1_pub) }, + { MBEDTLS_ECP_DP_SECP256R1, test_ec_secp256r1_priv, sizeof(test_ec_secp256r1_priv), + test_ec_secp256r1_pub, sizeof(test_ec_secp256r1_pub) }, + { MBEDTLS_ECP_DP_SECP384R1, test_ec_secp384r1_priv, sizeof(test_ec_secp384r1_priv), + test_ec_secp384r1_pub, sizeof(test_ec_secp384r1_pub) }, + { MBEDTLS_ECP_DP_SECP521R1, test_ec_secp521r1_priv, sizeof(test_ec_secp521r1_priv), + test_ec_secp521r1_pub, sizeof(test_ec_secp521r1_pub) }, + { MBEDTLS_ECP_DP_BP256R1, test_ec_bp256r1_priv, sizeof(test_ec_bp256r1_priv), + test_ec_bp256r1_pub, sizeof(test_ec_bp256r1_pub) }, + { MBEDTLS_ECP_DP_BP384R1, test_ec_bp384r1_priv, sizeof(test_ec_bp384r1_priv), + test_ec_bp384r1_pub, sizeof(test_ec_bp384r1_pub) }, + { MBEDTLS_ECP_DP_BP512R1, test_ec_bp512r1_priv, sizeof(test_ec_bp512r1_priv), + test_ec_bp512r1_pub, sizeof(test_ec_bp512r1_pub) }, + { MBEDTLS_ECP_DP_CURVE25519, test_ec_curve25519_priv, sizeof(test_ec_curve25519_priv), + test_ec_curve25519_pub, sizeof(test_ec_curve25519_pub) }, + { MBEDTLS_ECP_DP_SECP192K1, test_ec_secp192k1_priv, sizeof(test_ec_secp192k1_priv), + test_ec_secp192k1_pub, sizeof(test_ec_secp192k1_pub) }, + { MBEDTLS_ECP_DP_SECP256K1, test_ec_secp256k1_priv, sizeof(test_ec_secp256k1_priv), + test_ec_secp256k1_pub, sizeof(test_ec_secp256k1_pub) }, + { MBEDTLS_ECP_DP_CURVE448, test_ec_curve448_priv, sizeof(test_ec_curve448_priv), + test_ec_curve448_pub, sizeof(test_ec_curve448_pub) }, }; static int get_predefined_key_data(int curve_or_keybits, - const unsigned char **key, size_t *key_len) + const unsigned char **key, size_t *key_len, + const unsigned char **pub_key, size_t *pub_key_len) { size_t i; for (i = 0; i < ARRAY_LENGTH(keys_lut); i++) { if (curve_or_keybits == keys_lut[i].curve_or_keybits) { *key = keys_lut[i].key; *key_len = keys_lut[i].key_len; + if (pub_key != NULL) { + *pub_key = keys_lut[i].pub_key; + *pub_key_len = keys_lut[i].pub_key_len; + } return 0; } } @@ -227,6 +246,27 @@ static int get_predefined_key_data(int curve_or_keybits, return MBEDTLS_ERR_PK_BAD_INPUT_DATA; } +#if defined(MBEDTLS_PSA_CRYPTO_C) +psa_status_t pk_psa_import_key(const unsigned char *key_data, size_t key_len, + psa_key_type_t type, psa_key_usage_t usage, + psa_algorithm_t alg, mbedtls_svc_key_id_t *key) +{ + psa_key_attributes_t attributes = PSA_KEY_ATTRIBUTES_INIT; + psa_status_t status; + + *key = MBEDTLS_SVC_KEY_ID_INIT; + + /* Note: psa_import_key() automatically determines the key's bit length + * from the provided key data. That's why psa_set_key_bits() is not used below. */ + psa_set_key_usage_flags(&attributes, usage); + psa_set_key_algorithm(&attributes, alg); + psa_set_key_type(&attributes, type); + status = psa_import_key(&attributes, key_data, key_len, key); + + return status; +} +#endif /* MBEDTLS_PSA_CRYPTO_C */ + #if defined(MBEDTLS_PK_PARSE_C) /** Fill the provided PK context with a proper key. * @@ -249,12 +289,42 @@ static int get_predefined_key_data(int curve_or_keybits, static int pk_genkey(mbedtls_pk_context *pk, mbedtls_pk_type_t pk_type, int curve_or_keybits) { const unsigned char *key_data = NULL; + const unsigned char *pub_key_data = NULL; size_t key_data_len = 0; + size_t pub_key_data_len = 0; int ret = MBEDTLS_ERR_PK_BAD_INPUT_DATA; - TEST_EQUAL(get_predefined_key_data(curve_or_keybits, &key_data, &key_data_len), 0); - TEST_EQUAL(mbedtls_pk_parse_key(pk, key_data, key_data_len, NULL, 0, - mbedtls_test_rnd_std_rand, NULL), 0); + if (pk_type == MBEDTLS_PK_RSA) { + TEST_EQUAL(get_predefined_key_data(curve_or_keybits, &key_data, &key_data_len, + NULL, 0), 0); + TEST_EQUAL(mbedtls_pk_parse_key(pk, key_data, key_data_len, NULL, 0, + mbedtls_test_rnd_std_rand, NULL), 0); + } else { + TEST_EQUAL(get_predefined_key_data(curve_or_keybits, &key_data, &key_data_len, + &pub_key_data, &pub_key_data_len), 0); + TEST_EQUAL(mbedtls_pk_setup(pk, mbedtls_pk_info_from_type(pk_type)), 0); +#if defined(MBEDTLS_PK_USE_PSA_EC_DATA) + pk->ec_family = mbedtls_ecc_group_to_psa(curve_or_keybits, &pk->ec_bits); + TEST_EQUAL(pk_psa_import_key(key_data, key_data_len, + PSA_KEY_TYPE_ECC_KEY_PAIR(pk->ec_family), + PSA_KEY_USAGE_SIGN_HASH | PSA_KEY_USAGE_VERIFY_HASH | + PSA_KEY_USAGE_SIGN_MESSAGE | PSA_KEY_USAGE_VERIFY_MESSAGE | + PSA_KEY_USAGE_DERIVE | PSA_KEY_USAGE_COPY | + PSA_KEY_USAGE_EXPORT, + MBEDTLS_PK_PSA_ALG_ECDSA_MAYBE_DET(PSA_ALG_ANY_HASH), + &pk->priv_id), 0); + memcpy(pk->pub_raw, pub_key_data, pub_key_data_len); + pk->pub_raw_len = pub_key_data_len; +#elif defined(MBEDTLS_ECP_C) + TEST_EQUAL(mbedtls_ecp_read_key(curve_or_keybits, mbedtls_pk_ec_rw(*pk), + key_data, key_data_len), 0); + TEST_EQUAL(mbedtls_ecp_point_read_binary(&(mbedtls_pk_ec_rw(*pk)->grp), + &(mbedtls_pk_ec_rw(*pk)->Q), + pub_key_data, pub_key_data_len), 0); +#else /* MBEDTLS_PK_USE_PSA_EC_DATA || MBEDTLS_ECP_C */ + TEST_FAIL("EC keys not supported."); +#endif /* MBEDTLS_PK_USE_PSA_EC_DATA || MBEDTLS_ECP_C */ + } /* Override pk_info. */ pk->pk_info = mbedtls_pk_info_from_type(pk_type); ret = 0; @@ -289,44 +359,17 @@ psa_status_t pk_psa_genkey(psa_key_type_t type, size_t bits, psa_key_attributes_t attributes = PSA_KEY_ATTRIBUTES_INIT; psa_status_t status = PSA_ERROR_GENERIC_ERROR; const unsigned char *key_data = NULL; - size_t key_data_size = 0; /* Overall size of key_data in bytes. It includes leading - * zeros (if any). */ - size_t key_data_len = 0; /* Length of valid bytes in key_data. */ - const unsigned char *key_data_start; + size_t key_data_size = 0; - /* Get the predefined key: - * - RSA keys are already in a valid format to be imported into PSA. - * - EC ones instead would require some adaptation. However instead of going - * through the PK module for import/export, we can directly skip the - * unrelevant data and go directly to the private key. - */ if (PSA_KEY_TYPE_IS_RSA(type)) { - TEST_EQUAL(get_predefined_key_data(bits, &key_data, &key_data_size), 0); - key_data_start = (unsigned char *) key_data; - key_data_len = key_data_size; + TEST_EQUAL(get_predefined_key_data(bits, &key_data, &key_data_size, NULL, 0), 0); } else { #if defined(PSA_WANT_KEY_TYPE_ECC_PUBLIC_KEY) mbedtls_ecp_group_id grp_id; grp_id = mbedtls_ecc_group_from_psa(PSA_KEY_TYPE_ECC_GET_FAMILY(type), bits); - TEST_EQUAL(get_predefined_key_data(grp_id, &key_data, &key_data_size), 0); - - unsigned char *p = (unsigned char *) key_data; - const unsigned char *end = key_data + key_data_size; - size_t len; - int version; - - TEST_EQUAL(mbedtls_asn1_get_tag(&p, end, &len, MBEDTLS_ASN1_SEQUENCE | - MBEDTLS_ASN1_CONSTRUCTED), 0); - TEST_EQUAL(mbedtls_asn1_get_int(&p, end, &version), 0); - if ((grp_id == MBEDTLS_ECP_DP_CURVE25519) || (grp_id == MBEDTLS_ECP_DP_CURVE448)) { - TEST_EQUAL(mbedtls_asn1_get_tag(&p, end, &len, MBEDTLS_ASN1_SEQUENCE | - MBEDTLS_ASN1_CONSTRUCTED), 0); - p += len; - TEST_EQUAL(mbedtls_asn1_get_tag(&p, end, &len, MBEDTLS_ASN1_OCTET_STRING), 0); - } - TEST_EQUAL(mbedtls_asn1_get_tag(&p, end, &len, MBEDTLS_ASN1_OCTET_STRING), 0); - key_data_start = p; - key_data_len = len; + TEST_EQUAL(get_predefined_key_data(grp_id, &key_data, &key_data_size, NULL, 0), 0); +#else /* PSA_WANT_KEY_TYPE_ECC_PUBLIC_KEY */ + TEST_FAIL("EC keys are not supported"); #endif /* PSA_WANT_KEY_TYPE_ECC_PUBLIC_KEY */ } @@ -340,7 +383,7 @@ psa_status_t pk_psa_genkey(psa_key_type_t type, size_t bits, if (!mbedtls_svc_key_id_is_null(persistent_key_id)) { psa_set_key_id(&attributes, persistent_key_id); } - status = psa_import_key(&attributes, key_data_start, key_data_len, key); + status = psa_import_key(&attributes, key_data, key_data_size, key); exit: return status; @@ -628,25 +671,6 @@ exit: psa_reset_key_attributes(&new_attr); return new_key_id; } - -psa_status_t pk_psa_import_key(unsigned char *key_data, size_t key_len, - psa_key_type_t type, psa_key_usage_t usage, - psa_algorithm_t alg, mbedtls_svc_key_id_t *key) -{ - psa_key_attributes_t attributes = PSA_KEY_ATTRIBUTES_INIT; - psa_status_t status; - - *key = MBEDTLS_SVC_KEY_ID_INIT; - - /* Note: psa_import_key() automatically determines the key's bit length - * from the provided key data. That's why psa_set_key_bits() is not used below. */ - psa_set_key_usage_flags(&attributes, usage); - psa_set_key_algorithm(&attributes, alg); - psa_set_key_type(&attributes, type); - status = psa_import_key(&attributes, key_data, key_len, key); - - return status; -} #endif /* MBEDTLS_PSA_CRYPTO_C */ /* END_HEADER */