4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
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.
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).
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
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
27 * Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved.
28 * Use is subject to license terms.
30 * Copyright (c) 2011, Intel Corporation.
33 * This file is part of Lustre, http://www.lustre.org/
34 * Lustre is a trademark of Sun Microsystems, Inc.
36 * lustre/include/linux/lustre_lib.h
38 * Basic Lustre library routines.
41 #ifndef _LINUX_LUSTRE_LIB_H
42 #define _LINUX_LUSTRE_LIB_H
45 #error Do not #include this file directly. #include <lustre_lib.h> instead
50 # include <sys/types.h>
52 # include <linux/rwsem.h>
53 # include <linux/sched.h>
54 # include <linux/signal.h>
55 # include <linux/types.h>
56 # include <linux/lustre_compat25.h>
57 # include <linux/lustre_common.h>
61 #if BITS_PER_LONG > 32
62 # define LI_POISON ((int)0x5a5a5a5a5a5a5a5a)
63 # define LL_POISON ((long)0x5a5a5a5a5a5a5a5a)
64 # define LP_POISON ((void *)(long)0x5a5a5a5a5a5a5a5a)
66 # define LI_POISON ((int)0x5a5a5a5a)
67 # define LL_POISON ((long)0x5a5a5a5a)
68 # define LP_POISON ((void *)(long)0x5a5a5a5a)
72 /* This macro is only for compatibility reasons with older Linux Lustre user
73 * tools. New ioctls should NOT use this macro as the ioctl "size". Instead
74 * the ioctl should get a "size" argument which is the actual data type used
75 * by the ioctl, to ensure the ioctl interface is versioned correctly. */
76 #define OBD_IOC_DATA_TYPE long
78 #define LUSTRE_FATAL_SIGS (sigmask(SIGKILL) | sigmask(SIGINT) | \
79 sigmask(SIGTERM) | sigmask(SIGQUIT) | \
83 /* initialize ost_lvb according to inode */
84 static inline void inode_init_lvb(struct inode *inode, struct ost_lvb *lvb)
86 lvb->lvb_size = i_size_read(inode);
87 lvb->lvb_blocks = inode->i_blocks;
88 lvb->lvb_mtime = LTIME_S(inode->i_mtime);
89 lvb->lvb_atime = LTIME_S(inode->i_atime);
90 lvb->lvb_ctime = LTIME_S(inode->i_ctime);
93 /* defined in liblustre/llite_lib.h */
96 #endif /* _LUSTRE_LIB_H */