Whamcloud - gitweb
LU-1402 libcfs: CFS_ALLOC_HIGH is __GFP_HIGHMEM
[fs/lustre-release.git] / libcfs / libcfs / linux / linux-lwt.c
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 /*
31  * This file is part of Lustre, http://www.lustre.org/
32  * Lustre is a trademark of Sun Microsystems, Inc.
33  */
34
35 # define DEBUG_SUBSYSTEM S_LNET
36 #include <linux/module.h>
37 #include <linux/sched.h>
38 #include <linux/spinlock.h>
39
40 #ifdef HAVE_LINUX_OOM_H
41 #include <linux/oom.h>
42 #else
43 #include <linux/mm.h>
44 #endif
45
46 int oom_get_adj(struct task_struct *task, int scope)
47 {
48
49         int oom_adj;
50 #ifdef HAVE_OOMADJ_IN_SIG
51         unsigned long flags;
52
53         spin_lock_irqsave(&task->sighand->siglock, flags);
54         oom_adj = task->signal->oom_adj;
55         task->signal->oom_adj = scope;
56         spin_unlock_irqrestore(&task->sighand->siglock, flags);
57
58 #else
59         oom_adj = task->oomkilladj;
60         task->oomkilladj = scope;
61 #endif
62         return oom_adj;
63 }
64
65 int cfs_create_thread(int (*fn)(void *),
66                       void *arg, unsigned long flags)
67 {
68         void *orig_info = current->journal_info;
69         int rc;
70         int old_oom;
71
72         old_oom = oom_get_adj(current, OOM_DISABLE);
73         current->journal_info = NULL;
74         rc = kernel_thread(fn, arg, flags);
75         current->journal_info = orig_info;
76         oom_get_adj(current, old_oom);
77
78         return rc;
79 }
80 EXPORT_SYMBOL(cfs_create_thread);