public_key.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /* In-software asymmetric public-key crypto subtype
  3. *
  4. * See Documentation/crypto/asymmetric-keys.rst
  5. *
  6. * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
  7. * Written by David Howells ([email protected])
  8. */
  9. #define pr_fmt(fmt) "PKEY: "fmt
  10. #include <linux/module.h>
  11. #include <linux/export.h>
  12. #include <linux/kernel.h>
  13. #include <linux/slab.h>
  14. #include <linux/seq_file.h>
  15. #include <linux/scatterlist.h>
  16. #include <linux/asn1.h>
  17. #include <keys/asymmetric-subtype.h>
  18. #include <crypto/public_key.h>
  19. #include <crypto/akcipher.h>
  20. #include <crypto/sm2.h>
  21. #include <crypto/sm3_base.h>
  22. MODULE_DESCRIPTION("In-software asymmetric public-key subtype");
  23. MODULE_AUTHOR("Red Hat, Inc.");
  24. MODULE_LICENSE("GPL");
  25. /*
  26. * Provide a part of a description of the key for /proc/keys.
  27. */
  28. static void public_key_describe(const struct key *asymmetric_key,
  29. struct seq_file *m)
  30. {
  31. struct public_key *key = asymmetric_key->payload.data[asym_crypto];
  32. if (key)
  33. seq_printf(m, "%s.%s", key->id_type, key->pkey_algo);
  34. }
  35. /*
  36. * Destroy a public key algorithm key.
  37. */
  38. void public_key_free(struct public_key *key)
  39. {
  40. if (key) {
  41. kfree(key->key);
  42. kfree(key->params);
  43. kfree(key);
  44. }
  45. }
  46. EXPORT_SYMBOL_GPL(public_key_free);
  47. /*
  48. * Destroy a public key algorithm key.
  49. */
  50. static void public_key_destroy(void *payload0, void *payload3)
  51. {
  52. public_key_free(payload0);
  53. public_key_signature_free(payload3);
  54. }
  55. /*
  56. * Given a public_key, and an encoding and hash_algo to be used for signing
  57. * and/or verification with that key, determine the name of the corresponding
  58. * akcipher algorithm. Also check that encoding and hash_algo are allowed.
  59. */
  60. static int
  61. software_key_determine_akcipher(const struct public_key *pkey,
  62. const char *encoding, const char *hash_algo,
  63. char alg_name[CRYPTO_MAX_ALG_NAME])
  64. {
  65. int n;
  66. if (!encoding)
  67. return -EINVAL;
  68. if (strcmp(pkey->pkey_algo, "rsa") == 0) {
  69. /*
  70. * RSA signatures usually use EMSA-PKCS1-1_5 [RFC3447 sec 8.2].
  71. */
  72. if (strcmp(encoding, "pkcs1") == 0) {
  73. if (!hash_algo)
  74. n = snprintf(alg_name, CRYPTO_MAX_ALG_NAME,
  75. "pkcs1pad(%s)",
  76. pkey->pkey_algo);
  77. else
  78. n = snprintf(alg_name, CRYPTO_MAX_ALG_NAME,
  79. "pkcs1pad(%s,%s)",
  80. pkey->pkey_algo, hash_algo);
  81. return n >= CRYPTO_MAX_ALG_NAME ? -EINVAL : 0;
  82. }
  83. if (strcmp(encoding, "raw") != 0)
  84. return -EINVAL;
  85. /*
  86. * Raw RSA cannot differentiate between different hash
  87. * algorithms.
  88. */
  89. if (hash_algo)
  90. return -EINVAL;
  91. } else if (strncmp(pkey->pkey_algo, "ecdsa", 5) == 0) {
  92. if (strcmp(encoding, "x962") != 0)
  93. return -EINVAL;
  94. /*
  95. * ECDSA signatures are taken over a raw hash, so they don't
  96. * differentiate between different hash algorithms. That means
  97. * that the verifier should hard-code a specific hash algorithm.
  98. * Unfortunately, in practice ECDSA is used with multiple SHAs,
  99. * so we have to allow all of them and not just one.
  100. */
  101. if (!hash_algo)
  102. return -EINVAL;
  103. if (strcmp(hash_algo, "sha1") != 0 &&
  104. strcmp(hash_algo, "sha224") != 0 &&
  105. strcmp(hash_algo, "sha256") != 0 &&
  106. strcmp(hash_algo, "sha384") != 0 &&
  107. strcmp(hash_algo, "sha512") != 0)
  108. return -EINVAL;
  109. } else if (strcmp(pkey->pkey_algo, "sm2") == 0) {
  110. if (strcmp(encoding, "raw") != 0)
  111. return -EINVAL;
  112. if (!hash_algo)
  113. return -EINVAL;
  114. if (strcmp(hash_algo, "sm3") != 0)
  115. return -EINVAL;
  116. } else if (strcmp(pkey->pkey_algo, "ecrdsa") == 0) {
  117. if (strcmp(encoding, "raw") != 0)
  118. return -EINVAL;
  119. if (!hash_algo)
  120. return -EINVAL;
  121. if (strcmp(hash_algo, "streebog256") != 0 &&
  122. strcmp(hash_algo, "streebog512") != 0)
  123. return -EINVAL;
  124. } else {
  125. /* Unknown public key algorithm */
  126. return -ENOPKG;
  127. }
  128. if (strscpy(alg_name, pkey->pkey_algo, CRYPTO_MAX_ALG_NAME) < 0)
  129. return -EINVAL;
  130. return 0;
  131. }
  132. static u8 *pkey_pack_u32(u8 *dst, u32 val)
  133. {
  134. memcpy(dst, &val, sizeof(val));
  135. return dst + sizeof(val);
  136. }
  137. /*
  138. * Query information about a key.
  139. */
  140. static int software_key_query(const struct kernel_pkey_params *params,
  141. struct kernel_pkey_query *info)
  142. {
  143. struct crypto_akcipher *tfm;
  144. struct public_key *pkey = params->key->payload.data[asym_crypto];
  145. char alg_name[CRYPTO_MAX_ALG_NAME];
  146. u8 *key, *ptr;
  147. int ret, len;
  148. ret = software_key_determine_akcipher(pkey, params->encoding,
  149. params->hash_algo, alg_name);
  150. if (ret < 0)
  151. return ret;
  152. tfm = crypto_alloc_akcipher(alg_name, 0, 0);
  153. if (IS_ERR(tfm))
  154. return PTR_ERR(tfm);
  155. ret = -ENOMEM;
  156. key = kmalloc(pkey->keylen + sizeof(u32) * 2 + pkey->paramlen,
  157. GFP_KERNEL);
  158. if (!key)
  159. goto error_free_tfm;
  160. memcpy(key, pkey->key, pkey->keylen);
  161. ptr = key + pkey->keylen;
  162. ptr = pkey_pack_u32(ptr, pkey->algo);
  163. ptr = pkey_pack_u32(ptr, pkey->paramlen);
  164. memcpy(ptr, pkey->params, pkey->paramlen);
  165. if (pkey->key_is_private)
  166. ret = crypto_akcipher_set_priv_key(tfm, key, pkey->keylen);
  167. else
  168. ret = crypto_akcipher_set_pub_key(tfm, key, pkey->keylen);
  169. if (ret < 0)
  170. goto error_free_key;
  171. len = crypto_akcipher_maxsize(tfm);
  172. info->key_size = len * 8;
  173. if (strncmp(pkey->pkey_algo, "ecdsa", 5) == 0) {
  174. /*
  175. * ECDSA key sizes are much smaller than RSA, and thus could
  176. * operate on (hashed) inputs that are larger than key size.
  177. * For example SHA384-hashed input used with secp256r1
  178. * based keys. Set max_data_size to be at least as large as
  179. * the largest supported hash size (SHA512)
  180. */
  181. info->max_data_size = 64;
  182. /*
  183. * Verify takes ECDSA-Sig (described in RFC 5480) as input,
  184. * which is actually 2 'key_size'-bit integers encoded in
  185. * ASN.1. Account for the ASN.1 encoding overhead here.
  186. */
  187. info->max_sig_size = 2 * (len + 3) + 2;
  188. } else {
  189. info->max_data_size = len;
  190. info->max_sig_size = len;
  191. }
  192. info->max_enc_size = len;
  193. info->max_dec_size = len;
  194. info->supported_ops = (KEYCTL_SUPPORTS_ENCRYPT |
  195. KEYCTL_SUPPORTS_VERIFY);
  196. if (pkey->key_is_private)
  197. info->supported_ops |= (KEYCTL_SUPPORTS_DECRYPT |
  198. KEYCTL_SUPPORTS_SIGN);
  199. ret = 0;
  200. error_free_key:
  201. kfree(key);
  202. error_free_tfm:
  203. crypto_free_akcipher(tfm);
  204. pr_devel("<==%s() = %d\n", __func__, ret);
  205. return ret;
  206. }
  207. /*
  208. * Do encryption, decryption and signing ops.
  209. */
  210. static int software_key_eds_op(struct kernel_pkey_params *params,
  211. const void *in, void *out)
  212. {
  213. const struct public_key *pkey = params->key->payload.data[asym_crypto];
  214. struct akcipher_request *req;
  215. struct crypto_akcipher *tfm;
  216. struct crypto_wait cwait;
  217. struct scatterlist in_sg, out_sg;
  218. char alg_name[CRYPTO_MAX_ALG_NAME];
  219. char *key, *ptr;
  220. int ret;
  221. pr_devel("==>%s()\n", __func__);
  222. ret = software_key_determine_akcipher(pkey, params->encoding,
  223. params->hash_algo, alg_name);
  224. if (ret < 0)
  225. return ret;
  226. tfm = crypto_alloc_akcipher(alg_name, 0, 0);
  227. if (IS_ERR(tfm))
  228. return PTR_ERR(tfm);
  229. ret = -ENOMEM;
  230. req = akcipher_request_alloc(tfm, GFP_KERNEL);
  231. if (!req)
  232. goto error_free_tfm;
  233. key = kmalloc(pkey->keylen + sizeof(u32) * 2 + pkey->paramlen,
  234. GFP_KERNEL);
  235. if (!key)
  236. goto error_free_req;
  237. memcpy(key, pkey->key, pkey->keylen);
  238. ptr = key + pkey->keylen;
  239. ptr = pkey_pack_u32(ptr, pkey->algo);
  240. ptr = pkey_pack_u32(ptr, pkey->paramlen);
  241. memcpy(ptr, pkey->params, pkey->paramlen);
  242. if (pkey->key_is_private)
  243. ret = crypto_akcipher_set_priv_key(tfm, key, pkey->keylen);
  244. else
  245. ret = crypto_akcipher_set_pub_key(tfm, key, pkey->keylen);
  246. if (ret)
  247. goto error_free_key;
  248. sg_init_one(&in_sg, in, params->in_len);
  249. sg_init_one(&out_sg, out, params->out_len);
  250. akcipher_request_set_crypt(req, &in_sg, &out_sg, params->in_len,
  251. params->out_len);
  252. crypto_init_wait(&cwait);
  253. akcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG |
  254. CRYPTO_TFM_REQ_MAY_SLEEP,
  255. crypto_req_done, &cwait);
  256. /* Perform the encryption calculation. */
  257. switch (params->op) {
  258. case kernel_pkey_encrypt:
  259. ret = crypto_akcipher_encrypt(req);
  260. break;
  261. case kernel_pkey_decrypt:
  262. ret = crypto_akcipher_decrypt(req);
  263. break;
  264. case kernel_pkey_sign:
  265. ret = crypto_akcipher_sign(req);
  266. break;
  267. default:
  268. BUG();
  269. }
  270. ret = crypto_wait_req(ret, &cwait);
  271. if (ret == 0)
  272. ret = req->dst_len;
  273. error_free_key:
  274. kfree(key);
  275. error_free_req:
  276. akcipher_request_free(req);
  277. error_free_tfm:
  278. crypto_free_akcipher(tfm);
  279. pr_devel("<==%s() = %d\n", __func__, ret);
  280. return ret;
  281. }
  282. #if IS_REACHABLE(CONFIG_CRYPTO_SM2)
  283. static int cert_sig_digest_update(const struct public_key_signature *sig,
  284. struct crypto_akcipher *tfm_pkey)
  285. {
  286. struct crypto_shash *tfm;
  287. struct shash_desc *desc;
  288. size_t desc_size;
  289. unsigned char dgst[SM3_DIGEST_SIZE];
  290. int ret;
  291. BUG_ON(!sig->data);
  292. /* SM2 signatures always use the SM3 hash algorithm */
  293. if (!sig->hash_algo || strcmp(sig->hash_algo, "sm3") != 0)
  294. return -EINVAL;
  295. ret = sm2_compute_z_digest(tfm_pkey, SM2_DEFAULT_USERID,
  296. SM2_DEFAULT_USERID_LEN, dgst);
  297. if (ret)
  298. return ret;
  299. tfm = crypto_alloc_shash(sig->hash_algo, 0, 0);
  300. if (IS_ERR(tfm))
  301. return PTR_ERR(tfm);
  302. desc_size = crypto_shash_descsize(tfm) + sizeof(*desc);
  303. desc = kzalloc(desc_size, GFP_KERNEL);
  304. if (!desc) {
  305. ret = -ENOMEM;
  306. goto error_free_tfm;
  307. }
  308. desc->tfm = tfm;
  309. ret = crypto_shash_init(desc);
  310. if (ret < 0)
  311. goto error_free_desc;
  312. ret = crypto_shash_update(desc, dgst, SM3_DIGEST_SIZE);
  313. if (ret < 0)
  314. goto error_free_desc;
  315. ret = crypto_shash_finup(desc, sig->data, sig->data_size, sig->digest);
  316. error_free_desc:
  317. kfree(desc);
  318. error_free_tfm:
  319. crypto_free_shash(tfm);
  320. return ret;
  321. }
  322. #else
  323. static inline int cert_sig_digest_update(
  324. const struct public_key_signature *sig,
  325. struct crypto_akcipher *tfm_pkey)
  326. {
  327. return -ENOTSUPP;
  328. }
  329. #endif /* ! IS_REACHABLE(CONFIG_CRYPTO_SM2) */
  330. /*
  331. * Verify a signature using a public key.
  332. */
  333. int public_key_verify_signature(const struct public_key *pkey,
  334. const struct public_key_signature *sig)
  335. {
  336. struct crypto_wait cwait;
  337. struct crypto_akcipher *tfm;
  338. struct akcipher_request *req;
  339. struct scatterlist src_sg;
  340. char alg_name[CRYPTO_MAX_ALG_NAME];
  341. char *buf, *ptr;
  342. size_t buf_len;
  343. int ret;
  344. pr_devel("==>%s()\n", __func__);
  345. BUG_ON(!pkey);
  346. BUG_ON(!sig);
  347. BUG_ON(!sig->s);
  348. /*
  349. * If the signature specifies a public key algorithm, it *must* match
  350. * the key's actual public key algorithm.
  351. *
  352. * Small exception: ECDSA signatures don't specify the curve, but ECDSA
  353. * keys do. So the strings can mismatch slightly in that case:
  354. * "ecdsa-nist-*" for the key, but "ecdsa" for the signature.
  355. */
  356. if (sig->pkey_algo) {
  357. if (strcmp(pkey->pkey_algo, sig->pkey_algo) != 0 &&
  358. (strncmp(pkey->pkey_algo, "ecdsa-", 6) != 0 ||
  359. strcmp(sig->pkey_algo, "ecdsa") != 0))
  360. return -EKEYREJECTED;
  361. }
  362. ret = software_key_determine_akcipher(pkey, sig->encoding,
  363. sig->hash_algo, alg_name);
  364. if (ret < 0)
  365. return ret;
  366. tfm = crypto_alloc_akcipher(alg_name, 0, 0);
  367. if (IS_ERR(tfm))
  368. return PTR_ERR(tfm);
  369. ret = -ENOMEM;
  370. req = akcipher_request_alloc(tfm, GFP_KERNEL);
  371. if (!req)
  372. goto error_free_tfm;
  373. buf_len = max_t(size_t, pkey->keylen + sizeof(u32) * 2 + pkey->paramlen,
  374. sig->s_size + sig->digest_size);
  375. buf = kmalloc(buf_len, GFP_KERNEL);
  376. if (!buf)
  377. goto error_free_req;
  378. memcpy(buf, pkey->key, pkey->keylen);
  379. ptr = buf + pkey->keylen;
  380. ptr = pkey_pack_u32(ptr, pkey->algo);
  381. ptr = pkey_pack_u32(ptr, pkey->paramlen);
  382. memcpy(ptr, pkey->params, pkey->paramlen);
  383. if (pkey->key_is_private)
  384. ret = crypto_akcipher_set_priv_key(tfm, buf, pkey->keylen);
  385. else
  386. ret = crypto_akcipher_set_pub_key(tfm, buf, pkey->keylen);
  387. if (ret)
  388. goto error_free_buf;
  389. if (strcmp(pkey->pkey_algo, "sm2") == 0 && sig->data_size) {
  390. ret = cert_sig_digest_update(sig, tfm);
  391. if (ret)
  392. goto error_free_buf;
  393. }
  394. memcpy(buf, sig->s, sig->s_size);
  395. memcpy(buf + sig->s_size, sig->digest, sig->digest_size);
  396. sg_init_one(&src_sg, buf, sig->s_size + sig->digest_size);
  397. akcipher_request_set_crypt(req, &src_sg, NULL, sig->s_size,
  398. sig->digest_size);
  399. crypto_init_wait(&cwait);
  400. akcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG |
  401. CRYPTO_TFM_REQ_MAY_SLEEP,
  402. crypto_req_done, &cwait);
  403. ret = crypto_wait_req(crypto_akcipher_verify(req), &cwait);
  404. error_free_buf:
  405. kfree(buf);
  406. error_free_req:
  407. akcipher_request_free(req);
  408. error_free_tfm:
  409. crypto_free_akcipher(tfm);
  410. pr_devel("<==%s() = %d\n", __func__, ret);
  411. if (WARN_ON_ONCE(ret > 0))
  412. ret = -EINVAL;
  413. return ret;
  414. }
  415. EXPORT_SYMBOL_GPL(public_key_verify_signature);
  416. static int public_key_verify_signature_2(const struct key *key,
  417. const struct public_key_signature *sig)
  418. {
  419. const struct public_key *pk = key->payload.data[asym_crypto];
  420. return public_key_verify_signature(pk, sig);
  421. }
  422. /*
  423. * Public key algorithm asymmetric key subtype
  424. */
  425. struct asymmetric_key_subtype public_key_subtype = {
  426. .owner = THIS_MODULE,
  427. .name = "public_key",
  428. .name_len = sizeof("public_key") - 1,
  429. .describe = public_key_describe,
  430. .destroy = public_key_destroy,
  431. .query = software_key_query,
  432. .eds_op = software_key_eds_op,
  433. .verify_signature = public_key_verify_signature_2,
  434. };
  435. EXPORT_SYMBOL_GPL(public_key_subtype);