mirror of
https://github.com/Qortal/Brooklyn.git
synced 2025-02-15 03:35:55 +00:00
* 0day explit mitigation * Memory corruption prevention * Privilege escalation prevention * Buffer over flow prevention * File System corruption defense * Thread escape prevention This may very well be the most intensive inclusion to BrooklynR. This will not be part of an x86 suite nor it will be released as tool kit. The security core toolkit will remain part of kernel base.
50 lines
1.4 KiB
C
50 lines
1.4 KiB
C
#ifndef _LINUX_CEPH_CLS_LOCK_CLIENT_H
|
|
#define _LINUX_CEPH_CLS_LOCK_CLIENT_H
|
|
|
|
#include <linux/ceph/osd_client.h>
|
|
|
|
enum ceph_cls_lock_type {
|
|
CEPH_CLS_LOCK_NONE = 0,
|
|
CEPH_CLS_LOCK_EXCLUSIVE = 1,
|
|
CEPH_CLS_LOCK_SHARED = 2,
|
|
};
|
|
|
|
struct ceph_locker_id {
|
|
struct ceph_entity_name name; /* locker's client name */
|
|
char *cookie; /* locker's cookie */
|
|
};
|
|
|
|
struct ceph_locker_info {
|
|
struct ceph_entity_addr addr; /* locker's address */
|
|
};
|
|
|
|
struct ceph_locker {
|
|
struct ceph_locker_id id;
|
|
struct ceph_locker_info info;
|
|
};
|
|
|
|
int ceph_cls_lock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, u8 type, char *cookie,
|
|
char *tag, char *desc, u8 flags);
|
|
int ceph_cls_unlock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, char *cookie);
|
|
int ceph_cls_break_lock(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, char *cookie,
|
|
struct ceph_entity_name *locker);
|
|
|
|
void ceph_free_lockers(struct ceph_locker *lockers, u32 num_lockers);
|
|
|
|
int ceph_cls_lock_info(struct ceph_osd_client *osdc,
|
|
struct ceph_object_id *oid,
|
|
struct ceph_object_locator *oloc,
|
|
char *lock_name, u8 *type, char **tag,
|
|
struct ceph_locker **lockers, u32 *num_lockers);
|
|
|
|
#endif
|