1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Asynchronous Compression operations 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (c) 2016, Intel Corporation 6*4882a593Smuzhiyun * Authors: Weigang Li <weigang.li@intel.com> 7*4882a593Smuzhiyun * Giovanni Cabiddu <giovanni.cabiddu@intel.com> 8*4882a593Smuzhiyun */ 9*4882a593Smuzhiyun #ifndef _CRYPTO_ACOMP_INT_H 10*4882a593Smuzhiyun #define _CRYPTO_ACOMP_INT_H 11*4882a593Smuzhiyun #include <crypto/acompress.h> 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /* 14*4882a593Smuzhiyun * Transform internal helpers. 15*4882a593Smuzhiyun */ acomp_request_ctx(struct acomp_req * req)16*4882a593Smuzhiyunstatic inline void *acomp_request_ctx(struct acomp_req *req) 17*4882a593Smuzhiyun { 18*4882a593Smuzhiyun return req->__ctx; 19*4882a593Smuzhiyun } 20*4882a593Smuzhiyun acomp_tfm_ctx(struct crypto_acomp * tfm)21*4882a593Smuzhiyunstatic inline void *acomp_tfm_ctx(struct crypto_acomp *tfm) 22*4882a593Smuzhiyun { 23*4882a593Smuzhiyun return tfm->base.__crt_ctx; 24*4882a593Smuzhiyun } 25*4882a593Smuzhiyun acomp_request_complete(struct acomp_req * req,int err)26*4882a593Smuzhiyunstatic inline void acomp_request_complete(struct acomp_req *req, 27*4882a593Smuzhiyun int err) 28*4882a593Smuzhiyun { 29*4882a593Smuzhiyun req->base.complete(&req->base, err); 30*4882a593Smuzhiyun } 31*4882a593Smuzhiyun acomp_alg_name(struct crypto_acomp * tfm)32*4882a593Smuzhiyunstatic inline const char *acomp_alg_name(struct crypto_acomp *tfm) 33*4882a593Smuzhiyun { 34*4882a593Smuzhiyun return crypto_acomp_tfm(tfm)->__crt_alg->cra_name; 35*4882a593Smuzhiyun } 36*4882a593Smuzhiyun __acomp_request_alloc(struct crypto_acomp * tfm)37*4882a593Smuzhiyunstatic inline struct acomp_req *__acomp_request_alloc(struct crypto_acomp *tfm) 38*4882a593Smuzhiyun { 39*4882a593Smuzhiyun struct acomp_req *req; 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun req = kzalloc(sizeof(*req) + crypto_acomp_reqsize(tfm), GFP_KERNEL); 42*4882a593Smuzhiyun if (likely(req)) 43*4882a593Smuzhiyun acomp_request_set_tfm(req, tfm); 44*4882a593Smuzhiyun return req; 45*4882a593Smuzhiyun } 46*4882a593Smuzhiyun __acomp_request_free(struct acomp_req * req)47*4882a593Smuzhiyunstatic inline void __acomp_request_free(struct acomp_req *req) 48*4882a593Smuzhiyun { 49*4882a593Smuzhiyun kfree_sensitive(req); 50*4882a593Smuzhiyun } 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun /** 53*4882a593Smuzhiyun * crypto_register_acomp() -- Register asynchronous compression algorithm 54*4882a593Smuzhiyun * 55*4882a593Smuzhiyun * Function registers an implementation of an asynchronous 56*4882a593Smuzhiyun * compression algorithm 57*4882a593Smuzhiyun * 58*4882a593Smuzhiyun * @alg: algorithm definition 59*4882a593Smuzhiyun * 60*4882a593Smuzhiyun * Return: zero on success; error code in case of error 61*4882a593Smuzhiyun */ 62*4882a593Smuzhiyun int crypto_register_acomp(struct acomp_alg *alg); 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun /** 65*4882a593Smuzhiyun * crypto_unregister_acomp() -- Unregister asynchronous compression algorithm 66*4882a593Smuzhiyun * 67*4882a593Smuzhiyun * Function unregisters an implementation of an asynchronous 68*4882a593Smuzhiyun * compression algorithm 69*4882a593Smuzhiyun * 70*4882a593Smuzhiyun * @alg: algorithm definition 71*4882a593Smuzhiyun */ 72*4882a593Smuzhiyun void crypto_unregister_acomp(struct acomp_alg *alg); 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun int crypto_register_acomps(struct acomp_alg *algs, int count); 75*4882a593Smuzhiyun void crypto_unregister_acomps(struct acomp_alg *algs, int count); 76*4882a593Smuzhiyun 77*4882a593Smuzhiyun #endif 78