⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 system.h

📁 linux 内核源代码
💻 H
字号:
/* * Copyright (C) 2004-2006 Atmel Corporation * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#ifndef __ASM_AVR32_SYSTEM_H#define __ASM_AVR32_SYSTEM_H#include <linux/compiler.h>#include <linux/linkage.h>#include <linux/types.h>#include <asm/ptrace.h>#include <asm/sysreg.h>#define xchg(ptr,x) \	((__typeof__(*(ptr)))__xchg((unsigned long)(x),(ptr),sizeof(*(ptr))))#define nop() asm volatile("nop")#define mb()			asm volatile("" : : : "memory")#define rmb()			mb()#define wmb()			asm volatile("sync 0" : : : "memory")#define read_barrier_depends()  do { } while(0)#define set_mb(var, value)      do { var = value; mb(); } while(0)/* * Help PathFinder and other Nexus-compliant debuggers keep track of * the current PID by emitting an Ownership Trace Message each time we * switch task. */#ifdef CONFIG_OWNERSHIP_TRACE#include <asm/ocd.h>#define finish_arch_switch(prev)			\	do {						\		ocd_write(PID, prev->pid);		\		ocd_write(PID, current->pid);		\	} while(0)#endif/* * switch_to(prev, next, last) should switch from task `prev' to task * `next'. `prev' will never be the same as `next'. * * We just delegate everything to the __switch_to assembly function, * which is implemented in arch/avr32/kernel/switch_to.S * * mb() tells GCC not to cache `current' across this call. */struct cpu_context;struct task_struct;extern struct task_struct *__switch_to(struct task_struct *,				       struct cpu_context *,				       struct cpu_context *);#define switch_to(prev, next, last)					\	do {								\		last = __switch_to(prev, &prev->thread.cpu_context + 1,	\				   &next->thread.cpu_context);		\	} while (0)#ifdef CONFIG_SMP# error "The AVR32 port does not support SMP"#else# define smp_mb()		barrier()# define smp_rmb()		barrier()# define smp_wmb()		barrier()# define smp_read_barrier_depends() do { } while(0)#endif#include <linux/irqflags.h>extern void __xchg_called_with_bad_pointer(void);static inline unsigned long xchg_u32(u32 val, volatile u32 *m){	u32 ret;	asm volatile("xchg %[ret], %[m], %[val]"			: [ret] "=&r"(ret), "=m"(*m)			: "m"(*m), [m] "r"(m), [val] "r"(val)			: "memory");	return ret;}static inline unsigned long __xchg(unsigned long x,				       volatile void *ptr,				       int size){	switch(size) {	case 4:		return xchg_u32(x, ptr);	default:		__xchg_called_with_bad_pointer();		return x;	}}static inline unsigned long __cmpxchg_u32(volatile int *m, unsigned long old,					  unsigned long new){	__u32 ret;	asm volatile(		"1:	ssrf	5\n"		"	ld.w	%[ret], %[m]\n"		"	cp.w	%[ret], %[old]\n"		"	brne	2f\n"		"	stcond	%[m], %[new]\n"		"	brne	1b\n"		"2:\n"		: [ret] "=&r"(ret), [m] "=m"(*m)		: "m"(m), [old] "ir"(old), [new] "r"(new)		: "memory", "cc");	return ret;}extern unsigned long __cmpxchg_u64_unsupported_on_32bit_kernels(        volatile int * m, unsigned long old, unsigned long new);#define __cmpxchg_u64 __cmpxchg_u64_unsupported_on_32bit_kernels/* This function doesn't exist, so you'll get a linker error   if something tries to do an invalid cmpxchg().  */extern void __cmpxchg_called_with_bad_pointer(void);#define __HAVE_ARCH_CMPXCHG 1static inline unsigned long __cmpxchg(volatile void *ptr, unsigned long old,				      unsigned long new, int size){	switch (size) {	case 4:		return __cmpxchg_u32(ptr, old, new);	case 8:		return __cmpxchg_u64(ptr, old, new);	}	__cmpxchg_called_with_bad_pointer();	return old;}#define cmpxchg(ptr, old, new)					\	((typeof(*(ptr)))__cmpxchg((ptr), (unsigned long)(old),	\				   (unsigned long)(new),	\				   sizeof(*(ptr))))struct pt_regs;void NORET_TYPE die(const char *str, struct pt_regs *regs, long err);void _exception(long signr, struct pt_regs *regs, int code,		unsigned long addr);#define arch_align_stack(x)	(x)#endif /* __ASM_AVR32_SYSTEM_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -