2005-09-28 07:28:01 +04:00
/ *
* This f i l e c o n t a i n s m i s c e l l a n e o u s l o w - l e v e l f u n c t i o n s .
* Copyright ( C ) 1 9 9 5 - 2 0 0 5 I B M C o r p
*
* Largely r e w r i t t e n b y C o r t D o u g a n ( c o r t @cs.nmt.edu)
* and P a u l M a c k e r r a s .
* Adapted f o r i S e r i e s b y M i k e C o r r i g a n ( m i k e j c @us.ibm.com)
* PPC6 4 u p d a t e s b y D a v e E n g e b r e t s e n ( e n g e b r e t @us.ibm.com)
*
* This p r o g r a m i s f r e e s o f t w a r e ; you can redistribute it and/or
* modify i t u n d e r t h e t e r m s o f t h e G N U G e n e r a l P u b l i c L i c e n s e
* as p u b l i s h e d b y t h e F r e e S o f t w a r e F o u n d a t i o n ; either version
* 2 of t h e L i c e n s e , o r ( a t y o u r o p t i o n ) a n y l a t e r v e r s i o n .
* /
# include < a s m / p r o c e s s o r . h >
# include < a s m / a s m - o f f s e t s . h >
[PATCH] powerpc: Consolidate asm compatibility macros
This patch consolidates macros used to generate assembly for
compatibility across different CPUs or configs. A new header,
asm-powerpc/asm-compat.h contains the main compatibility macros. It
uses some preprocessor magic to make the macros suitable both for use
in .S files, and in inline asm in .c files. Headers (bitops.h,
uaccess.h, atomic.h, bug.h) which had their own such compatibility
macros are changed to use asm-compat.h.
ppc_asm.h is now for use in .S files *only*, and a #error enforces
that. As such, we're a lot more careless about namespace pollution
here than in asm-compat.h.
While we're at it, this patch adds a call to the PPC405_ERR77 macro in
futex.h which should have had it already, but didn't.
Built and booted on pSeries, Maple and iSeries (ARCH=powerpc). Built
for 32-bit powermac (ARCH=powerpc) and Walnut (ARCH=ppc).
Signed-off-by: David Gibson <dwg@au1.ibm.com>
Signed-off-by: Paul Mackerras <paulus@samba.org>
2005-11-10 04:56:55 +03:00
# include < a s m / p p c _ a s m . h >
2005-09-28 07:28:01 +04:00
.text
/* unsigned long local_save_flags(void) */
_ GLOBAL( l o c a l _ g e t _ f l a g s )
lbz r3 ,P A C A P R O C E N A B L E D ( r13 )
blr
/* unsigned long local_irq_disable(void) */
_ GLOBAL( l o c a l _ i r q _ d i s a b l e )
lbz r3 ,P A C A P R O C E N A B L E D ( r13 )
li r4 ,0
stb r4 ,P A C A P R O C E N A B L E D ( r13 )
blr / * D o n e * /
/* void local_irq_restore(unsigned long flags) */
_ GLOBAL( l o c a l _ i r q _ r e s t o r e )
lbz r5 ,P A C A P R O C E N A B L E D ( r13 )
/* Check if things are setup the way we want _already_. */
cmpw 0 ,r3 ,r5
beqlr
/* are we enabling interrupts? */
cmpdi 0 ,r3 ,0
stb r3 ,P A C A P R O C E N A B L E D ( r13 )
beqlr
/* Check pending interrupts */
/ * A d e c r e m e n t e r , I P I o r P M C i n t e r r u p t m a y h a v e o c c u r r e d
* while w e w e r e i n t h e h y p e r v i s o r ( w h i c h e n a b l e s ) * /
2006-01-13 02:26:42 +03:00
ld r4 ,P A C A L P P A C A P T R ( r13 )
ld r4 ,L P P A C A A N Y I N T ( r4 )
2005-09-28 07:28:01 +04:00
cmpdi r4 ,0
beqlr
/ *
* Handle p e n d i n g i n t e r r u p t s i n i n t e r r u p t c o n t e x t
* /
li r0 ,0 x55 5 5
sc
blr