2010-09-22 15:10:42 +02:00
/*
* Copyright ( C ) 2009 Kaspar Schleiser < kaspar @ schleiser . de >
*
2014-11-09 15:06:25 +01:00
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2 .1 . See the file LICENSE in the top level
* directory for more details .
*
2010-09-22 15:10:42 +02:00
* Parts taken from FeuerWhere - Project , lpc2387 . h .
*/
# ifndef __LPC2387_H
# define __LPC2387_H
2013-12-16 17:54:58 +01:00
# include "lpc23xx.h"
# include "bitarithm.h"
2010-09-22 15:10:42 +02:00
2014-07-31 20:46:28 +02:00
# define F_CCO 288000000
# define CL_CPU_DIV 4 ///< CPU clock divider
# define F_CPU (F_CCO / CL_CPU_DIV) ///< CPU target speed in Hz
# define F_RC_OSCILLATOR 4000000 ///< Frequency of internal RC oscillator
# define F_RTC_OSCILLATOR 32767 ///< Frequency of RTC oscillator
2010-09-22 15:10:42 +02:00
# define VIC_SIZE 32
# define GPIO_INT 17
# define IRQP_GPIO 4
2010-11-29 19:19:59 +01:00
# define _XTAL (72000)
2010-09-22 15:10:42 +02:00
/**
2014-07-31 20:46:28 +02:00
* @ name Timer Symbols
2010-09-22 15:10:42 +02:00
* @ {
*/
# define MR0I BIT0
# define MR0R BIT1
# define MR0S BIT2
# define MR1I BIT3
# define MR1R BIT4
# define MR1S BIT5
# define MR2I BIT6
# define MR2R BIT7
# define MR2S BIT8
# define MR3I BIT9
# define MR3R BIT10
# define MR3S BIT11
/** @} */
/**
* @ name RTC constants
* @ {
*/
2014-07-31 20:46:28 +02:00
# define IMSEC 0x00000001
# define IMMIN 0x00000002
# define IMHOUR 0x00000004
# define IMDOM 0x00000008
# define IMDOW 0x00000010
# define IMDOY 0x00000020
# define IMMON 0x00000040
# define IMYEAR 0x00000080
# define AMRSEC 0x00000001 /* Alarm mask for Seconds */
# define AMRMIN 0x00000002 /* Alarm mask for Minutes */
# define AMRHOUR 0x00000004 /* Alarm mask for Hours */
# define AMRDOM 0x00000008 /* Alarm mask for Day of Month */
# define AMRDOW 0x00000010 /* Alarm mask for Day of Week */
# define AMRDOY 0x00000020 /* Alarm mask for Day of Year */
# define AMRMON 0x00000040 /* Alarm mask for Month */
# define AMRYEAR 0x00000080 /* Alarm mask for Year */
# define ILR_RTCCIF BIT0
# define ILR_RTCALF BIT1
# define ILR_RTSSF BIT2
# define CCR_CLKEN 0x01
# define CCR_CTCRST 0x02
# define CCR_CLKSRC 0x10
2010-09-22 15:10:42 +02:00
/** @} */
/**
* @ name WD constants
* @ {
*/
2014-07-31 20:46:28 +02:00
# define WDEN BIT0
# define WDRESET BIT1
# define WDTOF BIT2
# define WDINT BIT3
2010-09-22 15:10:42 +02:00
/** @} */
/**
2014-07-31 20:46:28 +02:00
* @ name PCONP Constants
2010-09-22 15:10:42 +02:00
* @ {
*/
2014-07-31 20:46:28 +02:00
# define PCTIM0 BIT1
# define PCTIM1 BIT2
# define PCUART0 BIT3
# define PCUART1 BIT4
# define PCPWM1 BIT6
# define PCI2C0 BIT7
# define PCSPI BIT8
# define PCRTC BIT9
# define PCSSP1 BIT10
# define PCEMC BIT11
# define PCAD BIT12
# define PCAN1 BIT13
# define PCAN2 BIT14
# define PCI2C1 BIT19
# define PCSSP0 BIT21
# define PCTIM2 BIT22
# define PCTIM3 BIT23
# define PCUART2 BIT24
# define PCUART3 BIT25
# define PCI2C2 BIT26
# define PCI2S BIT27
# define PCSDC BIT28
# define PCGPDMA BIT29
# define PCENET BIT30
# define PCUSB BIT31
2010-09-22 15:10:42 +02:00
/** @} */
/**
2014-07-31 20:46:28 +02:00
* @ name PCON Constants
2010-09-22 15:10:42 +02:00
* @ {
*/
2014-07-31 20:46:28 +02:00
# define PM0 BIT0
# define PM1 BIT1
# define BODPDM BIT2
# define BOGD BIT3
# define BORD BIT4
# define PM2 BIT7
# define PM_IDLE (PM0)
# define PM_SLEEP (PM2|PM0)
# define PM_POWERDOWN (PM1)
2010-09-22 15:10:42 +02:00
/** @} */
/**
2014-07-31 20:46:28 +02:00
* @ name INTWAKE Constants
2010-09-22 15:10:42 +02:00
* @ {
*/
2014-07-31 20:46:28 +02:00
# define EXTWAKE0 BIT0
# define EXTWAKE1 BIT1
# define EXTWAKE2 BIT2
# define EXTWAKE3 BIT3
# define ETHWAKE BIT4
# define USBWAKE BIT5
# define CANWAKE BIT6
# define GPIO0WAKE BIT7
# define GPIO2WAKE BIT8
# define BODWAKE BIT14
# define RTCWAKE BIT15
2010-09-22 15:10:42 +02:00
/** @} */
/**
* @ name UART Constants
* @ {
*/
2014-07-31 20:46:28 +02:00
# define ULSR_RDR BIT0
# define ULSR_OE BIT1
# define ULSR_PE BIT2
# define ULSR_FE BIT3
# define ULSR_BI BIT4
# define ULSR_THRE BIT5
# define ULSR_TEMT BIT6
# define ULSR_RXFE BIT7
# define UIIR_INT_STATUS (BIT0) ///< Interrupt Status
# define UIIR_THRE_INT (BIT1) ///< Transmit Holding Register Empty
# define UIIR_RDA_INT (BIT2) ///< Receive Data Available
# define UIIR_RLS_INT (BIT1 | BIT2) ///< Receive Line Status
# define UIIR_CTI_INT (BIT2 | BIT3) ///< Character Timeout Indicator
2010-09-22 15:10:42 +02:00
# define UIIR_ID_MASK (BIT1 | BIT2 | BIT3)
2014-07-31 20:46:28 +02:00
# define UIIR_ABEO_INT BIT8
# define UIIR_ABTO_INT BIT9
2010-09-22 15:10:42 +02:00
/** @} */
/**
2014-07-31 20:46:28 +02:00
* @ name SSP Status Register Constants
2010-09-22 15:10:42 +02:00
* @ {
*/
2014-07-31 20:46:28 +02:00
# define SSPSR_TFE BIT0 ///< Transmit FIFO Empty. This bit is 1 is the Transmit FIFO is empty, 0 if not.
# define SSPSR_TNF BIT1 ///< Transmit FIFO Not Full. This bit is 0 if the Tx FIFO is full, 1 if not.
# define SSPSR_RNE BIT2 ///< Receive FIFO Not Empty. This bit is 0 if the Receive FIFO is empty, 1 if not.
# define SSPSR_RFF BIT3 ///< Receive FIFO Full. This bit is 1 if the Receive FIFO is full, 0 if not.
# define SSPSR_BSY BIT4 ///< Busy. This bit is 0 if the SSPn controller is idle, or 1 if it is currently sending/receiving a frame and/or the Tx FIFO is not empty.
2010-09-22 15:10:42 +02:00
/** @} */
/**
* @ name Timer register offsets
* @ {
*/
# define TXIR 0x00
# define TXTCR 0x04
2014-07-31 20:46:28 +02:00
# define TXTC 0x08 ///< Timer counter
2010-09-22 15:10:42 +02:00
# define TXPR 0x0C
# define TXPC 0x10
# define TXMCR 0x14
# define TXMR0 0x18
# define TXMR1 0x1C
# define TXMR2 0x20
# define TXMR3 0x24
# define TXCCR 0x28
# define TXCR0 0x2C
# define TXCR1 0x30
# define TXCR2 0x34
# define TXCR3 0x38
# define TXEMR 0x3C
# define TXCTCR 0x70
/** @} */
/** @} */
# endif // __LPC2387_H