Commit cd84db6e authored by Yehuda Sadeh's avatar Yehuda Sadeh Committed by Sage Weil

ceph: code cleanup

Mainly fixing minor issues reported by sparse.
Signed-off-by: default avatarYehuda Sadeh <yehuda@hq.newdream.net>
Signed-off-by: default avatarSage Weil <sage@newdream.net>
parent ca81f3f6
#include <linux/errno.h> #include <linux/errno.h>
int ceph_armor(char *dst, const char *src, const char *end);
int ceph_unarmor(char *dst, const char *src, const char *end);
/* /*
* base64 encode/decode. * base64 encode/decode.
*/ */
const char *pem_key = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; static const char *pem_key =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
static int encode_bits(int c) static int encode_bits(int c)
{ {
......
...@@ -20,7 +20,7 @@ static u32 supported_protocols[] = { ...@@ -20,7 +20,7 @@ static u32 supported_protocols[] = {
CEPH_AUTH_CEPHX CEPH_AUTH_CEPHX
}; };
int ceph_auth_init_protocol(struct ceph_auth_client *ac, int protocol) static int ceph_auth_init_protocol(struct ceph_auth_client *ac, int protocol)
{ {
switch (protocol) { switch (protocol) {
case CEPH_AUTH_NONE: case CEPH_AUTH_NONE:
...@@ -133,8 +133,8 @@ int ceph_auth_build_hello(struct ceph_auth_client *ac, void *buf, size_t len) ...@@ -133,8 +133,8 @@ int ceph_auth_build_hello(struct ceph_auth_client *ac, void *buf, size_t len)
return -ERANGE; return -ERANGE;
} }
int ceph_build_auth_request(struct ceph_auth_client *ac, static int ceph_build_auth_request(struct ceph_auth_client *ac,
void *msg_buf, size_t msg_len) void *msg_buf, size_t msg_len)
{ {
struct ceph_mon_request_header *monhdr = msg_buf; struct ceph_mon_request_header *monhdr = msg_buf;
void *p = monhdr + 1; void *p = monhdr + 1;
......
...@@ -87,8 +87,8 @@ static int ceph_x_decrypt(struct ceph_crypto_key *secret, ...@@ -87,8 +87,8 @@ static int ceph_x_decrypt(struct ceph_crypto_key *secret,
/* /*
* get existing (or insert new) ticket handler * get existing (or insert new) ticket handler
*/ */
struct ceph_x_ticket_handler *get_ticket_handler(struct ceph_auth_client *ac, static struct ceph_x_ticket_handler *
int service) get_ticket_handler(struct ceph_auth_client *ac, int service)
{ {
struct ceph_x_ticket_handler *th; struct ceph_x_ticket_handler *th;
struct ceph_x_info *xi = ac->private; struct ceph_x_info *xi = ac->private;
...@@ -429,7 +429,7 @@ static int ceph_x_build_request(struct ceph_auth_client *ac, ...@@ -429,7 +429,7 @@ static int ceph_x_build_request(struct ceph_auth_client *ac,
auth->struct_v = 1; auth->struct_v = 1;
auth->key = 0; auth->key = 0;
for (u = (u64 *)tmp_enc; u + 1 <= (u64 *)(tmp_enc + ret); u++) for (u = (u64 *)tmp_enc; u + 1 <= (u64 *)(tmp_enc + ret); u++)
auth->key ^= *u; auth->key ^= *(__le64 *)u;
dout(" server_challenge %llx client_challenge %llx key %llx\n", dout(" server_challenge %llx client_challenge %llx key %llx\n",
xi->server_challenge, le64_to_cpu(auth->client_challenge), xi->server_challenge, le64_to_cpu(auth->client_challenge),
le64_to_cpu(auth->key)); le64_to_cpu(auth->key));
......
...@@ -47,22 +47,6 @@ void ceph_buffer_release(struct kref *kref) ...@@ -47,22 +47,6 @@ void ceph_buffer_release(struct kref *kref)
kfree(b); kfree(b);
} }
int ceph_buffer_alloc(struct ceph_buffer *b, int len, gfp_t gfp)
{
b->vec.iov_base = kmalloc(len, gfp | __GFP_NOWARN);
if (b->vec.iov_base) {
b->is_vmalloc = false;
} else {
b->vec.iov_base = __vmalloc(len, gfp, PAGE_KERNEL);
b->is_vmalloc = true;
}
if (!b->vec.iov_base)
return -ENOMEM;
b->alloc_len = len;
b->vec.iov_len = len;
return 0;
}
int ceph_decode_buffer(struct ceph_buffer **b, void **p, void *end) int ceph_decode_buffer(struct ceph_buffer **b, void **p, void *end)
{ {
size_t len; size_t len;
......
...@@ -1194,6 +1194,8 @@ static int __send_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap, ...@@ -1194,6 +1194,8 @@ static int __send_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap,
*/ */
void __ceph_flush_snaps(struct ceph_inode_info *ci, void __ceph_flush_snaps(struct ceph_inode_info *ci,
struct ceph_mds_session **psession) struct ceph_mds_session **psession)
__releases(ci->vfs_inode->i_lock)
__acquires(ci->vfs_inode->i_lock)
{ {
struct inode *inode = &ci->vfs_inode; struct inode *inode = &ci->vfs_inode;
int mds; int mds;
...@@ -1439,7 +1441,6 @@ static int try_nonblocking_invalidate(struct inode *inode) ...@@ -1439,7 +1441,6 @@ static int try_nonblocking_invalidate(struct inode *inode)
*/ */
void ceph_check_caps(struct ceph_inode_info *ci, int flags, void ceph_check_caps(struct ceph_inode_info *ci, int flags,
struct ceph_mds_session *session) struct ceph_mds_session *session)
__releases(session->s_mutex)
{ {
struct ceph_client *client = ceph_inode_to_client(&ci->vfs_inode); struct ceph_client *client = ceph_inode_to_client(&ci->vfs_inode);
struct ceph_mds_client *mdsc = &client->mdsc; struct ceph_mds_client *mdsc = &client->mdsc;
...@@ -2256,8 +2257,7 @@ static void handle_cap_grant(struct inode *inode, struct ceph_mds_caps *grant, ...@@ -2256,8 +2257,7 @@ static void handle_cap_grant(struct inode *inode, struct ceph_mds_caps *grant,
struct ceph_mds_session *session, struct ceph_mds_session *session,
struct ceph_cap *cap, struct ceph_cap *cap,
struct ceph_buffer *xattr_buf) struct ceph_buffer *xattr_buf)
__releases(inode->i_lock) __releases(inode->i_lock)
__releases(session->s_mutex)
{ {
struct ceph_inode_info *ci = ceph_inode(inode); struct ceph_inode_info *ci = ceph_inode(inode);
int mds = session->s_mds; int mds = session->s_mds;
......
...@@ -75,10 +75,11 @@ static struct crypto_blkcipher *ceph_crypto_alloc_cipher(void) ...@@ -75,10 +75,11 @@ static struct crypto_blkcipher *ceph_crypto_alloc_cipher(void)
return crypto_alloc_blkcipher("cbc(aes)", 0, CRYPTO_ALG_ASYNC); return crypto_alloc_blkcipher("cbc(aes)", 0, CRYPTO_ALG_ASYNC);
} }
const u8 *aes_iv = "cephsageyudagreg"; static const u8 *aes_iv = "cephsageyudagreg";
int ceph_aes_encrypt(const void *key, int key_len, void *dst, size_t *dst_len, static int ceph_aes_encrypt(const void *key, int key_len,
const void *src, size_t src_len) void *dst, size_t *dst_len,
const void *src, size_t src_len)
{ {
struct scatterlist sg_in[2], sg_out[1]; struct scatterlist sg_in[2], sg_out[1];
struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher(); struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher();
...@@ -126,9 +127,10 @@ int ceph_aes_encrypt(const void *key, int key_len, void *dst, size_t *dst_len, ...@@ -126,9 +127,10 @@ int ceph_aes_encrypt(const void *key, int key_len, void *dst, size_t *dst_len,
return 0; return 0;
} }
int ceph_aes_encrypt2(const void *key, int key_len, void *dst, size_t *dst_len, static int ceph_aes_encrypt2(const void *key, int key_len, void *dst,
const void *src1, size_t src1_len, size_t *dst_len,
const void *src2, size_t src2_len) const void *src1, size_t src1_len,
const void *src2, size_t src2_len)
{ {
struct scatterlist sg_in[3], sg_out[1]; struct scatterlist sg_in[3], sg_out[1];
struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher(); struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher();
...@@ -179,8 +181,9 @@ int ceph_aes_encrypt2(const void *key, int key_len, void *dst, size_t *dst_len, ...@@ -179,8 +181,9 @@ int ceph_aes_encrypt2(const void *key, int key_len, void *dst, size_t *dst_len,
return 0; return 0;
} }
int ceph_aes_decrypt(const void *key, int key_len, void *dst, size_t *dst_len, static int ceph_aes_decrypt(const void *key, int key_len,
const void *src, size_t src_len) void *dst, size_t *dst_len,
const void *src, size_t src_len)
{ {
struct scatterlist sg_in[1], sg_out[2]; struct scatterlist sg_in[1], sg_out[2];
struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher(); struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher();
...@@ -238,10 +241,10 @@ int ceph_aes_decrypt(const void *key, int key_len, void *dst, size_t *dst_len, ...@@ -238,10 +241,10 @@ int ceph_aes_decrypt(const void *key, int key_len, void *dst, size_t *dst_len,
return 0; return 0;
} }
int ceph_aes_decrypt2(const void *key, int key_len, static int ceph_aes_decrypt2(const void *key, int key_len,
void *dst1, size_t *dst1_len, void *dst1, size_t *dst1_len,
void *dst2, size_t *dst2_len, void *dst2, size_t *dst2_len,
const void *src, size_t src_len) const void *src, size_t src_len)
{ {
struct scatterlist sg_in[1], sg_out[3]; struct scatterlist sg_in[1], sg_out[3];
struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher(); struct crypto_blkcipher *tfm = ceph_crypto_alloc_cipher();
......
...@@ -42,7 +42,7 @@ extern int ceph_encrypt2(struct ceph_crypto_key *secret, ...@@ -42,7 +42,7 @@ extern int ceph_encrypt2(struct ceph_crypto_key *secret,
const void *src2, size_t src2_len); const void *src2, size_t src2_len);
/* armor.c */ /* armor.c */
extern int ceph_armor(char *dst, const void *src, const void *end); extern int ceph_armor(char *dst, const char *src, const char *end);
extern int ceph_unarmor(void *dst, const char *src, const char *end); extern int ceph_unarmor(char *dst, const char *src, const char *end);
#endif #endif
...@@ -99,11 +99,13 @@ static inline void ceph_encode_timespec(struct ceph_timespec *tv, ...@@ -99,11 +99,13 @@ static inline void ceph_encode_timespec(struct ceph_timespec *tv,
*/ */
static inline void ceph_encode_addr(struct ceph_entity_addr *a) static inline void ceph_encode_addr(struct ceph_entity_addr *a)
{ {
a->in_addr.ss_family = htons(a->in_addr.ss_family); __be16 ss_family = htons(a->in_addr.ss_family);
a->in_addr.ss_family = *(__u16 *)&ss_family;
} }
static inline void ceph_decode_addr(struct ceph_entity_addr *a) static inline void ceph_decode_addr(struct ceph_entity_addr *a)
{ {
a->in_addr.ss_family = ntohs(a->in_addr.ss_family); __be16 ss_family = *(__be16 *)&a->in_addr.ss_family;
a->in_addr.ss_family = ntohs(ss_family);
WARN_ON(a->in_addr.ss_family == 512); WARN_ON(a->in_addr.ss_family == 512);
} }
......
...@@ -94,6 +94,8 @@ static unsigned fpos_off(loff_t p) ...@@ -94,6 +94,8 @@ static unsigned fpos_off(loff_t p)
*/ */
static int __dcache_readdir(struct file *filp, static int __dcache_readdir(struct file *filp,
void *dirent, filldir_t filldir) void *dirent, filldir_t filldir)
__releases(inode->i_lock)
__acquires(inode->i_lock)
{ {
struct inode *inode = filp->f_dentry->d_inode; struct inode *inode = filp->f_dentry->d_inode;
struct ceph_file_info *fi = filp->private_data; struct ceph_file_info *fi = filp->private_data;
......
...@@ -317,7 +317,7 @@ void ceph_release_page_vector(struct page **pages, int num_pages) ...@@ -317,7 +317,7 @@ void ceph_release_page_vector(struct page **pages, int num_pages)
/* /*
* allocate a vector new pages * allocate a vector new pages
*/ */
struct page **ceph_alloc_page_vector(int num_pages, gfp_t flags) static struct page **ceph_alloc_page_vector(int num_pages, gfp_t flags)
{ {
struct page **pages; struct page **pages;
int i; int i;
...@@ -745,7 +745,7 @@ static ssize_t ceph_aio_read(struct kiocb *iocb, const struct iovec *iov, ...@@ -745,7 +745,7 @@ static ssize_t ceph_aio_read(struct kiocb *iocb, const struct iovec *iov,
size_t len = iov->iov_len; size_t len = iov->iov_len;
struct inode *inode = filp->f_dentry->d_inode; struct inode *inode = filp->f_dentry->d_inode;
struct ceph_inode_info *ci = ceph_inode(inode); struct ceph_inode_info *ci = ceph_inode(inode);
void *base = iov->iov_base; void __user *base = iov->iov_base;
ssize_t ret; ssize_t ret;
int want, got = 0; int want, got = 0;
int checkeof = 0, read = 0; int checkeof = 0, read = 0;
......
...@@ -108,7 +108,7 @@ void ceph_msgr_exit(void) ...@@ -108,7 +108,7 @@ void ceph_msgr_exit(void)
destroy_workqueue(ceph_msgr_wq); destroy_workqueue(ceph_msgr_wq);
} }
void ceph_msgr_flush() void ceph_msgr_flush(void)
{ {
flush_workqueue(ceph_msgr_wq); flush_workqueue(ceph_msgr_wq);
} }
...@@ -1081,11 +1081,11 @@ static int process_banner(struct ceph_connection *con) ...@@ -1081,11 +1081,11 @@ static int process_banner(struct ceph_connection *con)
sizeof(con->peer_addr)) != 0 && sizeof(con->peer_addr)) != 0 &&
!(addr_is_blank(&con->actual_peer_addr.in_addr) && !(addr_is_blank(&con->actual_peer_addr.in_addr) &&
con->actual_peer_addr.nonce == con->peer_addr.nonce)) { con->actual_peer_addr.nonce == con->peer_addr.nonce)) {
pr_warning("wrong peer, want %s/%lld, got %s/%lld\n", pr_warning("wrong peer, want %s/%d, got %s/%d\n",
pr_addr(&con->peer_addr.in_addr), pr_addr(&con->peer_addr.in_addr),
le64_to_cpu(con->peer_addr.nonce), (int)le32_to_cpu(con->peer_addr.nonce),
pr_addr(&con->actual_peer_addr.in_addr), pr_addr(&con->actual_peer_addr.in_addr),
le64_to_cpu(con->actual_peer_addr.nonce)); (int)le32_to_cpu(con->actual_peer_addr.nonce));
con->error_msg = "wrong peer at address"; con->error_msg = "wrong peer at address";
return -1; return -1;
} }
......
...@@ -424,7 +424,7 @@ static void __remove_pg_pool(struct rb_root *root, struct ceph_pg_pool_info *pi) ...@@ -424,7 +424,7 @@ static void __remove_pg_pool(struct rb_root *root, struct ceph_pg_pool_info *pi)
kfree(pi); kfree(pi);
} }
void __decode_pool(void **p, struct ceph_pg_pool_info *pi) static void __decode_pool(void **p, struct ceph_pg_pool_info *pi)
{ {
ceph_decode_copy(p, &pi->v, sizeof(pi->v)); ceph_decode_copy(p, &pi->v, sizeof(pi->v));
calc_pg_masks(pi); calc_pg_masks(pi);
......
...@@ -337,6 +337,8 @@ void __ceph_destroy_xattrs(struct ceph_inode_info *ci) ...@@ -337,6 +337,8 @@ void __ceph_destroy_xattrs(struct ceph_inode_info *ci)
} }
static int __build_xattrs(struct inode *inode) static int __build_xattrs(struct inode *inode)
__releases(inode->i_lock)
__acquires(inode->i_lock)
{ {
u32 namelen; u32 namelen;
u32 numattr = 0; u32 numattr = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment