test_suite_bignum.misc.data 102 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796
  1. Arguments with no value
  2. mpi_null:
  3. Base test mpi_read_write_string #1
  4. mpi_read_write_string:10:"128":10:"128":100:0:0
  5. Base test mpi_read_write_string #1 (Leading 0)
  6. mpi_read_write_string:10:"0128":10:"128":100:0:0
  7. Base test mpi_read_write_string #2
  8. mpi_read_write_string:10:"128":16:"80":100:0:0
  9. Base test mpi_read_write_string #3 (Read zero decimal)
  10. mpi_read_write_string:10:"0":10:"0":100:0:0
  11. Base test mpi_read_write_string #3 (Read zero hex)
  12. mpi_read_write_string:16:"0":16:"00":100:0:0
  13. Base test mpi_read_write_string #3 (Read minus zero decimal)
  14. mpi_read_write_string:10:"-0":10:"0":100:0:0
  15. Base test mpi_read_write_string #3 (Read minus zero hex)
  16. mpi_read_write_string:16:"-0":16:"00":100:0:0
  17. Base test mpi_read_write_string #3 (Negative decimal)
  18. mpi_read_write_string:10:"-23":10:"-23":100:0:0
  19. Base test mpi_read_write_string #3 (Negative decimal, leading 0)
  20. mpi_read_write_string:10:"-023":10:"-23":100:0:0
  21. Base test mpi_read_write_string #3 (Negative hex -> decimal)
  22. mpi_read_write_string:16:"-20":10:"-32":100:0:0
  23. Base test mpi_read_write_string #3 (Negative hex)
  24. mpi_read_write_string:16:"-23":16:"-23":100:0:0
  25. Base test mpi_read_write_string #3 (Negative hex, leading 0)
  26. mpi_read_write_string:16:"-023":16:"-23":100:0:0
  27. Base test mpi_read_write_string #4 (Buffer just fits)
  28. mpi_read_write_string:16:"-4":4:"-10":4:0:0
  29. Test mpi_read_write_string #1 (Invalid character)
  30. mpi_read_write_string:10:"a28":0:"":100:MBEDTLS_ERR_MPI_INVALID_CHARACTER:0
  31. Test mpi_read_write_string #2 (Illegal input radix)
  32. mpi_read_write_string:19:"a28":0:"":100:MBEDTLS_ERR_MPI_BAD_INPUT_DATA:0
  33. Test mpi_read_write_string #3 (Buffer just fits)
  34. mpi_read_write_string:16:"-23":16:"-23":4:0:0
  35. Test mpi_read_write_string #4 (Buffer too small)
  36. mpi_read_write_string:16:"-23":16:"-23":3:0:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
  37. Test mpi_read_write_string #5 (Illegal output radix)
  38. mpi_read_write_string:16:"-23":17:"-23":4:0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  39. Test mpi_read_write_string #6 (Output radix of 15)
  40. mpi_read_write_string:10:"29":15:"1e":100:0:0
  41. Test mpi_read_write_string #7
  42. mpi_read_write_string:10:"56125680981752282334141896320372489490613963693556392520816017892111350604111697682705498319512049040516698827829292076808006940873974979584527073481012636016353913462376755556720019831187364993587901952757307830896531678727717924":16:"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":200:0:0
  43. Test mpi_read_write_string #8 (Empty MPI hex -> hex)
  44. mpi_read_write_string:16:"":16:"":4:0:0
  45. Test mpi_read_write_string #9 (Empty MPI hex -> dec)
  46. mpi_read_write_string:16:"":10:"0":4:0:0
  47. Test mpi_read_write_string #9 (Empty MPI hex -> base 2)
  48. mpi_read_write_string:16:"":2:"0":4:0:0
  49. Test mpi_read_write_string #8 (Empty MPI dec -> hex)
  50. mpi_read_write_string:10:"":16:"":4:0:0
  51. Test mpi_read_write_string #9 (Empty MPI dec -> dec)
  52. mpi_read_write_string:10:"":10:"0":4:0:0
  53. Test mpi_read_write_string #9 (Empty MPI dec -> base 2)
  54. mpi_read_write_string:16:"":2:"0":4:0:0
  55. Test mpi_write_string #10 (Negative hex with odd number of digits)
  56. mpi_read_write_string:16:"-1":16:"":3:0:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
  57. Base test mbedtls_mpi_read_binary #1
  58. mpi_read_binary:"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":"0941379D00FED1491FE15DF284DFDE4A142F68AA8D412023195CEE66883E6290FFE703F4EA5963BF212713CEE46B107C09182B5EDCD955ADAC418BF4918E2889AF48E1099D513830CEC85C26AC1E158B52620E33BA8692F893EFBB2F958B4424"
  59. Base test mbedtls_mpi_read_binary_le #1
  60. mpi_read_binary_le:"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":"24448B952FBBEF93F89286BA330E62528B151EAC265CC8CE3038519D09E148AF89288E91F48B41ACAD55D9DC5E2B18097C106BE4CE132721BF6359EAF403E7FF90623E8866EE5C192320418DAA682F144ADEDF84F25DE11F49D1FE009D374109"
  61. Base test mbedtls_mpi_write_binary #1
  62. mpi_write_binary:"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":"0941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":200:0
  63. Test mbedtls_mpi_write_binary #1 (Buffer just fits)
  64. mpi_write_binary:"123123123123123123123123123":"0123123123123123123123123123":14:0
  65. Test mbedtls_mpi_write_binary #2 (Buffer too small)
  66. mpi_write_binary:"123123123123123123123123123":"23123123123123123123123123":13:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
  67. Base test mbedtls_mpi_write_binary_le #1
  68. mpi_write_binary_le:"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":"24448b952fbbef93f89286ba330e62528b151eac265cc8ce3038519d09e148af89288e91f48b41acad55d9dc5e2b18097c106be4ce132721bf6359eaf403e7ff90623e8866ee5c192320418daa682f144adedf84f25de11f49d1fe009d374109":200:0
  69. Test mbedtls_mpi_write_binary_le #1 (Buffer just fits)
  70. mpi_write_binary_le:"123123123123123123123123123":"2331122331122331122331122301":14:0
  71. Test mbedtls_mpi_write_binary_le #2 (Buffer too small)
  72. mpi_write_binary_le:"123123123123123123123123123":"23311223311223311223311223":13:MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
  73. Base test mbedtls_mpi_read_file #1
  74. mpi_read_file:"data_files/mpi_16":"01f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":0
  75. Test mbedtls_mpi_read_file #1 (Empty file)
  76. mpi_read_file:"data_files/hash_file_4":"":MBEDTLS_ERR_MPI_FILE_IO_ERROR
  77. Test mbedtls_mpi_read_file #2 (Illegal input)
  78. mpi_read_file:"data_files/hash_file_2":"":0
  79. Test mbedtls_mpi_read_file #3 (Input too big)
  80. mpi_read_file:"data_files/mpi_too_big":"":MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL
  81. Base test mbedtls_mpi_write_file #1
  82. mpi_write_file:"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":"data_files/mpi_write"
  83. Test mbedtls_mpi_lsb: 0 (null)
  84. mpi_lsb:"":0
  85. Test mbedtls_mpi_lsb: 0 (1 limb)
  86. mpi_lsb:"0":0
  87. Base test mbedtls_mpi_lsb #1
  88. mpi_lsb:"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":2
  89. Base test mbedtls_mpi_lsb #2
  90. mpi_lsb:"18":3
  91. Base test mbedtls_mpi_lsb #3
  92. mpi_lsb:"24":2
  93. Base test mbedtls_mpi_lsb #4
  94. mpi_lsb:"2000":13
  95. Test mbedtls_mpi_bitlen 764-bit
  96. mpi_bitlen:"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424":764
  97. Test mbedtls_mpi_bitlen 0x18
  98. mpi_bitlen:"18":5
  99. Test mbedtls_mpi_bitlen 0x18 with leading 0 limb(s)
  100. mpi_bitlen:"00000000000000018":5
  101. Test mbedtls_mpi_bitlen 0x18 << 64
  102. mpi_bitlen:"180000000000000000":69
  103. Test mbedtls_mpi_bitlen 0x01
  104. mpi_bitlen:"1":1
  105. Test mbedtls_mpi_bitlen 0x0f
  106. mpi_bitlen:"f":4
  107. Test mbedtls_mpi_bitlen 0x10
  108. mpi_bitlen:"10":5
  109. Test mbedtls_mpi_bitlen 0x0a
  110. mpi_bitlen:"a":4
  111. Test mbedtls_mpi_bitlen: 0 (null)
  112. mpi_bitlen:"":0
  113. Test mbedtls_mpi_bitlen: 0 (1 limb)
  114. mpi_bitlen:"0":0
  115. Test mbedtls_mpi_bitlen: -0x18
  116. mpi_bitlen:"-18":5
  117. Base test mbedtls_mpi_cmp_int #1
  118. mpi_cmp_int:693:693:0
  119. Base test mbedtls_mpi_cmp_int #2
  120. mpi_cmp_int:693:692:1
  121. Base test mbedtls_mpi_cmp_int #3
  122. mpi_cmp_int:693:694:-1
  123. Base test mbedtls_mpi_cmp_int (Negative values) #1
  124. mpi_cmp_int:-2:-2:0
  125. Base test mbedtls_mpi_cmp_int (Negative values) #2
  126. mpi_cmp_int:-2:-3:1
  127. Base test mbedtls_mpi_cmp_int (Negative values) #3
  128. mpi_cmp_int:-2:-1:-1
  129. Base test mbedtls_mpi_cmp_mpi #1
  130. mpi_cmp_mpi:"2b5":"2b5":0
  131. Base test mbedtls_mpi_cmp_mpi #2
  132. mpi_cmp_mpi:"2b5":"2b4":1
  133. Base test mbedtls_mpi_cmp_mpi #3
  134. mpi_cmp_mpi:"2b5":"2b6":-1
  135. Base test mbedtls_mpi_cmp_mpi (Negative values) #1
  136. mpi_cmp_mpi:"-2":"-2":0
  137. Base test mbedtls_mpi_cmp_mpi (Negative values) #2
  138. mpi_cmp_mpi:"-2":"-3":1
  139. Base test mbedtls_mpi_cmp_mpi (Negative values) #3
  140. mpi_cmp_mpi:"-2":"-1":-1
  141. Base test mbedtls_mpi_cmp_mpi (Mixed values) #4
  142. mpi_cmp_mpi:"-3":"2":-1
  143. Base test mbedtls_mpi_cmp_mpi (Mixed values) #5
  144. mpi_cmp_mpi:"2":"-3":1
  145. Base test mbedtls_mpi_cmp_mpi (Mixed values) #6
  146. mpi_cmp_mpi:"-2":"1c67967269c6":-1
  147. Test mbedtls_mpi_cmp_mpi: 0 (null) = 0 (null)
  148. mpi_cmp_mpi:"":"":0
  149. Test mbedtls_mpi_cmp_mpi: 0 (null) = 0 (1 limb)
  150. mpi_cmp_mpi:"":"0":0
  151. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) = 0 (null)
  152. mpi_cmp_mpi:"0":"":0
  153. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) = 0 (1 limb)
  154. mpi_cmp_mpi:"0":"0":0
  155. Test mbedtls_mpi_cmp_mpi: 0 (null) < positive
  156. mpi_cmp_mpi:"":"7b":-1
  157. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < positive
  158. mpi_cmp_mpi:"0":"7b":-1
  159. Test mbedtls_mpi_cmp_mpi: 0 (null) > negative
  160. mpi_cmp_mpi:"":"-7b":1
  161. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > negative
  162. mpi_cmp_mpi:"0":"-7b":1
  163. Test mbedtls_mpi_cmp_mpi: positive > 0 (null)
  164. mpi_cmp_mpi:"7b":"":1
  165. Test mbedtls_mpi_cmp_mpi: positive > 0 (1 limb)
  166. mpi_cmp_mpi:"7b":"0":1
  167. Test mbedtls_mpi_cmp_mpi: negative < 0 (null)
  168. mpi_cmp_mpi:"-7b":"":-1
  169. Test mbedtls_mpi_cmp_mpi: negative < 0 (1 limb)
  170. mpi_cmp_mpi:"-7b":"0":-1
  171. Test mbedtls_mpi_cmp_mpi: 0 (null) < positive with leading zero limb
  172. mpi_cmp_mpi:"":"0000000000000000123":-1
  173. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < positive with leading zero limb
  174. mpi_cmp_mpi:"0":"0000000000000000123":-1
  175. Test mbedtls_mpi_cmp_mpi: 0 (null) > negative with leading zero limb
  176. mpi_cmp_mpi:"":"-0000000000000000123":1
  177. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > negative with leading zero limb
  178. mpi_cmp_mpi:"0":"-0000000000000000123":1
  179. Test mbedtls_mpi_cmp_mpi: positive with leading zero limb > 0 (null)
  180. mpi_cmp_mpi:"0000000000000000123":"":1
  181. Test mbedtls_mpi_cmp_mpi: positive with leading zero limb > 0 (1 limb)
  182. mpi_cmp_mpi:"0000000000000000123":"0":1
  183. Test mbedtls_mpi_cmp_mpi: negative with leading zero limb < 0 (null)
  184. mpi_cmp_mpi:"-0000000000000000123":"":-1
  185. Test mbedtls_mpi_cmp_mpi: negative with leading zero limb < 0 (1 limb)
  186. mpi_cmp_mpi:"-0000000000000000123":"0":-1
  187. Test mbedtls_mpi_cmp_mpi: 0 (null) < large positive
  188. mpi_cmp_mpi:"":"1230000000000000000":-1
  189. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) < large positive
  190. mpi_cmp_mpi:"0":"1230000000000000000":-1
  191. Test mbedtls_mpi_cmp_mpi: 0 (null) > large negative
  192. mpi_cmp_mpi:"":"-1230000000000000000":1
  193. Test mbedtls_mpi_cmp_mpi: 0 (1 limb) > large negative
  194. mpi_cmp_mpi:"0":"-1230000000000000000":1
  195. Test mbedtls_mpi_cmp_mpi: large positive > 0 (null)
  196. mpi_cmp_mpi:"1230000000000000000":"":1
  197. Test mbedtls_mpi_cmp_mpi: large positive > 0 (1 limb)
  198. mpi_cmp_mpi:"1230000000000000000":"0":1
  199. Test mbedtls_mpi_cmp_mpi: large negative < 0 (null)
  200. mpi_cmp_mpi:"-1230000000000000000":"":-1
  201. Test mbedtls_mpi_cmp_mpi: large negative < 0 (1 limb)
  202. mpi_cmp_mpi:"-1230000000000000000":"0":-1
  203. Base test mbedtls_mpi_lt_mpi_ct #1
  204. mpi_lt_mpi_ct:1:"2B5":1:"2B5":0:0
  205. Base test mbedtls_mpi_lt_mpi_ct #2
  206. mpi_lt_mpi_ct:1:"2B5":1:"2B4":0:0
  207. Base test mbedtls_mpi_lt_mpi_ct #3
  208. mpi_lt_mpi_ct:1:"2B5":1:"2B6":1:0
  209. Base test mbedtls_mpi_lt_mpi_ct (Negative values) #1
  210. mpi_lt_mpi_ct:1:"-2":1:"-2":0:0
  211. Base test mbedtls_mpi_lt_mpi_ct (Negative values) #2
  212. mpi_lt_mpi_ct:1:"-2":1:"-3":0:0
  213. Base test mbedtls_mpi_lt_mpi_ct (Negative values) #3
  214. mpi_lt_mpi_ct:1:"-2":1:"-1":1:0
  215. Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #1
  216. mpi_lt_mpi_ct:1:"-3":1:"2":1:0
  217. Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #2
  218. mpi_lt_mpi_ct:1:"2":1:"-3":0:0
  219. Base test mbedtls_mpi_lt_mpi_ct (Mixed values) #3
  220. mpi_lt_mpi_ct:2:"-2":2:"1C67967269C6":1:0
  221. Base test mbedtls_mpi_lt_mpi_ct (X is longer in storage)
  222. mpi_lt_mpi_ct:3:"2B5":2:"2B5":0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  223. Base test mbedtls_mpi_lt_mpi_ct (Y is longer in storage)
  224. mpi_lt_mpi_ct:3:"2B5":4:"2B5":0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  225. Base test mbedtls_mpi_lt_mpi_ct (length=0)
  226. mpi_lt_mpi_ct:0:"":0:"":0:0
  227. Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #1
  228. mpi_lt_mpi_ct:2:"7FFFFFFFFFFFFFFF":2:"FF":0:0
  229. Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #2
  230. mpi_lt_mpi_ct:2:"8000000000000000":2:"7FFFFFFFFFFFFFFF":0:0
  231. Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #3
  232. mpi_lt_mpi_ct:2:"8000000000000000":2:"1":0:0
  233. Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #4
  234. mpi_lt_mpi_ct:2:"8000000000000000":2:"0":0:0
  235. Base test mbedtls_mpi_lt_mpi_ct (corner case - 64 bit) #5
  236. mpi_lt_mpi_ct:2:"FFFFFFFFFFFFFFFF":2:"FF":0:0
  237. Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #1
  238. mpi_lt_mpi_ct:1:"7FFFFFFF":1:"FF":0:0
  239. Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #2
  240. mpi_lt_mpi_ct:1:"80000000":1:"7FFFFFFF":0:0
  241. Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #3
  242. mpi_lt_mpi_ct:1:"80000000":1:"1":0:0
  243. Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #4
  244. mpi_lt_mpi_ct:1:"80000000":1:"0":0:0
  245. Base test mbedtls_mpi_lt_mpi_ct (corner case - 32 bit) #5
  246. mpi_lt_mpi_ct:1:"FFFFFFFF":1:"FF":0:0
  247. Multi-limb mbedtls_mpi_lt_mpi_ct (X<Y, zero vs non-zero MS limb)
  248. mpi_lt_mpi_ct:2:"0FFFFFFFFFFFFFFFF":2:"1FFFFFFFFFFFFFFFF":1:0
  249. Multi-limb mbedtls_mpi_lt_mpi_ct (X>Y, equal MS limbs)
  250. mpi_lt_mpi_ct:2:"-EEFFFFFFFFFFFFFFF1":2:"-EEFFFFFFFFFFFFFFFF":0:0
  251. Multi-limb mbedtls_mpi_lt_mpi_ct (X=Y)
  252. mpi_lt_mpi_ct:2:"EEFFFFFFFFFFFFFFFF":2:"EEFFFFFFFFFFFFFFFF":0:0
  253. Multi-limb mbedtls_mpi_lt_mpi_ct (X=-Y)
  254. mpi_lt_mpi_ct:2:"-EEFFFFFFFFFFFFFFFF":2:"EEFFFFFFFFFFFFFFFF":1:0
  255. Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #1
  256. mpi_lt_mpi_ct:2:"11FFFFFFFFFFFFFFFF":2:"FF1111111111111111":1:0
  257. Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #2
  258. mpi_lt_mpi_ct:2:"FF1111111111111111":2:"11FFFFFFFFFFFFFFFF":0:0
  259. Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #3
  260. mpi_lt_mpi_ct:2:"-11FFFFFFFFFFFFFFFF":2:"-FF1111111111111111":0:0
  261. Multi-limb mbedtls_mpi_lt_mpi_ct (Alternating limbs) #4
  262. mpi_lt_mpi_ct:2:"-FF1111111111111111":2:"-11FFFFFFFFFFFFFFFF":1:0
  263. Base test mbedtls_mpi_cmp_abs #1
  264. mpi_cmp_abs:"2b5":"2b5":0
  265. Base test mbedtls_mpi_cmp_abs #2
  266. mpi_cmp_abs:"2b5":"2b4":1
  267. Base test mbedtls_mpi_cmp_abs #3
  268. mpi_cmp_abs:"2b5":"2b6":-1
  269. Base test mbedtls_mpi_cmp_abs (Negative values) #1
  270. mpi_cmp_abs:"-2":"-2":0
  271. Base test mbedtls_mpi_cmp_abs (Negative values) #2
  272. mpi_cmp_abs:"-2":"-3":-1
  273. Base test mbedtls_mpi_cmp_abs (Negative values) #3
  274. mpi_cmp_abs:"-2":"-1":1
  275. Test mbedtls_mpi_cmp_abs: 0 (null) = 0 (null)
  276. mpi_cmp_abs:"":"":0
  277. Test mbedtls_mpi_cmp_abs: 0 (null) = 0 (1 limb)
  278. mpi_cmp_abs:"":"0":0
  279. Test mbedtls_mpi_cmp_abs: 0 (1 limb) = 0 (null)
  280. mpi_cmp_abs:"0":"":0
  281. Test mbedtls_mpi_cmp_abs: 0 (1 limb) = 0 (1 limb)
  282. mpi_cmp_abs:"0":"0":0
  283. Base test mbedtls_mpi_cmp_abs (Mix values) #1
  284. mpi_cmp_abs:"-2":"2":0
  285. Base test mbedtls_mpi_cmp_abs (Mix values) #2
  286. mpi_cmp_abs:"2":"-3":-1
  287. Base test mbedtls_mpi_cmp_abs (Mix values) #3
  288. mpi_cmp_abs:"-2":"1":1
  289. Copy large negative to large negative
  290. mpi_copy:"-ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
  291. Copy large negative to large positive
  292. mpi_copy:"-ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
  293. Copy large negative to small negative
  294. mpi_copy:"-ca5cadedb01dfaceacc01ade":"-beef"
  295. Copy large negative to small positive
  296. mpi_copy:"-ca5cadedb01dfaceacc01ade":"beef"
  297. Copy large negative to zero (1 limb)
  298. mpi_copy:"-ca5cadedb01dfaceacc01ade":"0"
  299. Copy large negative to zero (null)
  300. mpi_copy:"-ca5cadedb01dfaceacc01ade":""
  301. Copy large positive to large negative
  302. mpi_copy:"ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
  303. Copy large positive to large positive
  304. mpi_copy:"ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
  305. Copy large positive to small negative
  306. mpi_copy:"ca5cadedb01dfaceacc01ade":"-beef"
  307. Copy large positive to small positive
  308. mpi_copy:"ca5cadedb01dfaceacc01ade":"beef"
  309. Copy large positive to zero (1 limb)
  310. mpi_copy:"ca5cadedb01dfaceacc01ade":"0"
  311. Copy large positive to zero (null)
  312. mpi_copy:"ca5cadedb01dfaceacc01ade":""
  313. Copy small negative to large negative
  314. mpi_copy:"-bead":"-face1e55ca11ab1ecab005e5"
  315. Copy small negative to large positive
  316. mpi_copy:"-bead":"face1e55ca11ab1ecab005e5"
  317. Copy small negative to small negative
  318. mpi_copy:"-bead":"-beef"
  319. Copy small negative to small positive
  320. mpi_copy:"-bead":"beef"
  321. Copy small negative to zero (1 limb)
  322. mpi_copy:"-bead":"0"
  323. Copy small negative to zero (null)
  324. mpi_copy:"-bead":""
  325. Copy small positive to large negative
  326. mpi_copy:"bead":"-face1e55ca11ab1ecab005e5"
  327. Copy small positive to large positive
  328. mpi_copy:"bead":"face1e55ca11ab1ecab005e5"
  329. Copy small positive to small negative
  330. mpi_copy:"bead":"-beef"
  331. Copy small positive to small positive
  332. mpi_copy:"bead":"beef"
  333. Copy small positive to zero (1 limb)
  334. mpi_copy:"bead":"0"
  335. Copy small positive to zero (null)
  336. mpi_copy:"bead":""
  337. Copy zero (1 limb) to large negative
  338. mpi_copy:"0":"-face1e55ca11ab1ecab005e5"
  339. Copy zero (1 limb) to large positive
  340. mpi_copy:"0":"face1e55ca11ab1ecab005e5"
  341. Copy zero (1 limb) to small negative
  342. mpi_copy:"0":"-beef"
  343. Copy zero (1 limb) to small positive
  344. mpi_copy:"0":"beef"
  345. Copy zero (1 limb) to zero (1 limb)
  346. mpi_copy:"0":"0"
  347. Copy zero (1 limb) to zero (null)
  348. mpi_copy:"0":""
  349. Copy zero (null) to large negative
  350. mpi_copy:"":"-face1e55ca11ab1ecab005e5"
  351. Copy zero (null) to large positive
  352. mpi_copy:"":"face1e55ca11ab1ecab005e5"
  353. Copy zero (null) to small negative
  354. mpi_copy:"":"-beef"
  355. Copy zero (null) to small positive
  356. mpi_copy:"":"beef"
  357. Copy zero (null) to zero (1 limb)
  358. mpi_copy:"":"0"
  359. Copy zero (null) to zero (null)
  360. mpi_copy:"":""
  361. Copy self: large negative
  362. mpi_copy_self:"-ca5cadedb01dfaceacc01ade"
  363. Copy self: large positive
  364. mpi_copy_self:"ca5cadedb01dfaceacc01ade"
  365. Copy self: small negative
  366. mpi_copy_self:"-bead"
  367. Copy self: small positive
  368. mpi_copy_self:"bead"
  369. Copy self: zero (1 limb)
  370. mpi_copy_self:"0"
  371. Copy self: zero (null)
  372. mpi_copy_self:""
  373. Swap large negative with large negative
  374. mpi_swap:"-ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
  375. Swap large negative with large positive
  376. mpi_swap:"-ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
  377. Swap large negative with small negative
  378. mpi_swap:"-ca5cadedb01dfaceacc01ade":"-beef"
  379. Swap large negative with small positive
  380. mpi_swap:"-ca5cadedb01dfaceacc01ade":"beef"
  381. Swap large negative with zero (1 limb)
  382. mpi_swap:"-ca5cadedb01dfaceacc01ade":"0"
  383. Swap large negative with zero (null)
  384. mpi_swap:"-ca5cadedb01dfaceacc01ade":""
  385. Swap large positive with large negative
  386. mpi_swap:"ca5cadedb01dfaceacc01ade":"-face1e55ca11ab1ecab005e5"
  387. Swap large positive with large positive
  388. mpi_swap:"ca5cadedb01dfaceacc01ade":"face1e55ca11ab1ecab005e5"
  389. Swap large positive with small negative
  390. mpi_swap:"ca5cadedb01dfaceacc01ade":"-beef"
  391. Swap large positive with small positive
  392. mpi_swap:"ca5cadedb01dfaceacc01ade":"beef"
  393. Swap large positive with zero (1 limb)
  394. mpi_swap:"ca5cadedb01dfaceacc01ade":"0"
  395. Swap large positive with zero (null)
  396. mpi_swap:"ca5cadedb01dfaceacc01ade":""
  397. Swap small negative with large negative
  398. mpi_swap:"-bead":"-face1e55ca11ab1ecab005e5"
  399. Swap small negative with large positive
  400. mpi_swap:"-bead":"face1e55ca11ab1ecab005e5"
  401. Swap small negative with small negative
  402. mpi_swap:"-bead":"-beef"
  403. Swap small negative with small positive
  404. mpi_swap:"-bead":"beef"
  405. Swap small negative with zero (1 limb)
  406. mpi_swap:"-bead":"0"
  407. Swap small negative with zero (null)
  408. mpi_swap:"-bead":""
  409. Swap small positive with large negative
  410. mpi_swap:"bead":"-face1e55ca11ab1ecab005e5"
  411. Swap small positive with large positive
  412. mpi_swap:"bead":"face1e55ca11ab1ecab005e5"
  413. Swap small positive with small negative
  414. mpi_swap:"bead":"-beef"
  415. Swap small positive with small positive
  416. mpi_swap:"bead":"beef"
  417. Swap small positive with zero (1 limb)
  418. mpi_swap:"bead":"0"
  419. Swap small positive with zero (null)
  420. mpi_swap:"bead":""
  421. Swap zero (1 limb) with large negative
  422. mpi_swap:"0":"-face1e55ca11ab1ecab005e5"
  423. Swap zero (1 limb) with large positive
  424. mpi_swap:"0":"face1e55ca11ab1ecab005e5"
  425. Swap zero (1 limb) with small negative
  426. mpi_swap:"0":"-beef"
  427. Swap zero (1 limb) with small positive
  428. mpi_swap:"0":"beef"
  429. Swap zero (1 limb) with zero (1 limb)
  430. mpi_swap:"0":"0"
  431. Swap zero (1 limb) with zero (null)
  432. mpi_swap:"0":""
  433. Swap zero (null) with large negative
  434. mpi_swap:"":"-face1e55ca11ab1ecab005e5"
  435. Swap zero (null) with large positive
  436. mpi_swap:"":"face1e55ca11ab1ecab005e5"
  437. Swap zero (null) with small negative
  438. mpi_swap:"":"-beef"
  439. Swap zero (null) with small positive
  440. mpi_swap:"":"beef"
  441. Swap zero (null) with zero (1 limb)
  442. mpi_swap:"":"0"
  443. Swap zero (null) with zero (null)
  444. mpi_swap:"":""
  445. Swap self: large negative
  446. mpi_swap_self:"-ca5cadedb01dfaceacc01ade"
  447. Swap self: large positive
  448. mpi_swap_self:"ca5cadedb01dfaceacc01ade"
  449. Swap self: small negative
  450. mpi_swap_self:"-bead"
  451. Swap self: small positive
  452. mpi_swap_self:"bead"
  453. Swap self: zero (1 limb)
  454. mpi_swap_self:"0"
  455. Swap self: zero (null)
  456. mpi_swap_self:""
  457. Shrink 0 limbs in a buffer of size 0 to 0
  458. mpi_shrink:0:0:0:0
  459. Shrink 2 limbs in a buffer of size 2 to 4
  460. mpi_shrink:2:2:4:4
  461. Shrink 2 limbs in a buffer of size 4 to 4
  462. mpi_shrink:4:2:4:4
  463. Shrink 2 limbs in a buffer of size 8 to 4
  464. mpi_shrink:8:2:4:4
  465. Shrink 4 limbs in a buffer of size 8 to 4
  466. mpi_shrink:8:4:4:4
  467. Shrink 6 limbs in a buffer of size 8 to 4 yielding 6
  468. mpi_shrink:8:6:4:6
  469. Shrink 2 limbs in a buffer of size 4 to 0 yielding 2
  470. mpi_shrink:4:2:0:2
  471. Shrink 1 limbs in a buffer of size 4 to 0 yielding 1
  472. mpi_shrink:4:1:0:1
  473. Shrink 0 limbs in a buffer of size 4 to 0 yielding 1
  474. mpi_shrink:4:0:0:1
  475. Base test mbedtls_mpi_add_abs #1
  476. mpi_add_abs:"bc614e":"9cde3":"c62f31"
  477. Base test mbedtls_mpi_add_abs #2
  478. mpi_add_abs:"-bc614e":"9cde3":"c62f31"
  479. Base test mbedtls_mpi_add_abs #3
  480. mpi_add_abs:"bc614e":"-9cde3":"c62f31"
  481. Base test mbedtls_mpi_add_abs #4
  482. mpi_add_abs:"-bc614e":"-9cde3":"c62f31"
  483. Test mbedtls_mpi_add_abs: 0 (null) + 0 (null)
  484. mpi_add_abs:"":"":"0"
  485. Test mbedtls_mpi_add_abs: 0 (null) + 1
  486. mpi_add_abs:"":"01":"01"
  487. Test mbedtls_mpi_add_abs: 1 + 0 (null)
  488. mpi_add_abs:"01":"":"01"
  489. Test mbedtls_mpi_add_abs #1
  490. mpi_add_abs:"-1f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":"941379d00fed1491dec0abfc13b52b9049625b3c42c3a972a2549e7a3e1b12c5a304b23e9ed6e251b8af28a4b3124900b23138bfafda925ab3410d57d6f8f0dd8c8c32eb0b4329fbf792e43f9593e766fa0c3c0be077b4e5162616a6428c51b":"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424"
  491. Regression mbedtls_mpi_add_abs (add small to very large MPI with carry rollover) [#1]
  492. mpi_add_abs:"FFFFFFFFFFFFFFFFFFFFFFFFFFFFF8":"08":"1000000000000000000000000000000"
  493. Regression mbedtls_mpi_add_abs (add small to very large MPI with carry rollover) [#2]
  494. mpi_add_abs:"08":"FFFFFFFFFFFFFFFFFFFFFFFFFFFFF8":"1000000000000000000000000000000"
  495. Base test mbedtls_mpi_add_mpi #1
  496. mpi_add_mpi:"bc614e":"9cde3":"c62f31"
  497. Base test mbedtls_mpi_add_mpi #2
  498. mpi_add_mpi:"-bc614e":"9cde3":"-b2936b"
  499. Base test mbedtls_mpi_add_mpi #3
  500. mpi_add_mpi:"bc614e":"-9cde3":"b2936b"
  501. Base test mbedtls_mpi_add_mpi #4
  502. mpi_add_mpi:"-bc614e":"-9cde3":"-c62f31"
  503. Test mbedtls_mpi_add_mpi: 0 (null) + 0 (null)
  504. mpi_add_mpi:"":"":"0"
  505. Test mbedtls_mpi_add_mpi: 0 (null) + 1
  506. mpi_add_mpi:"":"01":"01"
  507. Test mbedtls_mpi_add_mpi: 1 + 0 (null)
  508. mpi_add_mpi:"01":"":"01"
  509. Test mbedtls_mpi_add_mpi: 0 (null) + -1
  510. mpi_add_mpi:"":"-01":"-01"
  511. Test mbedtls_mpi_add_mpi: -1 + 0 (null)
  512. mpi_add_mpi:"-01":"":"-01"
  513. Test mbedtls_mpi_add_mpi #1
  514. mpi_add_mpi:"4df72d07b4b71c8dacb6cffa954f8d88254b6277099308baf003fab73227f34029643b5a263f66e0d3c3fa297ef71755efd53b8fb6cb812c6bbf7bcf179298bd9947c4c8b14324140a2c0f5fad7958a69050a987a6096e9f055fb38edf0c5889eca4a0cfa99b45fbdeee4c696b328ddceae4723945901ec025076b12b":"cb50e82a8583f44ee0025942e7362991b24e12663a0ddc234a57b0f7b4ff7b025bf5a6707dedc2898e70b739042c95a996283dffdf67558768784553c61e302e8812bc90f0bb0696870cfb910b560cefed8d99bbf7a00b31ccdbd56f3594e5a653cfd127d2167b13119e5c45c3f76b4e3d904a9bc0cbb43c33aa7f23b":"1194815323a3b10dc8cb9293d7c85b719d79974dd43a0e4de3a5babaee7276e428559e1caa42d296a6234b1628323acff85fd798f9632d6b3d437c122ddb0c8ec215a8159a1fe2aaa91390af0b8cf65967dde43439da979d0d23b88fe14a13e30407471f77bb1c10ef08ca8af2f29f92b2874bcd5065bd2fc58b1ea366"
  515. Test mbedtls_mpi_add_mpi #2
  516. mpi_add_mpi:"1f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":"941379d00fed1491dec0abfc13b52b9049625b3c42c3a972a2549e7a3e1b12c5a304b23e9ed6e251b8af28a4b3124900b23138bfafda925ab3410d57d6f8f0dd8c8c32eb0b4329fbf792e43f9593e766fa0c3c0be077b4e5162616a6428c51b":"941379d00fed1491fe15df284dfde4a142f68aa8d412023195cee66883e6290ffe703f4ea5963bf212713cee46b107c09182b5edcd955adac418bf4918e2889af48e1099d513830cec85c26ac1e158b52620e33ba8692f893efbb2f958b4424"
  517. Base test mbedtls_mpi_add_mpi inplace #1
  518. mpi_add_mpi_inplace:"bc614e":"178c29c"
  519. Test mbedtls_mpi_add_mpi inplace #2
  520. mpi_add_mpi_inplace:"1f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":"3eaa665874917221f3285ed9229cb17de6f48fdc8b962c94b6d71a200d7eb340b3842893273d7d7fbea2fa5c3b75910021af63e283d32f7ad003bb5d93a0b221e9e5bc56589ae29c58294e5f8fe2f54851ab38a62c4fe12"
  521. Test mbedtls_mpi_add_mpi inplace #3
  522. mpi_add_mpi_inplace:"ffffffffffffffffffffffffffffffff":"01fffffffffffffffffffffffffffffffe"
  523. Test mbedtls_mpi_add_int #1
  524. mpi_add_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":9871232:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd9343e109"
  525. Test mbedtls_mpi_add_int #2
  526. mpi_add_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":-9871232:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd9216a209"
  527. Test mbedtls_mpi_add_int: 0 (null) + 0
  528. mpi_add_int:"":0:"0"
  529. Test mbedtls_mpi_add_int: 0 (null) + 1
  530. mpi_add_int:"":1:"1"
  531. Base test mbedtls_mpi_sub_abs #1 (|B| > |A|)
  532. mpi_sub_abs:"5":"7":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  533. Base test mbedtls_mpi_sub_abs #2 (|B| > |A|)
  534. mpi_sub_abs:"-5":"-7":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  535. Base test mbedtls_mpi_sub_abs #3 (|B| > |A|)
  536. mpi_sub_abs:"-5":"7":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  537. Base test mbedtls_mpi_sub_abs #4 (|B| > |A|)
  538. mpi_sub_abs:"5":"-7":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  539. Base test mbedtls_mpi_sub_abs #1 (|B| >> |A| with more limbs)
  540. mpi_sub_abs:"5":"123456789abcdef01":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  541. Base test mbedtls_mpi_sub_abs #2 (|B| >> |A| with more limbs)
  542. mpi_sub_abs:"-5":"-123456789abcdef01":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  543. Base test mbedtls_mpi_sub_abs #3 (|B| >> |A| with more limbs)
  544. mpi_sub_abs:"-5":"123456789abcdef01":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  545. Base test mbedtls_mpi_sub_abs #4 (|B| >> |A| with more limbs)
  546. mpi_sub_abs:"5":"-123456789abcdef01":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  547. Base test mbedtls_mpi_sub_abs #1
  548. mpi_sub_abs:"7":"5":"2":0
  549. Base test mbedtls_mpi_sub_abs #2
  550. mpi_sub_abs:"-7":"-5":"2":0
  551. Base test mbedtls_mpi_sub_abs #3
  552. mpi_sub_abs:"-7":"5":"2":0
  553. Base test mbedtls_mpi_sub_abs #4
  554. mpi_sub_abs:"7":"-5":"2":0
  555. Test mbedtls_mpi_sub_abs: 0 (null) - 0 (null)
  556. mpi_sub_abs:"":"":"":0
  557. Test mbedtls_mpi_sub_abs: 0 (null) - 0 (1 limb)
  558. mpi_sub_abs:"":"00":"":0
  559. Test mbedtls_mpi_sub_abs: 0 (1 limb) - 0 (null)
  560. mpi_sub_abs:"00":"":"":0
  561. Test mbedtls_mpi_sub_abs: 0 (1 limb) - 0 (1 limb)
  562. mpi_sub_abs:"00":"00":"":0
  563. Test mbedtls_mpi_sub_abs: 1 - 0 (null)
  564. mpi_sub_abs:"01":"":"01":0
  565. Test mbedtls_mpi_sub_abs: 0 (null) - 1
  566. mpi_sub_abs:"":"01":"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  567. Test mbedtls_mpi_sub_abs #1
  568. mpi_sub_abs:"FFFFFFFFFF":"01":"FFFFFFFFFE":0
  569. Test mbedtls_mpi_sub_abs #2
  570. mpi_sub_abs:"FFFFFFFFF0":"01":"FFFFFFFFEF":0
  571. Test mbedtls_mpi_sub_abs #3
  572. mpi_sub_abs:"FF00000000":"0F00000000":"F000000000":0
  573. Test mbedtls_mpi_sub_abs #4
  574. mpi_sub_abs:"FF00000000":"0F00000001":"EFFFFFFFFF":0
  575. Base test mbedtls_mpi_sub_mpi #1 (Test with negative result)
  576. mpi_sub_mpi:"5":"7":"-2"
  577. Base test mbedtls_mpi_sub_mpi #2 (Test with negative inputs)
  578. mpi_sub_mpi:"-5":"-7":"2"
  579. Base test mbedtls_mpi_sub_mpi #3 (Test with negative base)
  580. mpi_sub_mpi:"-5":"7":"-c"
  581. Base test mbedtls_mpi_sub_mpi #4 (Test with negative subtraction)
  582. mpi_sub_mpi:"5":"-7":"c"
  583. Test mbedtls_mpi_sub_mpi: 0 (null) - 0 (null)
  584. mpi_sub_mpi:"":"":"0"
  585. Test mbedtls_mpi_sub_mpi: 0 (null) - 0 (1 limb)
  586. mpi_sub_mpi:"":"00":"0"
  587. Test mbedtls_mpi_sub_mpi: 0 (null) - 1
  588. mpi_sub_mpi:"":"1":"-1"
  589. Test mbedtls_mpi_sub_mpi: 0 (null) - -1
  590. mpi_sub_mpi:"":"-1":"1"
  591. Test mbedtls_mpi_sub_mpi: 0 (1 limb) - 0 (null)
  592. mpi_sub_mpi:"00":"":"0"
  593. Test mbedtls_mpi_sub_mpi: 1 - 0 (null)
  594. mpi_sub_mpi:"1":"":"1"
  595. Test mbedtls_mpi_sub_mpi: -1 - 0 (null)
  596. mpi_sub_mpi:"-1":"":"-1"
  597. Test mbedtls_mpi_sub_mpi #1
  598. mpi_sub_mpi:"cb50e82a8583f44ee0025942e7362991b24e12663a0ddc234a57b0f7b4ff7b025bf5a6707dedc2898e70b739042c95a996283dffdf67558768784553c61e302e8812bc90f0bb0696870cfb910b560cefed8d99bbf7a00b31ccdbd56f3594e5a653cfd127d2167b13119e5c45c3f76b4e3d904a9bc0cbb43c33aa7f23b":"4df72d07b4b71c8dacb6cffa954f8d88254b6277099308baf003fab73227f34029643b5a263f66e0d3c3fa297ef71755efd53b8fb6cb812c6bbf7bcf179298bd9947c4c8b14324140a2c0f5fad7958a69050a987a6096e9f055fb38edf0c5889eca4a0cfa99b45fbdeee4c696b328ddceae4723945901ec025076b12b":"7d59bb22d0ccd7c1334b894851e69c098d02afef307ad3685a53b64082d787c232916b1657ae5ba8baacbd0f85357e53a6530270289bd45afcb8c984ae8b9770eecaf7c83f77e2827ce0ec315ddcb4495d3cf03451969c92c77c21e056888d1c672b3058287b351732b00fdc58c4dd7152abd8627b3b957c0ea314110"
  599. Test mbedtls_mpi_sub_mpi #2 (Test for negative result)
  600. mpi_sub_mpi:"1f55332c3a48b910f9942f6c914e58bef37a47ee45cb164a5b6b8d1006bf59a059c21449939ebebfdf517d2e1dbac88010d7b1f141e997bd6801ddaec9d05910f4f2de2b2c4d714e2c14a72fc7f17aa428d59c531627f09":"941379d00fed1491dec0abfc13b52b9049625b3c42c3a972a2549e7a3e1b12c5a304b23e9ed6e251b8af28a4b3124900b23138bfafda925ab3410d57d6f8f0dd8c8c32eb0b4329fbf792e43f9593e766fa0c3c0be077b4e5162616a6428c51b":"-941379d00fed1491bf6b78cfd96c727f4fce2bcfb17550b3aeda568bf84ffc7b4799252e981788b15eed145b1f738a40d2dfbb91921fc9daa2695b66950f5920248a553c4172d0eb02a0061469467618cdf794dc18863a40ed507a532c64612"
  601. Test mbedtls_mpi_sub_int #1
  602. mpi_sub_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":-9871232:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd9343e109"
  603. Test mbedtls_mpi_sub_int #2
  604. mpi_sub_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":9871232:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd9216a209"
  605. Test mbedtls_mpi_sub_int: 0 (null) - 0
  606. mpi_sub_int:"":0:"0"
  607. Test mbedtls_mpi_sub_int: 0 (null) - 1
  608. mpi_sub_int:"":1:"-1"
  609. Test mbedtls_mpi_sub_int: 0 (null) - -1
  610. mpi_sub_int:"":-1:"1"
  611. Test mbedtls_mpi_shift_l #1
  612. mpi_shift_l:"40":1:"80"
  613. Test mbedtls_mpi_shift_l #2
  614. mpi_shift_l:"1946e2958a85d8863ae21f4904fcc49478412534ed53eaf321f63f2a2227a3c63acbf50b6305595f90cfa8327f6db80d986fe96080bcbb5df1bdbe9b74fb8dedf2bddb3f8215b54dffd66409323bcc473e45a8fe9d08e77a511698b5dad0416305db7fcf":37:"328dc52b150bb10c75c43e9209f98928f0824a69daa7d5e643ec7e54444f478c7597ea16c60ab2bf219f5064fedb701b30dfd2c1017976bbe37b7d36e9f71bdbe57bb67f042b6a9bffacc8126477988e7c8b51fd3a11cef4a22d316bb5a082c60bb6ff9e000000000"
  615. Test mbedtls_mpi_shift_l: 0 (null) <<= 0
  616. mpi_shift_l:"":0:"0"
  617. Test mbedtls_mpi_shift_l: 0 (null) <<= 1
  618. mpi_shift_l:"":1:"0"
  619. Test mbedtls_mpi_shift_l: 0 (null) <<= 64
  620. mpi_shift_l:"":64:"0"
  621. Test mbedtls_mpi_shift_r #1
  622. mpi_shift_r:"80":1:"40"
  623. Test mbedtls_mpi_shift_r #2
  624. mpi_shift_r:"4a36ce2a2eba161116629d6196efb17ee4f01ef753cd32b9e952d4d69e4b2401e85e0c3ba0ea761f44e312db10209fb6b38963c9c0302dc67b1b531c32301d8d341968c734387ef8bc2496051e0bb530975839852d8dd15684788f9dca62cb0c372ac51":45:"251b6715175d0b088b314eb0cb77d8bf72780f7ba9e6995cf4a96a6b4f259200f42f061dd0753b0fa271896d88104fdb59c4b1e4e01816e33d8da98e19180ec69a0cb4639a1c3f7c5e124b028f05da984bac1cc296c6e8ab423c47cee531"
  625. Test mbedtls_mpi_shift_r #4 [#1]
  626. mpi_shift_r:"FFFFFFFFFFFFFFFF":63:"01"
  627. Test mbedtls_mpi_shift_r #4 [#2]
  628. mpi_shift_r:"FFFFFFFFFFFFFFFF":64:"00"
  629. Test mbedtls_mpi_shift_r #6
  630. mpi_shift_r:"FFFFFFFFFFFFFFFF":65:"00"
  631. Test mbedtls_mpi_shift_r #7
  632. mpi_shift_r:"FFFFFFFFFFFFFFFF":128:"00"
  633. Test mbedtls_mpi_shift_r: 0 (null) >>= 0
  634. mpi_shift_r:"":0:"0"
  635. Test mbedtls_mpi_shift_r: 0 (null) >>= 1
  636. mpi_shift_r:"":1:"0"
  637. Test mbedtls_mpi_shift_r: 0 (null) >>= 64
  638. mpi_shift_r:"":64:"0"
  639. Base test mbedtls_mpi_mul_mpi #1
  640. mpi_mul_mpi:"5":"7":"23"
  641. Base test mbedtls_mpi_mul_mpi #2
  642. mpi_mul_mpi:"-5":"7":"-23"
  643. Base test mbedtls_mpi_mul_mpi #3
  644. mpi_mul_mpi:"5":"-7":"-23"
  645. Base test mbedtls_mpi_mul_mpi #4
  646. mpi_mul_mpi:"-5":"-7":"23"
  647. Test mbedtls_mpi_mul_mpi: 0 (null) * 0 (null)
  648. mpi_mul_mpi:"":"":"0"
  649. Test mbedtls_mpi_mul_mpi: 0 (null) * 0 (1 limb)
  650. mpi_mul_mpi:"":"00":"0"
  651. Test mbedtls_mpi_mul_mpi: 0 (null) * 1
  652. mpi_mul_mpi:"":"01":"0"
  653. Test mbedtls_mpi_mul_mpi: 0 (null) * -1
  654. mpi_mul_mpi:"":"-01":"0"
  655. Test mbedtls_mpi_mul_mpi: 0 (1 limb) * -1
  656. mpi_mul_mpi:"00":"-01":"0"
  657. Test mbedtls_mpi_mul_mpi: 0 (1 limb) * 0 (null)
  658. mpi_mul_mpi:"00":"":"0"
  659. Test mbedtls_mpi_mul_mpi: 1 * 0 (null)
  660. mpi_mul_mpi:"01":"":"0"
  661. Test mbedtls_mpi_mul_mpi: -1 * 0 (null)
  662. mpi_mul_mpi:"-01":"":"0"
  663. Test mbedtls_mpi_mul_mpi: -1 * 0 (1 limb)
  664. mpi_mul_mpi:"-01":"00":"0"
  665. Test mbedtls_mpi_mul_mpi #1
  666. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  667. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B
  668. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  669. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, A < 0
  670. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  671. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, B < 0
  672. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  673. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in B, A < 0, B < 0
  674. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  675. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A
  676. mpi_mul_mpi:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  677. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, A < 0
  678. mpi_mul_mpi:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  679. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, B < 0
  680. mpi_mul_mpi:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  681. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A, A < 0, B < 0
  682. mpi_mul_mpi:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  683. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B
  684. mpi_mul_mpi:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  685. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, A < 0
  686. mpi_mul_mpi:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  687. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, B < 0
  688. mpi_mul_mpi:"000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  689. Test mbedtls_mpi_mul_mpi #1, leading 0 limb in A and B, A < 0, B < 0
  690. mpi_mul_mpi:"-000000000000000002f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-000000000000000001b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb59"
  691. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A
  692. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  693. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, A < 0
  694. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  695. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, B < 0
  696. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  697. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A, A < 0, B < 0
  698. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  699. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B
  700. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  701. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, A < 0
  702. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  703. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, B < 0
  704. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  705. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in B, A < 0, B < 0
  706. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb590000000000000000"
  707. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B
  708. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  709. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, A < 0
  710. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  711. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, B < 0
  712. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  713. Test mbedtls_mpi_mul_mpi #2, trailing 0 limb in A and B, A < 0, B < 0
  714. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf24510000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c890000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  715. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A
  716. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  717. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, A < 0
  718. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  719. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, B < 0
  720. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  721. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in A, A < 0, B < 0
  722. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf245100000000000000000000000000000000":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  723. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B
  724. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  725. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, A < 0
  726. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  727. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, B < 0
  728. mpi_mul_mpi:"02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":"-0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  729. Test mbedtls_mpi_mul_mpi #3, trailing 0 limbs in B, A < 0, B < 0
  730. mpi_mul_mpi:"-02f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"-01b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c8900000000000000000000000000000000":"0503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5900000000000000000000000000000000"
  731. Test mbedtls_mpi_mul_int #1
  732. mpi_mul_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":9871232:"9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":"=="
  733. Test mbedtls_mpi_mul_int #2 (Unsigned, thus failure)
  734. mpi_mul_int:"10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":-9871232:"-9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":"!="
  735. Test mbedtls_mpi_mul_int #3
  736. mpi_mul_int:"-10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":9871232:"-9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":"=="
  737. Test mbedtls_mpi_mul_int #4 (Unsigned, thus failure)
  738. mpi_mul_int:"-10cc4ebcb68cbdaa438b80692d9e586b384ae3e1fa33f3db5962d394bec17fd92ad4189":-9871232:"9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":"!="
  739. Test mbedtls_mpi_mul_int: 0 (null) * 0
  740. mpi_mul_int:"":0:"":"=="
  741. Test mbedtls_mpi_mul_int: 0 (null) * 1
  742. mpi_mul_int:"":1:"":"=="
  743. Test mbedtls_mpi_mul_int: 0 (null) * 0x1234
  744. mpi_mul_int:"":0x1234:"":"=="
  745. Base test mbedtls_mpi_div_mpi #1
  746. mpi_div_mpi:"3e8":"d":"4c":"c":0
  747. Base test mbedtls_mpi_div_mpi #2 (Divide by zero (1 limb))
  748. mpi_div_mpi:"3e8":"0":"1":"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  749. Base test mbedtls_mpi_div_mpi #2 (Divide by zero (null))
  750. mpi_div_mpi:"3e8":"":"1":"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  751. Base test mbedtls_mpi_div_mpi #3
  752. mpi_div_mpi:"3e8":"-d":"-4c":"c":0
  753. Test mbedtls_mpi_div_mpi: 0 (null) / 0 (null)
  754. mpi_div_mpi:"":"":"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  755. Test mbedtls_mpi_div_mpi: 0 (null) / 0 (1 limb)
  756. mpi_div_mpi:"":"0":"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  757. Test mbedtls_mpi_div_mpi: 0 (1 limb) / 0 (null)
  758. mpi_div_mpi:"0":"":"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  759. Test mbedtls_mpi_div_mpi: 0 (1 limb) / 0 (1 limb)
  760. mpi_div_mpi:"0":"0":"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  761. Test mbedtls_mpi_div_mpi: 0 (null) / 1
  762. mpi_div_mpi:"":"1":"":"":0
  763. Test mbedtls_mpi_div_mpi: 0 (null) / -1
  764. mpi_div_mpi:"":"-1":"":"":0
  765. Test mbedtls_mpi_div_mpi: -0 (null) / 1
  766. mpi_div_mpi:"-":"1":"":"":0
  767. Test mbedtls_mpi_div_mpi: -0 (null) / -1
  768. mpi_div_mpi:"-":"-1":"":"":0
  769. Test mbedtls_mpi_div_mpi: -0 (null) / 42
  770. mpi_div_mpi:"-":"2a":"":"":0
  771. Test mbedtls_mpi_div_mpi: -0 (null) / -42
  772. mpi_div_mpi:"-":"-2a":"":"":0
  773. Test mbedtls_mpi_div_mpi #1
  774. mpi_div_mpi:"9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":"22":"4a6abf75b13dc268ea9cc8b5b6aaf0ac85ecd437a4e0987fb13cf8d2acc57c0306c738c1583":"1a":0
  775. Test mbedtls_mpi_div_mpi #2
  776. mpi_div_mpi:"503ae899d35ae5b7706b067aed7cb2952da37a5d4ad58f05f69abe14e8aaae88eab2baed858177cb4595c0edc92e5ac13c2bba2bfa23276dd023e9e52f547d4c9edb138d86aad329d7afb01e15eab7281e181cb249fc91bf09d621d86561301edda156f80e3bbff853a312852fe9e3d0541cb86801390aff1dc3c05bcb592c266f625b70e419b4c7e7e85399bb06c0e50b099b4292f9eaff4d869681faa1f745b5fcb3349ed93c572739a31dcf76b43370cf9f86cc54e982dfac9467bde915c697e60554e0d698be6bb2dd1f8bc64659f6baee7641b51f4b5ed7010c04600fcd382db84a93fe3d4d86e86a459c6cebb5a":"2f77b94b179d4a51360f04fa56e2c0784ce3b8a742280b016904896a5605fbe9e0f0683f82c439d979ab14e11b34e05ae96232b18fb2e0d1319f4942732d7eadf92ae90cb8c68ec8ece154d334f553564b6f6db185b33b8d3635598c3d128acde8bbb7b13697e48d1a542e5f9168d2d83a8dd05ae1eaf2451":"1b0b14c432710cde936e3fc100515e95dca61e10b8a68d9632bfa0546a9731a1ce6bebc6cb5fe6f5fd7e57b25f737f6a0ce5402e216b8b81c06f0c5ccce447d7f5631d14bff9dfa16f7cc72c56c84b636d00a5f35199d17ee9bf3f8746f44374ffd4ae22cf84089f04a9f7f356d6dc9f8cf8ef208a9b88c89":"1":0
  777. Test mbedtls_mpi_div_mpi #3
  778. mpi_div_mpi:"3e8":"7":"8e":"6":0
  779. Test mbedtls_mpi_div_mpi #4
  780. mpi_div_mpi:"309":"7":"6f":"0":0
  781. Base test mbedtls_mpi_div_int #1
  782. mpi_div_int:"3e8":13:"4c":"c":0
  783. Base test mbedtls_mpi_div_int #2 (Divide by zero)
  784. mpi_div_int:"3e8":0:"1":"1":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  785. Base test mbedtls_mpi_div_int #3
  786. mpi_div_int:"3e8":-13:"-4c":"c":0
  787. Test mbedtls_mpi_div_int #1
  788. mpi_div_int:"9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":34:"4a6abf75b13dc268ea9cc8b5b6aaf0ac85ecd437a4e0987fb13cf8d2acc57c0306c738c1583":"1a":0
  789. Test mbedtls_mpi_div_int #2
  790. mpi_div_int:"9e22d6da18a33d1ef28d2a82242b3f6e9c9742f63e5d440f58a190bfaf23a7866e67589adb80":-34:"-4a6abf75b13dc268ea9cc8b5b6aaf0ac85ecd437a4e0987fb13cf8d2acc57c0306c738c1583":"1a":0
  791. Test mbedtls_mpi_div_int: 0 (null) / 0
  792. mpi_div_int:"":0:"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  793. Test mbedtls_mpi_div_int: 0 (1 limb) / 0
  794. mpi_div_int:"00":0:"":"":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  795. Test mbedtls_mpi_div_int: 0 (null) / 1
  796. mpi_div_int:"":1:"":"":0
  797. Base test mbedtls_mpi_mod_mpi #1
  798. mpi_mod_mpi:"3e8":"d":"c":0
  799. Base test mbedtls_mpi_mod_mpi #2 (Divide by zero (null))
  800. mpi_mod_mpi:"3e8":"":"0":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  801. Base test mbedtls_mpi_mod_mpi #2 (Divide by zero (1 limb))
  802. mpi_mod_mpi:"3e8":"0":"0":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  803. Base test mbedtls_mpi_mod_mpi #3
  804. mpi_mod_mpi:"-3e8":"d":"1":0
  805. Base test mbedtls_mpi_mod_mpi #4 (Negative modulo)
  806. mpi_mod_mpi:"3e8":"-d":"-1":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  807. Base test mbedtls_mpi_mod_mpi #5 (Negative modulo)
  808. mpi_mod_mpi:"-3e8":"-d":"-c":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  809. Test mbedtls_mpi_mod_mpi: 0 (null) % 1
  810. mpi_mod_mpi:"":"1":"":0
  811. Test mbedtls_mpi_mod_mpi: 0 (null) % -1
  812. mpi_mod_mpi:"":"-1":"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  813. Test mbedtls_mpi_mod_mpi: -0 (null) % 1
  814. mpi_mod_mpi:"-":"1":"":0
  815. Test mbedtls_mpi_mod_mpi: -0 (null) % -1
  816. mpi_mod_mpi:"-":"-1":"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  817. Test mbedtls_mpi_mod_mpi: -0 (null) % 42
  818. mpi_mod_mpi:"-":"2a":"":0
  819. Test mbedtls_mpi_mod_mpi: -0 (null) % -42
  820. mpi_mod_mpi:"-":"-2a":"":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  821. Base test mbedtls_mpi_mod_int #1
  822. mpi_mod_int:"3e8":"d":"c":0
  823. Base test mbedtls_mpi_mod_int #2 (Divide by zero)
  824. mpi_mod_int:"3e8":"0":"0":MBEDTLS_ERR_MPI_DIVISION_BY_ZERO
  825. Base test mbedtls_mpi_mod_int #3
  826. mpi_mod_int:"-3e8":"d":"1":0
  827. Base test mbedtls_mpi_mod_int #4 (Negative modulo)
  828. mpi_mod_int:"3e8":"-d":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  829. Base test mbedtls_mpi_mod_int #5 (Negative modulo)
  830. mpi_mod_int:"-3e8":"-d":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  831. Base test mbedtls_mpi_mod_int #6 (By 1)
  832. mpi_mod_int:"3e8":"1":"0":0
  833. Base test mbedtls_mpi_mod_int #7 (By 2)
  834. mpi_mod_int:"3e9":"2":"1":0
  835. Base test mbedtls_mpi_mod_int #8 (By 2)
  836. mpi_mod_int:"3e8":"2":"0":0
  837. Test mbedtls_mpi_mod_int: 0 (null) % 1
  838. mpi_mod_int:"":"1":"0":0
  839. Test mbedtls_mpi_mod_int: 0 (null) % 2
  840. mpi_mod_int:"":"2":"0":0
  841. Test mbedtls_mpi_mod_int: 0 (null) % -1
  842. mpi_mod_int:"":"-1":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  843. Test mbedtls_mpi_mod_int: 0 (null) % -2
  844. mpi_mod_int:"":"-2":"0":MBEDTLS_ERR_MPI_NEGATIVE_VALUE
  845. # CURRENTLY FAILS - SEE GITHUB ISSUE #6540
  846. #Test mbedtls_mpi_mod_int: 230772460340063000000100500000300000010 % 5178236083361335880 -> 3386266129388798810
  847. #depends_on:MBEDTLS_HAVE_INT64
  848. #mpi_mod_int:"AD9D28BF6C4E98FDF156BF0980CEE30A":"47DCCA4847DCCA48":"2EFE6F1A7D28035A":0
  849. Test mbedtls_mpi_mod_mpi: 230772460340063000000100500000300000010 % 5178236083361335880 -> 3386266129388798810
  850. mpi_mod_mpi:"AD9D28BF6C4E98FDF156BF0980CEE30A":"47DCCA4847DCCA48":"2EFE6F1A7D28035A":0
  851. # CURRENTLY FAILS - SEE GITHUB ISSUE #6540
  852. #Test mbedtls_mpi_mod_int: 230772460340062999996714233870911201200 % 5178236083361335880 -> 0
  853. #depends_on:MBEDTLS_HAVE_INT64
  854. #mpi_mod_int:"AD9D28BF6C4E98FDC2584FEF03A6DFB0":"47DCCA4847DCCA48":"0":0
  855. Test mbedtls_mpi_mod_mpi: 230772460340062999996714233870911201200 % 5178236083361335880 -> 0
  856. mpi_mod_mpi:"AD9D28BF6C4E98FDC2584FEF03A6DFB0":"47DCCA4847DCCA48":"0":0
  857. # CURRENTLY FAILS WHEN MPIS ARE 32-BIT (ISSUE #6450): WHEN FIXED, REMOVE "depends_on" LINE
  858. Test mbedtls_mpi_mod_int: 230772460340063000000100500000300000010 % 1205652040 -> 3644370
  859. depends_on:MBEDTLS_HAVE_INT64
  860. mpi_mod_int:"AD9D28BF6C4E98FDF156BF0980CEE30A":"47DCCA48":"379BD2":0
  861. Test mbedtls_mpi_mod_mpi: 230772460340063000000100500000300000010 % 1205652040 -> 3644370
  862. mpi_mod_mpi:"AD9D28BF6C4E98FDF156BF0980CEE30A":"47DCCA48":"379BD2":0
  863. # CURRENTLY FAILS WHEN MPIS ARE 32-BIT (ISSUE #6450): WHEN FIXED, REMOVE "depends_on" LINE
  864. Test mbedtls_mpi_mod_int: 230772460340063000000100500000296355640 % 1205652040 -> 0
  865. depends_on:MBEDTLS_HAVE_INT64
  866. mpi_mod_int:"AD9D28BF6C4E98FDF156BF0980974738":"47DCCA48":"0":0
  867. Test mbedtls_mpi_mod_mpi: 230772460340063000000100500000296355640 % 1205652040 -> 0
  868. mpi_mod_mpi:"AD9D28BF6C4E98FDF156BF0980974738":"47DCCA48":"0":0
  869. Base test mbedtls_mpi_exp_mod #1
  870. mpi_exp_mod:"17":"d":"1d":"18":0
  871. Base test mbedtls_mpi_exp_mod #2 (Even N)
  872. mpi_exp_mod:"17":"d":"1e":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  873. Base test mbedtls_mpi_exp_mod #2 (N = 0 (null))
  874. mpi_exp_mod:"17":"d":"":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  875. Base test mbedtls_mpi_exp_mod #3 (Negative N)
  876. mpi_exp_mod:"17":"d":"-1d":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  877. Base test mbedtls_mpi_exp_mod #4 (Negative base)
  878. mpi_exp_mod:"-17":"d":"1d":"5":0
  879. Base test mbedtls_mpi_exp_mod #5 (Negative exponent)
  880. mpi_exp_mod:"17":"-d":"1d":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  881. Base test mbedtls_mpi_exp_mod #6 (Negative base + exponent)
  882. mpi_exp_mod:"-17":"-d":"1d":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  883. Test mbedtls_mpi_exp_mod: 0 (null) ^ 0 (null) mod 9
  884. mpi_exp_mod:"":"":"09":"1":0
  885. Test mbedtls_mpi_exp_mod: 0 (null) ^ 0 (1 limb) mod 9
  886. mpi_exp_mod:"":"00":"09":"1":0
  887. Test mbedtls_mpi_exp_mod: 0 (null) ^ 1 mod 9
  888. mpi_exp_mod:"":"01":"09":"":0
  889. Test mbedtls_mpi_exp_mod: 0 (null) ^ 2 mod 9
  890. mpi_exp_mod:"":"02":"09":"":0
  891. Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 0 (null) mod 9
  892. mpi_exp_mod:"00":"":"09":"1":0
  893. Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 0 (1 limb) mod 9
  894. mpi_exp_mod:"00":"00":"09":"1":0
  895. Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 1 mod 9
  896. mpi_exp_mod:"00":"01":"09":"":0
  897. Test mbedtls_mpi_exp_mod: 0 (1 limb) ^ 2 mod 9
  898. mpi_exp_mod:"00":"02":"09":"":0
  899. Test mbedtls_mpi_exp_mod: 1 ^ 0 (null) mod 9
  900. mpi_exp_mod:"01":"":"09":"1":0
  901. Test mbedtls_mpi_exp_mod: 4 ^ 0 (null) mod 9
  902. mpi_exp_mod:"04":"":"09":"1":0
  903. Test mbedtls_mpi_exp_mod: 10 ^ 0 (null) mod 9
  904. mpi_exp_mod:"0a":"":"09":"1":0
  905. Test mbedtls_mpi_exp_mod: 1 ^ 0 (1 limb) mod 9
  906. mpi_exp_mod:"01":"00":"09":"1":0
  907. Test mbedtls_mpi_exp_mod: 4 ^ 0 (1 limb) mod 9
  908. mpi_exp_mod:"04":"00":"09":"1":0
  909. Test mbedtls_mpi_exp_mod: 10 ^ 0 (1 limb) mod 9
  910. mpi_exp_mod:"0a":"00":"09":"1":0
  911. Test mbedtls_mpi_exp_mod: MAX_SIZE exponent
  912. mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE:10:"":0
  913. Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 exponent
  914. mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE + 1:10:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  915. Test mbedtls_mpi_exp_mod: MAX_SIZE modulus
  916. mpi_exp_mod_size:2:2:MBEDTLS_MPI_MAX_SIZE:"":0
  917. Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 modulus
  918. mpi_exp_mod_size:2:2:MBEDTLS_MPI_MAX_SIZE + 1:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  919. Test mbedtls_mpi_exp_mod: MAX_SIZE exponent and modulus
  920. mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE:"":0
  921. Test mbedtls_mpi_exp_mod: MAX_SIZE + 1 exponent and modulus
  922. mpi_exp_mod_size:2:MBEDTLS_MPI_MAX_SIZE + 1:MBEDTLS_MPI_MAX_SIZE + 1:"":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  923. Test mbedtls_mpi_exp_mod #1
  924. depends_on:MPI_MAX_BITS_LARGER_THAN_792
  925. mpi_exp_mod:"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"11a9351d2d32ccd568e75bf8b4ebbb2a36be691b55832edac662ff79803df8af525fba453068be16ac3920bcc1b468f8f7fe786e0fa4ecbabcad31e5e3b05def802eb8600deaf11ef452487db878df20a80606e4bb6a163b83895d034cc8b53dbcd005be42ffdd2ce99bed06089a0b79d":"37880b547b41bda303bddda307eefe24b4aedf076c9b814b903aaf328a10825c7e259a20afc6b70b487bb21a6d32d0ee98a0b9f42ff812c901e2f79237fe3e00856992dd69d93ebc0664c75863829621751b0ac35a8ae8a0965841607d3099b8e0ed24442749ba09acbcb165598dcd40":0
  926. Test mbedtls_mpi_exp_mod (Negative base) [#1]
  927. mpi_exp_mod:"-2540be400":"2540be400":"1869f":"1":0
  928. Test mbedtls_mpi_exp_mod (Negative base) [#2]
  929. depends_on:MPI_MAX_BITS_LARGER_THAN_792
  930. mpi_exp_mod:"-9f13012cd92aa72fb86ac8879d2fde4f7fd661aaae43a00971f081cc60ca277059d5c37e89652e2af2585d281d66ef6a9d38a117e9608e9e7574cd142dc55278838a2161dd56db9470d4c1da2d5df15a908ee2eb886aaa890f23be16de59386663a12f1afbb325431a3e835e3fd89b98b96a6f77382f458ef9a37e1f84a03045c8676ab55291a94c2228ea15448ee96b626b998":"40a54d1b9e86789f06d9607fb158672d64867665c73ee9abb545fc7a785634b354c7bae5b962ce8040cf45f2c1f3d3659b2ee5ede17534c8fc2ec85c815e8df1fe7048d12c90ee31b88a68a081f17f0d8ce5f4030521e9400083bcea73a429031d4ca7949c2000d597088e0c39a6014d8bf962b73bb2e8083bd0390a4e00b9b3":"eeaf0ab9adb38dd69c33f80afa8fc5e86072618775ff3c0b9ea2314c9c256576d674df7496ea81d3383b4813d692c6e0e0d5d8e250b98be48e495c1d6089dad15dc7d7b46154d6b6ce8ef4ad69b15d4982559b297bcf1885c529f566660e57ec68edbc3c05726cc02fd4cbf4976eaa9afd5138fe8376435b9fc61d2fc0eb06e3":"21acc7199e1b90f9b4844ffe12c19f00ec548c5d32b21c647d48b6015d8eb9ec9db05b4f3d44db4227a2b5659c1a7cceb9d5fa8fa60376047953ce7397d90aaeb7465e14e820734f84aa52ad0fc66701bcbb991d57715806a11531268e1e83dd48288c72b424a6287e9ce4e5cc4db0dd67614aecc23b0124a5776d36e5c89483":0
  931. Base test GCD #1
  932. mpi_gcd:"2b5":"261":"15"
  933. Base test GCD #2
  934. mpi_gcd:"6e4":"364":"1c"
  935. Base test GCD #3
  936. mpi_gcd:"2dcdb10b":"2050d306":"1"
  937. Test GCD: 0 (null), 0 (null)
  938. mpi_gcd:"":"":"0"
  939. Test GCD: 0 (null), 0 (1 limb)
  940. mpi_gcd:"":"00":"0"
  941. Test GCD: 0 (null), 3
  942. mpi_gcd:"":"03":"3"
  943. Test GCD: 0 (null), 6
  944. mpi_gcd:"":"06":"6"
  945. Test GCD: 0 (1 limb), 0 (null)
  946. mpi_gcd:"00":"":"0"
  947. Test GCD: 0 (1 limb), 3
  948. mpi_gcd:"00":"03":"3"
  949. Test GCD: 0 (1 limb), 6
  950. mpi_gcd:"00":"06":"6"
  951. Test GCD: 3, 0 (null)
  952. mpi_gcd:"03":"":"3"
  953. Test GCD: 3, 0 (1 limb)
  954. mpi_gcd:"03":"00":"3"
  955. Test GCD: 6, 0 (null)
  956. mpi_gcd:"06":"":"6"
  957. Test GCD: 6, 0 (1 limb)
  958. mpi_gcd:"06":"00":"6"
  959. Test GCD: gcd=1, 0 < A < B
  960. mpi_gcd:"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"1"
  961. Test GCD: gcd=1, 0 < B < A
  962. mpi_gcd:"33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"1"
  963. Test GCD: gcd=1, A > 0, B < 0
  964. mpi_gcd:"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"-33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"1"
  965. Test GCD: gcd=1, A < 0 < B, |A| < |B|
  966. mpi_gcd:"-109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"1"
  967. Test GCD: gcd=1, B < A < 0
  968. mpi_gcd:"-109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"-33ae3764fd06a00cdc3cba5c45dc79a9edb4e67e4d057cc74139d531c25190d111775fc4a0f4439b8b1930bbd766e7b46f170601f316c8a18ff8d5cb5ca5581f168345d101edb462b7d93b7c520ccb8fb276b447a63d869203cc11f67a1122dc4da034218de85e39":"1"
  969. Test GCD: gcd=2, 0 < A < B
  970. mpi_gcd:"213fc8ae290cdcadfba95b36d6d0dbe4e4495f6f0d19e9e1976f28a4d2650a797e17dd4c2b282ccca9a279b3fc1b3b4b2952fdc40461e25f6a869bce7f69f0204e4b402c4566363d485c744ca032073583be630d37b2f261af25f6e59b552e3b15002b5e":"675c6ec9fa0d4019b87974b88bb8f353db69ccfc9a0af98e8273aa6384a321a222eebf8941e8873716326177aecdcf68de2e0c03e62d91431ff1ab96b94ab03e2d068ba203db68c56fb276f8a419971f64ed688f4c7b0d24079823ecf42245b89b4068431bd0bc72":"2"
  971. Test GCD: gcd=2, 0 < B < A
  972. mpi_gcd:"675c6ec9fa0d4019b87974b88bb8f353db69ccfc9a0af98e8273aa6384a321a222eebf8941e8873716326177aecdcf68de2e0c03e62d91431ff1ab96b94ab03e2d068ba203db68c56fb276f8a419971f64ed688f4c7b0d24079823ecf42245b89b4068431bd0bc72":"213fc8ae290cdcadfba95b36d6d0dbe4e4495f6f0d19e9e1976f28a4d2650a797e17dd4c2b282ccca9a279b3fc1b3b4b2952fdc40461e25f6a869bce7f69f0204e4b402c4566363d485c744ca032073583be630d37b2f261af25f6e59b552e3b15002b5e":"2"
  973. Test GCD: gcd=3, 0 < A < B
  974. mpi_gcd:"31dfad053d934b04f97e08d2423949d7566e0f2693a6ded26326bcf73b978fb63d23cbf240bc4332fe73b68dfa28d8f0bdfc7ca60692d38f1fc9e9b5bf1ee8307570e0426819515bec8aae72f04b0ad0459d9493d38c6b9286b8f25868ffc5589f80410d":"9b0aa62ef713e02694b62f14d1956cfdc91eb37ae7107655c3ad7f9546f4b27334661f4de2dccad2a14b92338634b71d4d451205d94459e4afea816215f0085d4389d17305c91d28278bb274f62662af17641cd6f2b893b60b6435e36e336894e8e09c64a9b91aab":"3"
  975. Test GCD: gcd=3, 0 < B < A
  976. mpi_gcd:"9b0aa62ef713e02694b62f14d1956cfdc91eb37ae7107655c3ad7f9546f4b27334661f4de2dccad2a14b92338634b71d4d451205d94459e4afea816215f0085d4389d17305c91d28278bb274f62662af17641cd6f2b893b60b6435e36e336894e8e09c64a9b91aab":"31dfad053d934b04f97e08d2423949d7566e0f2693a6ded26326bcf73b978fb63d23cbf240bc4332fe73b68dfa28d8f0bdfc7ca60692d38f1fc9e9b5bf1ee8307570e0426819515bec8aae72f04b0ad0459d9493d38c6b9286b8f25868ffc5589f80410d":"3"
  977. Test GCD: gcd=4, 0 < A < B
  978. mpi_gcd:"427f915c5219b95bf752b66dada1b7c9c892bede1a33d3c32ede5149a4ca14f2fc2fba98565059995344f367f836769652a5fb8808c3c4bed50d379cfed3e0409c9680588acc6c7a90b8e89940640e6b077cc61a6f65e4c35e4bedcb36aa5c762a0056bc":"ceb8dd93f41a803370f2e9711771e6a7b6d399f93415f31d04e754c70946434445dd7f1283d10e6e2c64c2ef5d9b9ed1bc5c1807cc5b22863fe3572d7295607c5a0d174407b6d18adf64edf148332e3ec9dad11e98f61a480f3047d9e8448b713680d08637a178e4":"4"
  979. Test GCD: gcd=4, 0 < B < A
  980. mpi_gcd:"ceb8dd93f41a803370f2e9711771e6a7b6d399f93415f31d04e754c70946434445dd7f1283d10e6e2c64c2ef5d9b9ed1bc5c1807cc5b22863fe3572d7295607c5a0d174407b6d18adf64edf148332e3ec9dad11e98f61a480f3047d9e8448b713680d08637a178e4":"427f915c5219b95bf752b66dada1b7c9c892bede1a33d3c32ede5149a4ca14f2fc2fba98565059995344f367f836769652a5fb8808c3c4bed50d379cfed3e0409c9680588acc6c7a90b8e89940640e6b077cc61a6f65e4c35e4bedcb36aa5c762a0056bc":"4"
  981. Test GCD: gcd=6, 0 < A < B
  982. mpi_gcd:"63bf5a0a7b269609f2fc11a4847293aeacdc1e4d274dbda4c64d79ee772f1f6c7a4797e481788665fce76d1bf451b1e17bf8f94c0d25a71e3f93d36b7e3dd060eae1c084d032a2b7d9155ce5e09615a08b3b2927a718d7250d71e4b0d1ff8ab13f00821a":"136154c5dee27c04d296c5e29a32ad9fb923d66f5ce20ecab875aff2a8de964e668cc3e9bc5b995a5429724670c696e3a9a8a240bb288b3c95fd502c42be010ba8713a2e60b923a504f1764e9ec4cc55e2ec839ade571276c16c86bc6dc66d129d1c138c953723556":"6"
  983. Test GCD: gcd=6, 0 < B < A
  984. mpi_gcd:"136154c5dee27c04d296c5e29a32ad9fb923d66f5ce20ecab875aff2a8de964e668cc3e9bc5b995a5429724670c696e3a9a8a240bb288b3c95fd502c42be010ba8713a2e60b923a504f1764e9ec4cc55e2ec839ade571276c16c86bc6dc66d129d1c138c953723556":"63bf5a0a7b269609f2fc11a4847293aeacdc1e4d274dbda4c64d79ee772f1f6c7a4797e481788665fce76d1bf451b1e17bf8f94c0d25a71e3f93d36b7e3dd060eae1c084d032a2b7d9155ce5e09615a08b3b2927a718d7250d71e4b0d1ff8ab13f00821a":"6"
  985. Test GCD: 0 < A = B
  986. mpi_gcd:"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af":"109fe45714866e56fdd4ad9b6b686df27224afb7868cf4f0cbb794526932853cbf0beea61594166654d13cd9fe0d9da594a97ee20230f12fb5434de73fb4f8102725a01622b31b1ea42e3a265019039ac1df31869bd97930d792fb72cdaa971d8a8015af"
  987. Base test mbedtls_mpi_inv_mod #1
  988. mpi_inv_mod:"3":"b":"4":0
  989. Test mbedtls_mpi_inv_mod: mod 0 (null)
  990. mpi_inv_mod:"3":"":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  991. Test mbedtls_mpi_inv_mod: mod 0 (1 limb)
  992. mpi_inv_mod:"3":"0":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  993. Test mbedtls_mpi_inv_mod: mod negative
  994. mpi_inv_mod:"3":"-b":"4":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  995. Test mbedtls_mpi_inv_mod: 2^-1 mod 4
  996. mpi_inv_mod:"2":"4":"0":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  997. Test mbedtls_mpi_inv_mod: mod 1
  998. mpi_inv_mod:"3":"1":"0":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  999. Test mbedtls_mpi_inv_mod: 0 (null) ^-1
  1000. mpi_inv_mod:"":"11":"":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1001. Test mbedtls_mpi_inv_mod: 0 (1 limb) ^-1
  1002. mpi_inv_mod:"00":"11":"":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1003. Test mbedtls_mpi_inv_mod #1
  1004. mpi_inv_mod:"aa4df5cb14b4c31237f98bd1faf527c283c2d0f3eec89718664ba33f9762907c":"fffbbd660b94412ae61ead9c2906a344116e316a256fd387874c6c675b1d587d":"8d6a5c1d7adeae3e94b9bcd2c47e0d46e778bc8804a2cc25c02d775dc3d05b0c":0
  1005. Base test mbedtls_mpi_is_prime #1
  1006. depends_on:MBEDTLS_GENPRIME
  1007. mpi_is_prime:"0":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1008. Base test mbedtls_mpi_is_prime #2
  1009. depends_on:MBEDTLS_GENPRIME
  1010. mpi_is_prime:"1":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1011. Base test mbedtls_mpi_is_prime #3
  1012. depends_on:MBEDTLS_GENPRIME
  1013. mpi_is_prime:"2":0
  1014. Base test mbedtls_mpi_is_prime #4
  1015. depends_on:MBEDTLS_GENPRIME
  1016. mpi_is_prime:"3":0
  1017. Base test mbedtls_mpi_is_prime #5
  1018. depends_on:MBEDTLS_GENPRIME
  1019. mpi_is_prime:"4":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1020. Base test mbedtls_mpi_is_prime #6
  1021. depends_on:MBEDTLS_GENPRIME
  1022. mpi_is_prime:"5":0
  1023. Base test mbedtls_mpi_is_prime #7
  1024. depends_on:MBEDTLS_GENPRIME
  1025. mpi_is_prime:"1b":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1026. Base test mbedtls_mpi_is_prime #8
  1027. depends_on:MBEDTLS_GENPRIME
  1028. mpi_is_prime:"2f":0
  1029. Test mbedtls_mpi_is_prime #1a
  1030. depends_on:MBEDTLS_GENPRIME
  1031. mpi_is_prime:"b91ba63180c726fbd57786f27f1ede97a3b40c59a7fcfb5898f076e9af57028d":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1032. Test mbedtls_mpi_is_prime #1b
  1033. depends_on:MBEDTLS_GENPRIME
  1034. mpi_is_prime:"b3a119602ee213cde28581ecd892e0f592a338655dce4ca88054b3d124d0e561":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1035. Test mbedtls_mpi_is_prime #2a
  1036. depends_on:MBEDTLS_GENPRIME
  1037. mpi_is_prime:"284139ea19c139ebe09a8111926aaa39a2c2be12ed487a809d3cb5bc55854725b4cdcb5734c58f90b2f60d99cc1950cdbc8d651793e93c9c6f0ead752500a32c56c62082912b66132b2a6aa42ada923e1ad22ceb7ba0123":0
  1038. Test mbedtls_mpi_is_prime #2b
  1039. depends_on:MBEDTLS_GENPRIME
  1040. mpi_is_prime:"284139ea19c139ebe09a8111926aaa39a2c2be12ed487a809d3cb5bc55854725b4cdcb5734c58f90b2f60d99cc1950cdbc8d651793e93c9c6f0ead752500a32c56c62082912b66132b2a6aa42ada923e1ad22ceb7ba00c1":MBEDTLS_ERR_MPI_NOT_ACCEPTABLE
  1041. Test mbedtls_mpi_is_prime #3
  1042. depends_on:MBEDTLS_GENPRIME
  1043. mpi_is_prime:"257ffffffffffffffffff":0
  1044. Test mbedtls_mpi_is_prime #4
  1045. depends_on:MBEDTLS_GENPRIME
  1046. mpi_is_prime:"a1ffffffffffffffffffff":0
  1047. Test mbedtls_mpi_is_prime #5 [#1]
  1048. depends_on:MBEDTLS_GENPRIME
  1049. mpi_is_prime:"397ffffffffffffffffffffffffffff":0
  1050. Test mbedtls_mpi_is_prime #5 [#2]
  1051. depends_on:MBEDTLS_GENPRIME
  1052. mpi_is_prime:"aaaaaaaaaaaaaab":0
  1053. Test mbedtls_mpi_is_prime #6
  1054. depends_on:MBEDTLS_GENPRIME
  1055. mpi_is_prime:"2aaaaaaaaaaaaaaaaaab":0
  1056. Test mbedtls_mpi_is_prime #7
  1057. depends_on:MBEDTLS_GENPRIME
  1058. mpi_is_prime:"aaaaaaaaaaaaaaaaaaaaaaaab":0
  1059. Test mbedtls_mpi_is_prime #8
  1060. depends_on:MBEDTLS_GENPRIME
  1061. mpi_is_prime:"2aaaaaaaaaaaaaaaaaaaaaaaaaaaaaab":0
  1062. Test mbedtls_mpi_is_prime #9
  1063. depends_on:MBEDTLS_GENPRIME
  1064. mpi_is_prime:"4df72d07b4b71c8dacb6cffa954f8d88254b6277099308baf003fab73227f34029643b5a263f66e0d3c3fa297ef71755efd53b8fb6cb812c6bbf7bcf179298bd9947c4c8b14324140a2c0f5fad7958a69050a987a6096e9f055fb38edf0c5889eca4a0cfa99b45fbdeee4c696b328ddceae4723945901ec025076b12b":0
  1065. Test mbedtls_mpi_is_prime #10
  1066. depends_on:MBEDTLS_GENPRIME
  1067. mpi_is_prime:"cb50e82a8583f44ee0025942e7362991b24e12663a0ddc234a57b0f7b4ff7b025bf5a6707dedc2898e70b739042c95a996283dffdf67558768784553c61e302e8812bc90f0bb0696870cfb910b560cefed8d99bbf7a00b31ccdbd56f3594e5a653cfd127d2167b13119e5c45c3f76b4e3d904a9bc0cbb43c33aa7f23b":0
  1068. Test mbedtls_mpi_is_prime #11
  1069. depends_on:MBEDTLS_GENPRIME
  1070. mpi_is_prime:"7a364ab3de755f924642bd5273524234f78395da1ed9098f39af4fe248288b0cb7f1c27214588969479d7dc9f0d327b5544dd4c095aa1fa271df421fe9ee460855cc8423d223e2c85dc793f6babdca7fc804ea1f408f867db053bfd98c45085ea5d805c78d2863bacdfcaf4c6147ebb74a9056045074785714c0b84ed":0
  1071. Test mbedtls_mpi_is_prime #12
  1072. depends_on:MBEDTLS_GENPRIME
  1073. mpi_is_prime:"9c3525e8404f89b7d30b3ccfdb0fab17f81adebbac1b6c6bf558a796014fe3b6cd2c4445c0826d7ef5f5d3aff5ac108185675d2159cd275c64812f24da66dbb0147efc6a3d2f8060e8304f48844abc9d33686087ccc11f":0
  1074. Test mbedtls_mpi_is_prime #13
  1075. depends_on:MBEDTLS_GENPRIME
  1076. mpi_is_prime:"284139ea19c139ebe09a8111926aaa39a2c2be12ed487a809d3cb5bc55854725b4cdcb5734c58f90b2f60d99cc1950cdbc8d651793e93c9c6f0ead752500a32c56c62082912b66132b2a6aa42ada923e1ad22ceb7ba0123":0
  1077. Test mbedtls_mpi_is_prime #14
  1078. depends_on:MBEDTLS_GENPRIME
  1079. mpi_is_prime:"2eede25f74336afd1f51cbc4e809f8bb746ffac49335d129d1ff322ee3498b2b8144f0b136de076db169da4f4436de1f0c715b3d255272b4d77523174081a2fb703f82409185e0ef73e5a8bdf94e5b789fb7bf9be8eec9f":0
  1080. Test mbedtls_mpi_is_prime #15
  1081. depends_on:MBEDTLS_GENPRIME
  1082. mpi_is_prime:"7fffffffffffffffffffffffffffffff":0
  1083. Test mbedtls_mpi_is_prime #16
  1084. depends_on:MBEDTLS_GENPRIME
  1085. mpi_is_prime:"7fffffff":0
  1086. Test mbedtls_mpi_is_prime #17
  1087. depends_on:MBEDTLS_GENPRIME
  1088. mpi_is_prime:"39531fcd":0
  1089. Test mbedtls_mpi_is_prime #18
  1090. depends_on:MBEDTLS_GENPRIME
  1091. mpi_is_prime:"ab1cdb3":0
  1092. Test mbedtls_mpi_is_prime #19
  1093. depends_on:MBEDTLS_GENPRIME
  1094. mpi_is_prime:"1ef3103":0
  1095. Test mbedtls_mpi_is_prime #20
  1096. depends_on:MBEDTLS_GENPRIME
  1097. mpi_is_prime:"2faa127":0
  1098. Test mbedtls_mpi_is_prime_det (4 non-witnesses)
  1099. depends_on:MBEDTLS_GENPRIME
  1100. mpi_is_prime_det:"043BD64BA10B11DA83FBD296B04BCA9E0552FAF6E09CAC74E2D7E735ED0DB09FC47ED76145644203EE0C826013BC602F560BCDAAED557D04683859A65D659FF828A245A2C5B1AC41E01E4669A525A45E23AF":"040EA852F7935ACCECC0E87B845281F047D10DC9AAFEF990AF9D3D66770DA30B0C5B5E03EEA8C0CB79B936FE0BB8EE5389EC1D34EB16C58AA3F2E11AF084160CDF6400BE1CC179867AB074866952D9F34EE7042D27F960E715A97FCB93F3182247D0A6AE51BD21CC2F6B0651F9E572C5FB86F3137053FA85FD7A51816D69B3A53A5A438C17754836D04E98CA240B901F828332F2D72D88C497DA45F533F99A6E53EDEA6B0424EC8951B048FA9A80134B37D0A67014597934E3CFC52C5A4DD4751ADF8D66FC79E84E2A3148C4B15C17E12CB659390FD275F39A331FFC80EC699BC3F6FAB868E30E9B14575FCDAB6FAED01E00112DD28704177E09C335AD43A696FEA761E8DF3B0663277A5C3637F9060CB5E5654F72E9A6B0F369E660AD4CF7ABF4195493545B367BD55271CD4BB7D9C15D3F508FE8F7409C2126FC8E73B43A67CD4EFB21E9F15DBF040A2A8D5F5ED75CEAC12B595C0051F3EC9D5A58ACE82A9506E64F780E9836728260FFE1BFD73E8A9869E3D46A35A856D3028F7FEAB9F4F1A04449AEDC80017EE1014080D87F0B50C8EF255324CD89F7D039":82:5
  1101. Test mbedtls_mpi_is_prime_det (39 non-witnesses)
  1102. depends_on:MBEDTLS_GENPRIME
  1103. mpi_is_prime_det:"155102B67930FBE8858DF6C0642D77D419A7B7968E622CC7500F3E3F2C5168368C50E0083187":"119B3E2C721834D83416239B04447AA18AE0163E61DCAE97054563D79E094A6FA4485BD6A0501445BF57FE9C058926CDB862E04CC1A95D79D61D9AB3466857A53E04F8D7470C9C86649B226A13DDC534E18DFD5C22FAEA317CA4D4960F18457FD6D2FFB5F3273F74C89980DC774590D8D30D1159CA81999ED94A042D67DA68C82616AD46C2C88288A8EBD0B37AC7C152D9522CA4544642AD1210F6B642FEBF43563FA872B0DEFAFC69D0B6570E8FEA9570D0AADCFA9B06CC8BFD62CEDC221541210EEEF9762448C6D49F26AA767A4D66CB168589E0201923015314E6CD4A480E5936E7CF145F73A564C5B782635B3AFC3028E2632C5D3458224A7C9E8BA1876E8F690463C878292D3DC011E9640331E7F7621F2B5E0F6713DD8C9D6767521C4BA880DA8D11C67753C8493D2C4C4F1443147550D0B25B7FAD04EAFA9F8AA60974C1365C8A794CFEECEB4279B1150909A97E5A7A10B5D91186CA5B25A612036631FE73529C8CFAE51E76FB704A772DE5320EFC1212E7A399B1FEBF57D014AF9129DFF5D2C5DFBBEEAC55F360CF6D22FA90B8E2E9AD0C71AB6495A9452A58D653B8CC26128C66B43EFBA6E39AEC5717A1A3C2AE1449FCABAFE1180B159DA55190CD81A3D9E8D798647E11B827F0A057D6DA5AAD78AB5112EE65E10E8B8B369BA24E1B8AD2CD8548C497016C07A143DE1232F8059BE303572456FA92E76A0F23D1340629228B7D27C02D3833A72745B91A3DBEB5E081117A9F19597F00E4277B414FAEA8C8CEB895C37F956A5A22F8D7A10ADA50B22BAB312504904511AA0EFDD4D3BF20ECB17E8A684564FFB5BBD5E22C429F9A75A4FB4AE468FE7612ED53C7A11212E7EF3435CC9CA6E7DB167B8CCE2BECF35F89013F8F876223C77FA81570970858663C6E32B91080AA47F9C90177F51E6FD7747B910C9489C7B6ACB070996198AD9A40A69711274159210A9A12DBAAA4FB4632446066AB70D735DC95F7C2BCE517E88C064D728DE82B1B043DF4AEE0EFF5131120A4E5B9B4180EB6F6B8A0D1491ABDA069058A9966B1A517D8E7B4997DC52A1E698FD79E271153DF1913FE6787A5D99DE69F39C3F22D26DC731CFBB33FF5C267D85D7A3DAE8E1C87E1DB2F1236212EF1942EA756967FB3D07D629E59EA4034D9A9B5E270DD4A31C8A3DFDA99C1094B5537132C196DA2AEAF5253A019B9AF25B5DCB0D4DD75C7C9C353DA9DAABFB23959A5455312E7E1C21268C1BC14E83DCFDF50C27FD3E8B4EDC04C5F3CB5FCFFF2B57151E1B1EE1A6456DC006BC43E1158674AA4CF7D146DE4A57103BE43ED130C8007294ED2418C7A2B769A7D20EBB5A8367A77B313F81BB119B9954305FF160FF83EED7F808EE6D340A5CCC000CF81AA497D315D350CCE4E86A31456B8AA85B677491FC662933DFA55EB5BFF64B8D85430D676A85D1CAFAFF383E68C4E6C22A51063739EC03FC58C36C07C44E54828BE2152B2E9AFB0F179B157D09B64C147B524BB5424BB1914419424D9100D06EDCFC718F4DF3D562E9E16C446663F35273CA7BC5426B868A80C8D415C9A12A1619CDB7CDB5BEBC70313150BDF8C3AB26B809FE62D28E798EF1EF98C410A2DA0A9071F82154AC569078B0E647E2C085D1D907E634453442803D0492D3D0C78CACB762020C0E589C8B0981321EA2771305FD0413F3B2963FCE9A232F6641DB7E12ADC009A032063C41756E5E19E5711DE12711F07AFE7545B4D83F3EFD7BFD0435297C89DF3D4AF96EBE2CE8D64B93E36EA5D7E5A0492151D0CAEE7449A7D35E1A3C83E22C3B35162C073CC3B1CF76FBDEE84270721FC042EAAEB7325110181415E2031CFB7462F15111291CDAC0560FF9F4C7341F2FA261B97CEF348D074AA2EB4DB153FE6B1410519DA4213B611999868F3B867A2B6D758D333C4989DE80782683CA26ECDE373C71524F01B76349CE8A07A5EBECBB42259CF970DDA756EC996B189FEA045FEE45F23D476960913106ECA2510B8517AA75D56FA4152B2BDDC212014E5D07FD964D6EE532F0616DF74E104659955132331FABF2D2AD265E71C93C648A956FA0A3DB21FF103D516527F2DA0E870340B61EE8A8ED913B60605EB5A67B834D0FC90564386012585609870FEF6530B3E3C037B55506F0B5694F6B0FC":38:40
  1104. Test mbedtls_mpi_gen_prime (Too small)
  1105. depends_on:MBEDTLS_GENPRIME
  1106. mpi_gen_prime:2:0:MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  1107. Test mbedtls_mpi_gen_prime (OK, minimum size)
  1108. depends_on:MBEDTLS_GENPRIME
  1109. mpi_gen_prime:3:0:0
  1110. Test mbedtls_mpi_gen_prime (corner case limb size -1 bits)
  1111. depends_on:MBEDTLS_GENPRIME
  1112. mpi_gen_prime:63:0:0
  1113. Test mbedtls_mpi_gen_prime (corner case limb size)
  1114. depends_on:MBEDTLS_GENPRIME
  1115. mpi_gen_prime:64:0:0
  1116. Test mbedtls_mpi_gen_prime (corner case limb size +1 bits)
  1117. depends_on:MBEDTLS_GENPRIME
  1118. mpi_gen_prime:65:0:0
  1119. Test mbedtls_mpi_gen_prime (Larger)
  1120. depends_on:MBEDTLS_GENPRIME
  1121. mpi_gen_prime:128:0:0
  1122. Test mbedtls_mpi_gen_prime (Safe)
  1123. depends_on:MBEDTLS_GENPRIME
  1124. mpi_gen_prime:128:MBEDTLS_MPI_GEN_PRIME_FLAG_DH:0
  1125. Test mbedtls_mpi_gen_prime (Safe with lower error rate)
  1126. depends_on:MBEDTLS_GENPRIME
  1127. mpi_gen_prime:128:MBEDTLS_MPI_GEN_PRIME_FLAG_DH | MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
  1128. Test mbedtls_mpi_gen_prime standard RSA #1 (lower error rate)
  1129. depends_on:MBEDTLS_GENPRIME
  1130. mpi_gen_prime:1024:MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
  1131. Test mbedtls_mpi_gen_prime standard RSA #2 (lower error rate)
  1132. depends_on:MBEDTLS_GENPRIME
  1133. mpi_gen_prime:1536:MBEDTLS_MPI_GEN_PRIME_FLAG_LOW_ERR:0
  1134. Test bit getting (Value bit 25)
  1135. mpi_get_bit:"2faa127":25:1
  1136. Test bit getting (Larger but same limb)
  1137. mpi_get_bit:"2faa127":26:0
  1138. Test bit getting (Larger and non-existing limb)
  1139. mpi_get_bit:"2faa127":500:0
  1140. Test bit getting in 0 (null)
  1141. mpi_get_bit:"":500:0
  1142. Test bit getting (Value bit 24)
  1143. mpi_get_bit:"2faa127":24:0
  1144. Test bit getting (Value bit 23)
  1145. mpi_get_bit:"2faa127":23:1
  1146. Test bit set (Change existing value with a 1)
  1147. mpi_set_bit:"2faa127":24:1:"3faa127":0
  1148. Test bit set (Change existing value with a 0)
  1149. mpi_set_bit:"2faa127":25:0:"faa127":0
  1150. Test bit set (Add above existing limbs with a 0)
  1151. mpi_set_bit:"2faa127":80:0:"2faa127":0
  1152. Test bit set (Add above existing limbs with a 1)
  1153. mpi_set_bit:"2faa127":80:1:"100000000000002faa127":0
  1154. Test bit set (Add to 0 (null) with a 0)
  1155. mpi_set_bit:"":65:0:"":0
  1156. Test bit set (Add to 0 (null) with a 1)
  1157. mpi_set_bit:"":65:1:"020000000000000000":0
  1158. Test bit set (Bit index larger than 31 with a 0)
  1159. mpi_set_bit:"FFFFFFFFFFFFFFFF":32:0:"FFFFFFFEFFFFFFFF":0
  1160. Test bit set (Bit index larger than 31 with a 1)
  1161. mpi_set_bit:"00":32:1:"0100000000":0
  1162. Test bit set (Invalid bit value)
  1163. mpi_set_bit:"00":5:2:"00":MBEDTLS_ERR_MPI_BAD_INPUT_DATA
  1164. Fill random: 0 bytes
  1165. mpi_fill_random:0:0:0:0
  1166. Fill random: 1 byte, good
  1167. mpi_fill_random:1:1:0:0
  1168. Fill random: 2 bytes, good, no leading zero
  1169. mpi_fill_random:2:2:0:0
  1170. Fill random: 2 bytes, good, 1 leading zero
  1171. mpi_fill_random:2:256:0:0
  1172. Fill random: MAX_SIZE - 7, good
  1173. mpi_fill_random:MBEDTLS_MPI_MAX_SIZE - 7:MBEDTLS_MPI_MAX_SIZE - 7:0:0
  1174. Fill random: MAX_SIZE, good
  1175. mpi_fill_random:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE:0:0
  1176. Fill random: 0 bytes, previously small >0
  1177. mpi_fill_random:0:0:1:0
  1178. Fill random: 0 bytes, previously small <0
  1179. mpi_fill_random:0:0:-1:0
  1180. Fill random: 0 bytes, previously large >0
  1181. mpi_fill_random:0:0:65:0
  1182. Fill random: 0 bytes, previously large <0
  1183. mpi_fill_random:0:0:-65:0
  1184. Fill random: 1 byte, previously small >0
  1185. mpi_fill_random:1:1:1:0
  1186. Fill random: 1 byte, previously small <0
  1187. mpi_fill_random:1:1:-1:0
  1188. Fill random: 1 byte, previously large >0
  1189. mpi_fill_random:1:1:65:0
  1190. Fill random: 1 byte, previously large <0
  1191. mpi_fill_random:1:1:-65:0
  1192. Fill random: 9 bytes, previously small >0
  1193. mpi_fill_random:1:1:1:0
  1194. Fill random: 9 bytes, previously small <0
  1195. mpi_fill_random:1:1:-1:0
  1196. Fill random: 1 byte, RNG failure
  1197. mpi_fill_random:1:0:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1198. Fill random: 2 bytes, RNG failure after 1 byte
  1199. mpi_fill_random:2:1:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1200. Fill random: 4 bytes, RNG failure after 3 bytes
  1201. mpi_fill_random:4:3:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1202. Fill random: 8 bytes, RNG failure after 7 bytes
  1203. mpi_fill_random:8:7:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1204. Fill random: 16 bytes, RNG failure after 1 bytes
  1205. mpi_fill_random:16:1:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1206. Fill random: 16 bytes, RNG failure after 8 bytes
  1207. mpi_fill_random:16:8:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1208. Fill random: 16 bytes, RNG failure after 15 bytes
  1209. mpi_fill_random:16:15:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1210. Fill random: MAX_SIZE bytes, RNG failure after MAX_SIZE-1 bytes
  1211. mpi_fill_random:MBEDTLS_MPI_MAX_SIZE:MBEDTLS_MPI_MAX_SIZE-1:0:MBEDTLS_ERR_ENTROPY_SOURCE_FAILED
  1212. Most negative mbedtls_mpi_sint
  1213. most_negative_mpi_sint:
  1214. MPI Selftest
  1215. depends_on:MBEDTLS_SELF_TEST
  1216. mpi_selftest: