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) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
28 * Use is subject to license terms.
30 * Copyright (c) 2012, Intel Corporation.
33 * This file is part of Lustre, http://www.lustre.org/
34 * Lustre is a trademark of Sun Microsystems, Inc.
37 #ifndef OST_INTERNAL_H
38 #define OST_INTERNAL_H
40 #define OSS_SERVICE_WATCHDOG_FACTOR 2
43 * tunables for per-thread page pool (bug 5137)
45 #define OST_THREAD_POOL_SIZE PTLRPC_MAX_BRW_PAGES /* pool size in pages */
46 #define OST_THREAD_POOL_GFP CFS_ALLOC_HIGHUSER /* GFP mask for pool pages */
51 struct ptlrpc_request;
54 * struct ost_thread_local_cache is allocated and initialized for each OST
55 * thread by ost_thread_init().
57 struct ost_thread_local_cache {
59 * pool of nio buffers used by write-path
61 struct niobuf_local local[OST_THREAD_POOL_SIZE];
62 unsigned int temporary:1;
65 struct ost_thread_local_cache *ost_tls(struct ptlrpc_request *r);
68 void lprocfs_ost_init_vars(struct lprocfs_static_vars *lvars);
70 static void lprocfs_ost_init_vars(struct lprocfs_static_vars *lvars)
72 memset(lvars, 0, sizeof(*lvars));
76 /* Here "ostid" maybe part of "oa", the return value of "ostid_id()" depends on
77 * the original "ostid->oi_seq", which maybe changed by the assignment of
78 * "oa->o_seq = ostid_seq(ostid)", so keep the order of setting "oa->o_id" and
80 static inline void obdo_from_ostid(struct obdo *oa, struct ost_id *ostid)
82 oa->o_id = ostid_id(ostid);
83 oa->o_seq = ostid_seq(ostid);
86 static inline void ioobj_from_obdo(struct obd_ioobj *ioobj, struct obdo *oa)
88 ioobj->ioo_id = oa->o_id;
89 ioobj->ioo_seq = oa->o_seq;
92 #endif /* OST_INTERNAL_H */