mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-19 06:47:48 +00:00
0e1a5ee657
refcount_t type and corresponding API should be used instead of atomic_t when the variable is used as a reference counter. This allows to avoid accidental refcounter overflows that might lead to use-after-free situations. Signed-off-by: Elena Reshetova <elena.reshetova@intel.com> Signed-off-by: Hans Liljestrand <ishkamiel@gmail.com> Signed-off-by: Kees Cook <keescook@chromium.org> Signed-off-by: David Windsor <dwindsor@gmail.com> Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
81 lines
2.1 KiB
C
81 lines
2.1 KiB
C
#ifndef __FS_CEPH_PAGELIST_H
|
|
#define __FS_CEPH_PAGELIST_H
|
|
|
|
#include <asm/byteorder.h>
|
|
#include <linux/refcount.h>
|
|
#include <linux/list.h>
|
|
#include <linux/types.h>
|
|
|
|
struct ceph_pagelist {
|
|
struct list_head head;
|
|
void *mapped_tail;
|
|
size_t length;
|
|
size_t room;
|
|
struct list_head free_list;
|
|
size_t num_pages_free;
|
|
refcount_t refcnt;
|
|
};
|
|
|
|
struct ceph_pagelist_cursor {
|
|
struct ceph_pagelist *pl; /* pagelist, for error checking */
|
|
struct list_head *page_lru; /* page in list */
|
|
size_t room; /* room remaining to reset to */
|
|
};
|
|
|
|
static inline void ceph_pagelist_init(struct ceph_pagelist *pl)
|
|
{
|
|
INIT_LIST_HEAD(&pl->head);
|
|
pl->mapped_tail = NULL;
|
|
pl->length = 0;
|
|
pl->room = 0;
|
|
INIT_LIST_HEAD(&pl->free_list);
|
|
pl->num_pages_free = 0;
|
|
refcount_set(&pl->refcnt, 1);
|
|
}
|
|
|
|
extern void ceph_pagelist_release(struct ceph_pagelist *pl);
|
|
|
|
extern int ceph_pagelist_append(struct ceph_pagelist *pl, const void *d, size_t l);
|
|
|
|
extern int ceph_pagelist_reserve(struct ceph_pagelist *pl, size_t space);
|
|
|
|
extern int ceph_pagelist_free_reserve(struct ceph_pagelist *pl);
|
|
|
|
extern void ceph_pagelist_set_cursor(struct ceph_pagelist *pl,
|
|
struct ceph_pagelist_cursor *c);
|
|
|
|
extern int ceph_pagelist_truncate(struct ceph_pagelist *pl,
|
|
struct ceph_pagelist_cursor *c);
|
|
|
|
static inline int ceph_pagelist_encode_64(struct ceph_pagelist *pl, u64 v)
|
|
{
|
|
__le64 ev = cpu_to_le64(v);
|
|
return ceph_pagelist_append(pl, &ev, sizeof(ev));
|
|
}
|
|
static inline int ceph_pagelist_encode_32(struct ceph_pagelist *pl, u32 v)
|
|
{
|
|
__le32 ev = cpu_to_le32(v);
|
|
return ceph_pagelist_append(pl, &ev, sizeof(ev));
|
|
}
|
|
static inline int ceph_pagelist_encode_16(struct ceph_pagelist *pl, u16 v)
|
|
{
|
|
__le16 ev = cpu_to_le16(v);
|
|
return ceph_pagelist_append(pl, &ev, sizeof(ev));
|
|
}
|
|
static inline int ceph_pagelist_encode_8(struct ceph_pagelist *pl, u8 v)
|
|
{
|
|
return ceph_pagelist_append(pl, &v, 1);
|
|
}
|
|
static inline int ceph_pagelist_encode_string(struct ceph_pagelist *pl,
|
|
char *s, size_t len)
|
|
{
|
|
int ret = ceph_pagelist_encode_32(pl, len);
|
|
if (ret)
|
|
return ret;
|
|
if (len)
|
|
return ceph_pagelist_append(pl, s, len);
|
|
return 0;
|
|
}
|
|
|
|
#endif
|