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 .
*/
2016-06-07 16:29:37 +02:00
# ifndef LPC2387_H
# define LPC2387_H
2010-09-22 15:10:42 +02:00
2017-03-06 16:28:11 +01:00
# include "vendor/lpc23xx.h"
2015-07-17 10:05:33 +02:00
# include "arm7_common.h"
2013-12-16 17:54:58 +01:00
# include "bitarithm.h"
2010-09-22 15:10:42 +02:00
2014-10-13 10:53:20 +02:00
# ifdef __cplusplus
extern " C " {
# endif
2014-07-31 20:46:28 +02:00
# define F_CCO 288000000
# define CL_CPU_DIV 4 ///< CPU clock divider
# 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
2019-10-27 00:47:40 +02:00
# define PLLCFG_N(n) ((n - 1) << 16)
# define PLLCFG_M(m) (m - 1)
2010-09-22 15:10:42 +02:00
# 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
/**
* @ 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 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
* @ {
*/
2019-11-04 01:15:18 +01:00
# define ULSR_RDR BIT0
2014-07-31 20:46:28 +02:00
# 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
/** @} */
/** @} */
2014-10-13 10:53:20 +02:00
# ifdef __cplusplus
}
# endif
2016-06-07 16:29:37 +02:00
# endif /* LPC2387_H */