mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 cbf99a11fb
			
		
	
	
		cbf99a11fb
		
	
	
	
	
		
			
			Commit ae385eaf24 ("libceph: store session key in cephx authorizer")
introduced ceph_x_authorizer::session_key, but didn't update all the
exit/error paths.  Introduce ceph_x_authorizer_cleanup() to encapsulate
ceph_x_authorizer cleanup and switch to it.  This fixes ceph_x_destroy(),
which currently always leaks key and ceph_x_build_authorizer() error
paths.
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Reviewed-by: Yan, Zheng <zyan@redhat.com>
		
	
			
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _FS_CEPH_CRYPTO_H
 | |
| #define _FS_CEPH_CRYPTO_H
 | |
| 
 | |
| #include <linux/ceph/types.h>
 | |
| #include <linux/ceph/buffer.h>
 | |
| 
 | |
| /*
 | |
|  * cryptographic secret
 | |
|  */
 | |
| struct ceph_crypto_key {
 | |
| 	int type;
 | |
| 	struct ceph_timespec created;
 | |
| 	int len;
 | |
| 	void *key;
 | |
| };
 | |
| 
 | |
| static inline void ceph_crypto_key_destroy(struct ceph_crypto_key *key)
 | |
| {
 | |
| 	if (key) {
 | |
| 		kfree(key->key);
 | |
| 		key->key = NULL;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| int ceph_crypto_key_clone(struct ceph_crypto_key *dst,
 | |
| 			  const struct ceph_crypto_key *src);
 | |
| int ceph_crypto_key_encode(struct ceph_crypto_key *key, void **p, void *end);
 | |
| int ceph_crypto_key_decode(struct ceph_crypto_key *key, void **p, void *end);
 | |
| int ceph_crypto_key_unarmor(struct ceph_crypto_key *key, const char *in);
 | |
| 
 | |
| /* crypto.c */
 | |
| int ceph_decrypt(struct ceph_crypto_key *secret,
 | |
| 		 void *dst, size_t *dst_len,
 | |
| 		 const void *src, size_t src_len);
 | |
| int ceph_encrypt(struct ceph_crypto_key *secret,
 | |
| 		 void *dst, size_t *dst_len,
 | |
| 		 const void *src, size_t src_len);
 | |
| int ceph_decrypt2(struct ceph_crypto_key *secret,
 | |
| 		  void *dst1, size_t *dst1_len,
 | |
| 		  void *dst2, size_t *dst2_len,
 | |
| 		  const void *src, size_t src_len);
 | |
| int ceph_encrypt2(struct ceph_crypto_key *secret,
 | |
| 		  void *dst, size_t *dst_len,
 | |
| 		  const void *src1, size_t src1_len,
 | |
| 		  const void *src2, size_t src2_len);
 | |
| int ceph_crypto_init(void);
 | |
| void ceph_crypto_shutdown(void);
 | |
| 
 | |
| /* armor.c */
 | |
| int ceph_armor(char *dst, const char *src, const char *end);
 | |
| int ceph_unarmor(char *dst, const char *src, const char *end);
 | |
| 
 | |
| #endif
 |