Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 188641
b: refs/heads/master
c: dd26d85
h: refs/heads/master
i:
  188639: 55addc2
v: v3
  • Loading branch information
Sage Weil committed Dec 7, 2009
1 parent 6d454e5 commit 476d0eb
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 13 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 2f2ffd35822688a3650e503197b8724f47312748
refs/heads/master: dd26d857a7bf1b5b734a23180c19eac3e46db944
14 changes: 13 additions & 1 deletion trunk/fs/ceph/buffer.c
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,25 @@ struct ceph_buffer *ceph_buffer_new(gfp_t gfp)
b = kmalloc(sizeof(*b), gfp);
if (!b)
return NULL;
atomic_set(&b->nref, 1);
kref_init(&b->kref);
b->vec.iov_base = NULL;
b->vec.iov_len = 0;
b->alloc_len = 0;
return b;
}

void ceph_buffer_release(struct kref *kref)
{
struct ceph_buffer *b = container_of(kref, struct ceph_buffer, kref);
if (b->vec.iov_base) {
if (b->is_vmalloc)
vfree(b->vec.iov_base);
else
kfree(b->vec.iov_base);
}
kfree(b);
}

int ceph_buffer_alloc(struct ceph_buffer *b, int len, gfp_t gfp)
{
b->vec.iov_base = kmalloc(len, gfp | __GFP_NOWARN);
Expand Down
18 changes: 7 additions & 11 deletions trunk/fs/ceph/buffer.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#ifndef __FS_CEPH_BUFFER_H
#define __FS_CEPH_BUFFER_H

#include <linux/kref.h>
#include <linux/mm.h>
#include <linux/vmalloc.h>
#include <linux/types.h>
Expand All @@ -13,7 +14,7 @@
* sizes.
*/
struct ceph_buffer {
atomic_t nref;
struct kref kref;
struct kvec vec;
size_t alloc_len;
bool is_vmalloc;
Expand All @@ -24,21 +25,16 @@ int ceph_buffer_alloc(struct ceph_buffer *b, int len, gfp_t gfp);

static inline struct ceph_buffer *ceph_buffer_get(struct ceph_buffer *b)
{
atomic_inc(&b->nref);
kref_get(&b->kref);
return b;
}

void ceph_buffer_release(struct kref *kref);

static inline void ceph_buffer_put(struct ceph_buffer *b)
{
if (b && atomic_dec_and_test(&b->nref)) {
if (b->vec.iov_base) {
if (b->is_vmalloc)
vfree(b->vec.iov_base);
else
kfree(b->vec.iov_base);
}
kfree(b);
}
if (b)
kref_put(&b->kref, ceph_buffer_release);
}

static inline struct ceph_buffer *ceph_buffer_new_alloc(int len, gfp_t gfp)
Expand Down

0 comments on commit 476d0eb

Please sign in to comment.