/**
* @file compat24.h
* Compatability functions for 2.4 kernels
*
* @remark Copyright 2002 OProfile authors
* @remark Read the file COPYING
*
* @author John Levon
* @author Philippe Elie
*/
#ifndef COMPAT24_H
#define COMPAT24_H
#include <linux/version.h>
static inline pid_t op_get_tgid(void)
{
return current->tgid;
}
#define pte_page_address(a) page_address(pte_page(a))
#define oprof_wake_up(w) wake_up(w)
#define lock_rtc(f) spin_lock_irqsave(&rtc_lock, f)
#define unlock_rtc(f) spin_unlock_irqrestore(&rtc_lock, f)
#define wind_dentries(d, v, r, m) wind_dentries_2_4(d, v, r, m)
extern uint do_path_hash_2_4(struct dentry * dentry, struct vfsmount * vfsmnt);
#define hash_path(f) do_path_hash_2_4((f)->f_dentry, (f)->f_vfsmnt)
#define request_region_check request_region
#define op_cpu_id() cpu_number_map(smp_processor_id())
#define GET_VM_OFFSET(v) ((v)->vm_pgoff << PAGE_SHIFT)
#define PTRACE_OFF(t) ((t)->ptrace &= ~PT_DTRACE)
#define lock_execve() do { } while (0)
#define unlock_execve() do { } while (0)
#define lock_out_mmap() do { } while (0)
#define unlock_out_mmap() do { } while (0)
#define HAVE_MMAP2
#define HAVE_FILE_OPERATIONS_OWNER
/* ->owner field in 2.4 */
#define INC_USE_COUNT_MAYBE
#define DEC_USE_COUNT_MAYBE
/* no global waitqueue spinlock in 2.4 */
#define wq_is_lockable() (1)
/* 2.4.3 introduced rw mmap semaphore */
#if V_AT_LEAST(2, 4, 3)
#define lock_mmap(mm) down_read(&mm->mmap_sem)
#define unlock_mmap(mm) up_read(&mm->mmap_sem)
#else
#define lock_mmap(mm) down(&mm->mmap_sem)
#define unlock_mmap(mm) up(&mm->mmap_sem)
#endif
/* 2.4.26 exported the needed stuff for HT support */
#if V_AT_LEAST(2, 4, 26) && defined(CONFIG_SMP)
#define HT_SUPPORT
#endif
#endif /* COMPAT24_H */