12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- /*
- * Copyright (c) 2008-2012, Freescale Semiconductor, Inc.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without modification,
- * are permitted provided that the following conditions are met:
- *
- * o Redistributions of source code must retain the above copyright notice, this list
- * of conditions and the following disclaimer.
- *
- * o Redistributions in binary form must reproduce the above copyright notice, this
- * list of conditions and the following disclaimer in the documentation and/or
- * other materials provided with the distribution.
- *
- * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
- * contributors may be used to endorse or promote products derived from this
- * software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
- * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
- * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
- /*!
- * @file asm_defines.h
- * @brief defines for startup assembly code
- *
- * @ingroup diag_util
- */
- #ifndef _ASM_DEFINES_H_
- #define _ASM_DEFINES_H_
- ////////////////////////////////////////////////////////////////////////////////
- // Definitions
- ////////////////////////////////////////////////////////////////////////////////
- //! @name CPSR fields
- //@{
- #define CPSR_N (1 << 31) //!< Negative
- #define CPSR_Z (1 << 30) //!< Zero
- #define CPSR_C (1 << 29) //!< Carry
- #define CPSR_V (1 << 28) //!< Overflow
- #define CPSR_Q (1 << 27) //!< Saturation
- #define CPSR_E (1 << 9) //!< Endianness
- #define CPSR_A (1 << 8) //!< Async abort mask
- #define CPSR_I (1 << 7) //!< IRQ mask
- #define CPSR_F (1 << 6) //!< FIQ mask
- #define CPSR_T (1 << 5) //!< Thumb mode
- #define CPSR_MODE (0x1f) //!< Current processor mode
- //@}
- //! @name Mode bits in CPSR
- //@{
- #define MODE_USR 0x10 //!< User mode
- #define MODE_FIQ 0x11 //!< FIQ mode
- #define MODE_IRQ 0x12 //!< IRQ mode
- #define MODE_SVC 0x13 //!< Supervisor mode
- #define MODE_ABT 0x17 //!< Abort exception mode
- #define MODE_UND 0x1B //!< Undefined instruction exception mode
- #define MODE_SYS 0x1F //!< System mode
- //@}
- //! @name Interrupt enable bits in CPSR
- //@{
- #define I_BIT 0x80 //!< When I bit is set, IRQ is disabled
- #define F_BIT 0x40 //!< When F bit is set, FIQ is disabled
- //@}
- //! @name Stack sizes
- //@{
- //! @brief Size of stacks for exceptions.
- #define EXCEPTION_STACK_SIZE 2048
- //! @brief Supervisor mode stack size.
- //!
- //! This stack is much larger because most application code runs in
- //! Supervisor mode.
- #define SVC_STACK_SIZE 8192
- //@}
- #endif /*_ASM_DEFINES_H_ */
- ////////////////////////////////////////////////////////////////////////////////
- // EOF
- ////////////////////////////////////////////////////////////////////////////////
|