162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Some non-inline ceph helpers 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci#include <linux/module.h> 662306a36Sopenharmony_ci#include <linux/ceph/types.h> 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci/* 962306a36Sopenharmony_ci * return true if @layout appears to be valid 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ciint ceph_file_layout_is_valid(const struct ceph_file_layout *layout) 1262306a36Sopenharmony_ci{ 1362306a36Sopenharmony_ci __u32 su = layout->stripe_unit; 1462306a36Sopenharmony_ci __u32 sc = layout->stripe_count; 1562306a36Sopenharmony_ci __u32 os = layout->object_size; 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci /* stripe unit, object size must be non-zero, 64k increment */ 1862306a36Sopenharmony_ci if (!su || (su & (CEPH_MIN_STRIPE_UNIT-1))) 1962306a36Sopenharmony_ci return 0; 2062306a36Sopenharmony_ci if (!os || (os & (CEPH_MIN_STRIPE_UNIT-1))) 2162306a36Sopenharmony_ci return 0; 2262306a36Sopenharmony_ci /* object size must be a multiple of stripe unit */ 2362306a36Sopenharmony_ci if (os < su || os % su) 2462306a36Sopenharmony_ci return 0; 2562306a36Sopenharmony_ci /* stripe count must be non-zero */ 2662306a36Sopenharmony_ci if (!sc) 2762306a36Sopenharmony_ci return 0; 2862306a36Sopenharmony_ci return 1; 2962306a36Sopenharmony_ci} 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_civoid ceph_file_layout_from_legacy(struct ceph_file_layout *fl, 3262306a36Sopenharmony_ci struct ceph_file_layout_legacy *legacy) 3362306a36Sopenharmony_ci{ 3462306a36Sopenharmony_ci fl->stripe_unit = le32_to_cpu(legacy->fl_stripe_unit); 3562306a36Sopenharmony_ci fl->stripe_count = le32_to_cpu(legacy->fl_stripe_count); 3662306a36Sopenharmony_ci fl->object_size = le32_to_cpu(legacy->fl_object_size); 3762306a36Sopenharmony_ci fl->pool_id = le32_to_cpu(legacy->fl_pg_pool); 3862306a36Sopenharmony_ci if (fl->pool_id == 0 && fl->stripe_unit == 0 && 3962306a36Sopenharmony_ci fl->stripe_count == 0 && fl->object_size == 0) 4062306a36Sopenharmony_ci fl->pool_id = -1; 4162306a36Sopenharmony_ci} 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_civoid ceph_file_layout_to_legacy(struct ceph_file_layout *fl, 4462306a36Sopenharmony_ci struct ceph_file_layout_legacy *legacy) 4562306a36Sopenharmony_ci{ 4662306a36Sopenharmony_ci legacy->fl_stripe_unit = cpu_to_le32(fl->stripe_unit); 4762306a36Sopenharmony_ci legacy->fl_stripe_count = cpu_to_le32(fl->stripe_count); 4862306a36Sopenharmony_ci legacy->fl_object_size = cpu_to_le32(fl->object_size); 4962306a36Sopenharmony_ci if (fl->pool_id >= 0) 5062306a36Sopenharmony_ci legacy->fl_pg_pool = cpu_to_le32(fl->pool_id); 5162306a36Sopenharmony_ci else 5262306a36Sopenharmony_ci legacy->fl_pg_pool = 0; 5362306a36Sopenharmony_ci} 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ciint ceph_flags_to_mode(int flags) 5662306a36Sopenharmony_ci{ 5762306a36Sopenharmony_ci int mode; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci#ifdef O_DIRECTORY /* fixme */ 6062306a36Sopenharmony_ci if ((flags & O_DIRECTORY) == O_DIRECTORY) 6162306a36Sopenharmony_ci return CEPH_FILE_MODE_PIN; 6262306a36Sopenharmony_ci#endif 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci switch (flags & O_ACCMODE) { 6562306a36Sopenharmony_ci case O_WRONLY: 6662306a36Sopenharmony_ci mode = CEPH_FILE_MODE_WR; 6762306a36Sopenharmony_ci break; 6862306a36Sopenharmony_ci case O_RDONLY: 6962306a36Sopenharmony_ci mode = CEPH_FILE_MODE_RD; 7062306a36Sopenharmony_ci break; 7162306a36Sopenharmony_ci case O_RDWR: 7262306a36Sopenharmony_ci case O_ACCMODE: /* this is what the VFS does */ 7362306a36Sopenharmony_ci mode = CEPH_FILE_MODE_RDWR; 7462306a36Sopenharmony_ci break; 7562306a36Sopenharmony_ci } 7662306a36Sopenharmony_ci#ifdef O_LAZY 7762306a36Sopenharmony_ci if (flags & O_LAZY) 7862306a36Sopenharmony_ci mode |= CEPH_FILE_MODE_LAZY; 7962306a36Sopenharmony_ci#endif 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci return mode; 8262306a36Sopenharmony_ci} 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ciint ceph_caps_for_mode(int mode) 8562306a36Sopenharmony_ci{ 8662306a36Sopenharmony_ci int caps = CEPH_CAP_PIN; 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci if (mode & CEPH_FILE_MODE_RD) 8962306a36Sopenharmony_ci caps |= CEPH_CAP_FILE_SHARED | 9062306a36Sopenharmony_ci CEPH_CAP_FILE_RD | CEPH_CAP_FILE_CACHE; 9162306a36Sopenharmony_ci if (mode & CEPH_FILE_MODE_WR) 9262306a36Sopenharmony_ci caps |= CEPH_CAP_FILE_EXCL | 9362306a36Sopenharmony_ci CEPH_CAP_FILE_WR | CEPH_CAP_FILE_BUFFER | 9462306a36Sopenharmony_ci CEPH_CAP_AUTH_SHARED | CEPH_CAP_AUTH_EXCL | 9562306a36Sopenharmony_ci CEPH_CAP_XATTR_SHARED | CEPH_CAP_XATTR_EXCL; 9662306a36Sopenharmony_ci if (mode & CEPH_FILE_MODE_LAZY) 9762306a36Sopenharmony_ci caps |= CEPH_CAP_FILE_LAZYIO; 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci return caps; 10062306a36Sopenharmony_ci} 101