/* * Create a protected key from a clear key value. */ int pkey_clr2protkey(u32 keytype, const struct pkey_clrkey *clrkey, struct pkey_protkey *protkey) { long fc; int keysize; u8 paramblock[64]; switch (keytype) { case PKEY_KEYTYPE_AES_128: keysize = 16; fc = CPACF_PCKMO_ENC_AES_128_KEY; break; case PKEY_KEYTYPE_AES_192: keysize = 24; fc = CPACF_PCKMO_ENC_AES_192_KEY; break; case PKEY_KEYTYPE_AES_256: keysize = 32; fc = CPACF_PCKMO_ENC_AES_256_KEY; break; default: DEBUG_ERR("%s unknown/unsupported keytype %d\n", __func__, keytype); return -EINVAL; } /* * Check if the needed pckmo subfunction is available. * These subfunctions can be enabled/disabled by customers * in the LPAR profile or may even change on the fly. */ if (!cpacf_test_func(&pckmo_functions, fc)) { DEBUG_ERR("%s pckmo functions not available\n", __func__); return -EOPNOTSUPP; } /* prepare param block */ memset(paramblock, 0, sizeof(paramblock)); memcpy(paramblock, clrkey->clrkey, keysize); /* call the pckmo instruction */ cpacf_pckmo(fc, paramblock); /* copy created protected key */ protkey->type = keytype; protkey->len = keysize + 32; memcpy(protkey->protkey, paramblock, keysize + 32); return 0; }
/* * Create a protected key from a clear key value. */ int pkey_clr2protkey(u32 keytype, const struct pkey_clrkey *clrkey, struct pkey_protkey *protkey) { long fc; int keysize; u8 paramblock[64]; switch (keytype) { case PKEY_KEYTYPE_AES_128: keysize = 16; fc = CPACF_PCKMO_ENC_AES_128_KEY; break; case PKEY_KEYTYPE_AES_192: keysize = 24; fc = CPACF_PCKMO_ENC_AES_192_KEY; break; case PKEY_KEYTYPE_AES_256: keysize = 32; fc = CPACF_PCKMO_ENC_AES_256_KEY; break; default: DEBUG_ERR("pkey_clr2protkey unknown/unsupported keytype %d\n", keytype); return -EINVAL; } /* prepare param block */ memset(paramblock, 0, sizeof(paramblock)); memcpy(paramblock, clrkey->clrkey, keysize); /* call the pckmo instruction */ cpacf_pckmo(fc, paramblock); /* copy created protected key */ protkey->type = keytype; protkey->len = keysize + 32; memcpy(protkey->protkey, paramblock, keysize + 32); return 0; }