/** * @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 */