2005-09-26 10:04:21 +04:00
/*
* Copyright ( C ) 1999 Cort Dougan < cort @ cs . nmt . edu >
*/
2005-09-27 07:51:59 +04:00
# ifndef _ASM_POWERPC_SYSTEM_H
# define _ASM_POWERPC_SYSTEM_H
2005-09-26 10:04:21 +04:00
# include <linux/kernel.h>
2008-04-20 11:57:10 +04:00
# include <linux/irqflags.h>
2005-09-26 10:04:21 +04:00
# include <asm/hw_irq.h>
/*
* Memory barrier .
* The sync instruction guarantees that all memory accesses initiated
* by this processor have been performed ( with respect to all other
* mechanisms that access memory ) . The eieio instruction is a barrier
* providing an ordering ( separately ) for ( a ) cacheable stores and ( b )
* loads and stores to non - cacheable memory ( e . g . I / O devices ) .
*
* mb ( ) prevents loads and stores being reordered across this point .
* rmb ( ) prevents loads being reordered across this point .
* wmb ( ) prevents stores being reordered across this point .
* read_barrier_depends ( ) prevents data - dependent loads being reordered
* across this point ( nop on PPC ) .
*
2008-11-11 20:51:18 +03:00
* * mb ( ) variants without smp_ prefix must order all types of memory
* operations with one another . sync is the only instruction sufficient
* to do this .
2005-09-26 10:04:21 +04:00
*
2008-11-11 20:51:18 +03:00
* For the smp_ barriers , ordering is for cacheable memory operations
* only . We have to use the sync instruction for smp_mb ( ) , since lwsync
* doesn ' t order loads with respect to previous stores . Lwsync can be
* used for smp_rmb ( ) and smp_wmb ( ) .
*
* However , on CPUs that don ' t support lwsync , lwsync actually maps to a
* heavy - weight sync , so smp_wmb ( ) can be a lighter - weight eieio .
2005-09-26 10:04:21 +04:00
*/
# define mb() __asm__ __volatile__ ("sync" : : : "memory")
2008-05-21 18:10:56 +04:00
# define rmb() __asm__ __volatile__ ("sync" : : : "memory")
2005-09-26 10:04:21 +04:00
# define wmb() __asm__ __volatile__ ("sync" : : : "memory")
# define read_barrier_depends() do { } while(0)
# define set_mb(var, value) do { var = value; mb(); } while (0)
2005-12-17 00:43:46 +03:00
# ifdef __KERNEL__
2007-10-17 10:30:12 +04:00
# define AT_VECTOR_SIZE_ARCH 6 /* entries in ARCH_DLINFO */
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_SMP
2008-05-21 18:12:31 +04:00
# ifdef __SUBARCH_HAS_LWSYNC
2008-11-11 20:50:48 +03:00
# define SMPWMB LWSYNC
2008-05-21 18:12:31 +04:00
# else
# define SMPWMB eieio
# endif
2005-09-26 10:04:21 +04:00
# define smp_mb() mb()
2008-11-11 20:51:18 +03:00
# define smp_rmb() __asm__ __volatile__ (stringify_in_c(LWSYNC) : : :"memory")
2008-11-11 20:50:48 +03:00
# define smp_wmb() __asm__ __volatile__ (stringify_in_c(SMPWMB) : : :"memory")
2005-09-26 10:04:21 +04:00
# define smp_read_barrier_depends() read_barrier_depends()
# else
# define smp_mb() barrier()
# define smp_rmb() barrier()
# define smp_wmb() barrier()
# define smp_read_barrier_depends() do { } while(0)
# endif /* CONFIG_SMP */
2006-08-23 05:36:05 +04:00
/*
* This is a barrier which prevents following instructions from being
* started until the value of the argument x is known . For example , if
* x is a variable loaded from memory , this prevents following
* instructions from being executed until the load has been performed .
*/
# define data_barrier(x) \
asm volatile ( " twi 0,%0,0; isync " : : " r " ( x ) : " memory " ) ;
2005-09-26 10:04:21 +04:00
struct task_struct ;
struct pt_regs ;
2008-01-31 06:34:47 +03:00
# if defined(CONFIG_DEBUGGER) || defined(CONFIG_KEXEC)
2005-09-26 10:04:21 +04:00
extern int ( * __debugger ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_ipi ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_bpt ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_sstep ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_iabr_match ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_dabr_match ) ( struct pt_regs * regs ) ;
extern int ( * __debugger_fault_handler ) ( struct pt_regs * regs ) ;
# define DEBUGGER_BOILERPLATE(__NAME) \
static inline int __NAME ( struct pt_regs * regs ) \
{ \
if ( unlikely ( __ # # __NAME ) ) \
return __ # # __NAME ( regs ) ; \
return 0 ; \
}
DEBUGGER_BOILERPLATE ( debugger )
DEBUGGER_BOILERPLATE ( debugger_ipi )
DEBUGGER_BOILERPLATE ( debugger_bpt )
DEBUGGER_BOILERPLATE ( debugger_sstep )
DEBUGGER_BOILERPLATE ( debugger_iabr_match )
DEBUGGER_BOILERPLATE ( debugger_dabr_match )
DEBUGGER_BOILERPLATE ( debugger_fault_handler )
# else
static inline int debugger ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_ipi ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_bpt ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_sstep ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_iabr_match ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_dabr_match ( struct pt_regs * regs ) { return 0 ; }
static inline int debugger_fault_handler ( struct pt_regs * regs ) { return 0 ; }
# endif
extern int set_dabr ( unsigned long dabr ) ;
2010-02-08 14:51:18 +03:00
# ifdef CONFIG_PPC_ADV_DEBUG_REGS
extern void do_send_trap ( struct pt_regs * regs , unsigned long address ,
unsigned long error_code , int signal_code , int brkpt ) ;
# else
2008-07-23 20:10:41 +04:00
extern void do_dabr ( struct pt_regs * regs , unsigned long address ,
unsigned long error_code ) ;
2010-02-08 14:51:18 +03:00
# endif
2005-09-26 10:04:21 +04:00
extern void print_backtrace ( unsigned long * ) ;
extern void flush_instruction_cache ( void ) ;
extern void hard_reset_now ( void ) ;
extern void poweroff_now ( void ) ;
# ifdef CONFIG_6xx
extern long _get_L2CR ( void ) ;
extern long _get_L3CR ( void ) ;
extern void _set_L2CR ( unsigned long ) ;
extern void _set_L3CR ( unsigned long ) ;
# else
# define _get_L2CR() 0L
# define _get_L3CR() 0L
# define _set_L2CR(val) do { } while(0)
# define _set_L3CR(val) do { } while(0)
# endif
extern void via_cuda_init ( void ) ;
extern void read_rtc_time ( void ) ;
extern void pmac_find_display ( void ) ;
extern void giveup_fpu ( struct task_struct * ) ;
2005-09-30 10:16:52 +04:00
extern void disable_kernel_fp ( void ) ;
2005-09-26 10:04:21 +04:00
extern void enable_kernel_fp ( void ) ;
extern void flush_fp_to_thread ( struct task_struct * ) ;
extern void enable_kernel_altivec ( void ) ;
extern void giveup_altivec ( struct task_struct * ) ;
extern void load_up_altivec ( struct task_struct * ) ;
2005-10-10 16:50:37 +04:00
extern int emulate_altivec ( struct pt_regs * ) ;
2008-07-11 10:29:12 +04:00
extern void __giveup_vsx ( struct task_struct * ) ;
2008-06-25 08:07:18 +04:00
extern void giveup_vsx ( struct task_struct * ) ;
2007-04-28 02:00:03 +04:00
extern void enable_kernel_spe ( void ) ;
2005-09-26 10:04:21 +04:00
extern void giveup_spe ( struct task_struct * ) ;
extern void load_up_spe ( struct task_struct * ) ;
extern int fix_alignment ( struct pt_regs * ) ;
2010-08-21 15:43:20 +04:00
extern void cvt_fd ( float * from , double * to ) ;
extern void cvt_df ( double * from , float * to ) ;
2005-09-26 10:04:21 +04:00
2006-01-11 14:11:39 +03:00
# ifndef CONFIG_SMP
extern void discard_lazy_cpu_state ( void ) ;
# else
static inline void discard_lazy_cpu_state ( void )
{
}
# endif
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_ALTIVEC
extern void flush_altivec_to_thread ( struct task_struct * ) ;
# else
static inline void flush_altivec_to_thread ( struct task_struct * t )
{
}
# endif
2008-06-25 08:07:18 +04:00
# ifdef CONFIG_VSX
extern void flush_vsx_to_thread ( struct task_struct * ) ;
# else
static inline void flush_vsx_to_thread ( struct task_struct * t )
{
}
# endif
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_SPE
extern void flush_spe_to_thread ( struct task_struct * ) ;
# else
static inline void flush_spe_to_thread ( struct task_struct * t )
{
}
# endif
extern int call_rtas ( const char * , int , int , unsigned long * , . . . ) ;
extern void cacheable_memzero ( void * p , unsigned int nb ) ;
extern void * cacheable_memcpy ( void * , const void * , unsigned int ) ;
extern int do_page_fault ( struct pt_regs * , unsigned long , unsigned long ) ;
extern void bad_page_fault ( struct pt_regs * , unsigned long , int ) ;
extern int die ( const char * , struct pt_regs * , long ) ;
extern void _exception ( int , struct pt_regs * , int , unsigned long ) ;
2008-01-23 21:42:07 +03:00
extern void _nmask_and_or_msr ( unsigned long nmask , unsigned long or_val ) ;
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_BOOKE_WDT
extern u32 booke_wdt_enabled ;
extern u32 booke_wdt_period ;
# endif /* CONFIG_BOOKE_WDT */
struct device_node ;
extern void note_scsi_host ( struct device_node * , void * ) ;
extern struct task_struct * __switch_to ( struct task_struct * ,
struct task_struct * ) ;
# define switch_to(prev, next, last) ((last) = __switch_to((prev), (next)))
struct thread_struct ;
extern struct task_struct * _switch ( struct thread_struct * prev ,
struct thread_struct * next ) ;
extern unsigned int rtas_data ;
2005-10-10 16:50:37 +04:00
extern int mem_init_done ; /* set on boot once kmalloc can be called */
2009-06-03 01:16:38 +04:00
extern int init_bootmem_done ; /* set once bootmem is available */
2009-05-08 16:19:27 +04:00
extern phys_addr_t memory_limit ;
2005-11-10 07:53:40 +03:00
extern unsigned long klimit ;
2007-10-02 07:37:53 +04:00
extern void * zalloc_maybe_bootmem ( size_t size , gfp_t mask ) ;
2007-09-17 08:08:06 +04:00
2005-10-20 15:10:09 +04:00
extern int powersave_nap ; /* set if nap mode can be used in idle loop */
2005-09-26 10:04:21 +04:00
/*
* Atomic exchange
*
* Changes the memory location ' * ptr ' to be val and returns
* the previous value stored there .
*/
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-09-26 10:04:21 +04:00
__xchg_u32 ( volatile void * p , unsigned long val )
{
unsigned long prev ;
__asm__ __volatile__ (
2010-02-10 04:04:06 +03:00
PPC_RELEASE_BARRIER
2005-09-26 10:04:21 +04:00
" 1: lwarx %0,0,%2 \n "
PPC405_ERR77 ( 0 , % 2 )
" stwcx. %3,0,%2 \n \
bne - 1 b "
2010-02-10 04:04:06 +03:00
PPC_ACQUIRE_BARRIER
2006-07-09 02:00:28 +04:00
: " =&r " ( prev ) , " +m " ( * ( volatile unsigned int * ) p )
: " r " ( p ) , " r " ( val )
2005-09-26 10:04:21 +04:00
: " cc " , " memory " ) ;
return prev ;
}
2007-05-08 11:34:27 +04:00
/*
* Atomic exchange
*
* Changes the memory location ' * ptr ' to be val and returns
* the previous value stored there .
*/
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__xchg_u32_local ( volatile void * p , unsigned long val )
{
unsigned long prev ;
__asm__ __volatile__ (
" 1: lwarx %0,0,%2 \n "
PPC405_ERR77 ( 0 , % 2 )
" stwcx. %3,0,%2 \n \
bne - 1 b "
: " =&r " ( prev ) , " +m " ( * ( volatile unsigned int * ) p )
: " r " ( p ) , " r " ( val )
: " cc " , " memory " ) ;
return prev ;
}
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_PPC64
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-09-26 10:04:21 +04:00
__xchg_u64 ( volatile void * p , unsigned long val )
{
unsigned long prev ;
__asm__ __volatile__ (
2010-02-10 04:04:06 +03:00
PPC_RELEASE_BARRIER
2005-09-26 10:04:21 +04:00
" 1: ldarx %0,0,%2 \n "
PPC405_ERR77 ( 0 , % 2 )
" stdcx. %3,0,%2 \n \
bne - 1 b "
2010-02-10 04:04:06 +03:00
PPC_ACQUIRE_BARRIER
2006-07-09 02:00:28 +04:00
: " =&r " ( prev ) , " +m " ( * ( volatile unsigned long * ) p )
: " r " ( p ) , " r " ( val )
2005-09-26 10:04:21 +04:00
: " cc " , " memory " ) ;
return prev ;
}
2007-05-08 11:34:27 +04:00
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__xchg_u64_local ( volatile void * p , unsigned long val )
{
unsigned long prev ;
__asm__ __volatile__ (
" 1: ldarx %0,0,%2 \n "
PPC405_ERR77 ( 0 , % 2 )
" stdcx. %3,0,%2 \n \
bne - 1 b "
: " =&r " ( prev ) , " +m " ( * ( volatile unsigned long * ) p )
: " r " ( p ) , " r " ( val )
: " cc " , " memory " ) ;
return prev ;
}
2005-09-26 10:04:21 +04:00
# endif
/*
* This function doesn ' t exist , so you ' ll get a linker error
* if something tries to do an invalid xchg ( ) .
*/
extern void __xchg_called_with_bad_pointer ( void ) ;
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-09-26 10:04:21 +04:00
__xchg ( volatile void * ptr , unsigned long x , unsigned int size )
{
switch ( size ) {
case 4 :
return __xchg_u32 ( ptr , x ) ;
# ifdef CONFIG_PPC64
case 8 :
return __xchg_u64 ( ptr , x ) ;
# endif
}
__xchg_called_with_bad_pointer ( ) ;
return x ;
}
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__xchg_local ( volatile void * ptr , unsigned long x , unsigned int size )
{
switch ( size ) {
case 4 :
return __xchg_u32_local ( ptr , x ) ;
# ifdef CONFIG_PPC64
case 8 :
return __xchg_u64_local ( ptr , x ) ;
# endif
}
__xchg_called_with_bad_pointer ( ) ;
return x ;
}
2005-09-26 10:04:21 +04:00
# define xchg(ptr,x) \
( { \
__typeof__ ( * ( ptr ) ) _x_ = ( x ) ; \
( __typeof__ ( * ( ptr ) ) ) __xchg ( ( ptr ) , ( unsigned long ) _x_ , sizeof ( * ( ptr ) ) ) ; \
} )
2007-05-08 11:34:27 +04:00
# define xchg_local(ptr,x) \
( { \
__typeof__ ( * ( ptr ) ) _x_ = ( x ) ; \
( __typeof__ ( * ( ptr ) ) ) __xchg_local ( ( ptr ) , \
( unsigned long ) _x_ , sizeof ( * ( ptr ) ) ) ; \
} )
2005-09-26 10:04:21 +04:00
/*
* Compare and exchange - if * p = = old , set it to new ,
* and return the old value of * p .
*/
# define __HAVE_ARCH_CMPXCHG 1
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-09-26 10:04:21 +04:00
__cmpxchg_u32 ( volatile unsigned int * p , unsigned long old , unsigned long new )
{
unsigned int prev ;
__asm__ __volatile__ (
2010-02-10 04:04:06 +03:00
PPC_RELEASE_BARRIER
2005-09-26 10:04:21 +04:00
" 1: lwarx %0,0,%2 # __cmpxchg_u32 \n \
cmpw 0 , % 0 , % 3 \ n \
bne - 2f \ n "
PPC405_ERR77 ( 0 , % 2 )
" stwcx. %4,0,%2 \n \
bne - 1 b "
2010-02-10 04:04:06 +03:00
PPC_ACQUIRE_BARRIER
2005-09-26 10:04:21 +04:00
" \n \
2 : "
2006-07-09 02:00:28 +04:00
: " =&r " ( prev ) , " +m " ( * p )
: " r " ( p ) , " r " ( old ) , " r " ( new )
2005-09-26 10:04:21 +04:00
: " cc " , " memory " ) ;
return prev ;
}
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__cmpxchg_u32_local ( volatile unsigned int * p , unsigned long old ,
unsigned long new )
{
unsigned int prev ;
__asm__ __volatile__ (
" 1: lwarx %0,0,%2 # __cmpxchg_u32 \n \
cmpw 0 , % 0 , % 3 \ n \
bne - 2f \ n "
PPC405_ERR77 ( 0 , % 2 )
" stwcx. %4,0,%2 \n \
bne - 1 b "
" \n \
2 : "
: " =&r " ( prev ) , " +m " ( * p )
: " r " ( p ) , " r " ( old ) , " r " ( new )
: " cc " , " memory " ) ;
return prev ;
}
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_PPC64
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-11-07 03:06:55 +03:00
__cmpxchg_u64 ( volatile unsigned long * p , unsigned long old , unsigned long new )
2005-09-26 10:04:21 +04:00
{
unsigned long prev ;
__asm__ __volatile__ (
2010-02-10 04:04:06 +03:00
PPC_RELEASE_BARRIER
2005-09-26 10:04:21 +04:00
" 1: ldarx %0,0,%2 # __cmpxchg_u64 \n \
cmpd 0 , % 0 , % 3 \ n \
bne - 2f \ n \
stdcx . % 4 , 0 , % 2 \ n \
bne - 1 b "
2010-02-10 04:04:06 +03:00
PPC_ACQUIRE_BARRIER
2005-09-26 10:04:21 +04:00
" \n \
2 : "
2006-07-09 02:00:28 +04:00
: " =&r " ( prev ) , " +m " ( * p )
: " r " ( p ) , " r " ( old ) , " r " ( new )
2005-09-26 10:04:21 +04:00
: " cc " , " memory " ) ;
return prev ;
}
2007-05-08 11:34:27 +04:00
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__cmpxchg_u64_local ( volatile unsigned long * p , unsigned long old ,
unsigned long new )
{
unsigned long prev ;
__asm__ __volatile__ (
" 1: ldarx %0,0,%2 # __cmpxchg_u64 \n \
cmpd 0 , % 0 , % 3 \ n \
bne - 2f \ n \
stdcx . % 4 , 0 , % 2 \ n \
bne - 1 b "
" \n \
2 : "
: " =&r " ( prev ) , " +m " ( * p )
: " r " ( p ) , " r " ( old ) , " r " ( new )
: " cc " , " memory " ) ;
return prev ;
}
2005-09-26 10:04:21 +04:00
# endif
/* 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 ) ;
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2005-09-26 10:04:21 +04:00
__cmpxchg ( volatile void * ptr , unsigned long old , unsigned long new ,
unsigned int size )
{
switch ( size ) {
case 4 :
return __cmpxchg_u32 ( ptr , old , new ) ;
# ifdef CONFIG_PPC64
case 8 :
return __cmpxchg_u64 ( ptr , old , new ) ;
# endif
}
__cmpxchg_called_with_bad_pointer ( ) ;
return old ;
}
2008-04-28 08:44:08 +04:00
static __always_inline unsigned long
2007-05-08 11:34:27 +04:00
__cmpxchg_local ( volatile void * ptr , unsigned long old , unsigned long new ,
unsigned int size )
{
switch ( size ) {
case 4 :
return __cmpxchg_u32_local ( ptr , old , new ) ;
# ifdef CONFIG_PPC64
case 8 :
return __cmpxchg_u64_local ( ptr , old , new ) ;
# endif
}
__cmpxchg_called_with_bad_pointer ( ) ;
return old ;
}
2008-02-07 11:16:10 +03:00
# define cmpxchg(ptr, o, n) \
2005-09-26 10:04:21 +04:00
( { \
__typeof__ ( * ( ptr ) ) _o_ = ( o ) ; \
__typeof__ ( * ( ptr ) ) _n_ = ( n ) ; \
( __typeof__ ( * ( ptr ) ) ) __cmpxchg ( ( ptr ) , ( unsigned long ) _o_ , \
( unsigned long ) _n_ , sizeof ( * ( ptr ) ) ) ; \
} )
2007-05-08 11:34:27 +04:00
2008-02-07 11:16:10 +03:00
# define cmpxchg_local(ptr, o, n) \
2007-05-08 11:34:27 +04:00
( { \
__typeof__ ( * ( ptr ) ) _o_ = ( o ) ; \
__typeof__ ( * ( ptr ) ) _n_ = ( n ) ; \
( __typeof__ ( * ( ptr ) ) ) __cmpxchg_local ( ( ptr ) , ( unsigned long ) _o_ , \
( unsigned long ) _n_ , sizeof ( * ( ptr ) ) ) ; \
} )
2005-09-26 10:04:21 +04:00
# ifdef CONFIG_PPC64
/*
* We handle most unaligned accesses in hardware . On the other hand
* unaligned DMA can be very expensive on some ppc64 IO chips ( it does
* powers of 2 writes until it reaches sufficient alignment ) .
*
* Based on this we disable the IP header alignment in network drivers .
*/
2006-03-31 14:27:06 +04:00
# define NET_IP_ALIGN 0
2008-02-07 11:16:10 +03:00
# define cmpxchg64(ptr, o, n) \
( { \
BUILD_BUG_ON ( sizeof ( * ( ptr ) ) ! = 8 ) ; \
cmpxchg ( ( ptr ) , ( o ) , ( n ) ) ; \
} )
# define cmpxchg64_local(ptr, o, n) \
( { \
BUILD_BUG_ON ( sizeof ( * ( ptr ) ) ! = 8 ) ; \
cmpxchg_local ( ( ptr ) , ( o ) , ( n ) ) ; \
} )
# else
# include <asm-generic/cmpxchg-local.h>
# define cmpxchg64_local(ptr, o, n) __cmpxchg64_local_generic((ptr), (o), (n))
2005-09-26 10:04:21 +04:00
# endif
2009-02-22 04:50:03 +03:00
extern unsigned long arch_align_stack ( unsigned long sp ) ;
2005-09-26 10:04:21 +04:00
2005-10-06 06:06:20 +04:00
/* Used in very early kernel initialization. */
2005-09-30 10:16:52 +04:00
extern unsigned long reloc_offset ( void ) ;
2005-10-06 06:06:20 +04:00
extern unsigned long add_reloc_offset ( unsigned long ) ;
extern void reloc_got2 ( unsigned long ) ;
# define PTRRELOC(x) ((typeof(x)) add_reloc_offset((unsigned long)(x)))
2005-09-30 10:16:52 +04:00
2007-06-20 04:54:19 +04:00
extern struct dentry * powerpc_debugfs_root ;
2005-09-26 10:04:21 +04:00
# endif /* __KERNEL__ */
2005-09-27 07:51:59 +04:00
# endif /* _ASM_POWERPC_SYSTEM_H */