URL
https://opencores.org/ocsvn/aemb/aemb/trunk
[/] [aemb/] [trunk/] [sw/] [cc/] [aemb/] [stack.hh] - Diff between revs 121 and 128
Go to most recent revision |
Show entire file |
Details |
Blame |
View Log
Rev 121 |
Rev 128 |
Line 1... |
Line 1... |
/* $Id: stack.hh,v 1.2 2008-04-20 16:35:53 sybreon Exp $
|
/* $Id: stack.hh,v 1.3 2008-04-23 14:19:39 sybreon Exp $
|
**
|
**
|
** AEMB2 HI-PERFORMANCE CPU
|
** AEMB2 HI-PERFORMANCE CPU
|
** Copyright (C) 2004-2007 Shawn Tan Ser Ngiap
|
** Copyright (C) 2004-2007 Shawn Tan Ser Ngiap
|
**
|
**
|
** This file is part of AEMB.
|
** This file is part of AEMB.
|
Line 73... |
Line 73... |
*/
|
*/
|
|
|
inline int getStack()
|
inline int getStack()
|
{
|
{
|
int tmp;
|
int tmp;
|
asm ("or %0, r0, r1":"=r"(tmp));
|
asm ("addk %0, r0, r1":"=r"(tmp));
|
return tmp;
|
return tmp;
|
}
|
}
|
|
|
/**
|
/**
|
Sets register R1 to the new stack pointer.
|
Sets register R1 to the new stack pointer.
|
@param stk new stack pointer
|
@param stk new stack pointer
|
*/
|
*/
|
|
|
inline void setStack(int stk)
|
inline void setStack(int stk)
|
{
|
{
|
asm ("or r1, r0, %0"::"r"(stk));
|
asm ("addk r1, r0, %0"::"r"(stk));
|
}
|
}
|
|
|
#ifdef __cplusplus
|
#ifdef __cplusplus
|
}
|
}
|
#endif
|
#endif
|
|
|
#endif
|
#endif
|
|
|
/*
|
/*
|
$Log: not supported by cvs2svn $
|
$Log: not supported by cvs2svn $
|
|
Revision 1.2 2008/04/20 16:35:53 sybreon
|
|
Added C/C++ compatible #ifdef statements
|
|
|
Revision 1.1 2008/04/09 19:48:37 sybreon
|
Revision 1.1 2008/04/09 19:48:37 sybreon
|
Added new C++ files
|
Added new C++ files
|
|
|
*/
|
*/
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.