KEYCTL_PKEY_ENCRYPT - Online Linux Manual PageSection : 3
Updated : 8 Nov 2018
Source : Linux
Note : Linux Public-Key Encryption
NAMEkeyctl_pkey_encrypt, keyctl_pkey_decrypt − Encrypt and decrypt data
SYNOPSIS#include <keyutils.h>
long keyctl_pkey_encrypt(key_serial_t key, const char *info,
const void *data, size_t data_len,
void *enc, size_t enc_len);
long keyctl_pkey_decrypt(key_serial_t key, const char *info,
const void *enc, size_t enc_len,
void *data, size_t data_len);
DESCRIPTION
keyctl_pkey_encrypt() asks the kernel to use the crypto material attached to a key to encrypt a blob of data and keyctl_pkey_decrypt() asks the kernel to use the key to reverse the operation and recover the original data. Note that these operations may involve the kernel calling out to cryptographic hardware. The caller must have search permission on a key to be able to use them in this manner. When invoking the function, key indicates the key that will provide the cryptographic material and info points to a comma-separated string of "key[=value]" parameters that indicate things like encoding forms and passwords to unlock the key; see asymmetric-key(7) for more information. data and datalen indicate the address and size of the decrypted data buffer and enc and enclen indicate the address and size of the encrypted data buffer. The encrypt function draws data from the decrypted data buffer and places the output into the encryption buffer. The decrypt function does the reverse, drawing from the encryption buffer and writing into the data buffer. keyctl_pkey_query(2) can be called to find out how large the buffers need to be. Note that not all asymmetric-type keys will support these operations; further, the operations available may depend on which components of the key material are available: typically encryption only requires the public key, but decryption requires the private key as well. Which operations are supported on a particular key can also be determined using the query function.
RETURN VALUEOn success keyctl_pkey_encrypt()and"keyctl_pkey_decrypt() return the amount of data written into the output buffer. On error, the value -1 will be returned and errno will have been set to an appropriate error.
ERRORSENOKEY The key specified is invalid. EKEYEXPIRED The key specified has expired. EKEYREVOKED The key specified has been revoked. EACCES The key exists, but is not searchable by the calling process. ENOPKG Some facility needed to complete the requested operation is not available. This is most probably a requested or required digest or encryption algorithm. EFAULT Bad address.
LINKINGThis is a library function that can be found in libkeyutils. When linking, −lkeyutils should be specified to the linker.
SEE ALSOkeyctl(1), add_key(2), keyctl(2), keyctl(3), keyctl_pkey_query(3), keyctl_pkey_sign(3), keyrings(7), keyutils(7) 0
Johanes Gumabo
Data Size : 9,721 byte
man-keyctl_pkey_decrypt.3Build : 2024-12-29, 07:25 :
Visitor Screen : x
Visitor Counter ( page / site ) : 5 / 255,882
Visitor ID : :
Visitor IP : 18.225.55.42 :
Visitor Provider : AMAZON-02 :
Provider Position ( lat x lon ) : 39.962500 x -83.006100 : x
Provider Accuracy Radius ( km ) : 1000 :
Provider City : Columbus :
Provider Province : Ohio , : ,
Provider Country : United States :
Provider Continent : North America :
Visitor Recorder : Version :
Visitor Recorder : Library :
Online Linux Manual Page : Version : Online Linux Manual Page - Fedora.40 - march=x86-64 - mtune=generic - 24.12.29
Online Linux Manual Page : Library : lib_c - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Online Linux Manual Page : Library : lib_m - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Data Base : Version : Online Linux Manual Page Database - 24.04.13 - march=x86-64 - mtune=generic - fedora-38
Data Base : Library : lib_c - 23.02.07 - march=x86-64 - mtune=generic - fedora.36
Very long time ago, I have the best tutor, Wenzel Svojanovsky . If someone knows the email address of Wenzel Svojanovsky , please send an email to johanes_gumabo@yahoo.co.id .
If error, please print screen and send to johanes_gumabo@yahoo.co.id
Under development. Support me via PayPal.