1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- /*
- * This file defines the fixed addresses where userspace programs
- * can find atomic code sequences.
- *
- * Copyright 2007-2008 Analog Devices Inc.
- *
- * Licensed under the GPL-2 or later.
- */
- #ifndef __BFIN_ASM_FIXED_CODE_H__
- #define __BFIN_ASM_FIXED_CODE_H__
- #ifdef __KERNEL__
- #ifndef __ASSEMBLY__
- #include <linux/linkage.h>
- #include <linux/ptrace.h>
- extern asmlinkage void finish_atomic_sections(struct pt_regs *regs);
- extern char fixed_code_start;
- extern char fixed_code_end;
- extern int atomic_xchg32(void);
- extern int atomic_cas32(void);
- extern int atomic_add32(void);
- extern int atomic_sub32(void);
- extern int atomic_ior32(void);
- extern int atomic_and32(void);
- extern int atomic_xor32(void);
- extern void safe_user_instruction(void);
- extern void sigreturn_stub(void);
- #endif
- #endif
- #ifndef CONFIG_PHY_RAM_BASE_ADDRESS
- #define CONFIG_PHY_RAM_BASE_ADDRESS 0x0
- #endif
- #define FIXED_CODE_START (CONFIG_PHY_RAM_BASE_ADDRESS + 0x400)
- #define SIGRETURN_STUB (CONFIG_PHY_RAM_BASE_ADDRESS + 0x400)
- #define ATOMIC_SEQS_START (CONFIG_PHY_RAM_BASE_ADDRESS + 0x410)
- #define ATOMIC_XCHG32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x410)
- #define ATOMIC_CAS32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x420)
- #define ATOMIC_ADD32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x430)
- #define ATOMIC_SUB32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x440)
- #define ATOMIC_IOR32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x450)
- #define ATOMIC_AND32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x460)
- #define ATOMIC_XOR32 (CONFIG_PHY_RAM_BASE_ADDRESS + 0x470)
- #define ATOMIC_SEQS_END (CONFIG_PHY_RAM_BASE_ADDRESS + 0x480)
- #define SAFE_USER_INSTRUCTION (CONFIG_PHY_RAM_BASE_ADDRESS + 0x480)
- #define FIXED_CODE_END (CONFIG_PHY_RAM_BASE_ADDRESS + 0x490)
- #endif
|