Whamcloud - gitweb
LU-5275 libcfs: merge params_tree.h into lprocfs_status.h
[fs/lustre-release.git] / libcfs / include / libcfs / libcfs.h
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
19  *
20  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21  * CA 95054 USA or visit www.sun.com if you need additional information or
22  * have any questions.
23  *
24  * GPL HEADER END
25  */
26 /*
27  * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2011, 2014, Intel Corporation.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  */
36
37 #ifndef __LIBCFS_LIBCFS_H__
38 #define __LIBCFS_LIBCFS_H__
39
40 #include <libcfs/types.h>
41 #include <libcfs/list.h>
42
43 #ifdef __KERNEL__
44 # include <libcfs/linux/libcfs.h>
45 #else /* !__KERNEL__ */
46 # include <assert.h>
47 # include <ctype.h>
48 # include <errno.h>
49 # include <fcntl.h>
50 # include <limits.h>
51 # include <signal.h>
52 # include <stdarg.h>
53 # include <stdbool.h>
54 # include <stddef.h>
55 # include <stdint.h>
56 # include <stdio.h>
57 # include <stdlib.h>
58 # include <string.h>
59 # include <time.h>
60 # include <sys/ioctl.h>
61 # include <sys/socket.h>
62 # include <sys/stat.h>
63 # include <sys/time.h>
64 # include <sys/types.h>
65 # include <libcfs/user-time.h>
66 # include <libcfs/user-prim.h>
67 # include <libcfs/user-mem.h>
68 # include <libcfs/user-lock.h>
69 # include <libcfs/user-tcpip.h>
70 # include <libcfs/user-bitops.h>
71 #endif /* __KERNEL__ */
72
73 #include "curproc.h"
74
75 #ifndef offsetof
76 # define offsetof(typ,memb) ((long)(long_ptr_t)((char *)&(((typ *)0)->memb)))
77 #endif
78
79 #ifndef ARRAY_SIZE
80 #define ARRAY_SIZE(a) ((sizeof (a)) / (sizeof ((a)[0])))
81 #endif
82
83 #if !defined(swap)
84 #define swap(x,y) do { typeof(x) z = x; x = y; y = z; } while (0)
85 #endif
86
87 #if !defined(container_of)
88 /* given a pointer @ptr to the field @member embedded into type (usually
89  * struct) @type, return pointer to the embedding instance of @type. */
90 #define container_of(ptr, type, member) \
91         ((type *)((char *)(ptr)-(char *)(&((type *)0)->member)))
92 #endif
93
94 static inline int __is_po2(unsigned long long val)
95 {
96         return !(val & (val - 1));
97 }
98
99 #define IS_PO2(val) __is_po2((unsigned long long)(val))
100
101 #define LOWEST_BIT_SET(x)       ((x) & ~((x) - 1))
102
103 /* Sparse annotations */
104 #ifdef __KERNEL__
105 # if !defined(__must_hold)
106 #  ifdef __CHECKER__
107 #   define __must_hold(x) __attribute__((context(x, 1, 1)))
108 #  else /* __CHECKER__ */
109 #   define __must_hold(x)
110 #  endif /* !__CHECKER__ */
111 # endif /* !__must_hold */
112 #else /* __KERNEL__ */
113 # define __acquires(x)
114 # define __releases(x)
115 # define __must_hold(x)
116 #endif /* !__KERNEL__ */
117
118 /*
119  * Lustre Error Checksum: calculates checksum
120  * of Hex number by XORing each bit.
121  */
122 #define LERRCHKSUM(hexnum) (((hexnum) & 0xf) ^ ((hexnum) >> 4 & 0xf) ^ \
123                            ((hexnum) >> 8 & 0xf))
124
125 /*
126  * Some (nomina odiosa sunt) platforms define NULL as naked 0. This confuses
127  * Lustre RETURN(NULL) macro.
128  */
129 #if defined(NULL)
130 #undef NULL
131 #endif
132
133 #define NULL ((void *)0)
134
135 #ifdef __KERNEL__
136
137 #ifndef cfs_for_each_possible_cpu
138 #  error cfs_for_each_possible_cpu is not supported by kernel!
139 #endif
140
141 /* libcfs tcpip */
142 int libcfs_ipif_query(char *name, int *up, __u32 *ip, __u32 *mask);
143 int libcfs_ipif_enumerate(char ***names);
144 void libcfs_ipif_free_enumeration(char **names, int n);
145 int libcfs_sock_listen(cfs_socket_t **sockp, __u32 ip, int port, int backlog);
146 int libcfs_sock_accept(cfs_socket_t **newsockp, cfs_socket_t *sock);
147 void libcfs_sock_abort_accept(cfs_socket_t *sock);
148 int libcfs_sock_connect(cfs_socket_t **sockp, int *fatal,
149                         __u32 local_ip, int local_port,
150                         __u32 peer_ip, int peer_port);
151 int libcfs_sock_setbuf(cfs_socket_t *socket, int txbufsize, int rxbufsize);
152 int libcfs_sock_getbuf(cfs_socket_t *socket, int *txbufsize, int *rxbufsize);
153 int libcfs_sock_getaddr(cfs_socket_t *socket, int remote, __u32 *ip, int *port);
154 int libcfs_sock_write(cfs_socket_t *sock, void *buffer, int nob, int timeout);
155 int libcfs_sock_read(cfs_socket_t *sock, void *buffer, int nob, int timeout);
156 void libcfs_sock_release(cfs_socket_t *sock);
157
158 /* libcfs watchdogs */
159 struct lc_watchdog;
160
161 /* Add a watchdog which fires after "time" milliseconds of delay.  You have to
162  * touch it once to enable it. */
163 struct lc_watchdog *lc_watchdog_add(int time,
164                                     void (*cb)(pid_t pid, void *),
165                                     void *data);
166
167 /* Enables a watchdog and resets its timer. */
168 void lc_watchdog_touch(struct lc_watchdog *lcw, int timeout);
169 #define CFS_GET_TIMEOUT(svc) (max_t(int, obd_timeout,                   \
170                           AT_OFF ? 0 : at_get(&svc->srv_at_estimate)) * \
171                           svc->srv_watchdog_factor)
172
173 /* Disable a watchdog; touch it to restart it. */
174 void lc_watchdog_disable(struct lc_watchdog *lcw);
175
176 /* Clean up the watchdog */
177 void lc_watchdog_delete(struct lc_watchdog *lcw);
178
179 /* Dump a debug log */
180 void lc_watchdog_dumplog(pid_t pid, void *data);
181
182 #else /* !__KERNEL__ */
183 #include <unistd.h>
184 #ifndef PAGE_SIZE
185 #define PAGE_SIZE sysconf(_SC_PAGESIZE)
186 #endif
187 #endif /* !__KERNEL__ */
188
189 /* need both kernel and user-land acceptor */
190 #define LNET_ACCEPTOR_MIN_RESERVED_PORT    512
191 #define LNET_ACCEPTOR_MAX_RESERVED_PORT    1023
192
193 /*
194  * libcfs pseudo device operations
195  *
196  * struct struct miscdevice and
197  * misc_register() and
198  * misc_deregister() are declared in
199  * libcfs/<os>/<os>-prim.h
200  *
201  * It's just draft now.
202  */
203
204 struct cfs_psdev_file {
205         unsigned long   off;
206         void            *private_data;
207         unsigned long   reserved1;
208         unsigned long   reserved2;
209 };
210
211 struct cfs_psdev_ops {
212         int (*p_open)(unsigned long, void *);
213         int (*p_close)(unsigned long, void *);
214         int (*p_read)(struct cfs_psdev_file *, char *, unsigned long);
215         int (*p_write)(struct cfs_psdev_file *, char *, unsigned long);
216         int (*p_ioctl)(struct cfs_psdev_file *, unsigned long, void __user *);
217 };
218
219 /*
220  * Drop into debugger, if possible. Implementation is provided by platform.
221  */
222
223 void cfs_enter_debugger(void);
224
225 /*
226  * Defined by platform
227  */
228 int unshare_fs_struct(void);
229 sigset_t cfs_block_allsigs(void);
230 sigset_t cfs_block_sigs(unsigned long sigs);
231 sigset_t cfs_block_sigsinv(unsigned long sigs);
232 void cfs_restore_sigs(sigset_t);
233 int cfs_signal_pending(void);
234 void cfs_clear_sigpending(void);
235
236 int convert_server_error(__u64 ecode);
237 int convert_client_oflag(int cflag, int *result);
238
239 /*
240  * Stack-tracing filling.
241  */
242
243 /*
244  * Platform-dependent data-type to hold stack frames.
245  */
246 struct cfs_stack_trace;
247
248 /*
249  * Fill @trace with current back-trace.
250  */
251 void cfs_stack_trace_fill(struct cfs_stack_trace *trace);
252
253 /*
254  * Return instruction pointer for frame @frame_no. NULL if @frame_no is
255  * invalid.
256  */
257 void *cfs_stack_trace_frame(struct cfs_stack_trace *trace, int frame_no);
258
259 /*
260  * Random number handling
261  */
262
263 /* returns a random 32-bit integer */
264 unsigned int cfs_rand(void);
265 /* seed the generator */
266 void cfs_srand(unsigned int, unsigned int);
267 void cfs_get_random_bytes(void *buf, int size);
268
269 #include <libcfs/byteorder.h>
270 #include <libcfs/err.h>
271 #include <libcfs/libcfs_debug.h>
272 #include <libcfs/libcfs_private.h>
273 #include <libcfs/bitmap.h>
274 #include <libcfs/libcfs_cpu.h>
275 #include <libcfs/libcfs_ioctl.h>
276 #include <libcfs/libcfs_prim.h>
277 #include <libcfs/libcfs_time.h>
278 #include <libcfs/libcfs_string.h>
279 #include <libcfs/libcfs_kernelcomm.h>
280 #include <libcfs/libcfs_workitem.h>
281 #include <libcfs/libcfs_hash.h>
282 #include <libcfs/libcfs_heap.h>
283 #include <libcfs/libcfs_fail.h>
284
285 /* container_of depends on "likely" which is defined in libcfs_private.h */
286 static inline void *__container_of(const void *ptr, unsigned long shift)
287 {
288         if (unlikely(IS_ERR(ptr) || ptr == NULL))
289                 return ERR_CAST(ptr);
290         else
291                 return (char *)ptr - shift;
292 }
293
294 #define container_of0(ptr, type, member)                                \
295         ((type *)__container_of((ptr), offsetof(type, member)))
296
297 #define _LIBCFS_H
298
299 int libcfs_arch_init(void);
300 void libcfs_arch_cleanup(void);
301
302 #endif /* _LIBCFS_H */