srp_grps.h 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529
  1. /* start of generated data */
  2. static BN_ULONG bn_group_1024_value[] = {
  3. bn_pack4(0x9FC6, 0x1D2F, 0xC0EB, 0x06E3),
  4. bn_pack4(0xFD51, 0x38FE, 0x8376, 0x435B),
  5. bn_pack4(0x2FD4, 0xCBF4, 0x976E, 0xAA9A),
  6. bn_pack4(0x68ED, 0xBC3C, 0x0572, 0x6CC0),
  7. bn_pack4(0xC529, 0xF566, 0x660E, 0x57EC),
  8. bn_pack4(0x8255, 0x9B29, 0x7BCF, 0x1885),
  9. bn_pack4(0xCE8E, 0xF4AD, 0x69B1, 0x5D49),
  10. bn_pack4(0x5DC7, 0xD7B4, 0x6154, 0xD6B6),
  11. bn_pack4(0x8E49, 0x5C1D, 0x6089, 0xDAD1),
  12. bn_pack4(0xE0D5, 0xD8E2, 0x50B9, 0x8BE4),
  13. bn_pack4(0x383B, 0x4813, 0xD692, 0xC6E0),
  14. bn_pack4(0xD674, 0xDF74, 0x96EA, 0x81D3),
  15. bn_pack4(0x9EA2, 0x314C, 0x9C25, 0x6576),
  16. bn_pack4(0x6072, 0x6187, 0x75FF, 0x3C0B),
  17. bn_pack4(0x9C33, 0xF80A, 0xFA8F, 0xC5E8),
  18. bn_pack4(0xEEAF, 0x0AB9, 0xADB3, 0x8DD6)
  19. };
  20. static BIGNUM bn_group_1024 = {
  21. bn_group_1024_value,
  22. (sizeof bn_group_1024_value) / sizeof(BN_ULONG),
  23. (sizeof bn_group_1024_value) / sizeof(BN_ULONG),
  24. 0,
  25. BN_FLG_STATIC_DATA
  26. };
  27. static BN_ULONG bn_group_1536_value[] = {
  28. bn_pack4(0xCF76, 0xE3FE, 0xD135, 0xF9BB),
  29. bn_pack4(0x1518, 0x0F93, 0x499A, 0x234D),
  30. bn_pack4(0x8CE7, 0xA28C, 0x2442, 0xC6F3),
  31. bn_pack4(0x5A02, 0x1FFF, 0x5E91, 0x479E),
  32. bn_pack4(0x7F8A, 0x2FE9, 0xB8B5, 0x292E),
  33. bn_pack4(0x837C, 0x264A, 0xE3A9, 0xBEB8),
  34. bn_pack4(0xE442, 0x734A, 0xF7CC, 0xB7AE),
  35. bn_pack4(0x6577, 0x2E43, 0x7D6C, 0x7F8C),
  36. bn_pack4(0xDB2F, 0xD53D, 0x24B7, 0xC486),
  37. bn_pack4(0x6EDF, 0x0195, 0x3934, 0x9627),
  38. bn_pack4(0x158B, 0xFD3E, 0x2B9C, 0x8CF5),
  39. bn_pack4(0x764E, 0x3F4B, 0x53DD, 0x9DA1),
  40. bn_pack4(0x4754, 0x8381, 0xDBC5, 0xB1FC),
  41. bn_pack4(0x9B60, 0x9E0B, 0xE3BA, 0xB63D),
  42. bn_pack4(0x8134, 0xB1C8, 0xB979, 0x8914),
  43. bn_pack4(0xDF02, 0x8A7C, 0xEC67, 0xF0D0),
  44. bn_pack4(0x80B6, 0x55BB, 0x9A22, 0xE8DC),
  45. bn_pack4(0x1558, 0x903B, 0xA0D0, 0xF843),
  46. bn_pack4(0x51C6, 0xA94B, 0xE460, 0x7A29),
  47. bn_pack4(0x5F4F, 0x5F55, 0x6E27, 0xCBDE),
  48. bn_pack4(0xBEEE, 0xA961, 0x4B19, 0xCC4D),
  49. bn_pack4(0xDBA5, 0x1DF4, 0x99AC, 0x4C80),
  50. bn_pack4(0xB1F1, 0x2A86, 0x17A4, 0x7BBB),
  51. bn_pack4(0x9DEF, 0x3CAF, 0xB939, 0x277A)
  52. };
  53. static BIGNUM bn_group_1536 = {
  54. bn_group_1536_value,
  55. (sizeof bn_group_1536_value) / sizeof(BN_ULONG),
  56. (sizeof bn_group_1536_value) / sizeof(BN_ULONG),
  57. 0,
  58. BN_FLG_STATIC_DATA
  59. };
  60. static BN_ULONG bn_group_2048_value[] = {
  61. bn_pack4(0x0FA7, 0x111F, 0x9E4A, 0xFF73),
  62. bn_pack4(0x9B65, 0xE372, 0xFCD6, 0x8EF2),
  63. bn_pack4(0x35DE, 0x236D, 0x525F, 0x5475),
  64. bn_pack4(0x94B5, 0xC803, 0xD89F, 0x7AE4),
  65. bn_pack4(0x71AE, 0x35F8, 0xE9DB, 0xFBB6),
  66. bn_pack4(0x2A56, 0x98F3, 0xA8D0, 0xC382),
  67. bn_pack4(0x9CCC, 0x041C, 0x7BC3, 0x08D8),
  68. bn_pack4(0xAF87, 0x4E73, 0x03CE, 0x5329),
  69. bn_pack4(0x6160, 0x2790, 0x04E5, 0x7AE6),
  70. bn_pack4(0x032C, 0xFBDB, 0xF52F, 0xB378),
  71. bn_pack4(0x5EA7, 0x7A27, 0x75D2, 0xECFA),
  72. bn_pack4(0x5445, 0x23B5, 0x24B0, 0xD57D),
  73. bn_pack4(0x5B9D, 0x32E6, 0x88F8, 0x7748),
  74. bn_pack4(0xF1D2, 0xB907, 0x8717, 0x461A),
  75. bn_pack4(0x76BD, 0x207A, 0x436C, 0x6481),
  76. bn_pack4(0xCA97, 0xB43A, 0x23FB, 0x8016),
  77. bn_pack4(0x1D28, 0x1E44, 0x6B14, 0x773B),
  78. bn_pack4(0x7359, 0xD041, 0xD5C3, 0x3EA7),
  79. bn_pack4(0xA80D, 0x740A, 0xDBF4, 0xFF74),
  80. bn_pack4(0x55F9, 0x7993, 0xEC97, 0x5EEA),
  81. bn_pack4(0x2918, 0xA996, 0x2F0B, 0x93B8),
  82. bn_pack4(0x661A, 0x05FB, 0xD5FA, 0xAAE8),
  83. bn_pack4(0xCF60, 0x9517, 0x9A16, 0x3AB3),
  84. bn_pack4(0xE808, 0x3969, 0xEDB7, 0x67B0),
  85. bn_pack4(0xCD7F, 0x48A9, 0xDA04, 0xFD50),
  86. bn_pack4(0xD523, 0x12AB, 0x4B03, 0x310D),
  87. bn_pack4(0x8193, 0xE075, 0x7767, 0xA13D),
  88. bn_pack4(0xA373, 0x29CB, 0xB4A0, 0x99ED),
  89. bn_pack4(0xFC31, 0x9294, 0x3DB5, 0x6050),
  90. bn_pack4(0xAF72, 0xB665, 0x1987, 0xEE07),
  91. bn_pack4(0xF166, 0xDE5E, 0x1389, 0x582F),
  92. bn_pack4(0xAC6B, 0xDB41, 0x324A, 0x9A9B)
  93. };
  94. static BIGNUM bn_group_2048 = {
  95. bn_group_2048_value,
  96. (sizeof bn_group_2048_value) / sizeof(BN_ULONG),
  97. (sizeof bn_group_2048_value) / sizeof(BN_ULONG),
  98. 0,
  99. BN_FLG_STATIC_DATA
  100. };
  101. static BN_ULONG bn_group_3072_value[] = {
  102. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF),
  103. bn_pack4(0x4B82, 0xD120, 0xA93A, 0xD2CA),
  104. bn_pack4(0x43DB, 0x5BFC, 0xE0FD, 0x108E),
  105. bn_pack4(0x08E2, 0x4FA0, 0x74E5, 0xAB31),
  106. bn_pack4(0x7709, 0x88C0, 0xBAD9, 0x46E2),
  107. bn_pack4(0xBBE1, 0x1757, 0x7A61, 0x5D6C),
  108. bn_pack4(0x521F, 0x2B18, 0x177B, 0x200C),
  109. bn_pack4(0xD876, 0x0273, 0x3EC8, 0x6A64),
  110. bn_pack4(0xF12F, 0xFA06, 0xD98A, 0x0864),
  111. bn_pack4(0xCEE3, 0xD226, 0x1AD2, 0xEE6B),
  112. bn_pack4(0x1E8C, 0x94E0, 0x4A25, 0x619D),
  113. bn_pack4(0xABF5, 0xAE8C, 0xDB09, 0x33D7),
  114. bn_pack4(0xB397, 0x0F85, 0xA6E1, 0xE4C7),
  115. bn_pack4(0x8AEA, 0x7157, 0x5D06, 0x0C7D),
  116. bn_pack4(0xECFB, 0x8504, 0x58DB, 0xEF0A),
  117. bn_pack4(0xA855, 0x21AB, 0xDF1C, 0xBA64),
  118. bn_pack4(0xAD33, 0x170D, 0x0450, 0x7A33),
  119. bn_pack4(0x1572, 0x8E5A, 0x8AAA, 0xC42D),
  120. bn_pack4(0x15D2, 0x2618, 0x98FA, 0x0510),
  121. bn_pack4(0x3995, 0x497C, 0xEA95, 0x6AE5),
  122. bn_pack4(0xDE2B, 0xCBF6, 0x9558, 0x1718),
  123. bn_pack4(0xB5C5, 0x5DF0, 0x6F4C, 0x52C9),
  124. bn_pack4(0x9B27, 0x83A2, 0xEC07, 0xA28F),
  125. bn_pack4(0xE39E, 0x772C, 0x180E, 0x8603),
  126. bn_pack4(0x3290, 0x5E46, 0x2E36, 0xCE3B),
  127. bn_pack4(0xF174, 0x6C08, 0xCA18, 0x217C),
  128. bn_pack4(0x670C, 0x354E, 0x4ABC, 0x9804),
  129. bn_pack4(0x9ED5, 0x2907, 0x7096, 0x966D),
  130. bn_pack4(0x1C62, 0xF356, 0x2085, 0x52BB),
  131. bn_pack4(0x8365, 0x5D23, 0xDCA3, 0xAD96),
  132. bn_pack4(0x6916, 0x3FA8, 0xFD24, 0xCF5F),
  133. bn_pack4(0x98DA, 0x4836, 0x1C55, 0xD39A),
  134. bn_pack4(0xC200, 0x7CB8, 0xA163, 0xBF05),
  135. bn_pack4(0x4928, 0x6651, 0xECE4, 0x5B3D),
  136. bn_pack4(0xAE9F, 0x2411, 0x7C4B, 0x1FE6),
  137. bn_pack4(0xEE38, 0x6BFB, 0x5A89, 0x9FA5),
  138. bn_pack4(0x0BFF, 0x5CB6, 0xF406, 0xB7ED),
  139. bn_pack4(0xF44C, 0x42E9, 0xA637, 0xED6B),
  140. bn_pack4(0xE485, 0xB576, 0x625E, 0x7EC6),
  141. bn_pack4(0x4FE1, 0x356D, 0x6D51, 0xC245),
  142. bn_pack4(0x302B, 0x0A6D, 0xF25F, 0x1437),
  143. bn_pack4(0xEF95, 0x19B3, 0xCD3A, 0x431B),
  144. bn_pack4(0x514A, 0x0879, 0x8E34, 0x04DD),
  145. bn_pack4(0x020B, 0xBEA6, 0x3B13, 0x9B22),
  146. bn_pack4(0x2902, 0x4E08, 0x8A67, 0xCC74),
  147. bn_pack4(0xC4C6, 0x628B, 0x80DC, 0x1CD1),
  148. bn_pack4(0xC90F, 0xDAA2, 0x2168, 0xC234),
  149. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF)
  150. };
  151. static BIGNUM bn_group_3072 = {
  152. bn_group_3072_value,
  153. (sizeof bn_group_3072_value) / sizeof(BN_ULONG),
  154. (sizeof bn_group_3072_value) / sizeof(BN_ULONG),
  155. 0,
  156. BN_FLG_STATIC_DATA
  157. };
  158. static BN_ULONG bn_group_4096_value[] = {
  159. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF),
  160. bn_pack4(0x4DF4, 0x35C9, 0x3406, 0x3199),
  161. bn_pack4(0x86FF, 0xB7DC, 0x90A6, 0xC08F),
  162. bn_pack4(0x93B4, 0xEA98, 0x8D8F, 0xDDC1),
  163. bn_pack4(0xD006, 0x9127, 0xD5B0, 0x5AA9),
  164. bn_pack4(0xB81B, 0xDD76, 0x2170, 0x481C),
  165. bn_pack4(0x1F61, 0x2970, 0xCEE2, 0xD7AF),
  166. bn_pack4(0x233B, 0xA186, 0x515B, 0xE7ED),
  167. bn_pack4(0x99B2, 0x964F, 0xA090, 0xC3A2),
  168. bn_pack4(0x287C, 0x5947, 0x4E6B, 0xC05D),
  169. bn_pack4(0x2E8E, 0xFC14, 0x1FBE, 0xCAA6),
  170. bn_pack4(0xDBBB, 0xC2DB, 0x04DE, 0x8EF9),
  171. bn_pack4(0x2583, 0xE9CA, 0x2AD4, 0x4CE8),
  172. bn_pack4(0x1A94, 0x6834, 0xB615, 0x0BDA),
  173. bn_pack4(0x99C3, 0x2718, 0x6AF4, 0xE23C),
  174. bn_pack4(0x8871, 0x9A10, 0xBDBA, 0x5B26),
  175. bn_pack4(0x1A72, 0x3C12, 0xA787, 0xE6D7),
  176. bn_pack4(0x4B82, 0xD120, 0xA921, 0x0801),
  177. bn_pack4(0x43DB, 0x5BFC, 0xE0FD, 0x108E),
  178. bn_pack4(0x08E2, 0x4FA0, 0x74E5, 0xAB31),
  179. bn_pack4(0x7709, 0x88C0, 0xBAD9, 0x46E2),
  180. bn_pack4(0xBBE1, 0x1757, 0x7A61, 0x5D6C),
  181. bn_pack4(0x521F, 0x2B18, 0x177B, 0x200C),
  182. bn_pack4(0xD876, 0x0273, 0x3EC8, 0x6A64),
  183. bn_pack4(0xF12F, 0xFA06, 0xD98A, 0x0864),
  184. bn_pack4(0xCEE3, 0xD226, 0x1AD2, 0xEE6B),
  185. bn_pack4(0x1E8C, 0x94E0, 0x4A25, 0x619D),
  186. bn_pack4(0xABF5, 0xAE8C, 0xDB09, 0x33D7),
  187. bn_pack4(0xB397, 0x0F85, 0xA6E1, 0xE4C7),
  188. bn_pack4(0x8AEA, 0x7157, 0x5D06, 0x0C7D),
  189. bn_pack4(0xECFB, 0x8504, 0x58DB, 0xEF0A),
  190. bn_pack4(0xA855, 0x21AB, 0xDF1C, 0xBA64),
  191. bn_pack4(0xAD33, 0x170D, 0x0450, 0x7A33),
  192. bn_pack4(0x1572, 0x8E5A, 0x8AAA, 0xC42D),
  193. bn_pack4(0x15D2, 0x2618, 0x98FA, 0x0510),
  194. bn_pack4(0x3995, 0x497C, 0xEA95, 0x6AE5),
  195. bn_pack4(0xDE2B, 0xCBF6, 0x9558, 0x1718),
  196. bn_pack4(0xB5C5, 0x5DF0, 0x6F4C, 0x52C9),
  197. bn_pack4(0x9B27, 0x83A2, 0xEC07, 0xA28F),
  198. bn_pack4(0xE39E, 0x772C, 0x180E, 0x8603),
  199. bn_pack4(0x3290, 0x5E46, 0x2E36, 0xCE3B),
  200. bn_pack4(0xF174, 0x6C08, 0xCA18, 0x217C),
  201. bn_pack4(0x670C, 0x354E, 0x4ABC, 0x9804),
  202. bn_pack4(0x9ED5, 0x2907, 0x7096, 0x966D),
  203. bn_pack4(0x1C62, 0xF356, 0x2085, 0x52BB),
  204. bn_pack4(0x8365, 0x5D23, 0xDCA3, 0xAD96),
  205. bn_pack4(0x6916, 0x3FA8, 0xFD24, 0xCF5F),
  206. bn_pack4(0x98DA, 0x4836, 0x1C55, 0xD39A),
  207. bn_pack4(0xC200, 0x7CB8, 0xA163, 0xBF05),
  208. bn_pack4(0x4928, 0x6651, 0xECE4, 0x5B3D),
  209. bn_pack4(0xAE9F, 0x2411, 0x7C4B, 0x1FE6),
  210. bn_pack4(0xEE38, 0x6BFB, 0x5A89, 0x9FA5),
  211. bn_pack4(0x0BFF, 0x5CB6, 0xF406, 0xB7ED),
  212. bn_pack4(0xF44C, 0x42E9, 0xA637, 0xED6B),
  213. bn_pack4(0xE485, 0xB576, 0x625E, 0x7EC6),
  214. bn_pack4(0x4FE1, 0x356D, 0x6D51, 0xC245),
  215. bn_pack4(0x302B, 0x0A6D, 0xF25F, 0x1437),
  216. bn_pack4(0xEF95, 0x19B3, 0xCD3A, 0x431B),
  217. bn_pack4(0x514A, 0x0879, 0x8E34, 0x04DD),
  218. bn_pack4(0x020B, 0xBEA6, 0x3B13, 0x9B22),
  219. bn_pack4(0x2902, 0x4E08, 0x8A67, 0xCC74),
  220. bn_pack4(0xC4C6, 0x628B, 0x80DC, 0x1CD1),
  221. bn_pack4(0xC90F, 0xDAA2, 0x2168, 0xC234),
  222. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF)
  223. };
  224. static BIGNUM bn_group_4096 = {
  225. bn_group_4096_value,
  226. (sizeof bn_group_4096_value) / sizeof(BN_ULONG),
  227. (sizeof bn_group_4096_value) / sizeof(BN_ULONG),
  228. 0,
  229. BN_FLG_STATIC_DATA
  230. };
  231. static BN_ULONG bn_group_6144_value[] = {
  232. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF),
  233. bn_pack4(0xE694, 0xF91E, 0x6DCC, 0x4024),
  234. bn_pack4(0x12BF, 0x2D5B, 0x0B74, 0x74D6),
  235. bn_pack4(0x043E, 0x8F66, 0x3F48, 0x60EE),
  236. bn_pack4(0x387F, 0xE8D7, 0x6E3C, 0x0468),
  237. bn_pack4(0xDA56, 0xC9EC, 0x2EF2, 0x9632),
  238. bn_pack4(0xEB19, 0xCCB1, 0xA313, 0xD55C),
  239. bn_pack4(0xF550, 0xAA3D, 0x8A1F, 0xBFF0),
  240. bn_pack4(0x06A1, 0xD58B, 0xB7C5, 0xDA76),
  241. bn_pack4(0xA797, 0x15EE, 0xF29B, 0xE328),
  242. bn_pack4(0x14CC, 0x5ED2, 0x0F80, 0x37E0),
  243. bn_pack4(0xCC8F, 0x6D7E, 0xBF48, 0xE1D8),
  244. bn_pack4(0x4BD4, 0x07B2, 0x2B41, 0x54AA),
  245. bn_pack4(0x0F1D, 0x45B7, 0xFF58, 0x5AC5),
  246. bn_pack4(0x23A9, 0x7A7E, 0x36CC, 0x88BE),
  247. bn_pack4(0x59E7, 0xC97F, 0xBEC7, 0xE8F3),
  248. bn_pack4(0xB5A8, 0x4031, 0x900B, 0x1C9E),
  249. bn_pack4(0xD55E, 0x702F, 0x4698, 0x0C82),
  250. bn_pack4(0xF482, 0xD7CE, 0x6E74, 0xFEF6),
  251. bn_pack4(0xF032, 0xEA15, 0xD172, 0x1D03),
  252. bn_pack4(0x5983, 0xCA01, 0xC64B, 0x92EC),
  253. bn_pack4(0x6FB8, 0xF401, 0x378C, 0xD2BF),
  254. bn_pack4(0x3320, 0x5151, 0x2BD7, 0xAF42),
  255. bn_pack4(0xDB7F, 0x1447, 0xE6CC, 0x254B),
  256. bn_pack4(0x44CE, 0x6CBA, 0xCED4, 0xBB1B),
  257. bn_pack4(0xDA3E, 0xDBEB, 0xCF9B, 0x14ED),
  258. bn_pack4(0x1797, 0x27B0, 0x865A, 0x8918),
  259. bn_pack4(0xB06A, 0x53ED, 0x9027, 0xD831),
  260. bn_pack4(0xE5DB, 0x382F, 0x4130, 0x01AE),
  261. bn_pack4(0xF8FF, 0x9406, 0xAD9E, 0x530E),
  262. bn_pack4(0xC975, 0x1E76, 0x3DBA, 0x37BD),
  263. bn_pack4(0xC1D4, 0xDCB2, 0x6026, 0x46DE),
  264. bn_pack4(0x36C3, 0xFAB4, 0xD27C, 0x7026),
  265. bn_pack4(0x4DF4, 0x35C9, 0x3402, 0x8492),
  266. bn_pack4(0x86FF, 0xB7DC, 0x90A6, 0xC08F),
  267. bn_pack4(0x93B4, 0xEA98, 0x8D8F, 0xDDC1),
  268. bn_pack4(0xD006, 0x9127, 0xD5B0, 0x5AA9),
  269. bn_pack4(0xB81B, 0xDD76, 0x2170, 0x481C),
  270. bn_pack4(0x1F61, 0x2970, 0xCEE2, 0xD7AF),
  271. bn_pack4(0x233B, 0xA186, 0x515B, 0xE7ED),
  272. bn_pack4(0x99B2, 0x964F, 0xA090, 0xC3A2),
  273. bn_pack4(0x287C, 0x5947, 0x4E6B, 0xC05D),
  274. bn_pack4(0x2E8E, 0xFC14, 0x1FBE, 0xCAA6),
  275. bn_pack4(0xDBBB, 0xC2DB, 0x04DE, 0x8EF9),
  276. bn_pack4(0x2583, 0xE9CA, 0x2AD4, 0x4CE8),
  277. bn_pack4(0x1A94, 0x6834, 0xB615, 0x0BDA),
  278. bn_pack4(0x99C3, 0x2718, 0x6AF4, 0xE23C),
  279. bn_pack4(0x8871, 0x9A10, 0xBDBA, 0x5B26),
  280. bn_pack4(0x1A72, 0x3C12, 0xA787, 0xE6D7),
  281. bn_pack4(0x4B82, 0xD120, 0xA921, 0x0801),
  282. bn_pack4(0x43DB, 0x5BFC, 0xE0FD, 0x108E),
  283. bn_pack4(0x08E2, 0x4FA0, 0x74E5, 0xAB31),
  284. bn_pack4(0x7709, 0x88C0, 0xBAD9, 0x46E2),
  285. bn_pack4(0xBBE1, 0x1757, 0x7A61, 0x5D6C),
  286. bn_pack4(0x521F, 0x2B18, 0x177B, 0x200C),
  287. bn_pack4(0xD876, 0x0273, 0x3EC8, 0x6A64),
  288. bn_pack4(0xF12F, 0xFA06, 0xD98A, 0x0864),
  289. bn_pack4(0xCEE3, 0xD226, 0x1AD2, 0xEE6B),
  290. bn_pack4(0x1E8C, 0x94E0, 0x4A25, 0x619D),
  291. bn_pack4(0xABF5, 0xAE8C, 0xDB09, 0x33D7),
  292. bn_pack4(0xB397, 0x0F85, 0xA6E1, 0xE4C7),
  293. bn_pack4(0x8AEA, 0x7157, 0x5D06, 0x0C7D),
  294. bn_pack4(0xECFB, 0x8504, 0x58DB, 0xEF0A),
  295. bn_pack4(0xA855, 0x21AB, 0xDF1C, 0xBA64),
  296. bn_pack4(0xAD33, 0x170D, 0x0450, 0x7A33),
  297. bn_pack4(0x1572, 0x8E5A, 0x8AAA, 0xC42D),
  298. bn_pack4(0x15D2, 0x2618, 0x98FA, 0x0510),
  299. bn_pack4(0x3995, 0x497C, 0xEA95, 0x6AE5),
  300. bn_pack4(0xDE2B, 0xCBF6, 0x9558, 0x1718),
  301. bn_pack4(0xB5C5, 0x5DF0, 0x6F4C, 0x52C9),
  302. bn_pack4(0x9B27, 0x83A2, 0xEC07, 0xA28F),
  303. bn_pack4(0xE39E, 0x772C, 0x180E, 0x8603),
  304. bn_pack4(0x3290, 0x5E46, 0x2E36, 0xCE3B),
  305. bn_pack4(0xF174, 0x6C08, 0xCA18, 0x217C),
  306. bn_pack4(0x670C, 0x354E, 0x4ABC, 0x9804),
  307. bn_pack4(0x9ED5, 0x2907, 0x7096, 0x966D),
  308. bn_pack4(0x1C62, 0xF356, 0x2085, 0x52BB),
  309. bn_pack4(0x8365, 0x5D23, 0xDCA3, 0xAD96),
  310. bn_pack4(0x6916, 0x3FA8, 0xFD24, 0xCF5F),
  311. bn_pack4(0x98DA, 0x4836, 0x1C55, 0xD39A),
  312. bn_pack4(0xC200, 0x7CB8, 0xA163, 0xBF05),
  313. bn_pack4(0x4928, 0x6651, 0xECE4, 0x5B3D),
  314. bn_pack4(0xAE9F, 0x2411, 0x7C4B, 0x1FE6),
  315. bn_pack4(0xEE38, 0x6BFB, 0x5A89, 0x9FA5),
  316. bn_pack4(0x0BFF, 0x5CB6, 0xF406, 0xB7ED),
  317. bn_pack4(0xF44C, 0x42E9, 0xA637, 0xED6B),
  318. bn_pack4(0xE485, 0xB576, 0x625E, 0x7EC6),
  319. bn_pack4(0x4FE1, 0x356D, 0x6D51, 0xC245),
  320. bn_pack4(0x302B, 0x0A6D, 0xF25F, 0x1437),
  321. bn_pack4(0xEF95, 0x19B3, 0xCD3A, 0x431B),
  322. bn_pack4(0x514A, 0x0879, 0x8E34, 0x04DD),
  323. bn_pack4(0x020B, 0xBEA6, 0x3B13, 0x9B22),
  324. bn_pack4(0x2902, 0x4E08, 0x8A67, 0xCC74),
  325. bn_pack4(0xC4C6, 0x628B, 0x80DC, 0x1CD1),
  326. bn_pack4(0xC90F, 0xDAA2, 0x2168, 0xC234),
  327. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF)
  328. };
  329. static BIGNUM bn_group_6144 = {
  330. bn_group_6144_value,
  331. (sizeof bn_group_6144_value) / sizeof(BN_ULONG),
  332. (sizeof bn_group_6144_value) / sizeof(BN_ULONG),
  333. 0,
  334. BN_FLG_STATIC_DATA
  335. };
  336. static BN_ULONG bn_group_8192_value[] = {
  337. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF),
  338. bn_pack4(0x60C9, 0x80DD, 0x98ED, 0xD3DF),
  339. bn_pack4(0xC81F, 0x56E8, 0x80B9, 0x6E71),
  340. bn_pack4(0x9E30, 0x50E2, 0x7656, 0x94DF),
  341. bn_pack4(0x9558, 0xE447, 0x5677, 0xE9AA),
  342. bn_pack4(0xC919, 0x0DA6, 0xFC02, 0x6E47),
  343. bn_pack4(0x889A, 0x002E, 0xD5EE, 0x382B),
  344. bn_pack4(0x4009, 0x438B, 0x481C, 0x6CD7),
  345. bn_pack4(0x3590, 0x46F4, 0xEB87, 0x9F92),
  346. bn_pack4(0xFAF3, 0x6BC3, 0x1ECF, 0xA268),
  347. bn_pack4(0xB1D5, 0x10BD, 0x7EE7, 0x4D73),
  348. bn_pack4(0xF9AB, 0x4819, 0x5DED, 0x7EA1),
  349. bn_pack4(0x64F3, 0x1CC5, 0x0846, 0x851D),
  350. bn_pack4(0x4597, 0xE899, 0xA025, 0x5DC1),
  351. bn_pack4(0xDF31, 0x0EE0, 0x74AB, 0x6A36),
  352. bn_pack4(0x6D2A, 0x13F8, 0x3F44, 0xF82D),
  353. bn_pack4(0x062B, 0x3CF5, 0xB3A2, 0x78A6),
  354. bn_pack4(0x7968, 0x3303, 0xED5B, 0xDD3A),
  355. bn_pack4(0xFA9D, 0x4B7F, 0xA2C0, 0x87E8),
  356. bn_pack4(0x4BCB, 0xC886, 0x2F83, 0x85DD),
  357. bn_pack4(0x3473, 0xFC64, 0x6CEA, 0x306B),
  358. bn_pack4(0x13EB, 0x57A8, 0x1A23, 0xF0C7),
  359. bn_pack4(0x2222, 0x2E04, 0xA403, 0x7C07),
  360. bn_pack4(0xE3FD, 0xB8BE, 0xFC84, 0x8AD9),
  361. bn_pack4(0x238F, 0x16CB, 0xE39D, 0x652D),
  362. bn_pack4(0x3423, 0xB474, 0x2BF1, 0xC978),
  363. bn_pack4(0x3AAB, 0x639C, 0x5AE4, 0xF568),
  364. bn_pack4(0x2576, 0xF693, 0x6BA4, 0x2466),
  365. bn_pack4(0x741F, 0xA7BF, 0x8AFC, 0x47ED),
  366. bn_pack4(0x3BC8, 0x32B6, 0x8D9D, 0xD300),
  367. bn_pack4(0xD8BE, 0xC4D0, 0x73B9, 0x31BA),
  368. bn_pack4(0x3877, 0x7CB6, 0xA932, 0xDF8C),
  369. bn_pack4(0x74A3, 0x926F, 0x12FE, 0xE5E4),
  370. bn_pack4(0xE694, 0xF91E, 0x6DBE, 0x1159),
  371. bn_pack4(0x12BF, 0x2D5B, 0x0B74, 0x74D6),
  372. bn_pack4(0x043E, 0x8F66, 0x3F48, 0x60EE),
  373. bn_pack4(0x387F, 0xE8D7, 0x6E3C, 0x0468),
  374. bn_pack4(0xDA56, 0xC9EC, 0x2EF2, 0x9632),
  375. bn_pack4(0xEB19, 0xCCB1, 0xA313, 0xD55C),
  376. bn_pack4(0xF550, 0xAA3D, 0x8A1F, 0xBFF0),
  377. bn_pack4(0x06A1, 0xD58B, 0xB7C5, 0xDA76),
  378. bn_pack4(0xA797, 0x15EE, 0xF29B, 0xE328),
  379. bn_pack4(0x14CC, 0x5ED2, 0x0F80, 0x37E0),
  380. bn_pack4(0xCC8F, 0x6D7E, 0xBF48, 0xE1D8),
  381. bn_pack4(0x4BD4, 0x07B2, 0x2B41, 0x54AA),
  382. bn_pack4(0x0F1D, 0x45B7, 0xFF58, 0x5AC5),
  383. bn_pack4(0x23A9, 0x7A7E, 0x36CC, 0x88BE),
  384. bn_pack4(0x59E7, 0xC97F, 0xBEC7, 0xE8F3),
  385. bn_pack4(0xB5A8, 0x4031, 0x900B, 0x1C9E),
  386. bn_pack4(0xD55E, 0x702F, 0x4698, 0x0C82),
  387. bn_pack4(0xF482, 0xD7CE, 0x6E74, 0xFEF6),
  388. bn_pack4(0xF032, 0xEA15, 0xD172, 0x1D03),
  389. bn_pack4(0x5983, 0xCA01, 0xC64B, 0x92EC),
  390. bn_pack4(0x6FB8, 0xF401, 0x378C, 0xD2BF),
  391. bn_pack4(0x3320, 0x5151, 0x2BD7, 0xAF42),
  392. bn_pack4(0xDB7F, 0x1447, 0xE6CC, 0x254B),
  393. bn_pack4(0x44CE, 0x6CBA, 0xCED4, 0xBB1B),
  394. bn_pack4(0xDA3E, 0xDBEB, 0xCF9B, 0x14ED),
  395. bn_pack4(0x1797, 0x27B0, 0x865A, 0x8918),
  396. bn_pack4(0xB06A, 0x53ED, 0x9027, 0xD831),
  397. bn_pack4(0xE5DB, 0x382F, 0x4130, 0x01AE),
  398. bn_pack4(0xF8FF, 0x9406, 0xAD9E, 0x530E),
  399. bn_pack4(0xC975, 0x1E76, 0x3DBA, 0x37BD),
  400. bn_pack4(0xC1D4, 0xDCB2, 0x6026, 0x46DE),
  401. bn_pack4(0x36C3, 0xFAB4, 0xD27C, 0x7026),
  402. bn_pack4(0x4DF4, 0x35C9, 0x3402, 0x8492),
  403. bn_pack4(0x86FF, 0xB7DC, 0x90A6, 0xC08F),
  404. bn_pack4(0x93B4, 0xEA98, 0x8D8F, 0xDDC1),
  405. bn_pack4(0xD006, 0x9127, 0xD5B0, 0x5AA9),
  406. bn_pack4(0xB81B, 0xDD76, 0x2170, 0x481C),
  407. bn_pack4(0x1F61, 0x2970, 0xCEE2, 0xD7AF),
  408. bn_pack4(0x233B, 0xA186, 0x515B, 0xE7ED),
  409. bn_pack4(0x99B2, 0x964F, 0xA090, 0xC3A2),
  410. bn_pack4(0x287C, 0x5947, 0x4E6B, 0xC05D),
  411. bn_pack4(0x2E8E, 0xFC14, 0x1FBE, 0xCAA6),
  412. bn_pack4(0xDBBB, 0xC2DB, 0x04DE, 0x8EF9),
  413. bn_pack4(0x2583, 0xE9CA, 0x2AD4, 0x4CE8),
  414. bn_pack4(0x1A94, 0x6834, 0xB615, 0x0BDA),
  415. bn_pack4(0x99C3, 0x2718, 0x6AF4, 0xE23C),
  416. bn_pack4(0x8871, 0x9A10, 0xBDBA, 0x5B26),
  417. bn_pack4(0x1A72, 0x3C12, 0xA787, 0xE6D7),
  418. bn_pack4(0x4B82, 0xD120, 0xA921, 0x0801),
  419. bn_pack4(0x43DB, 0x5BFC, 0xE0FD, 0x108E),
  420. bn_pack4(0x08E2, 0x4FA0, 0x74E5, 0xAB31),
  421. bn_pack4(0x7709, 0x88C0, 0xBAD9, 0x46E2),
  422. bn_pack4(0xBBE1, 0x1757, 0x7A61, 0x5D6C),
  423. bn_pack4(0x521F, 0x2B18, 0x177B, 0x200C),
  424. bn_pack4(0xD876, 0x0273, 0x3EC8, 0x6A64),
  425. bn_pack4(0xF12F, 0xFA06, 0xD98A, 0x0864),
  426. bn_pack4(0xCEE3, 0xD226, 0x1AD2, 0xEE6B),
  427. bn_pack4(0x1E8C, 0x94E0, 0x4A25, 0x619D),
  428. bn_pack4(0xABF5, 0xAE8C, 0xDB09, 0x33D7),
  429. bn_pack4(0xB397, 0x0F85, 0xA6E1, 0xE4C7),
  430. bn_pack4(0x8AEA, 0x7157, 0x5D06, 0x0C7D),
  431. bn_pack4(0xECFB, 0x8504, 0x58DB, 0xEF0A),
  432. bn_pack4(0xA855, 0x21AB, 0xDF1C, 0xBA64),
  433. bn_pack4(0xAD33, 0x170D, 0x0450, 0x7A33),
  434. bn_pack4(0x1572, 0x8E5A, 0x8AAA, 0xC42D),
  435. bn_pack4(0x15D2, 0x2618, 0x98FA, 0x0510),
  436. bn_pack4(0x3995, 0x497C, 0xEA95, 0x6AE5),
  437. bn_pack4(0xDE2B, 0xCBF6, 0x9558, 0x1718),
  438. bn_pack4(0xB5C5, 0x5DF0, 0x6F4C, 0x52C9),
  439. bn_pack4(0x9B27, 0x83A2, 0xEC07, 0xA28F),
  440. bn_pack4(0xE39E, 0x772C, 0x180E, 0x8603),
  441. bn_pack4(0x3290, 0x5E46, 0x2E36, 0xCE3B),
  442. bn_pack4(0xF174, 0x6C08, 0xCA18, 0x217C),
  443. bn_pack4(0x670C, 0x354E, 0x4ABC, 0x9804),
  444. bn_pack4(0x9ED5, 0x2907, 0x7096, 0x966D),
  445. bn_pack4(0x1C62, 0xF356, 0x2085, 0x52BB),
  446. bn_pack4(0x8365, 0x5D23, 0xDCA3, 0xAD96),
  447. bn_pack4(0x6916, 0x3FA8, 0xFD24, 0xCF5F),
  448. bn_pack4(0x98DA, 0x4836, 0x1C55, 0xD39A),
  449. bn_pack4(0xC200, 0x7CB8, 0xA163, 0xBF05),
  450. bn_pack4(0x4928, 0x6651, 0xECE4, 0x5B3D),
  451. bn_pack4(0xAE9F, 0x2411, 0x7C4B, 0x1FE6),
  452. bn_pack4(0xEE38, 0x6BFB, 0x5A89, 0x9FA5),
  453. bn_pack4(0x0BFF, 0x5CB6, 0xF406, 0xB7ED),
  454. bn_pack4(0xF44C, 0x42E9, 0xA637, 0xED6B),
  455. bn_pack4(0xE485, 0xB576, 0x625E, 0x7EC6),
  456. bn_pack4(0x4FE1, 0x356D, 0x6D51, 0xC245),
  457. bn_pack4(0x302B, 0x0A6D, 0xF25F, 0x1437),
  458. bn_pack4(0xEF95, 0x19B3, 0xCD3A, 0x431B),
  459. bn_pack4(0x514A, 0x0879, 0x8E34, 0x04DD),
  460. bn_pack4(0x020B, 0xBEA6, 0x3B13, 0x9B22),
  461. bn_pack4(0x2902, 0x4E08, 0x8A67, 0xCC74),
  462. bn_pack4(0xC4C6, 0x628B, 0x80DC, 0x1CD1),
  463. bn_pack4(0xC90F, 0xDAA2, 0x2168, 0xC234),
  464. bn_pack4(0xFFFF, 0xFFFF, 0xFFFF, 0xFFFF)
  465. };
  466. static BIGNUM bn_group_8192 = {
  467. bn_group_8192_value,
  468. (sizeof bn_group_8192_value) / sizeof(BN_ULONG),
  469. (sizeof bn_group_8192_value) / sizeof(BN_ULONG),
  470. 0,
  471. BN_FLG_STATIC_DATA
  472. };
  473. static BN_ULONG bn_generator_19_value[] = { 19 };
  474. static BIGNUM bn_generator_19 = {
  475. bn_generator_19_value,
  476. 1,
  477. 1,
  478. 0,
  479. BN_FLG_STATIC_DATA
  480. };
  481. static BN_ULONG bn_generator_5_value[] = { 5 };
  482. static BIGNUM bn_generator_5 = {
  483. bn_generator_5_value,
  484. 1,
  485. 1,
  486. 0,
  487. BN_FLG_STATIC_DATA
  488. };
  489. static BN_ULONG bn_generator_2_value[] = { 2 };
  490. static BIGNUM bn_generator_2 = {
  491. bn_generator_2_value,
  492. 1,
  493. 1,
  494. 0,
  495. BN_FLG_STATIC_DATA
  496. };
  497. static SRP_gN knowngN[] = {
  498. {"8192", &bn_generator_19, &bn_group_8192},
  499. {"6144", &bn_generator_5, &bn_group_6144},
  500. {"4096", &bn_generator_5, &bn_group_4096},
  501. {"3072", &bn_generator_5, &bn_group_3072},
  502. {"2048", &bn_generator_2, &bn_group_2048},
  503. {"1536", &bn_generator_2, &bn_group_1536},
  504. {"1024", &bn_generator_2, &bn_group_1024},
  505. };
  506. #define KNOWN_GN_NUMBER sizeof(knowngN) / sizeof(SRP_gN)
  507. /* end of generated data */