blob: d1d69081386d49ef9671c226508a77542fcf05de [file] [log] [blame]
Hanno Beckerb48e1aa2018-12-18 23:25:01 +00001MPI - Valid parameters
2mpi_valid_param:
3
4MPI - Invalid parameters
Hanno Beckerafb607b2018-12-11 14:27:08 +00005mpi_invalid_param:
6
Manuel Pégourié-Gonnard770b5e12015-04-29 17:02:01 +02007Arguments with no value
8mpi_null:
9
Paul Bakker367dae42009-06-28 21:50:27 +000010Base test mpi_read_write_string #1
Paul Bakkerba48cb22009-07-12 11:01:32 +000011mpi_read_write_string:10:"128":10:"128":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000012
Gilles Peskine228b98f2021-04-03 18:25:29 +020013Base test mpi_read_write_string #1 (Leading 0)
14mpi_read_write_string:10:"0128":10:"128":100:0:0
15
Paul Bakker367dae42009-06-28 21:50:27 +000016Base test mpi_read_write_string #2
Paul Bakkerba48cb22009-07-12 11:01:32 +000017mpi_read_write_string:10:"128":16:"80":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000018
Gilles Peskine228b98f2021-04-03 18:25:29 +020019Base test mpi_read_write_string #3 (Read zero decimal)
Paul Bakkerba48cb22009-07-12 11:01:32 +000020mpi_read_write_string:10:"0":10:"0":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000021
Gilles Peskine228b98f2021-04-03 18:25:29 +020022Base test mpi_read_write_string #3 (Read zero hex)
23mpi_read_write_string:16:"0":16:"00":100:0:0
24
25Base test mpi_read_write_string #3 (Read minus zero decimal)
26mpi_read_write_string:10:"-0":10:"0":100:0:0
27
28Base test mpi_read_write_string #3 (Read minus zero hex)
29mpi_read_write_string:16:"-0":16:"00":100:0:0
30
Paul Bakker367dae42009-06-28 21:50:27 +000031Base test mpi_read_write_string #3 (Negative decimal)
Paul Bakkerba48cb22009-07-12 11:01:32 +000032mpi_read_write_string:10:"-23":10:"-23":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000033
Gilles Peskine228b98f2021-04-03 18:25:29 +020034Base test mpi_read_write_string #3 (Negative decimal, leading 0)
35mpi_read_write_string:10:"-023":10:"-23":100:0:0
36
Gilles Peskine5a1d0fc2021-04-09 15:46:40 +020037Base test mpi_read_write_string #3 (Negative hex -> decimal)
Paul Bakkerba48cb22009-07-12 11:01:32 +000038mpi_read_write_string:16:"-20":10:"-32":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000039
Gilles Peskine228b98f2021-04-03 18:25:29 +020040Base test mpi_read_write_string #3 (Negative hex)
Paul Bakkerba48cb22009-07-12 11:01:32 +000041mpi_read_write_string:16:"-23":16:"-23":100:0:0
Paul Bakker367dae42009-06-28 21:50:27 +000042
Gilles Peskine228b98f2021-04-03 18:25:29 +020043Base test mpi_read_write_string #3 (Negative hex, leading 0)
44mpi_read_write_string:16:"-023":16:"-23":100:0:0
45
Janos Follath276284f2019-03-06 12:29:37 +000046Base test mpi_read_write_string #4 (Buffer just fits)
47mpi_read_write_string:16:"-4":4:"-10":4:0:0
48
Paul Bakkerba48cb22009-07-12 11:01:32 +000049Test mpi_read_write_string #1 (Invalid character)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020050mpi_read_write_string:10:"a28":0:"":100:MBEDTLS_ERR_MPI_INVALID_CHARACTER:0
Paul Bakkerba48cb22009-07-12 11:01:32 +000051
52Test mpi_read_write_string #2 (Illegal input radix)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020053mpi_read_write_string:19:"a28":0:"":100:MBEDTLS_ERR_MPI_BAD_INPUT_DATA:0
Paul Bakkerba48cb22009-07-12 11:01:32 +000054
55Test mpi_read_write_string #3 (Buffer just fits)
56mpi_read_write_string:16:"-23":16:"-23":4:0:0
57
58Test mpi_read_write_string #4 (Buffer too small)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020059mpi_read_write_string:16:"-23":16:"-23":3:0:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
Paul Bakkerba48cb22009-07-12 11:01:32 +000060
61Test mpi_read_write_string #5 (Illegal output radix)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020062mpi_read_write_string:16:"-23":17:"-23":4:0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakkerba48cb22009-07-12 11:01:32 +000063
64Test mpi_read_write_string #6 (Output radix of 15)
65mpi_read_write_string:10:"29":15:"1e":100:0:0
66
67Test mpi_read_write_string #7
68mpi_read_write_string:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":16:"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":200:0:0
Paul Bakkere896fea2009-07-06 06:40:23 +000069
Gilles Peskine228b98f2021-04-03 18:25:29 +020070Test mpi_read_write_string #8 (Empty MPI hex -> hex)
Paul Bakker6c343d72014-07-10 14:36:19 +020071mpi_read_write_string:16:"":16:"00":4:0:0
72
Gilles Peskine228b98f2021-04-03 18:25:29 +020073Test mpi_read_write_string #9 (Empty MPI hex -> dec)
Paul Bakker6c343d72014-07-10 14:36:19 +020074mpi_read_write_string:16:"":10:"0":4:0:0
75
Gilles Peskine228b98f2021-04-03 18:25:29 +020076Test mpi_read_write_string #8 (Empty MPI dec -> hex)
77mpi_read_write_string:10:"":16:"00":4:0:0
78
79Test mpi_read_write_string #9 (Empty MPI dec -> dec)
80mpi_read_write_string:10:"":10:"0":4:0:0
81
Andres AGd1cc7f62017-01-06 13:17:35 +000082Test mpi_write_string #10 (Negative hex with odd number of digits)
83mpi_read_write_string:16:"-1":16:"":3:0:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
84
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020085Base test mbedtls_mpi_read_binary #1
86mbedtls_mpi_read_binary:"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924"
Paul Bakkere896fea2009-07-06 06:40:23 +000087
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020088Base test mbedtls_mpi_write_binary #1
89mbedtls_mpi_write_binary:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":200:0
Paul Bakkerba48cb22009-07-12 11:01:32 +000090
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020091Test mbedtls_mpi_write_binary #1 (Buffer just fits)
92mbedtls_mpi_write_binary:16:"123123123123123123123123123":"0123123123123123123123123123":14:0
Paul Bakkerba48cb22009-07-12 11:01:32 +000093
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020094Test mbedtls_mpi_write_binary #2 (Buffer too small)
Azim Khan46c9b1f2017-05-31 20:46:35 +010095mbedtls_mpi_write_binary:16:"123123123123123123123123123":"23123123123123123123123123":13:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
Paul Bakkere896fea2009-07-06 06:40:23 +000096
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020097Base test mbedtls_mpi_read_file #1
98mbedtls_mpi_read_file:10:"data_files/mpi_10":"01f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":0
Paul Bakkerba48cb22009-07-12 11:01:32 +000099
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200100Test mbedtls_mpi_read_file #1 (Empty file)
101mbedtls_mpi_read_file:10:"data_files/hash_file_4":"":MBEDTLS_ERR_MPI_FILE_IO_ERROR
Paul Bakkerba48cb22009-07-12 11:01:32 +0000102
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200103Test mbedtls_mpi_read_file #2 (Illegal input)
104mbedtls_mpi_read_file:10:"data_files/hash_file_3":"":0
Paul Bakkere896fea2009-07-06 06:40:23 +0000105
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200106Test mbedtls_mpi_read_file #3 (Input too big)
107mbedtls_mpi_read_file:10:"data_files/mpi_too_big":"":MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
Paul Bakkercb37aa52011-11-30 16:00:20 +0000108
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200109Base test mbedtls_mpi_write_file #1
110mbedtls_mpi_write_file:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":16:"data_files/mpi_write"
Paul Bakkere896fea2009-07-06 06:40:23 +0000111
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200112Test mbedtls_mpi_lsb: 0 (null)
113mbedtls_mpi_lsb:16:"":0
114
115Test mbedtls_mpi_lsb: 0 (1 limb)
116mbedtls_mpi_lsb:16:"0":0
117
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200118Base test mbedtls_mpi_lsb #1
119mbedtls_mpi_lsb:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":2
Paul Bakkere896fea2009-07-06 06:40:23 +0000120
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200121Base test mbedtls_mpi_lsb #2
122mbedtls_mpi_lsb:10:"24":3
Paul Bakkere896fea2009-07-06 06:40:23 +0000123
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200124Base test mbedtls_mpi_lsb #3
125mbedtls_mpi_lsb:16:"24":2
Paul Bakkere896fea2009-07-06 06:40:23 +0000126
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200127Base test mbedtls_mpi_lsb #4
128mbedtls_mpi_lsb:16:"2000":13
Paul Bakkere896fea2009-07-06 06:40:23 +0000129
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200130Base test mbedtls_mpi_bitlen #1
131mbedtls_mpi_bitlen:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":764
Paul Bakkere896fea2009-07-06 06:40:23 +0000132
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200133Base test mbedtls_mpi_bitlen #2
134mbedtls_mpi_bitlen:10:"24":5
Paul Bakkere896fea2009-07-06 06:40:23 +0000135
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200136Base test mbedtls_mpi_bitlen #3
137mbedtls_mpi_bitlen:10:"1":1
Paul Bakkere896fea2009-07-06 06:40:23 +0000138
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200139Base test mbedtls_mpi_bitlen #4
140mbedtls_mpi_bitlen:10:"15":4
Paul Bakkere896fea2009-07-06 06:40:23 +0000141
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200142Base test mbedtls_mpi_bitlen #5
143mbedtls_mpi_bitlen:10:"16":5
Paul Bakkere896fea2009-07-06 06:40:23 +0000144
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200145Base test mbedtls_mpi_bitlen #6
146mbedtls_mpi_bitlen:10:"10":4
Paul Bakkere896fea2009-07-06 06:40:23 +0000147
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200148Base test mbedtls_mpi_bitlen: 0 (null)
149mbedtls_mpi_bitlen:10:"":0
150
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +0200151Base test mbedtls_mpi_bitlen: 0 (1 limb)
Manuel Pégourié-Gonnardc0696c22015-06-18 16:47:17 +0200152mbedtls_mpi_bitlen:10:"0":0
Paul Bakkere896fea2009-07-06 06:40:23 +0000153
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200154Base test mbedtls_mpi_cmp_int #1
155mbedtls_mpi_cmp_int:693:693:0
Paul Bakker367dae42009-06-28 21:50:27 +0000156
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200157Base test mbedtls_mpi_cmp_int #2
158mbedtls_mpi_cmp_int:693:692:1
Paul Bakker367dae42009-06-28 21:50:27 +0000159
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200160Base test mbedtls_mpi_cmp_int #3
161mbedtls_mpi_cmp_int:693:694:-1
Paul Bakker367dae42009-06-28 21:50:27 +0000162
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200163Base test mbedtls_mpi_cmp_int (Negative values) #1
164mbedtls_mpi_cmp_int:-2:-2:0
Paul Bakker367dae42009-06-28 21:50:27 +0000165
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200166Base test mbedtls_mpi_cmp_int (Negative values) #2
167mbedtls_mpi_cmp_int:-2:-3:1
Paul Bakker367dae42009-06-28 21:50:27 +0000168
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200169Base test mbedtls_mpi_cmp_int (Negative values) #3
170mbedtls_mpi_cmp_int:-2:-1:-1
Paul Bakker367dae42009-06-28 21:50:27 +0000171
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200172Base test mbedtls_mpi_cmp_mpi #1
173mbedtls_mpi_cmp_mpi:10:"693":10:"693":0
Paul Bakker367dae42009-06-28 21:50:27 +0000174
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200175Base test mbedtls_mpi_cmp_mpi #2
176mbedtls_mpi_cmp_mpi:10:"693":10:"692":1
Paul Bakker367dae42009-06-28 21:50:27 +0000177
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200178Base test mbedtls_mpi_cmp_mpi #3
179mbedtls_mpi_cmp_mpi:10:"693":10:"694":-1
Paul Bakker367dae42009-06-28 21:50:27 +0000180
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200181Base test mbedtls_mpi_cmp_mpi (Negative values) #1
182mbedtls_mpi_cmp_mpi:10:"-2":10:"-2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000183
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200184Base test mbedtls_mpi_cmp_mpi (Negative values) #2
185mbedtls_mpi_cmp_mpi:10:"-2":10:"-3":1
Paul Bakker367dae42009-06-28 21:50:27 +0000186
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200187Base test mbedtls_mpi_cmp_mpi (Negative values) #3
188mbedtls_mpi_cmp_mpi:10:"-2":10:"-1":-1
Paul Bakker367dae42009-06-28 21:50:27 +0000189
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200190Base test mbedtls_mpi_cmp_mpi (Mixed values) #4
191mbedtls_mpi_cmp_mpi:10:"-3":10:"2":-1
Paul Bakker0c8f73b2012-03-22 14:08:57 +0000192
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200193Base test mbedtls_mpi_cmp_mpi (Mixed values) #5
194mbedtls_mpi_cmp_mpi:10:"2":10:"-3":1
Paul Bakker0c8f73b2012-03-22 14:08:57 +0000195
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200196Base test mbedtls_mpi_cmp_mpi (Mixed values) #6
197mbedtls_mpi_cmp_mpi:10:"-2":10:"31231231289798":-1
Paul Bakker0c8f73b2012-03-22 14:08:57 +0000198
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200199Test mbedtls_mpi_cmp_mpi: 0 (null) = 0 (null)
200mbedtls_mpi_cmp_mpi:10:"":10:"":0
201
202Test mbedtls_mpi_cmp_mpi: 0 (null) = 0 (1 limb)
203mbedtls_mpi_cmp_mpi:10:"":10:"0":0
204
205Test mbedtls_mpi_cmp_mpi: 0 (1 limb) = 0 (null)
206mbedtls_mpi_cmp_mpi:10:"0":10:"":0
207
208Test mbedtls_mpi_cmp_mpi: 0 (1 limb) = 0 (1 limb)
209mbedtls_mpi_cmp_mpi:10:"0":10:"0":0
210
Gilles Peskine8c68c972021-06-15 22:01:23 +0200211Test mbedtls_mpi_cmp_mpi: 0 (null) < positive
212mbedtls_mpi_cmp_mpi:10:"":10:"123":-1
213
214Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < positive
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200215mbedtls_mpi_cmp_mpi:10:"0":10:"123":-1
216
Gilles Peskine8c68c972021-06-15 22:01:23 +0200217Test mbedtls_mpi_cmp_mpi: 0 (null) > negative
218mbedtls_mpi_cmp_mpi:10:"":10:"-123":1
219
220Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > negative
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200221mbedtls_mpi_cmp_mpi:10:"0":10:"-123":1
222
Gilles Peskine8c68c972021-06-15 22:01:23 +0200223Test mbedtls_mpi_cmp_mpi: positive > 0 (null)
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200224mbedtls_mpi_cmp_mpi:10:"123":10:"":1
225
Gilles Peskine8c68c972021-06-15 22:01:23 +0200226Test mbedtls_mpi_cmp_mpi: positive > 0 (1 limb)
227mbedtls_mpi_cmp_mpi:10:"123":10:"0":1
228
229Test mbedtls_mpi_cmp_mpi: negative < 0 (null)
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200230mbedtls_mpi_cmp_mpi:10:"-123":10:"":-1
231
Gilles Peskine8c68c972021-06-15 22:01:23 +0200232Test mbedtls_mpi_cmp_mpi: negative < 0 (1 limb)
233mbedtls_mpi_cmp_mpi:10:"-123":10:"0":-1
234
235Test mbedtls_mpi_cmp_mpi: 0 (null) < positive with leading zero limb
236mbedtls_mpi_cmp_mpi:16:"":16:"0000000000000000123":-1
237
238Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < positive with leading zero limb
239mbedtls_mpi_cmp_mpi:16:"0":16:"0000000000000000123":-1
240
241Test mbedtls_mpi_cmp_mpi: 0 (null) > negative with leading zero limb
242mbedtls_mpi_cmp_mpi:16:"":16:"-0000000000000000123":1
243
244Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > negative with leading zero limb
245mbedtls_mpi_cmp_mpi:16:"0":16:"-0000000000000000123":1
246
247Test mbedtls_mpi_cmp_mpi: positive with leading zero limb > 0 (null)
248mbedtls_mpi_cmp_mpi:16:"0000000000000000123":16:"":1
249
250Test mbedtls_mpi_cmp_mpi: positive with leading zero limb > 0 (1 limb)
251mbedtls_mpi_cmp_mpi:16:"0000000000000000123":16:"0":1
252
253Test mbedtls_mpi_cmp_mpi: negative with leading zero limb < 0 (null)
254mbedtls_mpi_cmp_mpi:16:"-0000000000000000123":16:"":-1
255
256Test mbedtls_mpi_cmp_mpi: negative with leading zero limb < 0 (1 limb)
257mbedtls_mpi_cmp_mpi:16:"-0000000000000000123":16:"0":-1
258
259Test mbedtls_mpi_cmp_mpi: 0 (null) < large positive
260mbedtls_mpi_cmp_mpi:16:"":16:"1230000000000000000":-1
261
262Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < large positive
263mbedtls_mpi_cmp_mpi:16:"0":16:"1230000000000000000":-1
264
265Test mbedtls_mpi_cmp_mpi: 0 (null) > large negative
266mbedtls_mpi_cmp_mpi:16:"":16:"-1230000000000000000":1
267
268Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > large negative
269mbedtls_mpi_cmp_mpi:16:"0":16:"-1230000000000000000":1
270
271Test mbedtls_mpi_cmp_mpi: large positive > 0 (null)
272mbedtls_mpi_cmp_mpi:16:"1230000000000000000":16:"":1
273
274Test mbedtls_mpi_cmp_mpi: large positive > 0 (1 limb)
275mbedtls_mpi_cmp_mpi:16:"1230000000000000000":16:"0":1
276
277Test mbedtls_mpi_cmp_mpi: large negative < 0 (null)
278mbedtls_mpi_cmp_mpi:16:"-1230000000000000000":16:"":-1
279
280Test mbedtls_mpi_cmp_mpi: large negative < 0 (1 limb)
281mbedtls_mpi_cmp_mpi:16:"-1230000000000000000":16:"0":-1
282
Janos Follath867a3ab2019-10-11 14:21:53 +0100283Base test mbedtls_mpi_lt_mpi_ct #1
Janos Follath27d221a2019-10-14 09:21:49 +0100284mbedtls_mpi_lt_mpi_ct:1:"2B5":1:"2B5":0:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100285
Janos Follath867a3ab2019-10-11 14:21:53 +0100286Base test mbedtls_mpi_lt_mpi_ct #2
Janos Follath27d221a2019-10-14 09:21:49 +0100287mbedtls_mpi_lt_mpi_ct:1:"2B5":1:"2B4":0:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100288
Janos Follath867a3ab2019-10-11 14:21:53 +0100289Base test mbedtls_mpi_lt_mpi_ct #3
Janos Follath27d221a2019-10-14 09:21:49 +0100290mbedtls_mpi_lt_mpi_ct:1:"2B5":1:"2B6":1:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100291
Janos Follath867a3ab2019-10-11 14:21:53 +0100292Base test mbedtls_mpi_lt_mpi_ct (Negative values) #1
Janos Follath27d221a2019-10-14 09:21:49 +0100293mbedtls_mpi_lt_mpi_ct:1:"-2":1:"-2":0:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100294
Janos Follath867a3ab2019-10-11 14:21:53 +0100295Base test mbedtls_mpi_lt_mpi_ct (Negative values) #2
Janos Follath27d221a2019-10-14 09:21:49 +0100296mbedtls_mpi_lt_mpi_ct:1:"-2":1:"-3":0:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100297
Janos Follath867a3ab2019-10-11 14:21:53 +0100298Base test mbedtls_mpi_lt_mpi_ct (Negative values) #3
Janos Follath27d221a2019-10-14 09:21:49 +0100299mbedtls_mpi_lt_mpi_ct:1:"-2":1:"-1":1:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100300
Janos Follathb2fddfd2019-11-05 11:56:07 +0000301Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #1
Janos Follath27d221a2019-10-14 09:21:49 +0100302mbedtls_mpi_lt_mpi_ct:1:"-3":1:"2":1:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100303
Janos Follathb2fddfd2019-11-05 11:56:07 +0000304Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #2
Janos Follath27d221a2019-10-14 09:21:49 +0100305mbedtls_mpi_lt_mpi_ct:1:"2":1:"-3":0:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100306
Janos Follathb2fddfd2019-11-05 11:56:07 +0000307Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #3
Janos Follath27d221a2019-10-14 09:21:49 +0100308mbedtls_mpi_lt_mpi_ct:2:"-2":2:"1C67967269C6":1:0
Janos Follathe9ae6302019-09-11 16:07:14 +0100309
Janos Follathb2fddfd2019-11-05 11:56:07 +0000310Base test mbedtls_mpi_lt_mpi_ct (X is longer in storage)
Janos Follath27d221a2019-10-14 09:21:49 +0100311mbedtls_mpi_lt_mpi_ct:3:"2B5":2:"2B5":0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Janos Follathe9ae6302019-09-11 16:07:14 +0100312
Janos Follathb2fddfd2019-11-05 11:56:07 +0000313Base test mbedtls_mpi_lt_mpi_ct (Y is longer in storage)
Janos Follath27d221a2019-10-14 09:21:49 +0100314mbedtls_mpi_lt_mpi_ct:3:"2B5":4:"2B5":0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Janos Follathe9ae6302019-09-11 16:07:14 +0100315
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200316Base test mbedtls_mpi_lt_mpi_ct (length=0)
317mbedtls_mpi_lt_mpi_ct:0:"":0:"":0:0
318
Janos Follath798e3942019-10-29 15:05:12 +0000319Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #1
Janos Follath14528622019-11-05 11:42:20 +0000320mbedtls_mpi_lt_mpi_ct:2:"7FFFFFFFFFFFFFFF":2:"FF":0:0
Janos Follathe1bf02a2019-10-14 11:33:39 +0100321
Janos Follath798e3942019-10-29 15:05:12 +0000322Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #2
Janos Follath14528622019-11-05 11:42:20 +0000323mbedtls_mpi_lt_mpi_ct:2:"8000000000000000":2:"7FFFFFFFFFFFFFFF":0:0
Janos Follathe1bf02a2019-10-14 11:33:39 +0100324
Janos Follath798e3942019-10-29 15:05:12 +0000325Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #3
Janos Follath14528622019-11-05 11:42:20 +0000326mbedtls_mpi_lt_mpi_ct:2:"8000000000000000":2:"1":0:0
Janos Follathe1bf02a2019-10-14 11:33:39 +0100327
Janos Follath798e3942019-10-29 15:05:12 +0000328Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #4
Janos Follath14528622019-11-05 11:42:20 +0000329mbedtls_mpi_lt_mpi_ct:2:"8000000000000000":2:"0":0:0
Janos Follathe1bf02a2019-10-14 11:33:39 +0100330
Janos Follath798e3942019-10-29 15:05:12 +0000331Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #5
Janos Follath14528622019-11-05 11:42:20 +0000332mbedtls_mpi_lt_mpi_ct:2:"FFFFFFFFFFFFFFFF":2:"FF":0:0
Janos Follathe1bf02a2019-10-14 11:33:39 +0100333
Janos Follath798e3942019-10-29 15:05:12 +0000334Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #1
Janos Follath798e3942019-10-29 15:05:12 +0000335mbedtls_mpi_lt_mpi_ct:1:"7FFFFFFF":1:"FF":0:0
336
337Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #2
Janos Follath798e3942019-10-29 15:05:12 +0000338mbedtls_mpi_lt_mpi_ct:1:"80000000":1:"7FFFFFFF":0:0
339
340Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #3
Janos Follath798e3942019-10-29 15:05:12 +0000341mbedtls_mpi_lt_mpi_ct:1:"80000000":1:"1":0:0
342
343Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #4
Janos Follath798e3942019-10-29 15:05:12 +0000344mbedtls_mpi_lt_mpi_ct:1:"80000000":1:"0":0:0
345
346Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #5
Janos Follath798e3942019-10-29 15:05:12 +0000347mbedtls_mpi_lt_mpi_ct:1:"FFFFFFFF":1:"FF":0:0
348
Janos Follathb2fddfd2019-11-05 11:56:07 +0000349Multi-limb mbedtls_mpi_lt_mpi_ct (X<Y, zero vs non-zero MS limb)
Janos Follathe1bf02a2019-10-14 11:33:39 +0100350mbedtls_mpi_lt_mpi_ct:2:"0FFFFFFFFFFFFFFFF":2:"1FFFFFFFFFFFFFFFF":1:0
351
Janos Follathb2fddfd2019-11-05 11:56:07 +0000352Multi-limb mbedtls_mpi_lt_mpi_ct (X>Y, equal MS limbs)
Janos Follathe1bf02a2019-10-14 11:33:39 +0100353mbedtls_mpi_lt_mpi_ct:2:"-EEFFFFFFFFFFFFFFF1":2:"-EEFFFFFFFFFFFFFFFF":0:0
354
Janos Follathb2fddfd2019-11-05 11:56:07 +0000355Multi-limb mbedtls_mpi_lt_mpi_ct (X=Y)
Janos Follathe1bf02a2019-10-14 11:33:39 +0100356mbedtls_mpi_lt_mpi_ct:2:"EEFFFFFFFFFFFFFFFF":2:"EEFFFFFFFFFFFFFFFF":0:0
357
Janos Follathb2fddfd2019-11-05 11:56:07 +0000358Multi-limb mbedtls_mpi_lt_mpi_ct (X=-Y)
Janos Follathe1bf02a2019-10-14 11:33:39 +0100359mbedtls_mpi_lt_mpi_ct:2:"-EEFFFFFFFFFFFFFFFF":2:"EEFFFFFFFFFFFFFFFF":1:0
360
Janos Follathb159ae82019-11-05 12:19:14 +0000361Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #1
362mbedtls_mpi_lt_mpi_ct:2:"11FFFFFFFFFFFFFFFF":2:"FF1111111111111111":1:0
363
364Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #2
365mbedtls_mpi_lt_mpi_ct:2:"FF1111111111111111":2:"11FFFFFFFFFFFFFFFF":0:0
366
367Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #3
368mbedtls_mpi_lt_mpi_ct:2:"-11FFFFFFFFFFFFFFFF":2:"-FF1111111111111111":0:0
369
370Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #4
371mbedtls_mpi_lt_mpi_ct:2:"-FF1111111111111111":2:"-11FFFFFFFFFFFFFFFF":1:0
372
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200373Base test mbedtls_mpi_cmp_abs #1
374mbedtls_mpi_cmp_abs:10:"693":10:"693":0
Paul Bakker367dae42009-06-28 21:50:27 +0000375
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200376Base test mbedtls_mpi_cmp_abs #2
377mbedtls_mpi_cmp_abs:10:"693":10:"692":1
Paul Bakker367dae42009-06-28 21:50:27 +0000378
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200379Base test mbedtls_mpi_cmp_abs #3
380mbedtls_mpi_cmp_abs:10:"693":10:"694":-1
Paul Bakker367dae42009-06-28 21:50:27 +0000381
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200382Base test mbedtls_mpi_cmp_abs (Negative values) #1
383mbedtls_mpi_cmp_abs:10:"-2":10:"-2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000384
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200385Base test mbedtls_mpi_cmp_abs (Negative values) #2
386mbedtls_mpi_cmp_abs:10:"-2":10:"-3":-1
Paul Bakker367dae42009-06-28 21:50:27 +0000387
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200388Base test mbedtls_mpi_cmp_abs (Negative values) #3
389mbedtls_mpi_cmp_abs:10:"-2":10:"-1":1
Paul Bakker367dae42009-06-28 21:50:27 +0000390
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200391Test mbedtls_mpi_cmp_abs: 0 (null) = 0 (null)
392mbedtls_mpi_cmp_abs:10:"":10:"":0
393
394Test mbedtls_mpi_cmp_abs: 0 (null) = 0 (1 limb)
395mbedtls_mpi_cmp_abs:10:"":10:"0":0
396
397Test mbedtls_mpi_cmp_abs: 0 (1 limb) = 0 (null)
398mbedtls_mpi_cmp_abs:10:"0":10:"":0
399
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +0200400Test mbedtls_mpi_cmp_abs: 0 (1 limb) = 0 (1 limb)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200401mbedtls_mpi_cmp_abs:10:"0":10:"0":0
Paul Bakkerba48cb22009-07-12 11:01:32 +0000402
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200403Base test mbedtls_mpi_cmp_abs (Mix values) #1
404mbedtls_mpi_cmp_abs:10:"-2":10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000405
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200406Base test mbedtls_mpi_cmp_abs (Mix values) #2
407mbedtls_mpi_cmp_abs:10:"2":10:"-3":-1
Paul Bakker367dae42009-06-28 21:50:27 +0000408
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200409Base test mbedtls_mpi_cmp_abs (Mix values) #3
410mbedtls_mpi_cmp_abs:10:"-2":10:"1":1
Paul Bakker367dae42009-06-28 21:50:27 +0000411
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200412Copy large negative to large negative
413mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100414
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200415Copy large negative to large positive
416mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100417
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200418Copy large negative to small negative
419mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":"-beef"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100420
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200421Copy large negative to small positive
422mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":"beef"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100423
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200424Copy large negative to zero (1 limb)
425mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":"0"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100426
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200427Copy large negative to zero (null)
428mbedtls_mpi_copy:"-ca5cadedb01dfaceacc01ade":""
429
430Copy large positive to large negative
431mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
432
433Copy large positive to large positive
434mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
435
436Copy large positive to small negative
437mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":"-beef"
438
439Copy large positive to small positive
440mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":"beef"
441
442Copy large positive to zero (1 limb)
443mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":"0"
444
445Copy large positive to zero (null)
446mbedtls_mpi_copy:"ca5cadedb01dfaceacc01ade":""
447
448Copy small negative to large negative
449mbedtls_mpi_copy:"-bead":"-face1e55ca11ab1ecab005e5"
450
451Copy small negative to large positive
452mbedtls_mpi_copy:"-bead":"face1e55ca11ab1ecab005e5"
453
454Copy small negative to small negative
455mbedtls_mpi_copy:"-bead":"-beef"
456
457Copy small negative to small positive
458mbedtls_mpi_copy:"-bead":"beef"
459
460Copy small negative to zero (1 limb)
461mbedtls_mpi_copy:"-bead":"0"
462
463Copy small negative to zero (null)
464mbedtls_mpi_copy:"-bead":""
465
466Copy small positive to large negative
467mbedtls_mpi_copy:"bead":"-face1e55ca11ab1ecab005e5"
468
469Copy small positive to large positive
470mbedtls_mpi_copy:"bead":"face1e55ca11ab1ecab005e5"
471
472Copy small positive to small negative
473mbedtls_mpi_copy:"bead":"-beef"
474
475Copy small positive to small positive
476mbedtls_mpi_copy:"bead":"beef"
477
478Copy small positive to zero (1 limb)
479mbedtls_mpi_copy:"bead":"0"
480
481Copy small positive to zero (null)
482mbedtls_mpi_copy:"bead":""
483
484Copy zero (1 limb) to large negative
485mbedtls_mpi_copy:"0":"-face1e55ca11ab1ecab005e5"
486
487Copy zero (1 limb) to large positive
488mbedtls_mpi_copy:"0":"face1e55ca11ab1ecab005e5"
489
490Copy zero (1 limb) to small negative
491mbedtls_mpi_copy:"0":"-beef"
492
493Copy zero (1 limb) to small positive
494mbedtls_mpi_copy:"0":"beef"
495
496Copy zero (1 limb) to zero (1 limb)
497mbedtls_mpi_copy:"0":"0"
498
499Copy zero (1 limb) to zero (null)
500mbedtls_mpi_copy:"0":""
501
502Copy zero (null) to large negative
503mbedtls_mpi_copy:"":"-face1e55ca11ab1ecab005e5"
504
505Copy zero (null) to large positive
506mbedtls_mpi_copy:"":"face1e55ca11ab1ecab005e5"
507
508Copy zero (null) to small negative
509mbedtls_mpi_copy:"":"-beef"
510
511Copy zero (null) to small positive
512mbedtls_mpi_copy:"":"beef"
513
514Copy zero (null) to zero (1 limb)
515mbedtls_mpi_copy:"":"0"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100516
517Copy zero (null) to zero (null)
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200518mbedtls_mpi_copy:"":""
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100519
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200520Copy self: large negative
521mpi_copy_self:"-ca5cadedb01dfaceacc01ade"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100522
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200523Copy self: large positive
524mpi_copy_self:"ca5cadedb01dfaceacc01ade"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100525
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200526Copy self: small negative
527mpi_copy_self:"-bead"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100528
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200529Copy self: small positive
530mpi_copy_self:"bead"
Paul Bakkere896fea2009-07-06 06:40:23 +0000531
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100532Copy self: zero (1 limb)
Gilles Peskine8e1aa662021-06-10 15:17:30 +0200533mpi_copy_self:"0"
534
535Copy self: zero (null)
536mpi_copy_self:""
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100537
Gilles Peskine1e914262021-06-10 22:29:57 +0200538Swap large negative with large negative
539mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100540
Gilles Peskine1e914262021-06-10 22:29:57 +0200541Swap large negative with large positive
542mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100543
Gilles Peskine1e914262021-06-10 22:29:57 +0200544Swap large negative with small negative
545mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":"-beef"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100546
Gilles Peskine1e914262021-06-10 22:29:57 +0200547Swap large negative with small positive
548mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":"beef"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100549
Gilles Peskine1e914262021-06-10 22:29:57 +0200550Swap large negative with zero (1 limb)
551mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":"0"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100552
Gilles Peskine1e914262021-06-10 22:29:57 +0200553Swap large negative with zero (null)
554mbedtls_mpi_swap:"-ca5cadedb01dfaceacc01ade":""
555
556Swap large positive with large negative
557mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
558
559Swap large positive with large positive
560mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
561
562Swap large positive with small negative
563mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":"-beef"
564
565Swap large positive with small positive
566mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":"beef"
567
568Swap large positive with zero (1 limb)
569mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":"0"
570
571Swap large positive with zero (null)
572mbedtls_mpi_swap:"ca5cadedb01dfaceacc01ade":""
573
574Swap small negative with large negative
575mbedtls_mpi_swap:"-bead":"-face1e55ca11ab1ecab005e5"
576
577Swap small negative with large positive
578mbedtls_mpi_swap:"-bead":"face1e55ca11ab1ecab005e5"
579
580Swap small negative with small negative
581mbedtls_mpi_swap:"-bead":"-beef"
582
583Swap small negative with small positive
584mbedtls_mpi_swap:"-bead":"beef"
585
586Swap small negative with zero (1 limb)
587mbedtls_mpi_swap:"-bead":"0"
588
589Swap small negative with zero (null)
590mbedtls_mpi_swap:"-bead":""
591
592Swap small positive with large negative
593mbedtls_mpi_swap:"bead":"-face1e55ca11ab1ecab005e5"
594
595Swap small positive with large positive
596mbedtls_mpi_swap:"bead":"face1e55ca11ab1ecab005e5"
597
598Swap small positive with small negative
599mbedtls_mpi_swap:"bead":"-beef"
600
601Swap small positive with small positive
602mbedtls_mpi_swap:"bead":"beef"
603
604Swap small positive with zero (1 limb)
605mbedtls_mpi_swap:"bead":"0"
606
607Swap small positive with zero (null)
608mbedtls_mpi_swap:"bead":""
609
610Swap zero (1 limb) with large negative
611mbedtls_mpi_swap:"0":"-face1e55ca11ab1ecab005e5"
612
613Swap zero (1 limb) with large positive
614mbedtls_mpi_swap:"0":"face1e55ca11ab1ecab005e5"
615
616Swap zero (1 limb) with small negative
617mbedtls_mpi_swap:"0":"-beef"
618
619Swap zero (1 limb) with small positive
620mbedtls_mpi_swap:"0":"beef"
621
622Swap zero (1 limb) with zero (1 limb)
623mbedtls_mpi_swap:"0":"0"
624
625Swap zero (1 limb) with zero (null)
626mbedtls_mpi_swap:"0":""
627
628Swap zero (null) with large negative
629mbedtls_mpi_swap:"":"-face1e55ca11ab1ecab005e5"
630
631Swap zero (null) with large positive
632mbedtls_mpi_swap:"":"face1e55ca11ab1ecab005e5"
633
634Swap zero (null) with small negative
635mbedtls_mpi_swap:"":"-beef"
636
637Swap zero (null) with small positive
638mbedtls_mpi_swap:"":"beef"
639
640Swap zero (null) with zero (1 limb)
641mbedtls_mpi_swap:"":"0"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100642
643Swap zero (null) with zero (null)
Gilles Peskine1e914262021-06-10 22:29:57 +0200644mbedtls_mpi_swap:"":""
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100645
Gilles Peskine1e914262021-06-10 22:29:57 +0200646Swap self: large negative
647mpi_swap_self:"-ca5cadedb01dfaceacc01ade"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100648
Gilles Peskine1e914262021-06-10 22:29:57 +0200649Swap self: large positive
650mpi_swap_self:"ca5cadedb01dfaceacc01ade"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100651
Gilles Peskine1e914262021-06-10 22:29:57 +0200652Swap self: small negative
653mpi_swap_self:"-bead"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100654
Gilles Peskine1e914262021-06-10 22:29:57 +0200655Swap self: small positive
656mpi_swap_self:"bead"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100657
Gilles Peskine1e914262021-06-10 22:29:57 +0200658Swap self: zero (1 limb)
659mpi_swap_self:"0"
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100660
Gilles Peskine1e914262021-06-10 22:29:57 +0200661Swap self: zero (null)
Gilles Peskine8fe3b792020-01-20 21:01:51 +0100662mpi_swap_self:""
Paul Bakker367dae42009-06-28 21:50:27 +0000663
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200664Shrink 0 limbs in a buffer of size 0 to 0
665mbedtls_mpi_shrink:0:0:0:0
666
Gilles Peskine8ece8572020-02-03 16:18:30 +0100667Shrink 2 limbs in a buffer of size 2 to 4
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200668mbedtls_mpi_shrink:2:2:4:4
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100669
Gilles Peskine8ece8572020-02-03 16:18:30 +0100670Shrink 2 limbs in a buffer of size 4 to 4
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200671mbedtls_mpi_shrink:4:2:4:4
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100672
Gilles Peskine8ece8572020-02-03 16:18:30 +0100673Shrink 2 limbs in a buffer of size 8 to 4
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200674mbedtls_mpi_shrink:8:2:4:4
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100675
Gilles Peskine8ece8572020-02-03 16:18:30 +0100676Shrink 4 limbs in a buffer of size 8 to 4
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200677mbedtls_mpi_shrink:8:4:4:4
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100678
Gilles Peskine8ece8572020-02-03 16:18:30 +0100679Shrink 6 limbs in a buffer of size 8 to 4 yielding 6
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200680mbedtls_mpi_shrink:8:6:4:6
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100681
Gilles Peskine8ece8572020-02-03 16:18:30 +0100682Shrink 2 limbs in a buffer of size 4 to 0 yielding 2
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200683mbedtls_mpi_shrink:4:2:0:2
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100684
Gilles Peskine8ece8572020-02-03 16:18:30 +0100685Shrink 1 limbs in a buffer of size 4 to 0 yielding 1
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200686mbedtls_mpi_shrink:4:1:0:1
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100687
Gilles Peskine8ece8572020-02-03 16:18:30 +0100688Shrink 0 limbs in a buffer of size 4 to 0 yielding 1
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200689mbedtls_mpi_shrink:4:0:0:1
Manuel Pégourié-Gonnard58681632013-11-21 10:39:37 +0100690
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200691Base test mbedtls_mpi_add_abs #1
692mbedtls_mpi_add_abs:10:"12345678":10:"642531":10:"12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000693
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200694Base test mbedtls_mpi_add_abs #2
695mbedtls_mpi_add_abs:10:"-12345678":10:"642531":10:"12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000696
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200697Base test mbedtls_mpi_add_abs #3
698mbedtls_mpi_add_abs:10:"12345678":10:"-642531":10:"12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000699
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200700Base test mbedtls_mpi_add_abs #4
701mbedtls_mpi_add_abs:10:"-12345678":10:"-642531":10:"12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000702
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200703Test mbedtls_mpi_add_abs: 0 (null) + 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200704mbedtls_mpi_add_abs:16:"":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200705
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200706Test mbedtls_mpi_add_abs: 0 (null) + 1
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200707mbedtls_mpi_add_abs:16:"":16:"01":16:"01"
708
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200709Test mbedtls_mpi_add_abs: 1 + 0 (null)
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200710mbedtls_mpi_add_abs:16:"01":16:"":16:"01"
711
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200712Test mbedtls_mpi_add_abs #1
713mbedtls_mpi_add_abs:10:"-643808006803554439230129854961492699151386107534013432918073439524138264842370630061369715394739134090922937332590384720397133335969549256322620979036686633213903952966175107096769180017646161851573147596390153":10:"56125680981752282333498088313568935051383833838594899821664631784577337171193624243181360054669678410455329112434552942717084003541384594864129940145043086760031292483340068923506115878221189886491132772739661669044958531131327771":10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924"
Paul Bakker367dae42009-06-28 21:50:27 +0000714
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200715Regression mbedtls_mpi_add_abs (add small to very large MPI with carry rollover)
716mbedtls_mpi_add_abs:16:"FFFFFFFFFFFFFFFFFFFFFFFFFFFFF8":16:"08":16:"1000000000000000000000000000000"
Paul Bakker17a97902012-09-17 08:44:35 +0000717
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200718Regression mbedtls_mpi_add_abs (add small to very large MPI with carry rollover)
719mbedtls_mpi_add_abs:16:"08":16:"FFFFFFFFFFFFFFFFFFFFFFFFFFFFF8":16:"1000000000000000000000000000000"
Paul Bakker17a97902012-09-17 08:44:35 +0000720
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200721Base test mbedtls_mpi_add_mpi #1
722mbedtls_mpi_add_mpi:10:"12345678":10:"642531":10:"12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000723
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200724Base test mbedtls_mpi_add_mpi #2
725mbedtls_mpi_add_mpi:10:"-12345678":10:"642531":10:"-11703147"
Paul Bakker367dae42009-06-28 21:50:27 +0000726
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200727Base test mbedtls_mpi_add_mpi #3
728mbedtls_mpi_add_mpi:10:"12345678":10:"-642531":10:"11703147"
Paul Bakker367dae42009-06-28 21:50:27 +0000729
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200730Base test mbedtls_mpi_add_mpi #4
731mbedtls_mpi_add_mpi:10:"-12345678":10:"-642531":10:"-12988209"
Paul Bakker367dae42009-06-28 21:50:27 +0000732
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200733Test mbedtls_mpi_add_mpi: 0 (null) + 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200734mbedtls_mpi_add_mpi:16:"":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200735
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200736Test mbedtls_mpi_add_mpi: 0 (null) + 1
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200737mbedtls_mpi_add_mpi:16:"":16:"01":16:"01"
738
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200739Test mbedtls_mpi_add_mpi: 1 + 0 (null)
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200740mbedtls_mpi_add_mpi:16:"01":16:"":16:"01"
741
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200742Test mbedtls_mpi_add_mpi: 0 (null) + -1
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200743mbedtls_mpi_add_mpi:16:"":16:"-01":16:"-01"
744
Gilles Peskine3cfb7be2021-06-15 22:03:37 +0200745Test mbedtls_mpi_add_mpi: -1 + 0 (null)
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200746mbedtls_mpi_add_mpi:16:"-01":16:"":16:"-01"
747
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200748Test mbedtls_mpi_add_mpi #1
749mbedtls_mpi_add_mpi:10:"203956878356401977405765866929034577280193993314348263094772646453283062722701277632936616063144088173312372882677123879538709400158306567338328279154499698366071906766440037074217117805690872792848149112022286332144876183376326512083574821647933992961249917319836219304274280243803104015000563790123":10:"531872289054204184185084734375133399408303613982130856645299464930952178606045848877129147820387996428175564228204785846141207532462936339834139412401975338705794646595487324365194792822189473092273993580587964571659678084484152603881094176995594813302284232006001752128168901293560051833646881436219":10:"735829167410606161590850601304167976688497607296479119740072111384235241328747126510065763883532084601487937110881909725679916932621242907172467691556475037071866553361927361439411910627880345885122142692610250903804554267860479115964668998643528806263534149325837971432443181537363155848647445226342"
Paul Bakker367dae42009-06-28 21:50:27 +0000750
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200751Test mbedtls_mpi_add_mpi #2
752mbedtls_mpi_add_mpi:10:"643808006803554439230129854961492699151386107534013432918073439524138264842370630061369715394739134090922937332590384720397133335969549256322620979036686633213903952966175107096769180017646161851573147596390153":10:"56125680981752282333498088313568935051383833838594899821664631784577337171193624243181360054669678410455329112434552942717084003541384594864129940145043086760031292483340068923506115878221189886491132772739661669044958531131327771":10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924"
Paul Bakker367dae42009-06-28 21:50:27 +0000753
Janos Follath044a86b2015-10-25 10:58:03 +0100754Base test mbedtls_mpi_add_mpi inplace #1
755mbedtls_mpi_add_mpi_inplace:10:"12345678":10:"24691356"
756
Darryl Green11999bb2018-03-13 15:22:58 +0000757Test mbedtls_mpi_add_mpi inplace #2
Janos Follath044a86b2015-10-25 10:58:03 +0100758mbedtls_mpi_add_mpi_inplace:10:"643808006803554439230129854961492699151386107534013432918073439524138264842370630061369715394739134090922937332590384720397133335969549256322620979036686633213903952966175107096769180017646161851573147596390153":10:"1287616013607108878460259709922985398302772215068026865836146879048276529684741260122739430789478268181845874665180769440794266671939098512645241958073373266427807905932350214193538360035292323703146295192780306"
759
Darryl Green11999bb2018-03-13 15:22:58 +0000760Test mbedtls_mpi_add_mpi inplace #3
Janos Follath6c922682015-10-30 17:43:11 +0100761mbedtls_mpi_add_mpi_inplace:16:"ffffffffffffffffffffffffffffffff":16:"01fffffffffffffffffffffffffffffffe"
762
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200763Test mbedtls_mpi_add_int #1
764mbedtls_mpi_add_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":9871232:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227022647561"
Paul Bakker367dae42009-06-28 21:50:27 +0000765
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200766Test mbedtls_mpi_add_int #2
767mbedtls_mpi_add_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":-9871232:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227002905097"
Paul Bakker367dae42009-06-28 21:50:27 +0000768
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200769Test mbedtls_mpi_add_int: 0 (null) + 0
Gilles Peskine05a1af62021-06-15 21:49:31 +0200770mbedtls_mpi_add_int:16:"":0:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200771
772Test mbedtls_mpi_add_int: 0 (null) + 1
773mbedtls_mpi_add_int:16:"":1:16:"1"
774
Gilles Peskine9a3cf312021-01-27 22:24:30 +0100775Base test mbedtls_mpi_sub_abs #1 (|B| > |A|)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200776mbedtls_mpi_sub_abs:10:"5":10:"7":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +0000777
Gilles Peskine9a3cf312021-01-27 22:24:30 +0100778Base test mbedtls_mpi_sub_abs #2 (|B| > |A|)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200779mbedtls_mpi_sub_abs:10:"-5":10:"-7":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +0000780
Gilles Peskine9a3cf312021-01-27 22:24:30 +0100781Base test mbedtls_mpi_sub_abs #3 (|B| > |A|)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200782mbedtls_mpi_sub_abs:10:"-5":10:"7":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +0000783
Gilles Peskine9a3cf312021-01-27 22:24:30 +0100784Base test mbedtls_mpi_sub_abs #4 (|B| > |A|)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200785mbedtls_mpi_sub_abs:10:"5":10:"-7":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +0000786
Gilles Peskine9a3cf312021-01-27 22:24:30 +0100787Base test mbedtls_mpi_sub_abs #1 (|B| >> |A| with more limbs)
788mbedtls_mpi_sub_abs:10:"5":16:"123456789abcdef01":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
789
790Base test mbedtls_mpi_sub_abs #2 (|B| >> |A| with more limbs)
791mbedtls_mpi_sub_abs:10:"-5":16:"-123456789abcdef01":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
792
793Base test mbedtls_mpi_sub_abs #3 (|B| >> |A| with more limbs)
794mbedtls_mpi_sub_abs:10:"-5":16:"123456789abcdef01":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
795
796Base test mbedtls_mpi_sub_abs #4 (|B| >> |A| with more limbs)
797mbedtls_mpi_sub_abs:10:"5":16:"-123456789abcdef01":10:"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
798
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200799Base test mbedtls_mpi_sub_abs #1
800mbedtls_mpi_sub_abs:10:"7":10:"5":10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000801
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200802Base test mbedtls_mpi_sub_abs #2
803mbedtls_mpi_sub_abs:10:"-7":10:"-5":10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000804
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200805Base test mbedtls_mpi_sub_abs #3
806mbedtls_mpi_sub_abs:10:"-7":10:"5":10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000807
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200808Base test mbedtls_mpi_sub_abs #4
809mbedtls_mpi_sub_abs:10:"7":10:"-5":10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +0000810
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200811Test mbedtls_mpi_sub_abs: 0 (null) - 0 (null)
812mbedtls_mpi_sub_abs:16:"":16:"":16:"":0
813
814Test mbedtls_mpi_sub_abs: 0 (null) - 0 (1 limb)
815mbedtls_mpi_sub_abs:16:"":16:"00":16:"":0
816
817Test mbedtls_mpi_sub_abs: 0 (1 limb) - 0 (null)
818mbedtls_mpi_sub_abs:16:"00":16:"":16:"":0
819
820Test mbedtls_mpi_sub_abs: 0 (1 limb) - 0 (1 limb)
821mbedtls_mpi_sub_abs:16:"00":16:"00":16:"":0
822
823Test mbedtls_mpi_sub_abs: 1 - 0 (null)
824mbedtls_mpi_sub_abs:16:"01":16:"":16:"01":0
825
826Test mbedtls_mpi_sub_abs: 0 (null) - 1
827mbedtls_mpi_sub_abs:16:"":16:"01":16:"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
828
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200829Test mbedtls_mpi_sub_abs #1
830mbedtls_mpi_sub_abs:16:"FFFFFFFFFF":16:"01":16:"FFFFFFFFFE":0
Paul Bakkerc847f072010-01-18 21:26:30 +0000831
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200832Test mbedtls_mpi_sub_abs #2
833mbedtls_mpi_sub_abs:16:"FFFFFFFFF0":16:"01":16:"FFFFFFFFEF":0
Paul Bakkerc847f072010-01-18 21:26:30 +0000834
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200835Test mbedtls_mpi_sub_abs #3
836mbedtls_mpi_sub_abs:16:"FF00000000":16:"0F00000000":16:"F000000000":0
Paul Bakkerc847f072010-01-18 21:26:30 +0000837
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200838Test mbedtls_mpi_sub_abs #4
839mbedtls_mpi_sub_abs:16:"FF00000000":16:"0F00000001":16:"EFFFFFFFFF":0
Paul Bakkerc847f072010-01-18 21:26:30 +0000840
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200841Base test mbedtls_mpi_sub_mpi #1 (Test with negative result)
842mbedtls_mpi_sub_mpi:10:"5":10:"7":10:"-2"
Paul Bakker367dae42009-06-28 21:50:27 +0000843
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200844Base test mbedtls_mpi_sub_mpi #2 (Test with negative inputs)
845mbedtls_mpi_sub_mpi:10:"-5":10:"-7":10:"2"
Paul Bakker367dae42009-06-28 21:50:27 +0000846
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200847Base test mbedtls_mpi_sub_mpi #3 (Test with negative base)
848mbedtls_mpi_sub_mpi:10:"-5":10:"7":10:"-12"
Paul Bakker367dae42009-06-28 21:50:27 +0000849
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200850Base test mbedtls_mpi_sub_mpi #4 (Test with negative subtraction)
851mbedtls_mpi_sub_mpi:10:"5":10:"-7":10:"12"
Paul Bakker367dae42009-06-28 21:50:27 +0000852
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200853Test mbedtls_mpi_sub_mpi: 0 (null) - 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200854mbedtls_mpi_sub_mpi:16:"":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200855
856Test mbedtls_mpi_sub_mpi: 0 (null) - 0 (1 limb)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200857mbedtls_mpi_sub_mpi:16:"":16:"00":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200858
859Test mbedtls_mpi_sub_mpi: 0 (null) - 1
860mbedtls_mpi_sub_mpi:16:"":16:"1":16:"-1"
861
862Test mbedtls_mpi_sub_mpi: 0 (null) - -1
863mbedtls_mpi_sub_mpi:16:"":16:"-1":16:"1"
864
865Test mbedtls_mpi_sub_mpi: 0 (1 limb) - 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200866mbedtls_mpi_sub_mpi:16:"00":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200867
868Test mbedtls_mpi_sub_mpi: 1 - 0 (null)
869mbedtls_mpi_sub_mpi:16:"1":16:"":16:"1"
870
871Test mbedtls_mpi_sub_mpi: -1 - 0 (null)
872mbedtls_mpi_sub_mpi:16:"-1":16:"":16:"-1"
873
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200874Test mbedtls_mpi_sub_mpi #1
875mbedtls_mpi_sub_mpi:10:"531872289054204184185084734375133399408303613982130856645299464930952178606045848877129147820387996428175564228204785846141207532462936339834139412401975338705794646595487324365194792822189473092273993580587964571659678084484152603881094176995594813302284232006001752128168901293560051833646881436219":10:"203956878356401977405765866929034577280193993314348263094772646453283062722701277632936616063144088173312372882677123879538709400158306567338328279154499698366071906766440037074217117805690872792848149112022286332144876183376326512083574821647933992961249917319836219304274280243803104015000563790123":10:"327915410697802206779318867446098822128109620667782593550526818477669115883344571244192531757243908254863191345527661966602498132304629772495811133247475640339722739829047287290977675016498600299425844468565678239514801901107826091797519355347660820341034314686165532823894621049756947818646317646096"
Paul Bakker367dae42009-06-28 21:50:27 +0000876
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200877Test mbedtls_mpi_sub_mpi #2 (Test for negative result)
878mbedtls_mpi_sub_mpi:10:"643808006803554439230129854961492699151386107534013432918073439524138264842370630061369715394739134090922937332590384720397133335969549256322620979036686633213903952966175107096769180017646161851573147596390153":10:"56125680981752282333498088313568935051383833838594899821664631784577337171193624243181360054669678410455329112434552942717084003541384594864129940145043086760031292483340068923506115878221189886491132772739661669044958531131327771":10:"-56125680981752282332854280306765380612153703983633407122513245677043323738275550803657221789827307780393959397039813808626161066208794210143732806809073537503708671504303382290292211925255014779394363592722015507193385383534937618"
Paul Bakker367dae42009-06-28 21:50:27 +0000879
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200880Test mbedtls_mpi_sub_int #1
881mbedtls_mpi_sub_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":-9871232:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227022647561"
Paul Bakker367dae42009-06-28 21:50:27 +0000882
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200883Test mbedtls_mpi_sub_int #2
884mbedtls_mpi_sub_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":9871232:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227002905097"
Paul Bakker367dae42009-06-28 21:50:27 +0000885
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200886Test mbedtls_mpi_sub_int: 0 (null) - 0
Gilles Peskine05a1af62021-06-15 21:49:31 +0200887mbedtls_mpi_sub_int:16:"":0:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200888
889Test mbedtls_mpi_sub_int: 0 (null) - 1
890mbedtls_mpi_sub_int:16:"":1:16:"-1"
891
892Test mbedtls_mpi_sub_int: 0 (null) - -1
893mbedtls_mpi_sub_int:16:"":-1:16:"1"
894
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200895Test mbedtls_mpi_shift_l #1
896mbedtls_mpi_shift_l:10:"64":1:10:"128"
Paul Bakker367dae42009-06-28 21:50:27 +0000897
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200898Test mbedtls_mpi_shift_l #2
899mbedtls_mpi_shift_l:10:"658385546911733550164516088405238961461880256029834598831972039469421755117818013653494814438931957316403111689187691446941406788869098983929874080332195117465344344350008880118042764943201875870917468833709791733282363323948005998269792207":37:10:"90487820548639020691922304619723076305400961610119884872723190678642804168382367856686134531865643066983017249846286450251272364365605022750900439437595355052945035915579216557330505438734955340526145476988250171181404966718289259743378883640981192704"
Paul Bakker367dae42009-06-28 21:50:27 +0000900
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200901Test mbedtls_mpi_shift_l: 0 (null) <<= 0
Gilles Peskineead66602021-06-15 22:06:02 +0200902mbedtls_mpi_shift_l:16:"":0:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200903
904Test mbedtls_mpi_shift_l: 0 (null) <<= 1
Gilles Peskine05a1af62021-06-15 21:49:31 +0200905mbedtls_mpi_shift_l:16:"":1:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200906
907Test mbedtls_mpi_shift_l: 0 (null) <<= 64
Gilles Peskine05a1af62021-06-15 21:49:31 +0200908mbedtls_mpi_shift_l:16:"":64:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200909
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200910Test mbedtls_mpi_shift_r #1
911mbedtls_mpi_shift_r:10:"128":1:10:"64"
Paul Bakker367dae42009-06-28 21:50:27 +0000912
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200913Test mbedtls_mpi_shift_r #2
914mbedtls_mpi_shift_r:10:"120815570979701484704906977000760567182871429114712069861589084706550626575967516787438008593490722779337547394120718248995900363209947025063336882559539208430319216688889117222633155838468458047056355241515415159736436403445579777425189969":45:10:"3433785053053426415343295076376096153094051405637175942660777670498379921354157795219578264137985649407981651226029903483433269093721578004287291678324982297860947730012217028349628999378309630601971640587504883789518896817457"
Paul Bakker367dae42009-06-28 21:50:27 +0000915
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200916Test mbedtls_mpi_shift_r #4
917mbedtls_mpi_shift_r:16:"FFFFFFFFFFFFFFFF":63:16:"01"
Manuel Pégourié-Gonnarde44ec102012-11-17 12:42:51 +0100918
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200919Test mbedtls_mpi_shift_r #4
920mbedtls_mpi_shift_r:16:"FFFFFFFFFFFFFFFF":64:16:"00"
Manuel Pégourié-Gonnarde44ec102012-11-17 12:42:51 +0100921
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200922Test mbedtls_mpi_shift_r #6
923mbedtls_mpi_shift_r:16:"FFFFFFFFFFFFFFFF":65:16:"00"
Manuel Pégourié-Gonnarde44ec102012-11-17 12:42:51 +0100924
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200925Test mbedtls_mpi_shift_r #7
926mbedtls_mpi_shift_r:16:"FFFFFFFFFFFFFFFF":128:16:"00"
Manuel Pégourié-Gonnarde44ec102012-11-17 12:42:51 +0100927
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200928Test mbedtls_mpi_shift_r: 0 (null) >>= 0
Gilles Peskine05a1af62021-06-15 21:49:31 +0200929mbedtls_mpi_shift_r:16:"":0:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200930
931Test mbedtls_mpi_shift_r: 0 (null) >>= 1
Gilles Peskine05a1af62021-06-15 21:49:31 +0200932mbedtls_mpi_shift_r:16:"":1:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200933
934Test mbedtls_mpi_shift_r: 0 (null) >>= 64
Gilles Peskine05a1af62021-06-15 21:49:31 +0200935mbedtls_mpi_shift_r:16:"":64:16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200936
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200937Base test mbedtls_mpi_mul_mpi #1
938mbedtls_mpi_mul_mpi:10:"5":10:"7":10:"35"
Paul Bakker367dae42009-06-28 21:50:27 +0000939
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200940Base test mbedtls_mpi_mul_mpi #2
941mbedtls_mpi_mul_mpi:10:"-5":10:"7":10:"-35"
Paul Bakker367dae42009-06-28 21:50:27 +0000942
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200943Base test mbedtls_mpi_mul_mpi #3
944mbedtls_mpi_mul_mpi:10:"5":10:"-7":10:"-35"
Paul Bakker367dae42009-06-28 21:50:27 +0000945
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200946Base test mbedtls_mpi_mul_mpi #4
947mbedtls_mpi_mul_mpi:10:"-5":10:"-7":10:"35"
Paul Bakker367dae42009-06-28 21:50:27 +0000948
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200949Test mbedtls_mpi_mul_mpi: 0 (null) * 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200950mbedtls_mpi_mul_mpi:16:"":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200951
952Test mbedtls_mpi_mul_mpi: 0 (null) * 0 (1 limb)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200953mbedtls_mpi_mul_mpi:16:"":16:"00":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200954
955Test mbedtls_mpi_mul_mpi: 0 (null) * 1
Gilles Peskine05a1af62021-06-15 21:49:31 +0200956mbedtls_mpi_mul_mpi:16:"":16:"01":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200957
958Test mbedtls_mpi_mul_mpi: 0 (null) * -1
Gilles Peskine05a1af62021-06-15 21:49:31 +0200959mbedtls_mpi_mul_mpi:16:"":16:"-01":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200960
Gilles Peskineab6ab6a2021-06-10 15:51:54 +0200961Test mbedtls_mpi_mul_mpi: 0 (1 limb) * -1
Gilles Peskine05a1af62021-06-15 21:49:31 +0200962mbedtls_mpi_mul_mpi:16:"00":16:"-01":16:"0"
Gilles Peskineab6ab6a2021-06-10 15:51:54 +0200963
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200964Test mbedtls_mpi_mul_mpi: 0 (1 limb) * 0 (null)
Gilles Peskineead66602021-06-15 22:06:02 +0200965mbedtls_mpi_mul_mpi:16:"00":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200966
967Test mbedtls_mpi_mul_mpi: 1 * 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200968mbedtls_mpi_mul_mpi:16:"01":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200969
970Test mbedtls_mpi_mul_mpi: -1 * 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200971mbedtls_mpi_mul_mpi:16:"-01":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +0200972
Gilles Peskineab6ab6a2021-06-10 15:51:54 +0200973Test mbedtls_mpi_mul_mpi: -1 * 0 (1 limb)
Gilles Peskine05a1af62021-06-15 21:49:31 +0200974mbedtls_mpi_mul_mpi:16:"-01":16:"00":16:"0"
Gilles Peskineab6ab6a2021-06-10 15:51:54 +0200975
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200976Test mbedtls_mpi_mul_mpi #1
Gilles Peskine44e6bb62021-06-15 21:44:32 +0200977mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
978
979Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B
980mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
981
982Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, A < 0
983mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
984
985Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, B < 0
986mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
987
988Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, A < 0, B < 0
989mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
990
991Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A
992mbedtls_mpi_mul_mpi:16:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
993
994Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, A < 0
995mbedtls_mpi_mul_mpi:16:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
996
997Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, B < 0
998mbedtls_mpi_mul_mpi:16:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
999
1000Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, A < 0, B < 0
1001mbedtls_mpi_mul_mpi:16:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
1002
1003Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B
Gilles Peskine55e6abc2021-06-17 14:31:54 +02001004mbedtls_mpi_mul_mpi:16:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
Gilles Peskine44e6bb62021-06-15 21:44:32 +02001005
1006Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, A < 0
Gilles Peskine55e6abc2021-06-17 14:31:54 +02001007mbedtls_mpi_mul_mpi:16:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
Gilles Peskine44e6bb62021-06-15 21:44:32 +02001008
1009Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, B < 0
Gilles Peskine55e6abc2021-06-17 14:31:54 +02001010mbedtls_mpi_mul_mpi:16:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
Gilles Peskine44e6bb62021-06-15 21:44:32 +02001011
1012Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, A < 0, B < 0
Gilles Peskine55e6abc2021-06-17 14:31:54 +02001013mbedtls_mpi_mul_mpi:16:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
Gilles Peskine44e6bb62021-06-15 21:44:32 +02001014
1015Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A
1016mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1017
1018Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, A < 0
1019mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1020
1021Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, B < 0
1022mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1023
1024Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, A < 0, B < 0
1025mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1026
1027Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B
1028mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1029
1030Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, A < 0
1031mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1032
1033Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, B < 0
1034mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1035
1036Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, A < 0, B < 0
1037mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
1038
1039Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B
1040mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1041
1042Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, A < 0
1043mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1044
1045Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, B < 0
1046mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1047
1048Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, A < 0, B < 0
1049mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1050
1051Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A
1052mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1053
1054Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, A < 0
1055mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1056
1057Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, B < 0
1058mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1059
1060Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, A < 0, B < 0
1061mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1062
1063Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B
1064mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1065
1066Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, A < 0
1067mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1068
1069Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, B < 0
1070mbedtls_mpi_mul_mpi:16:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":16:"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
1071
1072Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, A < 0, B < 0
1073mbedtls_mpi_mul_mpi:16:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":16:"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":16:"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
Paul Bakker367dae42009-06-28 21:50:27 +00001074
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001075Test mbedtls_mpi_mul_int #1
1076mbedtls_mpi_mul_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":9871232:10:"20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":"=="
Paul Bakker367dae42009-06-28 21:50:27 +00001077
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001078Test mbedtls_mpi_mul_int #2 (Unsigned, thus failure)
1079mbedtls_mpi_mul_int:10:"2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":-9871232:10:"-20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":"!="
Paul Bakker367dae42009-06-28 21:50:27 +00001080
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001081Test mbedtls_mpi_mul_int #3
1082mbedtls_mpi_mul_int:10:"-2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":9871232:10:"-20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":"=="
Paul Bakker367dae42009-06-28 21:50:27 +00001083
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001084Test mbedtls_mpi_mul_int #4 (Unsigned, thus failure)
1085mbedtls_mpi_mul_int:10:"-2039568783564019774057658669290345772801939933143482630947726464532830627227012776329":-9871232:10:"20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":"!="
Paul Bakker367dae42009-06-28 21:50:27 +00001086
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001087Test mbedtls_mpi_mul_int: 0 (null) * 0
1088mbedtls_mpi_mul_int:16:"":0:16:"":"=="
1089
1090Test mbedtls_mpi_mul_int: 0 (null) * 1
1091mbedtls_mpi_mul_int:16:"":1:16:"":"=="
1092
1093Test mbedtls_mpi_mul_int: 0 (null) * 0x1234
1094mbedtls_mpi_mul_int:16:"":0x1234:16:"":"=="
1095
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001096Base test mbedtls_mpi_div_mpi #1
1097mbedtls_mpi_div_mpi:10:"1000":10:"13":10:"76":10:"12":0
Paul Bakker367dae42009-06-28 21:50:27 +00001098
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001099Base test mbedtls_mpi_div_mpi #2 (Divide by zero (1 limb))
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001100mbedtls_mpi_div_mpi:10:"1000":10:"0":10:"1":10:"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
Paul Bakker367dae42009-06-28 21:50:27 +00001101
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001102Base test mbedtls_mpi_div_mpi #2 (Divide by zero (null))
1103mbedtls_mpi_div_mpi:10:"1000":10:"":10:"1":10:"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1104
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001105Base test mbedtls_mpi_div_mpi #3
1106mbedtls_mpi_div_mpi:10:"1000":10:"-13":10:"-76":10:"12":0
Paul Bakker367dae42009-06-28 21:50:27 +00001107
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001108Test mbedtls_mpi_div_mpi: 0 (null) / 0 (null)
1109mbedtls_mpi_div_mpi:16:"":16:"":16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1110
1111Test mbedtls_mpi_div_mpi: 0 (null) / 0 (1 limb)
1112mbedtls_mpi_div_mpi:16:"":16:"0":16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1113
1114Test mbedtls_mpi_div_mpi: 0 (1 limb) / 0 (null)
1115mbedtls_mpi_div_mpi:16:"0":16:"":16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1116
1117Test mbedtls_mpi_div_mpi: 0 (1 limb) / 0 (1 limb)
1118mbedtls_mpi_div_mpi:16:"0":16:"0":16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1119
1120Test mbedtls_mpi_div_mpi: 0 (null) / 1
1121mbedtls_mpi_div_mpi:16:"":16:"1":16:"":16:"":0
1122
1123Test mbedtls_mpi_div_mpi: 0 (null) / -1
1124mbedtls_mpi_div_mpi:16:"":16:"-1":16:"":16:"":0
1125
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001126Test mbedtls_mpi_div_mpi #1
1127mbedtls_mpi_div_mpi:10:"20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":10:"34":10:"592148724779947824773845002981655249516095268533053127589864347174804198178334111238460803":10:"26":0
Paul Bakker367dae42009-06-28 21:50:27 +00001128
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001129Test mbedtls_mpi_div_mpi #2
1130mbedtls_mpi_div_mpi:10:"476221599179424887669515829231223263939342135681791605842540429321038144633323941248706405375723482912535192363845116154236465184147599697841273424891410002781967962186252583311115708128167171262206919514587899883547279647025952837516324649656913580411611297312678955801899536937577476819667861053063432906071315727948826276092545739432005962781562403795455162483159362585281248265005441715080197800335757871588045959754547836825977169125866324128449699877076762316768127816074587766799018626179199776188490087103869164122906791440101822594139648973454716256383294690817576188762":10:"28911710017320205966167820725313234361535259163045867986277478145081076845846493521348693253530011243988160148063424837895971948244167867236923919506962312185829914482993478947657472351461336729641485069323635424692930278888923450060546465883490944265147851036817433970984747733020522259537":10:"16471581891701794764704009719057349996270239948993452268812975037240586099924712715366967486587417803753916334331355573776945238871512026832810626226164346328807407669366029926221415383560814338828449642265377822759768011406757061063524768140567867350208554439342320410551341675119078050953":10:"1":0
Paul Bakker367dae42009-06-28 21:50:27 +00001131
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001132Test mbedtls_mpi_div_mpi #3
1133mbedtls_mpi_div_mpi:10:"1000":10:"7":10:"142":10:"6":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001134
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001135Test mbedtls_mpi_div_mpi #4
1136mbedtls_mpi_div_mpi:10:"777":10:"7":10:"111":10:"0":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001137
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001138Base test mbedtls_mpi_div_int #1
1139mbedtls_mpi_div_int:10:"1000":13:10:"76":10:"12":0
Paul Bakker367dae42009-06-28 21:50:27 +00001140
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001141Base test mbedtls_mpi_div_int #2 (Divide by zero)
1142mbedtls_mpi_div_int:10:"1000":0:10:"1":10:"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
Paul Bakker367dae42009-06-28 21:50:27 +00001143
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001144Base test mbedtls_mpi_div_int #3
1145mbedtls_mpi_div_int:10:"1000":-13:10:"-76":10:"12":0
Paul Bakker367dae42009-06-28 21:50:27 +00001146
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001147Test mbedtls_mpi_div_int #1
1148mbedtls_mpi_div_int:10:"20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":34:10:"592148724779947824773845002981655249516095268533053127589864347174804198178334111238460803":10:"26":0
Paul Bakker367dae42009-06-28 21:50:27 +00001149
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001150Test mbedtls_mpi_div_int #2
1151mbedtls_mpi_div_int:10:"20133056642518226042310730101376278483547239130123806338055387803943342738063359782107667328":-34:10:"-592148724779947824773845002981655249516095268533053127589864347174804198178334111238460803":10:"26":0
Paul Bakker367dae42009-06-28 21:50:27 +00001152
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001153Test mbedtls_mpi_div_int: 0 (null) / 0
1154mbedtls_mpi_div_int:16:"":0:16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1155
1156Test mbedtls_mpi_div_int: 0 (1 limb) / 0
1157mbedtls_mpi_div_int:16:"00":0:16:"":16:"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1158
1159Test mbedtls_mpi_div_int: 0 (null) / 1
1160mbedtls_mpi_div_int:16:"":1:16:"":16:"":0
1161
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001162Base test mbedtls_mpi_mod_mpi #1
1163mbedtls_mpi_mod_mpi:10:"1000":10:"13":10:"12":0
Paul Bakker367dae42009-06-28 21:50:27 +00001164
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001165Base test mbedtls_mpi_mod_mpi #2 (Divide by zero (null))
1166mbedtls_mpi_mod_mpi:10:"1000":10:"":10:"0":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
1167
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001168Base test mbedtls_mpi_mod_mpi #2 (Divide by zero (1 limb))
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001169mbedtls_mpi_mod_mpi:10:"1000":10:"0":10:"0":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
Paul Bakker367dae42009-06-28 21:50:27 +00001170
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001171Base test mbedtls_mpi_mod_mpi #3
1172mbedtls_mpi_mod_mpi:10:"-1000":10:"13":10:"1":0
Paul Bakker367dae42009-06-28 21:50:27 +00001173
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001174Base test mbedtls_mpi_mod_mpi #4 (Negative modulo)
1175mbedtls_mpi_mod_mpi:10:"1000":10:"-13":10:"-1":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +00001176
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001177Base test mbedtls_mpi_mod_mpi #5 (Negative modulo)
1178mbedtls_mpi_mod_mpi:10:"-1000":10:"-13":10:"-12":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +00001179
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001180Test mbedtls_mpi_mod_mpi: 0 (null) % 1
1181mbedtls_mpi_mod_mpi:16:"":16:"1":16:"":0
1182
1183Test mbedtls_mpi_mod_mpi: 0 (null) % -1
1184mbedtls_mpi_mod_mpi:16:"":16:"-1":16:"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
1185
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001186Base test mbedtls_mpi_mod_int #1
1187mbedtls_mpi_mod_int:10:"1000":13:12:0
Paul Bakker367dae42009-06-28 21:50:27 +00001188
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001189Base test mbedtls_mpi_mod_int #2 (Divide by zero)
1190mbedtls_mpi_mod_int:10:"1000":0:0:MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
Paul Bakker367dae42009-06-28 21:50:27 +00001191
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001192Base test mbedtls_mpi_mod_int #3
1193mbedtls_mpi_mod_int:10:"-1000":13:1:0
Paul Bakker367dae42009-06-28 21:50:27 +00001194
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001195Base test mbedtls_mpi_mod_int #4 (Negative modulo)
1196mbedtls_mpi_mod_int:10:"1000":-13:0:MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +00001197
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001198Base test mbedtls_mpi_mod_int #5 (Negative modulo)
1199mbedtls_mpi_mod_int:10:"-1000":-13:0:MBEDTLS_ERR_MPI_NEGATIVE_VALUE
Paul Bakker367dae42009-06-28 21:50:27 +00001200
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001201Base test mbedtls_mpi_mod_int #6 (By 1)
1202mbedtls_mpi_mod_int:10:"1000":1:0:0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001203
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001204Base test mbedtls_mpi_mod_int #7 (By 2)
1205mbedtls_mpi_mod_int:10:"1001":2:1:0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001206
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001207Base test mbedtls_mpi_mod_int #8 (By 2)
1208mbedtls_mpi_mod_int:10:"1000":2:0:0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001209
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001210Test mbedtls_mpi_mod_int: 0 (null) % 1
1211mbedtls_mpi_mod_int:16:"":1:0:0
1212
1213Test mbedtls_mpi_mod_int: 0 (null) % -1
1214mbedtls_mpi_mod_int:16:"":-1:0:MBEDTLS_ERR_MPI_NEGATIVE_VALUE
1215
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001216Base test mbedtls_mpi_exp_mod #1
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001217mbedtls_mpi_exp_mod:10:"23":10:"13":10:"29":10:"24":0
Paul Bakker367dae42009-06-28 21:50:27 +00001218
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001219Base test mbedtls_mpi_exp_mod #2 (Even N)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001220mbedtls_mpi_exp_mod:10:"23":10:"13":10:"30":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakker367dae42009-06-28 21:50:27 +00001221
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001222Base test mbedtls_mpi_exp_mod #2 (N = 0 (null))
1223mbedtls_mpi_exp_mod:10:"23":10:"13":10:"":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
1224
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001225Base test mbedtls_mpi_exp_mod #3 (Negative N)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001226mbedtls_mpi_exp_mod:10:"23":10:"13":10:"-29":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakkerf6198c12012-05-16 08:02:29 +00001227
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001228Base test mbedtls_mpi_exp_mod #4 (Negative base)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001229mbedtls_mpi_exp_mod:10:"-23":10:"13":10:"29":10:"5":0
Paul Bakkerf6198c12012-05-16 08:02:29 +00001230
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001231Base test mbedtls_mpi_exp_mod #5 (Negative exponent)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001232mbedtls_mpi_exp_mod:10:"23":10:"-13":10:"29":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakkerf6198c12012-05-16 08:02:29 +00001233
Chris Jones63d19c02020-11-26 11:21:53 +00001234Base test mbedtls_mpi_exp_mod #6 (Negative base + exponent)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001235mbedtls_mpi_exp_mod:10:"-23":10:"-13":10:"29":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakker367dae42009-06-28 21:50:27 +00001236
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001237Test mbedtls_mpi_exp_mod: 0 (null) ^ 0 (null) mod 9
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001238mbedtls_mpi_exp_mod:16:"":16:"":16:"09":16:"1":0
1239
1240Test mbedtls_mpi_exp_mod: 0 (null) ^ 0 (1 limb) mod 9
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001241mbedtls_mpi_exp_mod:16:"":16:"00":16:"09":16:"1":0
1242
1243Test mbedtls_mpi_exp_mod: 0 (null) ^ 1 mod 9
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001244mbedtls_mpi_exp_mod:16:"":16:"01":16:"09":16:"":0
1245
1246Test mbedtls_mpi_exp_mod: 0 (null) ^ 2 mod 9
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001247mbedtls_mpi_exp_mod:16:"":16:"02":16:"09":16:"":0
1248
1249Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 0 (null) mod 9
1250mbedtls_mpi_exp_mod:16:"00":16:"":16:"09":16:"1":0
1251
1252Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 0 (1 limb) mod 9
1253mbedtls_mpi_exp_mod:16:"00":16:"00":16:"09":16:"1":0
1254
1255Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 1 mod 9
1256mbedtls_mpi_exp_mod:16:"00":16:"01":16:"09":16:"":0
1257
1258Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 2 mod 9
1259mbedtls_mpi_exp_mod:16:"00":16:"02":16:"09":16:"":0
1260
1261Test mbedtls_mpi_exp_mod: 1 ^ 0 (null) mod 9
1262mbedtls_mpi_exp_mod:16:"01":16:"":16:"09":16:"1":0
1263
1264Test mbedtls_mpi_exp_mod: 4 ^ 0 (null) mod 9
1265mbedtls_mpi_exp_mod:16:"04":16:"":16:"09":16:"1":0
1266
1267Test mbedtls_mpi_exp_mod: 10 ^ 0 (null) mod 9
1268mbedtls_mpi_exp_mod:16:"0a":16:"":16:"09":16:"1":0
1269
1270Test mbedtls_mpi_exp_mod: 1 ^ 0 (1 limb) mod 9
1271mbedtls_mpi_exp_mod:16:"01":16:"00":16:"09":16:"1":0
1272
1273Test mbedtls_mpi_exp_mod: 4 ^ 0 (1 limb) mod 9
1274mbedtls_mpi_exp_mod:16:"04":16:"00":16:"09":16:"1":0
1275
1276Test mbedtls_mpi_exp_mod: 10 ^ 0 (1 limb) mod 9
1277mbedtls_mpi_exp_mod:16:"0a":16:"00":16:"09":16:"1":0
1278
Chris Jonesa18813e2020-12-03 11:35:41 +00001279Test mbedtls_mpi_exp_mod: MAX_SIZE exponent
Chris Jones877329a2020-12-03 11:52:40 +00001280mbedtls_mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE:10:10:"":0
Chris Jones415c7be2020-12-02 10:41:50 +00001281
Chris Jonesa18813e2020-12-03 11:35:41 +00001282Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 exponent
Chris Jones877329a2020-12-03 11:52:40 +00001283mbedtls_mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE + 1:10:10:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Chris Jones415c7be2020-12-02 10:41:50 +00001284
Chris Jonesa18813e2020-12-03 11:35:41 +00001285Test mbedtls_mpi_exp_mod: MAX_SIZE modulus
Chris Jones415c7be2020-12-02 10:41:50 +00001286mbedtls_mpi_exp_mod_size:2:2:MBEDTLS_MPI_MAX_SIZE:10:"":0
1287
Chris Jonesa18813e2020-12-03 11:35:41 +00001288Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 modulus
Chris Jones415c7be2020-12-02 10:41:50 +00001289mbedtls_mpi_exp_mod_size:2:2:MBEDTLS_MPI_MAX_SIZE + 1:10:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Chris Jones63d19c02020-11-26 11:21:53 +00001290
Chris Jonesa18813e2020-12-03 11:35:41 +00001291Test mbedtls_mpi_exp_mod: MAX_SIZE exponent and modulus
Chris Jones4a0ccb62020-12-02 16:27:42 +00001292mbedtls_mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE:10:"":0
1293
Chris Jonesa18813e2020-12-03 11:35:41 +00001294Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 exponent and modulus
Chris Jones4a0ccb62020-12-02 16:27:42 +00001295mbedtls_mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE + 1:MBEDTLS_MPI_MAX_SIZE + 1:10:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
1296
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001297Test mbedtls_mpi_exp_mod #1
Chris Jones5dd1e262020-12-03 17:44:03 +00001298depends_on:MPI_MAX_BITS_LARGER_THAN_792
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001299mbedtls_mpi_exp_mod:10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"583137007797276923956891216216022144052044091311388601652961409557516421612874571554415606746479105795833145583959622117418531166391184939066520869800857530421873250114773204354963864729386957427276448683092491947566992077136553066273207777134303397724679138833126700957":10:"114597449276684355144920670007147953232659436380163461553186940113929777196018164149703566472936578890991049344459204199888254907113495794730452699842273939581048142004834330369483813876618772578869083248061616444392091693787039636316845512292127097865026290173004860736":0
Paul Bakker367dae42009-06-28 21:50:27 +00001300
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001301Test mbedtls_mpi_exp_mod (Negative base)
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001302mbedtls_mpi_exp_mod:10:"-10000000000":10:"10000000000":10:"99999":10:"1":0
Paul Bakkerf6198c12012-05-16 08:02:29 +00001303
Chris Jones49e6e9d2020-12-03 15:22:25 +00001304Test mbedtls_mpi_exp_mod (Negative base) [#2]
Chris Jones5dd1e262020-12-03 17:44:03 +00001305depends_on:MPI_MAX_BITS_LARGER_THAN_792
Gilles Peskinecca6bb92021-06-09 18:28:35 +02001306mbedtls_mpi_exp_mod:16:"-9f13012cd92aa72fb86ac8879d2fde4f7fd661aaae43a00971f081cc60ca277059d5c37e89652e2af2585d281d66ef6a9d38a117e9608e9e7574cd142dc55278838a2161dd56db9470d4c1da2d5df15a908ee2eb886aaa890f23be16de59386663a12f1afbb325431a3e835e3fd89b98b96a6f77382f458ef9a37e1f84a03045c8676ab55291a94c2228ea15448ee96b626b998":16:"40a54d1b9e86789f06d9607fb158672d64867665c73ee9abb545fc7a785634b354c7bae5b962ce8040cf45f2c1f3d3659b2ee5ede17534c8fc2ec85c815e8df1fe7048d12c90ee31b88a68a081f17f0d8ce5f4030521e9400083bcea73a429031d4ca7949c2000d597088e0c39a6014d8bf962b73bb2e8083bd0390a4e00b9b3":16:"eeaf0ab9adb38dd69c33f80afa8fc5e86072618775ff3c0b9ea2314c9c256576d674df7496ea81d3383b4813d692c6e0e0d5d8e250b98be48e495c1d6089dad15dc7d7b46154d6b6ce8ef4ad69b15d4982559b297bcf1885c529f566660e57ec68edbc3c05726cc02fd4cbf4976eaa9afd5138fe8376435b9fc61d2fc0eb06e3":16:"21acc7199e1b90f9b4844ffe12c19f00ec548c5d32b21c647d48b6015d8eb9ec9db05b4f3d44db4227a2b5659c1a7cceb9d5fa8fa60376047953ce7397d90aaeb7465e14e820734f84aa52ad0fc66701bcbb991d57715806a11531268e1e83dd48288c72b424a6287e9ce4e5cc4db0dd67614aecc23b0124a5776d36e5c89483":0
Paul Bakkerf6198c12012-05-16 08:02:29 +00001307
Paul Bakker367dae42009-06-28 21:50:27 +00001308Base test GCD #1
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001309mbedtls_mpi_gcd:10:"693":10:"609":10:"21"
Paul Bakker367dae42009-06-28 21:50:27 +00001310
1311Base test GCD #2
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001312mbedtls_mpi_gcd:10:"1764":10:"868":10:"28"
Paul Bakker367dae42009-06-28 21:50:27 +00001313
1314Base test GCD #3
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001315mbedtls_mpi_gcd:10:"768454923":10:"542167814":10:"1"
Paul Bakker367dae42009-06-28 21:50:27 +00001316
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001317Test GCD: 0 (null), 0 (null)
Gilles Peskine05a1af62021-06-15 21:49:31 +02001318mbedtls_mpi_gcd:16:"":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001319
1320Test GCD: 0 (null), 0 (1 limb)
Gilles Peskine05a1af62021-06-15 21:49:31 +02001321mbedtls_mpi_gcd:16:"":16:"00":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001322
1323Test GCD: 0 (null), 3
1324mbedtls_mpi_gcd:16:"":16:"03":16:"3"
1325
1326Test GCD: 0 (null), 6
1327mbedtls_mpi_gcd:16:"":16:"06":16:"6"
1328
1329Test GCD: 0 (1 limb), 0 (null)
Gilles Peskineead66602021-06-15 22:06:02 +02001330mbedtls_mpi_gcd:16:"00":16:"":16:"0"
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001331
1332Test GCD: 0 (1 limb), 3
1333mbedtls_mpi_gcd:16:"00":16:"03":16:"3"
1334
1335Test GCD: 0 (1 limb), 6
1336mbedtls_mpi_gcd:16:"00":16:"06":16:"6"
1337
1338Test GCD: 3, 0 (null)
1339mbedtls_mpi_gcd:16:"03":16:"":16:"3"
1340
1341Test GCD: 3, 0 (1 limb)
1342mbedtls_mpi_gcd:16:"03":16:"00":16:"3"
1343
1344Test GCD: 6, 0 (null)
1345mbedtls_mpi_gcd:16:"06":16:"":16:"6"
1346
1347Test GCD: 6, 0 (1 limb)
1348mbedtls_mpi_gcd:16:"06":16:"00":16:"6"
1349
Gilles Peskined57f4032021-06-15 21:10:16 +02001350Test GCD: gcd=1, 0 < A < B
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001351mbedtls_mpi_gcd:10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"1"
Paul Bakker367dae42009-06-28 21:50:27 +00001352
Gilles Peskined57f4032021-06-15 21:10:16 +02001353Test GCD: gcd=1, 0 < B < A
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001354mbedtls_mpi_gcd:10:"5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"1"
1355
Gilles Peskined57f4032021-06-15 21:10:16 +02001356Test GCD: gcd=1, A > 0, B < 0
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001357mbedtls_mpi_gcd:10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"-5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"1"
1358
Gilles Peskined57f4032021-06-15 21:10:16 +02001359Test GCD: gcd=1, A < 0 < B, |A| < |B|
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001360mbedtls_mpi_gcd:10:"-433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"1"
1361
Gilles Peskined57f4032021-06-15 21:10:16 +02001362Test GCD: gcd=1, B < A < 0
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001363mbedtls_mpi_gcd:10:"-433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"-5781538327977828897150909166778407659250458379645823062042492461576758526757490910073628008613977550546382774775570888130029763571528699574717583228939535960234464230882573615930384979100379102915657483866755371559811718767760594919456971354184113721":10:"1"
1364
Gilles Peskined57f4032021-06-15 21:10:16 +02001365Test GCD: gcd=2, 0 < A < B
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001366mbedtls_mpi_gcd:10:"866038481820754956434747145919120219639297294032193121047538021762345738166676571147513149114791725930190032967735626087327963892955396933002903664815184654712662526249110275464787876484571564289857507839177265358101598397874265844290169694":10:"11563076655955657794301818333556815318500916759291646124084984923153517053514981820147256017227955101092765549551141776260059527143057399149435166457879071920468928461765147231860769958200758205831314967733510743119623437535521189838913942708368227442":10:"2"
1367
Gilles Peskined57f4032021-06-15 21:10:16 +02001368Test GCD: gcd=2, 0 < B < A
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001369mbedtls_mpi_gcd:10:"11563076655955657794301818333556815318500916759291646124084984923153517053514981820147256017227955101092765549551141776260059527143057399149435166457879071920468928461765147231860769958200758205831314967733510743119623437535521189838913942708368227442":10:"866038481820754956434747145919120219639297294032193121047538021762345738166676571147513149114791725930190032967735626087327963892955396933002903664815184654712662526249110275464787876484571564289857507839177265358101598397874265844290169694":10:"2"
1370
Gilles Peskined57f4032021-06-15 21:10:16 +02001371Test GCD: gcd=3, 0 < A < B
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001372mbedtls_mpi_gcd:10:"1299057722731132434652120718878680329458945941048289681571307032643518607250014856721269723672187588895285049451603439130991945839433095399504355497222776982068993789373665413197181814726857346434786261758765898037152397596811398766435254541":10:"17344614983933486691452727500335222977751375138937469186127477384730275580272472730220884025841932651639148324326712664390089290714586098724152749686818607880703392692647720847791154937301137308746972451600266114679435156303281784758370914062552341163":10:"3"
1373
Gilles Peskined57f4032021-06-15 21:10:16 +02001374Test GCD: gcd=3, 0 < B < A
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001375mbedtls_mpi_gcd:10:"17344614983933486691452727500335222977751375138937469186127477384730275580272472730220884025841932651639148324326712664390089290714586098724152749686818607880703392692647720847791154937301137308746972451600266114679435156303281784758370914062552341163":10:"1299057722731132434652120718878680329458945941048289681571307032643518607250014856721269723672187588895285049451603439130991945839433095399504355497222776982068993789373665413197181814726857346434786261758765898037152397596811398766435254541":10:"3"
1376
Gilles Peskined57f4032021-06-15 21:10:16 +02001377Test GCD: gcd=4, 0 < A < B
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001378mbedtls_mpi_gcd:10:"1732076963641509912869494291838240439278594588064386242095076043524691476333353142295026298229583451860380065935471252174655927785910793866005807329630369309425325052498220550929575752969143128579715015678354530716203196795748531688580339388":10:"23126153311911315588603636667113630637001833518583292248169969846307034107029963640294512034455910202185531099102283552520119054286114798298870332915758143840937856923530294463721539916401516411662629935467021486239246875071042379677827885416736454884":10:"4"
1379
Gilles Peskined57f4032021-06-15 21:10:16 +02001380Test GCD: gcd=4, 0 < B < A
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001381mbedtls_mpi_gcd:10:"23126153311911315588603636667113630637001833518583292248169969846307034107029963640294512034455910202185531099102283552520119054286114798298870332915758143840937856923530294463721539916401516411662629935467021486239246875071042379677827885416736454884":10:"1732076963641509912869494291838240439278594588064386242095076043524691476333353142295026298229583451860380065935471252174655927785910793866005807329630369309425325052498220550929575752969143128579715015678354530716203196795748531688580339388":10:"4"
1382
Gilles Peskined57f4032021-06-15 21:10:16 +02001383Test GCD: gcd=6, 0 < A < B
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001384mbedtls_mpi_gcd:10:"2598115445462264869304241437757360658917891882096579363142614065287037214500029713442539447344375177790570098903206878261983891678866190799008710994445553964137987578747330826394363629453714692869572523517531796074304795193622797532870509082":10:"34689229967866973382905455000670445955502750277874938372254954769460551160544945460441768051683865303278296648653425328780178581429172197448305499373637215761406785385295441695582309874602274617493944903200532229358870312606563569516741828125104682326":10:"6"
1385
Gilles Peskined57f4032021-06-15 21:10:16 +02001386Test GCD: gcd=6, 0 < B < A
Gilles Peskine9e8316e2021-06-09 10:52:12 +02001387mbedtls_mpi_gcd:10:"34689229967866973382905455000670445955502750277874938372254954769460551160544945460441768051683865303278296648653425328780178581429172197448305499373637215761406785385295441695582309874602274617493944903200532229358870312606563569516741828125104682326":10:"2598115445462264869304241437757360658917891882096579363142614065287037214500029713442539447344375177790570098903206878261983891678866190799008710994445553964137987578747330826394363629453714692869572523517531796074304795193622797532870509082":10:"6"
1388
Gilles Peskine81a67432021-06-15 21:10:50 +02001389Test GCD: 0 < A = B
1390mbedtls_mpi_gcd:10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847":10:"433019240910377478217373572959560109819648647016096560523769010881172869083338285573756574557395862965095016483867813043663981946477698466501451832407592327356331263124555137732393938242285782144928753919588632679050799198937132922145084847"
1391
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001392Base test mbedtls_mpi_inv_mod #1
1393mbedtls_mpi_inv_mod:10:"3":10:"11":10:"4":0
Paul Bakker367dae42009-06-28 21:50:27 +00001394
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001395Test mbedtls_mpi_inv_mod: mod 0 (null)
1396mbedtls_mpi_inv_mod:10:"3":10:"":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
1397
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001398Test mbedtls_mpi_inv_mod: mod 0 (1 limb)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001399mbedtls_mpi_inv_mod:10:"3":10:"0":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakker367dae42009-06-28 21:50:27 +00001400
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001401Test mbedtls_mpi_inv_mod: mod negative
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001402mbedtls_mpi_inv_mod:10:"3":10:"-11":10:"4":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Paul Bakker367dae42009-06-28 21:50:27 +00001403
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001404Test mbedtls_mpi_inv_mod: 2^-1 mod 4
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001405mbedtls_mpi_inv_mod:10:"2":10:"4":10:"0":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakker367dae42009-06-28 21:50:27 +00001406
Gilles Peskineaa9d9ac2021-06-08 23:00:17 +02001407Test mbedtls_mpi_inv_mod: mod 1
Hanno Becker4bcb4912017-04-18 15:49:39 +01001408mbedtls_mpi_inv_mod:10:"3":10:"1":10:"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
1409
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001410Test mbedtls_mpi_inv_mod: 0 (null) ^-1
1411mbedtls_mpi_inv_mod:16:"":16:"11":16:"":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
1412
1413Test mbedtls_mpi_inv_mod: 0 (1 limb) ^-1
1414mbedtls_mpi_inv_mod:16:"00":16:"11":16:"":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
1415
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001416Test mbedtls_mpi_inv_mod #1
1417mbedtls_mpi_inv_mod:16:"aa4df5cb14b4c31237f98bd1faf527c283c2d0f3eec89718664ba33f9762907c":16:"fffbbd660b94412ae61ead9c2906a344116e316a256fd387874c6c675b1d587d":16:"8d6a5c1d7adeae3e94b9bcd2c47e0d46e778bc8804a2cc25c02d775dc3d05b0c":0
Paul Bakker367dae42009-06-28 21:50:27 +00001418
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001419Base test mbedtls_mpi_is_prime #1
1420depends_on:MBEDTLS_GENPRIME
1421mbedtls_mpi_is_prime:10:"0":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakker367dae42009-06-28 21:50:27 +00001422
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001423Base test mbedtls_mpi_is_prime #2
1424depends_on:MBEDTLS_GENPRIME
1425mbedtls_mpi_is_prime:10:"1":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakker367dae42009-06-28 21:50:27 +00001426
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001427Base test mbedtls_mpi_is_prime #3
1428depends_on:MBEDTLS_GENPRIME
1429mbedtls_mpi_is_prime:10:"2":0
Paul Bakker367dae42009-06-28 21:50:27 +00001430
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001431Base test mbedtls_mpi_is_prime #4
1432depends_on:MBEDTLS_GENPRIME
1433mbedtls_mpi_is_prime:10:"3":0
Paul Bakker367dae42009-06-28 21:50:27 +00001434
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001435Base test mbedtls_mpi_is_prime #5
1436depends_on:MBEDTLS_GENPRIME
1437mbedtls_mpi_is_prime:10:"4":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakker367dae42009-06-28 21:50:27 +00001438
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001439Base test mbedtls_mpi_is_prime #6
1440depends_on:MBEDTLS_GENPRIME
1441mbedtls_mpi_is_prime:10:"5":0
Paul Bakker367dae42009-06-28 21:50:27 +00001442
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001443Base test mbedtls_mpi_is_prime #7
1444depends_on:MBEDTLS_GENPRIME
1445mbedtls_mpi_is_prime:10:"27":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakker367dae42009-06-28 21:50:27 +00001446
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001447Base test mbedtls_mpi_is_prime #8
1448depends_on:MBEDTLS_GENPRIME
1449mbedtls_mpi_is_prime:10:"47":0
Paul Bakker367dae42009-06-28 21:50:27 +00001450
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001451Test mbedtls_mpi_is_prime #1a
1452depends_on:MBEDTLS_GENPRIME
1453mbedtls_mpi_is_prime:10:"83726728883146151979668243326097049289208482987685965276439157162337476477581":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Manuel Pégourié-Gonnard378fb4b2013-11-22 18:39:18 +01001454
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001455Test mbedtls_mpi_is_prime #1b
1456depends_on:MBEDTLS_GENPRIME
1457mbedtls_mpi_is_prime:10:"81248637410584921454869308488899267096530643632730258201256092582281263244641":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Manuel Pégourié-Gonnard378fb4b2013-11-22 18:39:18 +01001458
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001459Test mbedtls_mpi_is_prime #2a
1460depends_on:MBEDTLS_GENPRIME
1461mbedtls_mpi_is_prime:10:"827131507221654563937832686696200995595835694437983658840870036586124168186967796809117749047430768825822857042432722828096779098498192459819306321073968735177531164565305635281198148032612029767584644305912099":0
Paul Bakker367dae42009-06-28 21:50:27 +00001462
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001463Test mbedtls_mpi_is_prime #2b
1464depends_on:MBEDTLS_GENPRIME
1465mbedtls_mpi_is_prime:10:"827131507221654563937832686696200995595835694437983658840870036586124168186967796809117749047430768825822857042432722828096779098498192459819306321073968735177531164565305635281198148032612029767584644305912001":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
Paul Bakkere896fea2009-07-06 06:40:23 +00001466
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001467Test mbedtls_mpi_is_prime #3
1468depends_on:MBEDTLS_GENPRIME
1469mbedtls_mpi_is_prime:10:"2833419889721787128217599":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001470
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001471Test mbedtls_mpi_is_prime #4
1472depends_on:MBEDTLS_GENPRIME
1473mbedtls_mpi_is_prime:10:"195845982777569926302400511":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001474
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001475Test mbedtls_mpi_is_prime #5
1476depends_on:MBEDTLS_GENPRIME
1477mbedtls_mpi_is_prime:10:"4776913109852041418248056622882488319":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001478
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001479Test mbedtls_mpi_is_prime #5
1480depends_on:MBEDTLS_GENPRIME
1481mbedtls_mpi_is_prime:10:"768614336404564651":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001482
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001483Test mbedtls_mpi_is_prime #6
1484depends_on:MBEDTLS_GENPRIME
1485mbedtls_mpi_is_prime:10:"201487636602438195784363":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001486
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001487Test mbedtls_mpi_is_prime #7
1488depends_on:MBEDTLS_GENPRIME
1489mbedtls_mpi_is_prime:10:"845100400152152934331135470251":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001490
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001491Test mbedtls_mpi_is_prime #8
1492depends_on:MBEDTLS_GENPRIME
1493mbedtls_mpi_is_prime:10:"56713727820156410577229101238628035243":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001494
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001495Test mbedtls_mpi_is_prime #9
1496depends_on:MBEDTLS_GENPRIME
1497mbedtls_mpi_is_prime:10:"203956878356401977405765866929034577280193993314348263094772646453283062722701277632936616063144088173312372882677123879538709400158306567338328279154499698366071906766440037074217117805690872792848149112022286332144876183376326512083574821647933992961249917319836219304274280243803104015000563790123":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001498
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001499Test mbedtls_mpi_is_prime #10
1500depends_on:MBEDTLS_GENPRIME
1501mbedtls_mpi_is_prime:10:"531872289054204184185084734375133399408303613982130856645299464930952178606045848877129147820387996428175564228204785846141207532462936339834139412401975338705794646595487324365194792822189473092273993580587964571659678084484152603881094176995594813302284232006001752128168901293560051833646881436219":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001502
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001503Test mbedtls_mpi_is_prime #11
1504depends_on:MBEDTLS_GENPRIME
1505mbedtls_mpi_is_prime:10:"319705304701141539155720137200974664666792526059405792539680974929469783512821793995613718943171723765238853752439032835985158829038528214925658918372196742089464683960239919950882355844766055365179937610326127675178857306260955550407044463370239890187189750909036833976197804646589380690779463976173":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001506
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001507Test mbedtls_mpi_is_prime #12
1508depends_on:MBEDTLS_GENPRIME
1509mbedtls_mpi_is_prime:10:"200603822195324642393516294012917598972967449320074999667103434371470616000652036570009912021332527788252300901905236578801044680456930305350440933538867383130165841118050781326291059830545891570648243241795871":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001510
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001511Test mbedtls_mpi_is_prime #13
1512depends_on:MBEDTLS_GENPRIME
1513mbedtls_mpi_is_prime:10:"827131507221654563937832686696200995595835694437983658840870036586124168186967796809117749047430768825822857042432722828096779098498192459819306321073968735177531164565305635281198148032612029767584644305912099":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001514
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001515Test mbedtls_mpi_is_prime #14
1516depends_on:MBEDTLS_GENPRIME
1517mbedtls_mpi_is_prime:10:"964274047248418797145090983157197980855078966882276492572788532954904112655338439361306213898569516593744267391754033306465125919199692703323878557833023573312685002670662846477592597659826113460619815244721311":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001518
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001519Test mbedtls_mpi_is_prime #15
1520depends_on:MBEDTLS_GENPRIME
1521mbedtls_mpi_is_prime:10:"170141183460469231731687303715884105727":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001522
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001523Test mbedtls_mpi_is_prime #16
1524depends_on:MBEDTLS_GENPRIME
1525mbedtls_mpi_is_prime:10:"2147483647":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001526
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001527Test mbedtls_mpi_is_prime #17
1528depends_on:MBEDTLS_GENPRIME
1529mbedtls_mpi_is_prime:10:"961748941":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001530
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001531Test mbedtls_mpi_is_prime #18
1532depends_on:MBEDTLS_GENPRIME
1533mbedtls_mpi_is_prime:10:"179424691":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001534
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001535Test mbedtls_mpi_is_prime #19
1536depends_on:MBEDTLS_GENPRIME
1537mbedtls_mpi_is_prime:10:"32452867":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001538
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001539Test mbedtls_mpi_is_prime #20
1540depends_on:MBEDTLS_GENPRIME
1541mbedtls_mpi_is_prime:10:"49979687":0
Paul Bakkerba48cb22009-07-12 11:01:32 +00001542
Janos Follath64eca052018-09-05 17:04:49 +01001543Test mbedtls_mpi_is_prime_det (4 non-witnesses)
1544depends_on:MBEDTLS_GENPRIME
Darryl Greenac2ead02018-10-02 15:30:39 +01001545mbedtls_mpi_is_prime_det:"043BD64BA10B11DA83FBD296B04BCA9E0552FAF6E09CAC74E2D7E735ED0DB09FC47ED76145644203EE0C826013BC602F560BCDAAED557D04683859A65D659FF828A245A2C5B1AC41E01E4669A525A45E23AF":"040EA852F7935ACCECC0E87B845281F047D10DC9AAFEF990AF9D3D66770DA30B0C5B5E03EEA8C0CB79B936FE0BB8EE5389EC1D34EB16C58AA3F2E11AF084160CDF6400BE1CC179867AB074866952D9F34EE7042D27F960E715A97FCB93F3182247D0A6AE51BD21CC2F6B0651F9E572C5FB86F3137053FA85FD7A51816D69B3A53A5A438C17754836D04E98CA240B901F828332F2D72D88C497DA45F533F99A6E53EDEA6B0424EC8951B048FA9A80134B37D0A67014597934E3CFC52C5A4DD4751ADF8D66FC79E84E2A3148C4B15C17E12CB659390FD275F39A331FFC80EC699BC3F6FAB868E30E9B14575FCDAB6FAED01E00112DD28704177E09C335AD43A696FEA761E8DF3B0663277A5C3637F9060CB5E5654F72E9A6B0F369E660AD4CF7ABF4195493545B367BD55271CD4BB7D9C15D3F508FE8F7409C2126FC8E73B43A67CD4EFB21E9F15DBF040A2A8D5F5ED75CEAC12B595C0051F3EC9D5A58ACE82A9506E64F780E9836728260FFE1BFD73E8A9869E3D46A35A856D3028F7FEAB9F4F1A04449AEDC80017EE1014080D87F0B50C8EF255324CD89F7D039":82:5
Janos Follath64eca052018-09-05 17:04:49 +01001546
1547Test mbedtls_mpi_is_prime_det (39 non-witnesses)
1548depends_on:MBEDTLS_GENPRIME
Darryl Greenac2ead02018-10-02 15:30:39 +01001549mbedtls_mpi_is_prime_det:"155102B67930FBE8858DF6C0642D77D419A7B7968E622CC7500F3E3F2C5168368C50E0083187":"119B3E2C721834D83416239B04447AA18AE0163E61DCAE97054563D79E094A6FA4485BD6A0501445BF57FE9C058926CDB862E04CC1A95D79D61D9AB3466857A53E04F8D7470C9C86649B226A13DDC534E18DFD5C22FAEA317CA4D4960F18457FD6D2FFB5F3273F74C89980DC774590D8D30D1159CA81999ED94A042D67DA68C82616AD46C2C88288A8EBD0B37AC7C152D9522CA4544642AD1210F6B642FEBF43563FA872B0DEFAFC69D0B6570E8FEA9570D0AADCFA9B06CC8BFD62CEDC221541210EEEF9762448C6D49F26AA767A4D66CB168589E0201923015314E6CD4A480E5936E7CF145F73A564C5B782635B3AFC3028E2632C5D3458224A7C9E8BA1876E8F690463C878292D3DC011E9640331E7F7621F2B5E0F6713DD8C9D6767521C4BA880DA8D11C67753C8493D2C4C4F1443147550D0B25B7FAD04EAFA9F8AA60974C1365C8A794CFEECEB4279B1150909A97E5A7A10B5D91186CA5B25A612036631FE73529C8CFAE51E76FB704A772DE5320EFC1212E7A399B1FEBF57D014AF9129DFF5D2C5DFBBEEAC55F360CF6D22FA90B8E2E9AD0C71AB6495A9452A58D653B8CC26128C66B43EFBA6E39AEC5717A1A3C2AE1449FCABAFE1180B159DA55190CD81A3D9E8D798647E11B827F0A057D6DA5AAD78AB5112EE65E10E8B8B369BA24E1B8AD2CD8548C497016C07A143DE1232F8059BE303572456FA92E76A0F23D1340629228B7D27C02D3833A72745B91A3DBEB5E081117A9F19597F00E4277B414FAEA8C8CEB895C37F956A5A22F8D7A10ADA50B22BAB312504904511AA0EFDD4D3BF20ECB17E8A684564FFB5BBD5E22C429F9A75A4FB4AE468FE7612ED53C7A11212E7EF3435CC9CA6E7DB167B8CCE2BECF35F89013F8F876223C77FA81570970858663C6E32B91080AA47F9C90177F51E6FD7747B910C9489C7B6ACB070996198AD9A40A69711274159210A9A12DBAAA4FB4632446066AB70D735DC95F7C2BCE517E88C064D728DE82B1B043DF4AEE0EFF5131120A4E5B9B4180EB6F6B8A0D1491ABDA069058A9966B1A517D8E7B4997DC52A1E698FD79E271153DF1913FE6787A5D99DE69F39C3F22D26DC731CFBB33FF5C267D85D7A3DAE8E1C87E1DB2F1236212EF1942EA756967FB3D07D629E59EA4034D9A9B5E270DD4A31C8A3DFDA99C1094B5537132C196DA2AEAF5253A019B9AF25B5DCB0D4DD75C7C9C353DA9DAABFB23959A5455312E7E1C21268C1BC14E83DCFDF50C27FD3E8B4EDC04C5F3CB5FCFFF2B57151E1B1EE1A6456DC006BC43E1158674AA4CF7D146DE4A57103BE43ED130C8007294ED2418C7A2B769A7D20EBB5A8367A77B313F81BB119B9954305FF160FF83EED7F808EE6D340A5CCC000CF81AA497D315D350CCE4E86A31456B8AA85B677491FC662933DFA55EB5BFF64B8D85430D676A85D1CAFAFF383E68C4E6C22A51063739EC03FC58C36C07C44E54828BE2152B2E9AFB0F179B157D09B64C147B524BB5424BB1914419424D9100D06EDCFC718F4DF3D562E9E16C446663F35273CA7BC5426B868A80C8D415C9A12A1619CDB7CDB5BEBC70313150BDF8C3AB26B809FE62D28E798EF1EF98C410A2DA0A9071F82154AC569078B0E647E2C085D1D907E634453442803D0492D3D0C78CACB762020C0E589C8B0981321EA2771305FD0413F3B2963FCE9A232F6641DB7E12ADC009A032063C41756E5E19E5711DE12711F07AFE7545B4D83F3EFD7BFD0435297C89DF3D4AF96EBE2CE8D64B93E36EA5D7E5A0492151D0CAEE7449A7D35E1A3C83E22C3B35162C073CC3B1CF76FBDEE84270721FC042EAAEB7325110181415E2031CFB7462F15111291CDAC0560FF9F4C7341F2FA261B97CEF348D074AA2EB4DB153FE6B1410519DA4213B611999868F3B867A2B6D758D333C4989DE80782683CA26ECDE373C71524F01B76349CE8A07A5EBECBB42259CF970DDA756EC996B189FEA045FEE45F23D476960913106ECA2510B8517AA75D56FA4152B2BDDC212014E5D07FD964D6EE532F0616DF74E104659955132331FABF2D2AD265E71C93C648A956FA0A3DB21FF103D516527F2DA0E870340B61EE8A8ED913B60605EB5A67B834D0FC90564386012585609870FEF6530B3E3C037B55506F0B5694F6B0FC":38:40
Janos Follath64eca052018-09-05 17:04:49 +01001550
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001551Test mbedtls_mpi_gen_prime (Too small)
1552depends_on:MBEDTLS_GENPRIME
1553mbedtls_mpi_gen_prime:2:0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Manuel Pégourié-Gonnard15f58a82014-06-16 17:12:40 +02001554
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001555Test mbedtls_mpi_gen_prime (OK, minimum size)
1556depends_on:MBEDTLS_GENPRIME
1557mbedtls_mpi_gen_prime:3:0:0
Manuel Pégourié-Gonnard15f58a82014-06-16 17:12:40 +02001558
Jethro Beekman66689272018-02-14 19:24:10 -08001559Test mbedtls_mpi_gen_prime (corner case limb size -1 bits)
1560depends_on:MBEDTLS_GENPRIME
1561mbedtls_mpi_gen_prime:63:0:0
1562
1563Test mbedtls_mpi_gen_prime (corner case limb size)
1564depends_on:MBEDTLS_GENPRIME
1565mbedtls_mpi_gen_prime:64:0:0
1566
1567Test mbedtls_mpi_gen_prime (corner case limb size +1 bits)
1568depends_on:MBEDTLS_GENPRIME
1569mbedtls_mpi_gen_prime:65:0:0
1570
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001571Test mbedtls_mpi_gen_prime (Larger)
1572depends_on:MBEDTLS_GENPRIME
1573mbedtls_mpi_gen_prime:128:0:0
Manuel Pégourié-Gonnard15f58a82014-06-16 17:12:40 +02001574
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001575Test mbedtls_mpi_gen_prime (Safe)
1576depends_on:MBEDTLS_GENPRIME
Janos Follath7c025a92018-08-14 11:08:41 +01001577mbedtls_mpi_gen_prime:128:MBEDTLS_MPI_GEN_PRIME_FLAG_DH:0
Manuel Pégourié-Gonnard15f58a82014-06-16 17:12:40 +02001578
Janos Follatha3cb7eb2018-08-14 15:31:54 +01001579Test mbedtls_mpi_gen_prime (Safe with lower error rate)
1580depends_on:MBEDTLS_GENPRIME
1581mbedtls_mpi_gen_prime:128:MBEDTLS_MPI_GEN_PRIME_FLAG_DH | MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
1582
1583Test mbedtls_mpi_gen_prime standard RSA #1 (lower error rate)
1584depends_on:MBEDTLS_GENPRIME
1585mbedtls_mpi_gen_prime:1024:MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
1586
1587Test mbedtls_mpi_gen_prime standard RSA #2 (lower error rate)
1588depends_on:MBEDTLS_GENPRIME
1589mbedtls_mpi_gen_prime:1536:MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
1590
Paul Bakker2f5947e2011-05-18 15:47:11 +00001591Test bit getting (Value bit 25)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001592mbedtls_mpi_get_bit:10:"49979687":25:1
Paul Bakker2f5947e2011-05-18 15:47:11 +00001593
1594Test bit getting (Larger but same limb)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001595mbedtls_mpi_get_bit:10:"49979687":26:0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001596
1597Test bit getting (Larger and non-existing limb)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001598mbedtls_mpi_get_bit:10:"49979687":500:0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001599
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001600Test bit getting in 0 (null)
1601mbedtls_mpi_get_bit:10:"":500:0
1602
Paul Bakker2f5947e2011-05-18 15:47:11 +00001603Test bit getting (Value bit 24)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001604mbedtls_mpi_get_bit:10:"49979687":24:0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001605
1606Test bit getting (Value bit 23)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001607mbedtls_mpi_get_bit:10:"49979687":23:1
Paul Bakker2f5947e2011-05-18 15:47:11 +00001608
1609Test bit set (Change existing value with a 1)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001610mbedtls_mpi_set_bit:10:"49979687":24:1:10:"66756903":0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001611
1612Test bit set (Change existing value with a 0)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001613mbedtls_mpi_set_bit:10:"49979687":25:0:10:"16425255":0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001614
1615Test bit set (Add above existing limbs with a 0)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001616mbedtls_mpi_set_bit:10:"49979687":80:0:10:"49979687":0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001617
1618Test bit set (Add above existing limbs with a 1)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001619mbedtls_mpi_set_bit:10:"49979687":80:1:10:"1208925819614629224685863":0
Paul Bakker2f5947e2011-05-18 15:47:11 +00001620
Gilles Peskinebc781ea2021-06-08 23:01:13 +02001621Test bit set (Add to 0 (null) with a 0)
1622mbedtls_mpi_set_bit:16:"":65:0:16:"":0
1623
1624Test bit set (Add to 0 (null) with a 1)
1625mbedtls_mpi_set_bit:16:"":65:1:16:"020000000000000000":0
1626
Manuel Pégourié-Gonnard9a4a5ac2013-12-04 18:05:29 +01001627Test bit set (Bit index larger than 31 with a 0)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001628mbedtls_mpi_set_bit:16:"FFFFFFFFFFFFFFFF":32:0:16:"FFFFFFFEFFFFFFFF":0
Manuel Pégourié-Gonnard9a4a5ac2013-12-04 18:05:29 +01001629
1630Test bit set (Bit index larger than 31 with a 1)
Paul Bakkerec5ceb62016-07-14 12:47:07 +01001631mbedtls_mpi_set_bit:16:"00":32:1:16:"0100000000":0
1632
1633Test bit set (Invalid bit value)
1634mbedtls_mpi_set_bit:16:"00":5:2:16:"00":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
Manuel Pégourié-Gonnard9a4a5ac2013-12-04 18:05:29 +01001635
Gilles Peskine2f780622020-11-25 15:37:20 +01001636Fill random: 0 bytes
1637mpi_fill_random:0:0:0
1638
1639Fill random: 1 byte, good
1640mpi_fill_random:1:1:0
1641
1642Fill random: 2 bytes, good, no leading zero
1643mpi_fill_random:2:2:0
1644
1645Fill random: 2 bytes, good, 1 leading zero
1646mpi_fill_random:2:256:0
1647
1648Fill random: MAX_SIZE - 7, good
1649mpi_fill_random:MBEDTLS_MPI_MAX_SIZE - 7:MBEDTLS_MPI_MAX_SIZE - 7:0
1650
1651Fill random: MAX_SIZE, good
1652mpi_fill_random:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE:0
1653
1654Fill random: 1 byte, RNG failure
1655mpi_fill_random:1:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1656
1657Fill random: 2 bytes, RNG failure after 1 byte
1658mpi_fill_random:2:1:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1659
1660Fill random: 4 bytes, RNG failure after 3 bytes
1661mpi_fill_random:4:3:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1662
1663Fill random: 8 bytes, RNG failure after 7 bytes
1664mpi_fill_random:8:7:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1665
1666Fill random: 16 bytes, RNG failure after 1 bytes
1667mpi_fill_random:16:1:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1668
1669Fill random: 16 bytes, RNG failure after 8 bytes
1670mpi_fill_random:16:8:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1671
1672Fill random: 16 bytes, RNG failure after 15 bytes
1673mpi_fill_random:16:15:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1674
1675Fill random: MAX_SIZE bytes, RNG failure after MAX_SIZE-1 bytes
1676mpi_fill_random:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE-1:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
1677
Paul Bakkere896fea2009-07-06 06:40:23 +00001678MPI Selftest
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +02001679depends_on:MBEDTLS_SELF_TEST
Paul Bakkere896fea2009-07-06 06:40:23 +00001680mpi_selftest: