Whamcloud - gitweb
LU-8585 llapi: use open_by_handle_at in llapi_open_by_fid
[fs/lustre-release.git] / lustre / utils / lustreapi_internal.h
1 /*
2  * LGPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * (C) Copyright 2012 Commissariat a l'energie atomique et aux energies
7  *     alternatives
8  *
9  * Copyright (c) 2016, 2017, Intel Corporation.
10  *
11  * All rights reserved. This program and the accompanying materials
12  * are made available under the terms of the GNU Lesser General Public License
13  * (LGPL) version 2.1 or (at your discretion) any later version.
14  * (LGPL) version 2.1 accompanies this distribution, and is available at
15  * http://www.gnu.org/licenses/lgpl-2.1.html
16  *
17  *
18  * This library is distributed in the hope that it will be useful,
19  * but WITHOUT ANY WARRANTY; without even the implied warranty of
20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21  * Lesser General Public License for more details.
22  *
23  * LGPL HEADER END
24  */
25 /*
26  *
27  * lustre/utils/lustreapi_internal.h
28  *
29  * Author: Aurelien Degremont <aurelien.degremont@cea.fr>
30  * Author: JC Lafoucriere <jacques-charles.lafoucriere@cea.fr>
31  * Author: Thomas Leibovici <thomas.leibovici@cea.fr>
32  */
33
34 #ifndef _LUSTREAPI_INTERNAL_H_
35 #define _LUSTREAPI_INTERNAL_H_
36
37 #include <limits.h>
38 #include <stdint.h>
39
40 #include <libcfs/util/ioctl.h>
41 #include <libcfs/util/param.h>
42
43 #include <linux/lustre/lustre_ioctl.h>
44 #include <linux/lustre/lustre_kernelcomm.h>
45
46 #define MAX_IOC_BUFLEN  8192
47 #define MAX_LINE_LEN     256
48 #define MAX_INSTANCE_LEN  32
49
50 #define WANT_PATH   0x1
51 #define WANT_FSNAME 0x2
52 #define WANT_FD     0x4
53 #define WANT_INDEX  0x8
54 #define WANT_ERROR  0x10
55 #define WANT_DEV    0x20
56 #define WANT_NID    0x40
57
58 /* Define a fixed 4096-byte encryption unit size */
59 #define LUSTRE_ENCRYPTION_BLOCKBITS   12
60 #define LUSTRE_ENCRYPTION_UNIT_SIZE   ((size_t)1 << LUSTRE_ENCRYPTION_BLOCKBITS)
61 #define LUSTRE_ENCRYPTION_MASK        (~(LUSTRE_ENCRYPTION_UNIT_SIZE - 1))
62
63 /* mount point listings in /proc/mounts */
64 #ifndef PROC_MOUNTS
65 #define PROC_MOUNTS "/proc/mounts"
66 #endif
67
68 int get_root_path(int want, char *fsname, int *outfd, char *path, int index,
69                   dev_t *dev, char *nid);
70 int llapi_ioctl_pack(struct obd_ioctl_data *data, char **pbuf, int max_len);
71 int llapi_ioctl_unpack(struct obd_ioctl_data *data, char *pbuf, int max_len);
72 int sattr_cache_get_defaults(const char *const fsname,
73                              const char *const pathname, unsigned int *scount,
74                              unsigned int *ssize, unsigned int *soffset);
75
76 /**
77  * Often when determining the parameter path in sysfs/procfs we
78  * are often only interest set of data. This enum gives use the
79  * ability to return data of parameters for:
80  *
81  * FILTER_BY_FS_NAME: a specific file system mount
82  * FILTER_BY_PATH:    Using a Lustre file path to determine which
83  *                    file system is of interest
84  * FILTER_BY_EXACT:   The default behavior. Search the parameter
85  *                    path as is.
86  */
87 enum param_filter {
88         FILTER_BY_NONE,
89         FILTER_BY_EXACT,
90         FILTER_BY_FS_NAME,
91         FILTER_BY_PATH
92 };
93
94 int get_lustre_param_path(const char *obd_type, const char *filter,
95                           enum param_filter type, const char *param_name,
96                           glob_t *param);
97 int get_lustre_param_value(const char *obd_type, const char *filter,
98                            enum param_filter type, const char *param_name,
99                            char *value, size_t val_len);
100
101 static inline int
102 poolpath(glob_t *pool_path, const char *fsname, char *pathname)
103 {
104         int rc;
105
106         if (fsname != NULL)
107                 rc = get_lustre_param_path("lov", fsname, FILTER_BY_FS_NAME,
108                                            "pools", pool_path);
109         else
110                 rc = get_lustre_param_path("lov", pathname, FILTER_BY_PATH,
111                                            "pools", pool_path);
112         return rc;
113 }
114
115 #define LLAPI_LAYOUT_MAGIC 0x11AD1107 /* LLAPILOT */
116
117 /* Helper functions for testing validity of stripe attributes. */
118
119 static inline bool llapi_stripe_size_is_aligned(uint64_t size)
120 {
121         return (size & (LOV_MIN_STRIPE_SIZE - 1)) == 0;
122 }
123
124 static inline bool llapi_stripe_size_is_too_big(uint64_t size)
125 {
126         return size >= (1ULL << 32);
127 }
128
129 static inline bool llapi_stripe_count_is_valid(int64_t count)
130 {
131         return count >= -1 && count <= LOV_MAX_STRIPE_COUNT;
132 }
133
134 static inline bool llapi_stripe_index_is_valid(int64_t index)
135 {
136         return index >= -1 && index <= LOV_V1_INSANE_STRIPE_COUNT;
137 }
138
139 static inline bool llapi_pool_name_is_valid(const char **pool_name)
140 {
141         const char *ptr;
142
143         if (*pool_name == NULL)
144                 return false;
145
146         /* Strip off any 'fsname.' portion. */
147         ptr = strchr(*pool_name, '.');
148         if (ptr != NULL)
149                 *pool_name = ptr + 1;
150
151         if (strlen(*pool_name) > LOV_MAXPOOLNAME)
152                 return false;
153
154         return true;
155 }
156
157 /* Compatibility macro for legacy llapi functions that use "offset"
158  * terminology instead of the preferred "index". */
159 #define llapi_stripe_offset_is_valid(os) llapi_stripe_index_is_valid(os)
160
161 static inline bool llapi_dir_stripe_count_is_valid(int64_t count)
162 {
163         return count >= -1 && count <= LMV_MAX_STRIPE_COUNT;
164 }
165
166 static inline bool llapi_dir_stripe_index_is_valid(int64_t index)
167 {
168         return index >= -1 && index < LMV_MAX_STRIPE_COUNT;
169 }
170
171 static inline bool llapi_dir_hash_type_is_valid(int64_t hash)
172 {
173         int64_t _hash = hash & LMV_HASH_TYPE_MASK;
174
175         return _hash >= LMV_HASH_TYPE_UNKNOWN && _hash <  LMV_HASH_TYPE_MAX;
176 }
177
178 /*
179  * Kernel communication for Changelogs and HSM requests.
180  */
181 int libcfs_ukuc_start(struct lustre_kernelcomm *l, int groups, int rfd_flags);
182 int libcfs_ukuc_stop(struct lustre_kernelcomm *l);
183 int libcfs_ukuc_get_rfd(struct lustre_kernelcomm *link);
184 int libcfs_ukuc_msg_get(struct lustre_kernelcomm *l, char *buf, int maxsize,
185                         int transport);
186
187 enum get_lmd_info_type {
188         GET_LMD_INFO = 1,
189         GET_LMD_STRIPE = 2,
190 };
191
192 int get_lmd_info_fd(const char *path, int parentfd, int dirfd,
193                     void *lmd_buf, int lmd_len, enum get_lmd_info_type type);
194
195 int lov_comp_md_size(struct lov_comp_md_v1 *lcm);
196 #endif /* _LUSTREAPI_INTERNAL_H_ */