Whamcloud - gitweb
fe0b63a14f5e3bca5785a0863b9df259899b3c62
[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         int oom_adj;
49 #ifdef HAVE_OOMADJ_IN_SIG
50         unsigned long flags;
51
52         spin_lock_irqsave(&task->sighand->siglock, flags);
53         oom_adj = task->signal->oom_adj;
54         task->signal->oom_adj = scope;
55         spin_unlock_irqrestore(&task->sighand->siglock, flags);
56
57 #else
58         oom_adj = task->oomkilladj;
59         task->oomkilladj = scope;
60 #endif
61         return oom_adj;
62 }
63
64 int cfs_create_thread(int (*fn)(void *),
65                       void *arg, unsigned long flags)
66 {
67         void *orig_info = current->journal_info;
68         int rc;
69         int old_oom;
70
71         old_oom = oom_get_adj(current, OOM_DISABLE);
72         current->journal_info = NULL;
73         rc = kernel_thread(fn, arg, flags);
74         current->journal_info = orig_info;
75         oom_get_adj(current, old_oom);
76
77         return rc;
78 }
79 EXPORT_SYMBOL(cfs_create_thread);