Switch from GPLv2 to GPLv2+
[fw/altos] / src / lpc / lpc.h
index 87af494a9c90274b3bc7e3e1859aac68a13d6c3f..38dd2aeedb2c222e4351c9d287ff393c736c0772 100644 (file)
@@ -3,7 +3,8 @@
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; version 2 of the License.
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful, but
  * WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -116,11 +117,11 @@ extern struct lpc_ioconf lpc_ioconf;
 #define  LPC_IOCONF_FUNC_SSEL0         1
 #define  LPC_IOCONF_FUNC_CT16B0_CAP0   2
 
-/* PIO0_3
+/* PIO0_3 */
 #define  LPC_IOCONF_FUNC_PIO0_3                0
 #define  LPC_IOCONF_FUNC_USB_VBUS      1
 
-/* PIO0_4
+/* PIO0_4 */
 #define  LPC_IOCONF_FUNC_PIO0_4                0
 #define  LPC_IOCONF_FUNC_I2C_SCL       1
 
@@ -131,13 +132,13 @@ extern struct lpc_ioconf lpc_ioconf;
 /* PIO0_6 */
 #define  LPC_IOCONF_FUNC_PIO0_6                0
 #define  LPC_IOCONF_FUNC_USB_CONNECT   1
-#define  LPC_IOCONF_FUNC_SCK0          2
+#define  LPC_IOCONF_FUNC_PIO0_6_SCK0   2
 
 /* PIO0_7 */
 #define  LPC_IOCONF_FUNC_PIO0_7                0
 #define  LPC_IOCONF_FUNC_CTS           1
 
-/* PIO0_8
+/* PIO0_8 */
 #define  LPC_IOCONF_FUNC_PIO0_8                0
 #define  LPC_IOCONF_FUNC_MISO0         1
 #define  LPC_IOCONF_FUNC_CT16B0_MAT0   2
@@ -150,7 +151,7 @@ extern struct lpc_ioconf lpc_ioconf;
 /* PIO0_10 */
 #define  LPC_IOCONF_FUNC_SWCLK         0
 #define  LPC_IOCONF_FUNC_PIO0_10       1
-#define  LPC_IOCONF_FUNC_SCK0          2
+#define  LPC_IOCONF_FUNC_PIO0_10_SCK0  2
 #define  LPC_IOCONF_FUNC_CT16B0_MAT2   3
 
 /* PIO0_11 */
@@ -211,13 +212,13 @@ extern struct lpc_ioconf lpc_ioconf;
 /* PIO0_21 */
 #define  LPC_IOCONF_FUNC_PIO0_21       0
 #define  LPC_IOCONF_FUNC_CT16B1_MAT0   1
-#define  LPC_IOCONF_FUNC_MOSI1         2
+#define  LPC_IOCONF_FUNC_PIO0_21_MOSI1 2
 
 /* PIO0_22 */
 #define  LPC_IOCONF_FUNC_PIO0_22       0
 #define  LPC_IOCONF_FUNC_AD6           1
 #define  LPC_IOCONF_FUNC_CT16B1_MAT1   2
-#define  LPC_IOCONF_FUNC_MISO1         3
+#define  LPC_IOCONF_FUNC_PIO0_22_MISO1 3
 
 /* PIO0_23 */
 #define  LPC_IOCONF_FUNC_PIO0_23       0
@@ -284,7 +285,7 @@ extern struct lpc_ioconf lpc_ioconf;
 #define  LPC_IOCONF_FUNC_PIO1_15       0
 #define  LPC_IOCONF_FUNC_DCD           1
 #define  LPC_IOCONF_FUNC_PIO1_15_CT16B0_MAT2   2
-#define  LPC_IOCONF_FUNC_SCK1          3
+#define  LPC_IOCONF_FUNC_PIO1_15_SCK1  3
 
 /* PIO1_16 */
 #define  LPC_IOCONF_FUNC_PIO1_16       0
@@ -319,7 +320,7 @@ extern struct lpc_ioconf lpc_ioconf;
 /* PIO1_22 */
 #define  LPC_IOCONF_FUNC_PIO1_22       0
 #define  LPC_IOCONF_FUNC_RI            1
-#define  LPC_IOCONF_FUNC_MOSI1         2
+#define  LPC_IOCONF_FUNC_PIO1_22_MOSI1 2
 
 /* PIO1_23 */
 #define  LPC_IOCONF_FUNC_PIO1_23       0
@@ -359,6 +360,13 @@ extern struct lpc_ioconf lpc_ioconf;
 
 #define  LPC_IOCONF_FUNC_MASK          0x7
 
+#define ao_lpc_alternate(func) (((func) << LPC_IOCONF_FUNC) | \
+                               (LPC_IOCONF_MODE_INACTIVE << LPC_IOCONF_MODE) | \
+                               (0 << LPC_IOCONF_HYS) |                 \
+                               (0 << LPC_IOCONF_INV) |                 \
+                               (0 << LPC_IOCONF_OD) |                  \
+                               0x80)
+
 #define LPC_IOCONF_MODE                        3
 #define  LPC_IOCONF_MODE_INACTIVE              0
 #define  LPC_IOCONF_MODE_PULL_DOWN             1
@@ -369,6 +377,8 @@ extern struct lpc_ioconf lpc_ioconf;
 #define LPC_IOCONF_HYS                 5
 
 #define LPC_IOCONF_INV                 6
+#define LPC_IOCONF_ADMODE              7
+#define LPC_IOCONF_FILTR               8
 #define LPC_IOCONF_OD                  10
 
 struct lpc_scb {
@@ -395,14 +405,14 @@ struct lpc_scb {
        vuint32_t       syspllclksel;   /* 0x40 */
        vuint32_t       syspllclkuen;
        vuint32_t       usbpllclksel;
-       vuint32_t       usbplllclkuen;
+       vuint32_t       usbpllclkuen;
 
        uint32_t        r50[8];
 
        vuint32_t       mainclksel;     /* 0x70 */
        vuint32_t       mainclkuen;
        vuint32_t       sysahbclkdiv;
-       uint32_t        r7c;            
+       uint32_t        r7c;
 
        vuint32_t       sysahbclkctrl;  /* 0x80 */
        uint32_t        r84[3];
@@ -420,14 +430,14 @@ struct lpc_scb {
        uint32_t        rcc;
 
        uint32_t        rd0[4];
-       
+
        vuint32_t       clkoutsel;      /* 0xe0 */
        vuint32_t       clkoutuen;
        vuint32_t       clkoutdiv;
        uint32_t        rec;
-       
+
        uint32_t        rf0[4];         /* 0xf0 */
-       
+
        vuint32_t       pioporcap0;     /* 0x100 */
        vuint32_t       pioporcap1;
        uint32_t        r102[2];
@@ -436,7 +446,7 @@ struct lpc_scb {
        uint32_t        r120[4];        /* 0x120 */
        uint32_t        r130[4];        /* 0x130 */
        uint32_t        r140[4];        /* 0x140 */
-       
+
        vuint32_t       bodctrl;        /* 0x150 */
        vuint32_t       systckcal;
        uint32_t        r158[2];
@@ -445,17 +455,9 @@ struct lpc_scb {
 
        vuint32_t       irqlatency;     /* 0x170 */
        vuint32_t       nmisrc;
-       vuint32_t       pintsel0;
-       vuint32_t       pintsel1;
-
-       vuint32_t       pintsel2;       /* 0x180 */
-       vuint32_t       pintsel3;
-       vuint32_t       pintsel4;
-       vuint32_t       pintsel5;
+       vuint32_t       pintsel[8];
 
-       vuint32_t       pintsel6;       /* 0x190 */
-       vuint32_t       pintsel7;
-       vuint32_t       usbclkctrl;
+       vuint32_t       usbclkctrl;     /* 0x198 */
        vuint32_t       usbclkst;
 
        uint32_t        r1a0[6*4];      /* 0x1a0 */
@@ -478,13 +480,18 @@ struct lpc_scb {
        uint32_t        r240[12 * 4];   /* 0x240 */
 
        uint32_t        r300[15 * 4];   /* 0x300 */
-                            
+
        uint32_t        r3f0;           /* 0x3f0 */
        vuint32_t       device_id;
 };
 
 extern struct lpc_scb lpc_scb;
 
+#define LPC_SCB_SYSMEMREMAP_MAP                0
+# define LPC_SCB_SYSMEMREMAP_MAP_BOOT_LOADER   0
+# define LPC_SCB_SYSMEMREMAP_MAP_RAM           1
+# define LPC_SCB_SYSMEMREMAP_MAP_FLASH         2
+
 #define LPC_SCB_PRESETCTRL_SSP0_RST_N  0
 #define LPC_SCB_PRESETCTRL_I2C_RST_N   1
 #define LPC_SCB_PRESETCTRL_SSP1_RST_N  2
@@ -600,8 +607,25 @@ extern struct lpc_scb lpc_scb;
 #define LPC_SCB_USBCLKUEN_ENA          0
 #define LPC_SCB_USBCLKDIV_DIV          0
 
-#define LPC_SCB_CLKOUTSEL_
-#define LPC_SCB_CLKOUTUEN_
+#define LPC_SCB_CLKOUTSEL_SEL          0
+#define  LPC_SCB_CLKOUTSEL_SEL_IRC             0
+#define  LPC_SCB_CLKOUTSEL_SEL_SYSOSC          1
+#define  LPC_SCB_CLKOUTSEL_SEL_LF              2
+#define  LPC_SCB_CLKOUTSEL_SEL_MAIN_CLOCK      3
+
+#define LPC_SCB_CLKOUTUEN_ENA          0
+
+#define LPC_SCB_BOD_BODRSTLEV          0
+# define LPC_SCB_BOD_BODRSTLEV_1_46            0
+# define LPC_SCB_BOD_BODRSTLEV_2_06            1
+# define LPC_SCB_BOD_BODRSTLEV_2_35            2
+# define LPC_SCB_BOD_BODRSTLEV_2_63            3
+#define LPC_SCB_BOD_BODINTVAL          2
+# define LPC_SCB_BOD_BODINTVAL_RESERVED                0
+# define LPC_SCB_BOD_BODINTVAL_2_22            1
+# define LPC_SCB_BOD_BODINTVAL_2_52            2
+# define LPC_SCB_BOD_BODINTVAL_2_80            3
+#define LPC_SCB_BOD_BODRSTENA          4
 
 #define LPC_SCB_PDRUNCFG_IRCOUT_PD     0
 #define LPC_SCB_PDRUNCFG_IRC_PD                1
@@ -623,6 +647,18 @@ struct lpc_flash {
 extern struct lpc_flash lpc_flash;
 
 struct lpc_gpio_pin {
+       vuint32_t       isel;           /* 0x00 */
+       vuint32_t       ienr;
+       vuint32_t       sienr;
+       vuint32_t       cienr;
+
+       vuint32_t       ienf;           /* 0x10 */
+       vuint32_t       sienf;
+       vuint32_t       cienf;
+       vuint32_t       rise;
+
+       vuint32_t       fall;           /* 0x20 */
+       vuint32_t       ist;
 };
 
 extern struct lpc_gpio_pin lpc_gpio_pin;
@@ -645,7 +681,7 @@ struct lpc_gpio {
        vuint32_t       word[0x40];     /* 0x1000 */
 
        uint8_t         r1100[0x2000 - 0x1100];
-       
+
        vuint32_t       dir[2];         /* 0x2000 */
 
        uint8_t         r2008[0x2080 - 0x2008];
@@ -720,4 +756,595 @@ struct lpc_usart {
 
 extern struct lpc_usart lpc_usart;
 
+#define LPC_USART_IER_RBRINTEN 0
+#define LPC_USART_IER_THREINTEN        1
+#define LPC_USART_IER_RSLINTEN 2
+#define LPC_USART_IER_MSINTEN  3
+#define LPC_USART_IER_ABEOINTEN        8
+#define LPC_USART_IER_ABTOINTEN        9
+
+#define LPC_USART_IIR_INTSTATUS                0
+#define LPC_USART_IIR_INTID            1
+#define LPC_USART_IIR_INTID_RLS                        3
+#define LPC_USART_IIR_INTID_RDA                        2
+#define LPC_USART_IIR_INTID_CTI                        6
+#define LPC_USART_IIR_INTID_THRE               1
+#define LPC_USART_IIR_INTID_MS                 0
+#define LPC_USART_IIR_INTID_MASK               7
+#define LPC_USART_IIR_FIFOEN           6
+#define LPC_USART_IIR_ABEOINT          8
+#define LPC_USART_IIR_ABTOINT          9
+
+#define LPC_USART_FCR_FIFOEN           0
+#define LPC_USART_FCR_RXFIFORES                1
+#define LPC_USART_FCR_TXFIFORES                2
+#define LPC_USART_FCR_RXTL             6
+#define LPC_USART_FCR_RXTL_1                   0
+#define LPC_USART_FCR_RXTL_4                   1
+#define LPC_USART_FCR_RXTL_8                   2
+#define LPC_USART_FCR_RXTL_14                  3
+
+#define LPC_USART_LCR_WLS      0
+#define LPC_USART_LCR_WLS_5            0
+#define LPC_USART_LCR_WLS_6            1
+#define LPC_USART_LCR_WLS_7            2
+#define LPC_USART_LCR_WLS_8            3
+#define LPC_USART_LCR_WLS_MASK         3
+#define LPC_USART_LCR_SBS      2
+#define LPC_USART_LCR_SBS_1            0
+#define LPC_USART_LCR_SBS_2            1
+#define LPC_USART_LCR_SBS_MASK         1
+#define LPC_USART_LCR_PE       3
+#define LPC_USART_LCR_PS       4
+#define LPC_USART_LCR_PS_ODD           0
+#define LPC_USART_LCR_PS_EVEN          1
+#define LPC_USART_LCR_PS_ONE           2
+#define LPC_USART_LCR_PS_ZERO          3
+#define LPC_USART_LCR_PS_MASK          3
+#define LPC_USART_LCR_BC       6
+#define LPC_USART_LCR_DLAB     7
+
+#define LPC_USART_MCR_DTRCTRL  0
+#define LPC_USART_MCR_RTSCTRL  1
+#define LPC_USART_MCR_LMS      4
+#define LPC_USART_MCR_RTSEN    6
+#define LPC_USART_MCR_CTSEN    7
+
+#define LPC_USART_LSR_RDR      0
+#define LPC_USART_LSR_OE       1
+#define LPC_USART_LSR_PE       2
+#define LPC_USART_LSR_FE       3
+#define LPC_USART_LSR_BI       4
+#define LPC_USART_LSR_THRE     5
+#define LPC_USART_LSR_TEMT     6
+#define LPC_USART_LSR_RXFE     7
+#define LPC_USART_LSR_TXERR    8
+
+#define LPC_USART_MSR_DCTS     0
+#define LPC_USART_MSR_DDSR     1
+#define LPC_USART_MSR_TERI     2
+#define LPC_USART_MSR_DDCD     3
+#define LPC_USART_MSR_CTS      4
+#define LPC_USART_MSR_DSR      5
+#define LPC_USART_MSR_RI       6
+#define LPC_USART_MSR_DCD      7
+
+#define LPC_USART_ACR_START    0
+#define LPC_USART_ACR_MODE     1
+#define LPC_USART_ACR_AUTORESTART      2
+#define LPC_USART_ACR_ABEOINTCLR       8
+#define LPC_USART_ACR_ABTOINTCLR       9
+
+#define LPC_USART_FDR_DIVADDVAL        0
+#define LPC_USART_FDR_MULVAL   4
+
+#define LPC_USART_OSR_OSFRAC   1
+#define LPC_USART_OSR_OSINT    4
+#define LPC_USART_OSR_FDINT    8
+
+#define LPC_USART_TER_TXEN     7
+
+#define LPC_USART_HDEN_HDEN    0
+
+struct lpc_usb {
+       vuint32_t       devcmdstat;
+       vuint32_t       info;
+       vuint32_t       epliststart;
+       vuint32_t       databufstart;
+       vuint32_t       lpm;
+       vuint32_t       epskip;
+       vuint32_t       epinuse;
+       vuint32_t       epbufcfg;
+       vuint32_t       intstat;
+       vuint32_t       inten;
+       vuint32_t       intsetstat;
+       vuint32_t       introuting;
+       uint32_t        r30;
+       vuint32_t       eptoggle;
+} lpc_usb;
+
+extern struct lpc_usb lpc_usb;
+
+#define LPC_USB_DEVCMDSTAT_DEV_ADDR    0
+#define LPC_USB_DEVCMDSTAT_DEV_ADDR_MASK       0x7f
+#define LPC_USB_DEVCMDSTAT_DEV_EN      7
+#define LPC_USB_DEVCMDSTAT_SETUP       8
+#define LPC_USB_DEVCMDSTAT_PLL_ON      9
+#define LPC_USB_DEVCMDSTAT_LPM_SUP     11
+#define LPC_USB_DEVCMDSTAT_INTONNAK_AO 12
+#define LPC_USB_DEVCMDSTAT_INTONNAK_AI 13
+#define LPC_USB_DEVCMDSTAT_INTONNAK_CO 14
+#define LPC_USB_DEVCMDSTAT_INTONNAK_CI 15
+#define LPC_USB_DEVCMDSTAT_DCON                16
+#define LPC_USB_DEVCMDSTAT_DSUS                17
+#define LPC_USB_DEVCMDSTAT_LPM_SUS     19
+#define LPC_USB_DEVCMDSTAT_LPM_REWP    20
+#define LPC_USB_DEVCMDSTAT_DCON_C      24
+#define LPC_USB_DEVCMDSTAT_DSUS_C      25
+#define LPC_USB_DEVCMDSTAT_DRES_C      26
+#define LPC_USB_DEVCMDSTAT_VBUSDEBOUNCED       28
+
+#define LPC_USB_INFO_FRAME_NR          0
+#define LPC_USB_INFO_FRAME_NR_MASK     0x3ff
+#define LPC_USB_INFO_ERR_CODE          11
+#define LPC_USB_INFO_ERR_CODE_NO_ERROR                 0
+#define LPC_USB_INFO_ERR_CODE_PID_ENCODING_ERROR       1
+#define LPC_USB_INFO_ERR_CODE_PID_UNKNOWN              2
+#define LPC_USB_INFO_ERR_CODE_PACKET_UNEXPECTED                3
+#define LPC_USB_INFO_ERR_CODE_TOKEN_CRC_ERROR          4
+#define LPC_USB_INFO_ERR_CODE_DATA_CRC_ERROR           5
+#define LPC_USB_INFO_ERR_CODE_TIME_OUT                 6
+#define LPC_USB_INFO_ERR_CODE_BABBLE                   7
+#define LPC_USB_INFO_ERR_CODE_TRUNCATED_EOP            8
+#define LPC_USB_INFO_ERR_CODE_SENT_RECEIVED_NAK                9
+#define LPC_USB_INFO_ERR_CODE_SENT_STALL               0xa
+#define LPC_USB_INFO_ERR_CODE_OVERRUN                  0xb
+#define LPC_USB_INFO_ERR_CODE_SENT_EMPTY_PACKET                0xc
+#define LPC_USB_INFO_ERR_CODE_BITSTUFF_ERROR           0xd
+#define LPC_USB_INFO_ERR_CODE_SYNC_ERROR               0xe
+#define LPC_USB_INFO_ERR_CODE_WRONG_DATA_TOGGLE                0xf
+#define LPC_USB_INFO_ERR_CODE_MASK                     0xf
+
+#define LPC_USB_EPLISTSTART_EP_LIST                    0
+
+#define LPC_USB_DATABUFSTART_DA_BUF                    0
+
+#define LPC_USB_LPM_HIRD_HW            0
+#define LPC_USB_LPM_HIRD_HW_MASK               0xf
+#define LPC_USB_LPM_HIRD_SW            4
+#define LPC_USB_LPM_HIRD_SW_MASK               0xf
+#define LPC_USB_LPM_DATA_PENDING       8
+
+#define LPC_USB_EPSKIP_SKIP            0
+
+#define LPC_USB_EPINUSE_BUF(ep)                (ep)
+
+#define LPC_USB_EPBUFCFG_BUF_SB(ep)    (ep)
+
+#define LPC_USB_INT_EPOUT(ep)          ((ep) << 1)
+#define LPC_USB_INT_EPIN(ep)           (((ep) << 1) + 1)
+
+#define LPC_USB_INT_FRAME              30
+#define LPC_USB_INT_DEV                        31
+
+#define LPC_USB_INTIN_EP_INT_EN(ep)    (ep)
+#define LPC_USB_INTIN_FRAME_INT_EN     30
+#define LPC_USB_INTIN_DEV_INT_EN       31
+
+#define LPC_USB_INTSETSTAT_EP_SET_INT(ep)      (ep)
+#define LPC_USB_INTSETSTAT_FRAME_SET_INT       30
+#define LPC_USB_INTSETSTAT_DEV_SET_INT         31
+
+#define LPC_USB_INTROUTING_ROUTE_INT(ep)       (ep)
+#define LPC_USB_INTROUTING_INT30               30
+#define LPC_USB_INTROUTING_INT31               31
+
+#define LPC_USB_EPTOGGLE_TOGGLE(ep)            (ep)
+
+struct lpc_usb_epn {
+       vuint32_t               out[2];
+       vuint32_t               in[2];
+};
+
+struct lpc_usb_endpoint {
+       vuint32_t               ep0_out;
+       vuint32_t               setup;
+       vuint32_t               ep0_in;
+       vuint32_t               reserved_0c;
+       struct lpc_usb_epn      epn[4];
+};
+
+/* Assigned in registers.ld to point at the base
+ * of USB ram
+ */
+
+extern uint8_t lpc_usb_sram[];
+
+#define LPC_USB_EP_ACTIVE              31
+#define LPC_USB_EP_DISABLED            30
+#define LPC_USB_EP_STALL               29
+#define LPC_USB_EP_TOGGLE_RESET                28
+#define LPC_USB_EP_RATE_FEEDBACK       27
+#define LPC_USB_EP_ENDPOINT_ISO                26
+#define LPC_USB_EP_NBYTES              16
+#define  LPC_USB_EP_NBYTES_MASK                        0x3ff
+#define LPC_USB_EP_OFFSET              0
+
+#define LPC_ISR_PIN_INT0_POS   0
+#define LPC_ISR_PIN_INT1_POS   1
+#define LPC_ISR_PIN_INT2_POS   2
+#define LPC_ISR_PIN_INT3_POS   3
+#define LPC_ISR_PIN_INT4_POS   4
+#define LPC_ISR_PIN_INT5_POS   5
+#define LPC_ISR_PIN_INT6_POS   6
+#define LPC_ISR_PIN_INT7_POS   7
+#define LPC_ISR_GINT0_POS      8
+#define LPC_ISR_GINT1_POS      9
+#define LPC_ISR_SSP1_POS       14
+#define LPC_ISR_I2C_POS                15
+#define LPC_ISR_CT16B0_POS     16
+#define LPC_ISR_CT16B1_POS     17
+#define LPC_ISR_CT32B0_POS     18
+#define LPC_ISR_CT32B1_POS     19
+#define LPC_ISR_SSP0_POS       20
+#define LPC_ISR_USART_POS      21
+#define LPC_ISR_USB_IRQ_POS    22
+#define LPC_ISR_USB_FIQ_POS    23
+#define LPC_ISR_ADC_POS                24
+#define LPC_ISR_WWDT_POS       25
+#define LPC_ISR_BOD_POS                26
+#define LPC_ISR_FLASH_POS      27
+#define LPC_ISR_USB_WAKEUP_POS 30
+
+struct lpc_nvic {
+       vuint32_t       iser;           /* 0x000 0xe000e100 Set Enable Register */
+
+       uint8_t         _unused020[0x080 - 0x004];
+
+       vuint32_t       icer;           /* 0x080 0xe000e180 Clear Enable Register */
+
+       uint8_t         _unused0a0[0x100 - 0x084];
+
+       vuint32_t       ispr;           /* 0x100 0xe000e200 Set Pending Register */
+
+       uint8_t         _unused120[0x180 - 0x104];
+
+       vuint32_t       icpr;           /* 0x180 0xe000e280 Clear Pending Register */
+
+       uint8_t         _unused1a0[0x300 - 0x184];
+
+       vuint32_t       ipr[8];         /* 0x300 0xe000e400 Priority Register */
+};
+
+extern struct lpc_nvic lpc_nvic;
+
+static inline void
+lpc_nvic_set_enable(int irq) {
+       lpc_nvic.iser = (1 << irq);
+}
+
+static inline void
+lpc_nvic_clear_enable(int irq) {
+       lpc_nvic.icer = (1 << irq);
+}
+
+static inline int
+lpc_nvic_enabled(int irq) {
+       return (lpc_nvic.iser >> irq) & 1;
+}
+
+
+static inline void
+lpc_nvic_set_pending(int irq) {
+       lpc_nvic.ispr = (1 << irq);
+}
+
+static inline void
+lpc_nvic_clear_pending(int irq) {
+       lpc_nvic.icpr = (1 << irq);
+}
+
+static inline int
+lpc_nvic_pending(int irq) {
+       return (lpc_nvic.ispr >> irq) & 1;
+}
+
+#define IRQ_PRIO_REG(irq)      ((irq) >> 2)
+#define IRQ_PRIO_BIT(irq)      (((irq) & 3) << 3)
+#define IRQ_PRIO_MASK(irq)     (0xff << IRQ_PRIO_BIT(irq))
+
+static inline void
+lpc_nvic_set_priority(int irq, uint8_t prio) {
+       int             n = IRQ_PRIO_REG(irq);
+       uint32_t        v;
+
+       v = lpc_nvic.ipr[n];
+       v &= ~IRQ_PRIO_MASK(irq);
+       v |= (prio) << IRQ_PRIO_BIT(irq);
+       lpc_nvic.ipr[n] = v;
+}
+
+static inline uint8_t
+lpc_nvic_get_priority(int irq) {
+       return (lpc_nvic.ipr[IRQ_PRIO_REG(irq)] >> IRQ_PRIO_BIT(irq)) & IRQ_PRIO_MASK(0);
+}
+
+struct arm_scb {
+       vuint32_t       cpuid;
+       vuint32_t       icsr;
+       uint32_t        reserved08;
+       vuint32_t       aircr;
+
+       vuint32_t       scr;
+       vuint32_t       ccr;
+       uint32_t        reserved18;
+       vuint32_t       shpr2;
+
+       vuint32_t       shpr3;
+};
+
+extern struct arm_scb arm_scb;
+
+struct lpc_ssp {
+       vuint32_t       cr0;    /* 0x00 */
+       vuint32_t       cr1;
+       vuint32_t       dr;
+       vuint32_t       sr;
+
+       vuint32_t       cpsr;   /* 0x10 */
+       vuint32_t       imsc;
+       vuint32_t       ris;
+       vuint32_t       mis;
+
+       vuint32_t       icr;    /* 0x20 */
+};
+
+extern struct lpc_ssp lpc_ssp0, lpc_ssp1;
+
+#define LPC_NUM_SPI            2
+
+#define LPC_SSP_FIFOSIZE       8
+
+#define LPC_SSP_CR0_DSS                0
+#define  LPC_SSP_CR0_DSS_4             0x3
+#define  LPC_SSP_CR0_DSS_5             0x4
+#define  LPC_SSP_CR0_DSS_6             0x5
+#define  LPC_SSP_CR0_DSS_7             0x6
+#define  LPC_SSP_CR0_DSS_8             0x7
+#define  LPC_SSP_CR0_DSS_9             0x8
+#define  LPC_SSP_CR0_DSS_10            0x9
+#define  LPC_SSP_CR0_DSS_11            0xa
+#define  LPC_SSP_CR0_DSS_12            0xb
+#define  LPC_SSP_CR0_DSS_13            0xc
+#define  LPC_SSP_CR0_DSS_14            0xd
+#define  LPC_SSP_CR0_DSS_15            0xe
+#define  LPC_SSP_CR0_DSS_16            0xf
+#define LPC_SSP_CR0_FRF                4
+#define  LPC_SSP_CR0_FRF_SPI           0
+#define  LPC_SSP_CR0_FRF_TI            1
+#define  LPC_SSP_CR0_FRF_MICROWIRE     2
+#define LPC_SSP_CR0_CPOL       6
+#define  LPC_SSP_CR0_CPOL_LOW          0
+#define  LPC_SSP_CR0_CPOL_HIGH         1
+#define LPC_SSP_CR0_CPHA       7
+#define  LPC_SSP_CR0_CPHA_FIRST                0
+#define  LPC_SSP_CR0_CPHA_SECOND       1
+#define LPC_SSP_CR0_SCR                8
+
+#define LPC_SSP_CR1_LBM                0
+#define LPC_SSP_CR1_SSE                1
+#define LPC_SSP_CR1_MS         2
+#define  LPC_SSP_CR1_MS_MASTER         0
+#define  LPC_SSP_CR1_MS_SLAVE          1
+#define LPC_SSP_CR1_SOD                3
+
+#define LPC_SSP_SR_TFE         0
+#define LPC_SSP_SR_TNF         1
+#define LPC_SSP_SR_RNE         2
+#define LPC_SSP_SR_RFF         3
+#define LPC_SSP_SR_BSY         4
+
+#define LPC_SSP_IMSC_RORIM     0
+#define LPC_SSP_IMSC_RTIM      1
+#define LPC_SSP_IMSC_RXIM      2
+#define LPC_SSP_IMSC_TXIM      3
+
+#define LPC_SSP_RIS_RORRIS     0
+#define LPC_SSP_RIS_RTRIS      1
+#define LPC_SSP_RIS_RXRIS      2
+#define LPC_SSP_RIS_TXRIS      3
+
+#define LPC_SSP_MIS_RORMIS     0
+#define LPC_SSP_MIS_RTMIS      1
+#define LPC_SSP_MIS_RXMIS      2
+#define LPC_SSP_MIS_TXMIS      3
+
+#define LPC_SSP_ICR_RORIC      0
+#define LPC_SSP_ICR_RTIC       1
+
+struct lpc_adc {
+       vuint32_t       cr;     /* 0x00 */
+       vuint32_t       gdr;
+       uint32_t        r08;
+       vuint32_t       inten;
+
+       vuint32_t       dr[8];  /* 0x10 */
+
+       vuint32_t       stat;   /* 0x30 */
+};
+
+extern struct lpc_adc lpc_adc;
+
+#define LPC_ADC_CR_SEL         0
+#define LPC_ADC_CR_CLKDIV      8
+#define LPC_ADC_CR_BURST       16
+#define LPC_ADC_CR_CLKS                17
+#define  LPC_ADC_CR_CLKS_11            0
+#define  LPC_ADC_CR_CLKS_10            1
+#define  LPC_ADC_CR_CLKS_9             2
+#define  LPC_ADC_CR_CLKS_8             3
+#define  LPC_ADC_CR_CLKS_7             4
+#define  LPC_ADC_CR_CLKS_6             5
+#define  LPC_ADC_CR_CLKS_5             6
+#define  LPC_ADC_CR_CLKS_4             7
+#define LPC_ADC_CR_START       24
+#define  LPC_ADC_CR_START_NONE         0
+#define  LPC_ADC_CR_START_NOW          1
+
+#define LPC_ADC_GDR_CHN                        24
+#define LPC_ADC_GDR_OVERRUN            30
+#define LPC_ADC_GDR_DONE               31
+
+#define LPC_ADC_INTEN_ADINTEN  0
+#define LPC_ADC_INTEN_ADGINTEN 8
+
+#define LPC_ADC_STAT_DONE      0
+#define LPC_ADC_STAT_OVERRUN   8
+#define LPC_ADC_STAT_ADINT     16
+
+struct lpc_ct16b {
+       vuint32_t       ir;     /* 0x00 */
+       vuint32_t       tcr;
+       vuint32_t       tc;
+       vuint32_t       pr;
+
+       vuint32_t       pc;     /* 0x10 */
+       vuint32_t       mcr;
+       vuint32_t       mr[4];  /* 0x18 */
+       vuint32_t       ccr;    /* 0x28 */
+       vuint32_t       cr0;
+
+       vuint32_t       cr1_0;  /* 0x30 (only for ct16b0 */
+       vuint32_t       cr1_1;  /* 0x34 (only for ct16b1 */
+       uint32_t        r38;
+       vuint32_t       emr;
+
+       uint8_t         r40[0x70 - 0x40];
+
+       vuint32_t       ctcr;   /* 0x70 */
+       vuint32_t       pwmc;
+};
+
+extern struct lpc_ct16b        lpc_ct16b0, lpc_ct16b1;
+
+#define lpc_ct16b0     (*(struct lpc_ct16b *) 0x4000c000)
+#define lpc_ct16b1     (*(struct lpc_ct16b *) 0x40010000)
+
+#define LPC_CT16B_IR_MR0INT    0
+#define LPC_CT16B_IR_MR1INT    1
+#define LPC_CT16B_IR_MR2INT    2
+#define LPC_CT16B_IR_MR3INT    3
+#define LPC_CT16B_IR_CR0INT    4
+#define LPC_CT16B0_IR_CR1INT   6
+#define LPC_CT16B1_IR_CR1INT   5
+
+#define LPC_CT16B_TCR_CEN      0
+#define LPC_CT16B_TCR_CRST     1
+
+#define LPC_CT16B_MCR_MR0I     0
+#define LPC_CT16B_MCR_MR0R     1
+#define LPC_CT16B_MCR_MR0S     2
+#define LPC_CT16B_MCR_MR1I     3
+#define LPC_CT16B_MCR_MR1R     4
+#define LPC_CT16B_MCR_MR1S     5
+#define LPC_CT16B_MCR_MR2I     6
+#define LPC_CT16B_MCR_MR2R     7
+#define LPC_CT16B_MCR_MR2S     8
+#define LPC_CT16B_MCR_MR3I     9
+#define LPC_CT16B_MCR_MR3R     10
+#define LPC_CT16B_MCR_MR3S     11
+
+#define LPC_CT16B_CCR_CAP0RE   0
+#define LPC_CT16B_CCR_CAP0FE   1
+#define LPC_CT16B_CCR_CAP0I    2
+#define LPC_CT16B0_CCR_CAP1RE  6
+#define LPC_CT16B0_CCR_CAP1FE  7
+#define LPC_CT16B0_CCR_CAP1I   8
+#define LPC_CT16B1_CCR_CAP1RE  3
+#define LPC_CT16B1_CCR_CAP1FE  4
+#define LPC_CT16B1_CCR_CAP1I   5
+
+#define LPC_CT16B_EMR_EM0      0
+#define LPC_CT16B_EMR_EM1      1
+#define LPC_CT16B_EMR_EM2      2
+#define LPC_CT16B_EMR_EM3      3
+#define LPC_CT16B_EMR_EMC0     4
+#define LPC_CT16B_EMR_EMC1     6
+#define LPC_CT16B_EMR_EMC2     8
+#define LPC_CT16B_EMR_EMC3     10
+
+#define LPC_CT16B_EMR_EMC_NOTHING      0
+#define LPC_CT16B_EMR_EMC_CLEAR                1
+#define LPC_CT16B_EMR_EMC_SET          2
+#define LPC_CT16B_EMR_EMC_TOGGLE       3
+
+#define LPC_CT16B_CCR_CTM      0
+#define  LPC_CT16B_CCR_CTM_TIMER               0
+#define  LPC_CT16B_CCR_CTM_COUNTER_RISING      1
+#define  LPC_CT16B_CCR_CTM_COUNTER_FALLING     2
+#define  LPC_CT16B_CCR_CTM_COUNTER_BOTH                3
+#define LPC_CT16B_CCR_CIS      2
+#define  LPC_CT16B_CCR_CIS_CAP0                        0
+#define  LPC_CT16B0_CCR_CIS_CAP1               2
+#define  LPC_CT16B1_CCR_CIS_CAP1               1
+#define LPC_CT16B_CCR_ENCC     4
+#define LPC_CT16B_CCR_SELCC    5
+#define  LPC_CT16B_CCR_SELCC_RISING_CAP0       0
+#define  LPC_CT16B_CCR_SELCC_FALLING_CAP0      1
+#define  LPC_CT16B0_CCR_SELCC_RISING_CAP1      4
+#define  LPC_CT16B0_CCR_SELCC_FALLING_CAP1     5
+#define  LPC_CT16B1_CCR_SELCC_RISING_CAP1      2
+#define  LPC_CT16B1_CCR_SELCC_FALLING_CAP1     3
+#define LPC_CT16B_CCR_
+
+#define LPC_CT16B_PWMC_PWMEN0  0
+#define LPC_CT16B_PWMC_PWMEN1  1
+#define LPC_CT16B_PWMC_PWMEN2  2
+#define LPC_CT16B_PWMC_PWMEN3  3
+
+struct lpc_ct32b {
+       vuint32_t       ir;     /* 0x00 */
+       vuint32_t       tcr;
+       vuint32_t       tc;
+       vuint32_t       pr;
+
+       vuint32_t       pc;     /* 0x10 */
+       vuint32_t       mcr;
+       vuint32_t       mr[4];  /* 0x18 */
+       vuint32_t       ccr;    /* 0x28 */
+       vuint32_t       cr0;
+
+       vuint32_t       cr1_0;  /* 0x30 (only for ct32b0 */
+       vuint32_t       cr1_1;  /* 0x34 (only for ct32b1 */
+       uint32_t        r38;
+       vuint32_t       emr;
+
+       uint32_t        r40[12];
+
+       vuint32_t       ctcr;   /* 0x70 */
+       vuint32_t       pwmc;
+};
+
+extern struct lpc_ct32b lpc_ct32b0, lpc_ct32b1;
+
+#define LPC_CT32B_TCR_CEN      0
+#define LPC_CT32B_TCR_CRST     1
+
+#define LPC_CT32B_MCR_MR0R     1
+
+#define LPC_CT32B_PWMC_PWMEN0  0
+#define LPC_CT32B_PWMC_PWMEN1  1
+#define LPC_CT32B_PWMC_PWMEN2  2
+#define LPC_CT32B_PWMC_PWMEN3  3
+
+#define LPC_CT32B_EMR_EMC0     4
+#define LPC_CT32B_EMR_EMC1     6
+#define LPC_CT32B_EMR_EMC2     8
+#define LPC_CT32B_EMR_EMC3     10
+
+#define LPC_CT32B_EMR_EMC_NOTHING      0
+#define LPC_CT32B_EMR_EMC_CLEAR                1
+#define LPC_CT32B_EMR_EMC_SET          2
+#define LPC_CT32B_EMR_EMC_TOGGLE       3
+
 #endif /* _LPC_H_ */