/* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*- * vim:expandtab:shiftwidth=8:tabstop=8: * * GPL HEADER START * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 only, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License version 2 for more details (a copy is included * in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU General Public License * version 2 along with this program; If not, see * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * CA 95054 USA or visit www.sun.com if you need additional information or * have any questions. * * GPL HEADER END */ /* * Copyright 2008 Sun Microsystems, Inc. All rights reserved * Use is subject to license terms. */ /* * This file is part of Lustre, http://www.lustre.org/ * Lustre is a trademark of Sun Microsystems, Inc. */ #ifndef __LIBCFS_LINUX_PORTALS_COMPAT_H__ #define __LIBCFS_LINUX_PORTALS_COMPAT_H__ // XXX BUG 1511 -- remove this stanza and all callers when bug 1511 is resolved #if defined(SPINLOCK_DEBUG) && SPINLOCK_DEBUG # if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)) || defined(CONFIG_RH_2_4_20) # define SIGNAL_MASK_ASSERT() \ LASSERT(current->sighand->siglock.magic == SPINLOCK_MAGIC) # else # define SIGNAL_MASK_ASSERT() \ LASSERT(current->sigmask_lock.magic == SPINLOCK_MAGIC) # endif #else # define SIGNAL_MASK_ASSERT() #endif // XXX BUG 1511 -- remove this stanza and all callers when bug 1511 is resolved #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)) # define SIGNAL_MASK_LOCK(task, flags) \ spin_lock_irqsave(&task->sighand->siglock, flags) # define SIGNAL_MASK_UNLOCK(task, flags) \ spin_unlock_irqrestore(&task->sighand->siglock, flags) # define USERMODEHELPER(path, argv, envp) \ call_usermodehelper(path, argv, envp, 1) # define RECALC_SIGPENDING recalc_sigpending() # define CLEAR_SIGPENDING clear_tsk_thread_flag(current, \ TIF_SIGPENDING) # define CURRENT_SECONDS get_seconds() # define smp_num_cpus num_online_cpus() #elif defined(CONFIG_RH_2_4_20) /* RH 2.4.x */ # define SIGNAL_MASK_LOCK(task, flags) \ spin_lock_irqsave(&task->sighand->siglock, flags) # define SIGNAL_MASK_UNLOCK(task, flags) \ spin_unlock_irqrestore(&task->sighand->siglock, flags) # define USERMODEHELPER(path, argv, envp) \ call_usermodehelper(path, argv, envp) # define RECALC_SIGPENDING recalc_sigpending() # define CLEAR_SIGPENDING (current->sigpending = 0) # define CURRENT_SECONDS CURRENT_TIME # define wait_event_interruptible_exclusive(wq, condition) \ wait_event_interruptible(wq, condition) #else /* 2.4.x */ # define SIGNAL_MASK_LOCK(task, flags) \ spin_lock_irqsave(&task->sigmask_lock, flags) # define SIGNAL_MASK_UNLOCK(task, flags) \ spin_unlock_irqrestore(&task->sigmask_lock, flags) # define USERMODEHELPER(path, argv, envp) \ call_usermodehelper(path, argv, envp) # define RECALC_SIGPENDING recalc_sigpending(current) # define CLEAR_SIGPENDING (current->sigpending = 0) # define CURRENT_SECONDS CURRENT_TIME # define wait_event_interruptible_exclusive(wq, condition) \ wait_event_interruptible(wq, condition) #endif # define cfs_wait_event_interruptible(wq, condition, ret) \ ret = wait_event_interruptible(wq, condition) # define cfs_wait_event_interruptible_exclusive(wq, condition, ret) \ ret = wait_event_interruptible(wq, condition) #if defined(__arch_um__) && (LINUX_VERSION_CODE < KERNEL_VERSION(2,4,20)) #define UML_PID(tsk) ((tsk)->thread.extern_pid) #elif defined(__arch_um__) && (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) #define UML_PID(tsk) ((tsk)->thread.mode.tt.extern_pid) #else #define UML_PID(tsk) ((tsk)->pid) #endif #if defined(__arch_um__) && (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) # define THREAD_NAME(comm, len, fmt, a...) \ snprintf(comm, len,fmt"|%d", ## a, UML_PID(current)) #else # define THREAD_NAME(comm, len, fmt, a...) \ snprintf(comm, len, fmt, ## a) #endif #ifdef HAVE_PAGE_LIST /* 2.4 alloc_page users can use page->list */ #define PAGE_LIST_ENTRY list #define PAGE_LIST(page) ((page)->list) #else /* 2.6 alloc_page users can use page->lru */ #define PAGE_LIST_ENTRY lru #define PAGE_LIST(page) ((page)->lru) #endif #ifndef HAVE_CPU_ONLINE #define cpu_online(cpu) ((1<f_pos #else #define ll_proc_dointvec(table, write, filp, buffer, lenp, ppos) \ proc_dointvec(table, write, filp, buffer, lenp, ppos); #define ll_proc_dostring(table, write, filp, buffer, lenp, ppos) \ proc_dostring(table, write, filp, buffer, lenp, ppos); #define LL_PROC_PROTO(name) \ name(cfs_sysctl_table_t *table, int write, struct file *filp, \ void __user *buffer, size_t *lenp, loff_t *ppos) #define DECLARE_LL_PROC_PPOS_DECL #endif #endif /* _PORTALS_COMPAT_H */