101 lines
2.4 KiB
C
101 lines
2.4 KiB
C
|
// SPDX-License-Identifier: GPL-2.0
|
||
|
/*
|
||
|
* Some non-inline ceph helpers
|
||
|
*/
|
||
|
#include <linux/module.h>
|
||
|
#include <linux/ceph/types.h>
|
||
|
|
||
|
/*
|
||
|
* return true if @layout appears to be valid
|
||
|
*/
|
||
|
int ceph_file_layout_is_valid(const struct ceph_file_layout *layout)
|
||
|
{
|
||
|
__u32 su = layout->stripe_unit;
|
||
|
__u32 sc = layout->stripe_count;
|
||
|
__u32 os = layout->object_size;
|
||
|
|
||
|
/* stripe unit, object size must be non-zero, 64k increment */
|
||
|
if (!su || (su & (CEPH_MIN_STRIPE_UNIT-1)))
|
||
|
return 0;
|
||
|
if (!os || (os & (CEPH_MIN_STRIPE_UNIT-1)))
|
||
|
return 0;
|
||
|
/* object size must be a multiple of stripe unit */
|
||
|
if (os < su || os % su)
|
||
|
return 0;
|
||
|
/* stripe count must be non-zero */
|
||
|
if (!sc)
|
||
|
return 0;
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
void ceph_file_layout_from_legacy(struct ceph_file_layout *fl,
|
||
|
struct ceph_file_layout_legacy *legacy)
|
||
|
{
|
||
|
fl->stripe_unit = le32_to_cpu(legacy->fl_stripe_unit);
|
||
|
fl->stripe_count = le32_to_cpu(legacy->fl_stripe_count);
|
||
|
fl->object_size = le32_to_cpu(legacy->fl_object_size);
|
||
|
fl->pool_id = le32_to_cpu(legacy->fl_pg_pool);
|
||
|
if (fl->pool_id == 0 && fl->stripe_unit == 0 &&
|
||
|
fl->stripe_count == 0 && fl->object_size == 0)
|
||
|
fl->pool_id = -1;
|
||
|
}
|
||
|
|
||
|
void ceph_file_layout_to_legacy(struct ceph_file_layout *fl,
|
||
|
struct ceph_file_layout_legacy *legacy)
|
||
|
{
|
||
|
legacy->fl_stripe_unit = cpu_to_le32(fl->stripe_unit);
|
||
|
legacy->fl_stripe_count = cpu_to_le32(fl->stripe_count);
|
||
|
legacy->fl_object_size = cpu_to_le32(fl->object_size);
|
||
|
if (fl->pool_id >= 0)
|
||
|
legacy->fl_pg_pool = cpu_to_le32(fl->pool_id);
|
||
|
else
|
||
|
legacy->fl_pg_pool = 0;
|
||
|
}
|
||
|
|
||
|
int ceph_flags_to_mode(int flags)
|
||
|
{
|
||
|
int mode;
|
||
|
|
||
|
#ifdef O_DIRECTORY /* fixme */
|
||
|
if ((flags & O_DIRECTORY) == O_DIRECTORY)
|
||
|
return CEPH_FILE_MODE_PIN;
|
||
|
#endif
|
||
|
|
||
|
switch (flags & O_ACCMODE) {
|
||
|
case O_WRONLY:
|
||
|
mode = CEPH_FILE_MODE_WR;
|
||
|
break;
|
||
|
case O_RDONLY:
|
||
|
mode = CEPH_FILE_MODE_RD;
|
||
|
break;
|
||
|
case O_RDWR:
|
||
|
case O_ACCMODE: /* this is what the VFS does */
|
||
|
mode = CEPH_FILE_MODE_RDWR;
|
||
|
break;
|
||
|
}
|
||
|
#ifdef O_LAZY
|
||
|
if (flags & O_LAZY)
|
||
|
mode |= CEPH_FILE_MODE_LAZY;
|
||
|
#endif
|
||
|
|
||
|
return mode;
|
||
|
}
|
||
|
|
||
|
int ceph_caps_for_mode(int mode)
|
||
|
{
|
||
|
int caps = CEPH_CAP_PIN;
|
||
|
|
||
|
if (mode & CEPH_FILE_MODE_RD)
|
||
|
caps |= CEPH_CAP_FILE_SHARED |
|
||
|
CEPH_CAP_FILE_RD | CEPH_CAP_FILE_CACHE;
|
||
|
if (mode & CEPH_FILE_MODE_WR)
|
||
|
caps |= CEPH_CAP_FILE_EXCL |
|
||
|
CEPH_CAP_FILE_WR | CEPH_CAP_FILE_BUFFER |
|
||
|
CEPH_CAP_AUTH_SHARED | CEPH_CAP_AUTH_EXCL |
|
||
|
CEPH_CAP_XATTR_SHARED | CEPH_CAP_XATTR_EXCL;
|
||
|
if (mode & CEPH_FILE_MODE_LAZY)
|
||
|
caps |= CEPH_CAP_FILE_LAZYIO;
|
||
|
|
||
|
return caps;
|
||
|
}
|