rsa.c 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /* RSA asymmetric public-key algorithm [RFC3447]
  3. *
  4. * Copyright (c) 2015, Intel Corporation
  5. * Authors: Tadeusz Struk <tadeusz.struk@intel.com>
  6. */
  7. #include <linux/fips.h>
  8. #include <linux/module.h>
  9. #include <linux/mpi.h>
  10. #include <crypto/internal/rsa.h>
  11. #include <crypto/internal/akcipher.h>
  12. #include <crypto/akcipher.h>
  13. #include <crypto/algapi.h>
  14. struct rsa_mpi_key {
  15. MPI n;
  16. MPI e;
  17. MPI d;
  18. MPI p;
  19. MPI q;
  20. MPI dp;
  21. MPI dq;
  22. MPI qinv;
  23. };
  24. static int rsa_check_payload(MPI x, MPI n)
  25. {
  26. MPI n1;
  27. if (mpi_cmp_ui(x, 1) <= 0)
  28. return -EINVAL;
  29. n1 = mpi_alloc(0);
  30. if (!n1)
  31. return -ENOMEM;
  32. if (mpi_sub_ui(n1, n, 1) || mpi_cmp(x, n1) >= 0) {
  33. mpi_free(n1);
  34. return -EINVAL;
  35. }
  36. mpi_free(n1);
  37. return 0;
  38. }
  39. /*
  40. * RSAEP function [RFC3447 sec 5.1.1]
  41. * c = m^e mod n;
  42. */
  43. static int _rsa_enc(const struct rsa_mpi_key *key, MPI c, MPI m)
  44. {
  45. /*
  46. * Even though (1) in RFC3447 only requires 0 <= m <= n - 1, we are
  47. * slightly more conservative and require 1 < m < n - 1. This is in line
  48. * with SP 800-56Br2, Section 7.1.1.
  49. */
  50. if (rsa_check_payload(m, key->n))
  51. return -EINVAL;
  52. /* (2) c = m^e mod n */
  53. return mpi_powm(c, m, key->e, key->n);
  54. }
  55. /*
  56. * RSADP function [RFC3447 sec 5.1.2]
  57. * m_1 = c^dP mod p;
  58. * m_2 = c^dQ mod q;
  59. * h = (m_1 - m_2) * qInv mod p;
  60. * m = m_2 + q * h;
  61. */
  62. static int _rsa_dec_crt(const struct rsa_mpi_key *key, MPI m_or_m1_or_h, MPI c)
  63. {
  64. MPI m2, m12_or_qh;
  65. int ret = -ENOMEM;
  66. /*
  67. * Even though (1) in RFC3447 only requires 0 <= c <= n - 1, we are
  68. * slightly more conservative and require 1 < c < n - 1. This is in line
  69. * with SP 800-56Br2, Section 7.1.2.
  70. */
  71. if (rsa_check_payload(c, key->n))
  72. return -EINVAL;
  73. m2 = mpi_alloc(0);
  74. m12_or_qh = mpi_alloc(0);
  75. if (!m2 || !m12_or_qh)
  76. goto err_free_mpi;
  77. /* (2i) m_1 = c^dP mod p */
  78. ret = mpi_powm(m_or_m1_or_h, c, key->dp, key->p);
  79. if (ret)
  80. goto err_free_mpi;
  81. /* (2i) m_2 = c^dQ mod q */
  82. ret = mpi_powm(m2, c, key->dq, key->q);
  83. if (ret)
  84. goto err_free_mpi;
  85. /* (2iii) h = (m_1 - m_2) * qInv mod p */
  86. ret = mpi_sub(m12_or_qh, m_or_m1_or_h, m2) ?:
  87. mpi_mulm(m_or_m1_or_h, m12_or_qh, key->qinv, key->p);
  88. /* (2iv) m = m_2 + q * h */
  89. ret = ret ?:
  90. mpi_mul(m12_or_qh, key->q, m_or_m1_or_h) ?:
  91. mpi_addm(m_or_m1_or_h, m2, m12_or_qh, key->n);
  92. err_free_mpi:
  93. mpi_free(m12_or_qh);
  94. mpi_free(m2);
  95. return ret;
  96. }
  97. static inline struct rsa_mpi_key *rsa_get_key(struct crypto_akcipher *tfm)
  98. {
  99. return akcipher_tfm_ctx(tfm);
  100. }
  101. static int rsa_enc(struct akcipher_request *req)
  102. {
  103. struct crypto_akcipher *tfm = crypto_akcipher_reqtfm(req);
  104. const struct rsa_mpi_key *pkey = rsa_get_key(tfm);
  105. MPI m, c = mpi_alloc(0);
  106. int ret = 0;
  107. int sign;
  108. if (!c)
  109. return -ENOMEM;
  110. if (unlikely(!pkey->n || !pkey->e)) {
  111. ret = -EINVAL;
  112. goto err_free_c;
  113. }
  114. ret = -ENOMEM;
  115. m = mpi_read_raw_from_sgl(req->src, req->src_len);
  116. if (!m)
  117. goto err_free_c;
  118. ret = _rsa_enc(pkey, c, m);
  119. if (ret)
  120. goto err_free_m;
  121. ret = mpi_write_to_sgl(c, req->dst, req->dst_len, &sign);
  122. if (ret)
  123. goto err_free_m;
  124. if (sign < 0)
  125. ret = -EBADMSG;
  126. err_free_m:
  127. mpi_free(m);
  128. err_free_c:
  129. mpi_free(c);
  130. return ret;
  131. }
  132. static int rsa_dec(struct akcipher_request *req)
  133. {
  134. struct crypto_akcipher *tfm = crypto_akcipher_reqtfm(req);
  135. const struct rsa_mpi_key *pkey = rsa_get_key(tfm);
  136. MPI c, m = mpi_alloc(0);
  137. int ret = 0;
  138. int sign;
  139. if (!m)
  140. return -ENOMEM;
  141. if (unlikely(!pkey->n || !pkey->d)) {
  142. ret = -EINVAL;
  143. goto err_free_m;
  144. }
  145. ret = -ENOMEM;
  146. c = mpi_read_raw_from_sgl(req->src, req->src_len);
  147. if (!c)
  148. goto err_free_m;
  149. ret = _rsa_dec_crt(pkey, m, c);
  150. if (ret)
  151. goto err_free_c;
  152. ret = mpi_write_to_sgl(m, req->dst, req->dst_len, &sign);
  153. if (ret)
  154. goto err_free_c;
  155. if (sign < 0)
  156. ret = -EBADMSG;
  157. err_free_c:
  158. mpi_free(c);
  159. err_free_m:
  160. mpi_free(m);
  161. return ret;
  162. }
  163. static void rsa_free_mpi_key(struct rsa_mpi_key *key)
  164. {
  165. mpi_free(key->d);
  166. mpi_free(key->e);
  167. mpi_free(key->n);
  168. mpi_free(key->p);
  169. mpi_free(key->q);
  170. mpi_free(key->dp);
  171. mpi_free(key->dq);
  172. mpi_free(key->qinv);
  173. key->d = NULL;
  174. key->e = NULL;
  175. key->n = NULL;
  176. key->p = NULL;
  177. key->q = NULL;
  178. key->dp = NULL;
  179. key->dq = NULL;
  180. key->qinv = NULL;
  181. }
  182. static int rsa_check_key_length(unsigned int len)
  183. {
  184. switch (len) {
  185. case 512:
  186. case 1024:
  187. case 1536:
  188. if (fips_enabled)
  189. return -EINVAL;
  190. fallthrough;
  191. case 2048:
  192. case 3072:
  193. case 4096:
  194. return 0;
  195. }
  196. return -EINVAL;
  197. }
  198. static int rsa_check_exponent_fips(MPI e)
  199. {
  200. MPI e_max = NULL;
  201. int err;
  202. /* check if odd */
  203. if (!mpi_test_bit(e, 0)) {
  204. return -EINVAL;
  205. }
  206. /* check if 2^16 < e < 2^256. */
  207. if (mpi_cmp_ui(e, 65536) <= 0) {
  208. return -EINVAL;
  209. }
  210. e_max = mpi_alloc(0);
  211. if (!e_max)
  212. return -ENOMEM;
  213. err = mpi_set_bit(e_max, 256);
  214. if (err) {
  215. mpi_free(e_max);
  216. return err;
  217. }
  218. if (mpi_cmp(e, e_max) >= 0) {
  219. mpi_free(e_max);
  220. return -EINVAL;
  221. }
  222. mpi_free(e_max);
  223. return 0;
  224. }
  225. static int rsa_set_pub_key(struct crypto_akcipher *tfm, const void *key,
  226. unsigned int keylen)
  227. {
  228. struct rsa_mpi_key *mpi_key = akcipher_tfm_ctx(tfm);
  229. struct rsa_key raw_key = {0};
  230. int ret;
  231. /* Free the old MPI key if any */
  232. rsa_free_mpi_key(mpi_key);
  233. ret = rsa_parse_pub_key(&raw_key, key, keylen);
  234. if (ret)
  235. return ret;
  236. mpi_key->e = mpi_read_raw_data(raw_key.e, raw_key.e_sz);
  237. if (!mpi_key->e)
  238. goto err;
  239. mpi_key->n = mpi_read_raw_data(raw_key.n, raw_key.n_sz);
  240. if (!mpi_key->n)
  241. goto err;
  242. if (rsa_check_key_length(mpi_get_size(mpi_key->n) << 3)) {
  243. rsa_free_mpi_key(mpi_key);
  244. return -EINVAL;
  245. }
  246. if (fips_enabled && rsa_check_exponent_fips(mpi_key->e)) {
  247. rsa_free_mpi_key(mpi_key);
  248. return -EINVAL;
  249. }
  250. return 0;
  251. err:
  252. rsa_free_mpi_key(mpi_key);
  253. return -ENOMEM;
  254. }
  255. static int rsa_set_priv_key(struct crypto_akcipher *tfm, const void *key,
  256. unsigned int keylen)
  257. {
  258. struct rsa_mpi_key *mpi_key = akcipher_tfm_ctx(tfm);
  259. struct rsa_key raw_key = {0};
  260. int ret;
  261. /* Free the old MPI key if any */
  262. rsa_free_mpi_key(mpi_key);
  263. ret = rsa_parse_priv_key(&raw_key, key, keylen);
  264. if (ret)
  265. return ret;
  266. mpi_key->d = mpi_read_raw_data(raw_key.d, raw_key.d_sz);
  267. if (!mpi_key->d)
  268. goto err;
  269. mpi_key->e = mpi_read_raw_data(raw_key.e, raw_key.e_sz);
  270. if (!mpi_key->e)
  271. goto err;
  272. mpi_key->n = mpi_read_raw_data(raw_key.n, raw_key.n_sz);
  273. if (!mpi_key->n)
  274. goto err;
  275. mpi_key->p = mpi_read_raw_data(raw_key.p, raw_key.p_sz);
  276. if (!mpi_key->p)
  277. goto err;
  278. mpi_key->q = mpi_read_raw_data(raw_key.q, raw_key.q_sz);
  279. if (!mpi_key->q)
  280. goto err;
  281. mpi_key->dp = mpi_read_raw_data(raw_key.dp, raw_key.dp_sz);
  282. if (!mpi_key->dp)
  283. goto err;
  284. mpi_key->dq = mpi_read_raw_data(raw_key.dq, raw_key.dq_sz);
  285. if (!mpi_key->dq)
  286. goto err;
  287. mpi_key->qinv = mpi_read_raw_data(raw_key.qinv, raw_key.qinv_sz);
  288. if (!mpi_key->qinv)
  289. goto err;
  290. if (rsa_check_key_length(mpi_get_size(mpi_key->n) << 3)) {
  291. rsa_free_mpi_key(mpi_key);
  292. return -EINVAL;
  293. }
  294. if (fips_enabled && rsa_check_exponent_fips(mpi_key->e)) {
  295. rsa_free_mpi_key(mpi_key);
  296. return -EINVAL;
  297. }
  298. return 0;
  299. err:
  300. rsa_free_mpi_key(mpi_key);
  301. return -ENOMEM;
  302. }
  303. static unsigned int rsa_max_size(struct crypto_akcipher *tfm)
  304. {
  305. struct rsa_mpi_key *pkey = akcipher_tfm_ctx(tfm);
  306. return mpi_get_size(pkey->n);
  307. }
  308. static void rsa_exit_tfm(struct crypto_akcipher *tfm)
  309. {
  310. struct rsa_mpi_key *pkey = akcipher_tfm_ctx(tfm);
  311. rsa_free_mpi_key(pkey);
  312. }
  313. static struct akcipher_alg rsa = {
  314. .encrypt = rsa_enc,
  315. .decrypt = rsa_dec,
  316. .set_priv_key = rsa_set_priv_key,
  317. .set_pub_key = rsa_set_pub_key,
  318. .max_size = rsa_max_size,
  319. .exit = rsa_exit_tfm,
  320. .base = {
  321. .cra_name = "rsa",
  322. .cra_driver_name = "rsa-generic",
  323. .cra_priority = 100,
  324. .cra_module = THIS_MODULE,
  325. .cra_ctxsize = sizeof(struct rsa_mpi_key),
  326. },
  327. };
  328. static int __init rsa_init(void)
  329. {
  330. int err;
  331. err = crypto_register_akcipher(&rsa);
  332. if (err)
  333. return err;
  334. err = crypto_register_template(&rsa_pkcs1pad_tmpl);
  335. if (err) {
  336. crypto_unregister_akcipher(&rsa);
  337. return err;
  338. }
  339. return 0;
  340. }
  341. static void __exit rsa_exit(void)
  342. {
  343. crypto_unregister_template(&rsa_pkcs1pad_tmpl);
  344. crypto_unregister_akcipher(&rsa);
  345. }
  346. subsys_initcall(rsa_init);
  347. module_exit(rsa_exit);
  348. MODULE_ALIAS_CRYPTO("rsa");
  349. MODULE_LICENSE("GPL");
  350. MODULE_DESCRIPTION("RSA generic algorithm");