//*****************************************************************************
//
// lpc.h - Prototypes for the Low Pin Count (LPC) driver.
//
// Copyright (c) 2010-2011 Texas Instruments Incorporated.  All rights reserved.
// Software License Agreement
// 
// Texas Instruments (TI) is supplying this software for use solely and
// exclusively on TI's microcontroller products. The software is owned by
// TI and/or its suppliers, and is protected under applicable copyright
// laws. You may not combine this software with "viral" open-source
// software in order to form a larger program.
// 
// THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
// NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
// NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
// CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
// DAMAGES, FOR ANY REASON WHATSOEVER.
// 
// This is part of revision 8264 of the Stellaris Peripheral Driver Library.
//
//*****************************************************************************

#ifndef __LPC_H__
#define __LPC_H__

//*****************************************************************************
//
// If building with a C++ compiler, make all of the definitions in this header
// have a C binding.
//
//*****************************************************************************
#ifdef __cplusplus
extern "C"
{
#endif

//*****************************************************************************
//
// Values that can be passed to LPCConfigSet as the ulConfig value, and
// returned from LPCConfigGet.
//
//*****************************************************************************
#define LPC_CFG_WAKE            0x00000100  // Restart the LPC Bus

//*****************************************************************************
//
// Values that can be returned from LPCStatus.
//
//*****************************************************************************
#define LPC_STATUS_RST          0x00000400  // LPC is in Reset
#define LPC_STATUS_BUSY         0x00000200  // LPC is Busy
#define LPC_STATUS_SLEEP        0x00000100  // LPC is in Sleep Mode
#define LPC_STATUS_CA7          0x00000080  // Channel 7 Active
#define LPC_STATUS_CA6          0x00000040  // Channel 6 Active
#define LPC_STATUS_CA5          0x00000020  // Channel 5 Active
#define LPC_STATUS_CA4          0x00000010  // Channel 4 Active
#define LPC_STATUS_CA3          0x00000008  // Channel 3 Active
#define LPC_STATUS_CA2          0x00000004  // Channel 2 Active
#define LPC_STATUS_CA1          0x00000002  // Channel 1 Active
#define LPC_STATUS_CA0          0x00000001  // Channel 0 Active

//*****************************************************************************
//
// Values that can be passed to LPCIRQSet and LPCIRQClear in the ulIRQ
// parameter and returned from LPCIRQGet.
//
//*****************************************************************************
#define LPC_IRQ15               0x80000000  // Serial IRQ15
#define LPC_IRQ14               0x40000000  // Serial IRQ14
#define LPC_IRQ13               0x20000000  // Serial IRQ13
#define LPC_IRQ12               0x10000000  // Serial IRQ12
#define LPC_IRQ11               0x08000000  // Serial IRQ11
#define LPC_IRQ10               0x04000000  // Serial IRQ10
#define LPC_IRQ9                0x02000000  // Serial IRQ9
#define LPC_IRQ8                0x01000000  // Serial IRQ8
#define LPC_IRQ7                0x00800000  // Serial IRQ7
#define LPC_IRQ6                0x00400000  // Serial IRQ6
#define LPC_IRQ5                0x00200000  // Serial IRQ5
#define LPC_IRQ4                0x00100000  // Serial IRQ4
#define LPC_IRQ3                0x00080000  // Serial IRQ3
#define LPC_IRQ2                0x00040000  // Serial IRQ2
#define LPC_IRQ1                0x00020000  // Serial IRQ1
#define LPC_IRQ0                0x00010000  // Serial IRQ0
                                 
//*****************************************************************************
//
// Addition values that can be returned from LPCIRQGet.
//
//*****************************************************************************
#define LPC_IRQ_BUSY            0x00000004  // SERIRQ frame in progress
#define LPC_IRQ_CONT            0x00000001  // SERIRQ in Continuous Mode
                                 
//*****************************************************************************
//
// Values that can be passed as the ulChannel parameter in LPCChannel...
// API calls.
//
//*****************************************************************************
#define LPC_CHAN_CH0            0           // LPC Channel 0
#define LPC_CHAN_CH1            1           // LPC Channel 1
#define LPC_CHAN_CH2            2           // LPC Channel 2
#define LPC_CHAN_CH3            3           // LPC Channel 3
#define LPC_CHAN_CH4            4           // LPC Channel 4
#define LPC_CHAN_CH5            5           // LPC Channel 5
#define LPC_CHAN_CH6            6           // LPC Channel 6
#define LPC_CHAN_CH7            7           // LPC Channel 7 (COMx)
#define LPC_CHAN_COMx           7           // LPC Channel 7 (COMx)

//*****************************************************************************
//
// Values that can be passed as part of the ulConfig parameter in the
// LPCChannelConfig... functions.
//
//*****************************************************************************
#define LPC_CHAN_IRQSEL2_NONE   0x00000000  // LPC Channel IRQSEL2 Disabled
#define LPC_CHAN_IRQSEL2_IRQ0   0x00080000  // LPC Channel IRQSEL2 IRQ0
#define LPC_CHAN_IRQSEL2_IRQ1   0x10080000  // LPC Channel IRQSEL2 IRQ1
#define LPC_CHAN_IRQSEL2_IRQ2   0x20080000  // LPC Channel IRQSEL2 IRQ2
#define LPC_CHAN_IRQSEL2_IRQ3   0x30080000  // LPC Channel IRQSEL2 IRQ3
#define LPC_CHAN_IRQSEL2_IRQ4   0x40080000  // LPC Channel IRQSEL2 IRQ4
#define LPC_CHAN_IRQSEL2_IRQ5   0x50080000  // LPC Channel IRQSEL2 IRQ5
#define LPC_CHAN_IRQSEL2_IRQ6   0x60080000  // LPC Channel IRQSEL2 IRQ6
#define LPC_CHAN_IRQSEL2_IRQ7   0x70080000  // LPC Channel IRQSEL2 IRQ7
#define LPC_CHAN_IRQSEL2_IRQ8   0x80080000  // LPC Channel IRQSEL2 IRQ8
#define LPC_CHAN_IRQSEL2_IRQ9   0x90080000  // LPC Channel IRQSEL2 IRQ9
#define LPC_CHAN_IRQSEL2_IRQ10  0xA0080000  // LPC Channel IRQSEL2 IRQ10
#define LPC_CHAN_IRQSEL2_IRQ11  0xB0080000  // LPC Channel IRQSEL2 IRQ11
#define LPC_CHAN_IRQSEL2_IRQ12  0xC0080000  // LPC Channel IRQSEL2 IRQ12
#define LPC_CHAN_IRQSEL2_IRQ13  0xD0080000  // LPC Channel IRQSEL2 IRQ13
#define LPC_CHAN_IRQSEL2_IRQ14  0xE0080000  // LPC Channel IRQSEL2 IRQ14
#define LPC_CHAN_IRQSEL2_IRQ15  0xF0080000  // LPC Channel IRQSEL2 IRQ15

#define LPC_CHAN_COMxIRQ_DISABLE \
                                0x00000000  // LCP Channel COMx IRQ Disabled
#define LPC_CHAN_COMxIRQ_ENABLE 0x00080000  // LCP Channel COMx IRQ Enabled

#define LPC_CHAN_IRQSEL1_NONE   0x00000000  // LPC Channel IRQSEL1 Disabled
#define LPC_CHAN_IRQSEL1_IRQ0   0x00040000  // LPC Channel IRQSEL1 IRQ0
#define LPC_CHAN_IRQSEL1_IRQ1   0x01040000  // LPC Channel IRQSEL1 IRQ1
#define LPC_CHAN_IRQSEL1_IRQ2   0x02040000  // LPC Channel IRQSEL1 IRQ2
#define LPC_CHAN_IRQSEL1_IRQ3   0x03040000  // LPC Channel IRQSEL1 IRQ3
#define LPC_CHAN_IRQSEL1_IRQ4   0x04040000  // LPC Channel IRQSEL1 IRQ4
#define LPC_CHAN_IRQSEL1_IRQ5   0x05040000  // LPC Channel IRQSEL1 IRQ5
#define LPC_CHAN_IRQSEL1_IRQ6   0x06040000  // LPC Channel IRQSEL1 IRQ6
#define LPC_CHAN_IRQSEL1_IRQ7   0x07040000  // LPC Channel IRQSEL1 IRQ7
#define LPC_CHAN_IRQSEL1_IRQ8   0x08040000  // LPC Channel IRQSEL1 IRQ8
#define LPC_CHAN_IRQSEL1_IRQ9   0x09040000  // LPC Channel IRQSEL1 IRQ9
#define LPC_CHAN_IRQSEL1_IRQ10  0x0A040000  // LPC Channel IRQSEL1 IRQ10
#define LPC_CHAN_IRQSEL1_IRQ11  0x0B040000  // LPC Channel IRQSEL1 IRQ11
#define LPC_CHAN_IRQSEL1_IRQ12  0x0C040000  // LPC Channel IRQSEL1 IRQ12
#define LPC_CHAN_IRQSEL1_IRQ13  0x0D040000  // LPC Channel IRQSEL1 IRQ13
#define LPC_CHAN_IRQSEL1_IRQ14  0x0E040000  // LPC Channel IRQSEL1 IRQ14
#define LPC_CHAN_IRQSEL1_IRQ15  0x0F040000  // LPC Channel IRQSEL1 IRQ15

#define LPC_CHAN_IRQSEL0_NONE   0x00000000  // LPC Channel IRQSEL0 Disabled
#define LPC_CHAN_IRQSEL0_IRQ0   0x00000000  // LPC Channel IRQSEL0 IRQ0
#define LPC_CHAN_IRQSEL0_IRQ1   0x00100000  // LPC Channel IRQSEL0 IRQ1
#define LPC_CHAN_IRQSEL0_IRQ2   0x00200000  // LPC Channel IRQSEL0 IRQ2
#define LPC_CHAN_IRQSEL0_IRQ3   0x00300000  // LPC Channel IRQSEL0 IRQ3
#define LPC_CHAN_IRQSEL0_IRQ4   0x00400000  // LPC Channel IRQSEL0 IRQ4
#define LPC_CHAN_IRQSEL0_IRQ5   0x00500000  // LPC Channel IRQSEL0 IRQ5
#define LPC_CHAN_IRQSEL0_IRQ6   0x00600000  // LPC Channel IRQSEL0 IRQ6
#define LPC_CHAN_IRQSEL0_IRQ7   0x00700000  // LPC Channel IRQSEL0 IRQ7
#define LPC_CHAN_IRQSEL0_IRQ8   0x00800000  // LPC Channel IRQSEL0 IRQ8
#define LPC_CHAN_IRQSEL0_IRQ9   0x00900000  // LPC Channel IRQSEL0 IRQ9
#define LPC_CHAN_IRQSEL0_IRQ10  0x00A00000  // LPC Channel IRQSEL0 IRQ10
#define LPC_CHAN_IRQSEL0_IRQ11  0x00B00000  // LPC Channel IRQSEL0 IRQ11
#define LPC_CHAN_IRQSEL0_IRQ12  0x00C00000  // LPC Channel IRQSEL0 IRQ12
#define LPC_CHAN_IRQSEL0_IRQ13  0x00D00000  // LPC Channel IRQSEL0 IRQ13
#define LPC_CHAN_IRQSEL0_IRQ14  0x00E00000  // LPC Channel IRQSEL0 IRQ14
#define LPC_CHAN_IRQSEL0_IRQ15  0x00F00000  // LPC Channel IRQSEL0 IRQ15
#define LPC_CHAN_IRQEN0_OFF     0x00000000  // LPC Channel IRQEN0 Disabled
#define LPC_CHAN_IRQEN0_TRG1    0x00010000  // LPC Channel IRQEN0 Trigger 1
#define LPC_CHAN_IRQEN0_TRG2    0x00020000  // LPC Channel IRQEN0 Trigger 2
#define LPC_CHAN_IRQEN0_TRG3    0x00030000  // LPC Channel IRQEN0 Trigger 3

#define LPC_CHAN_MBARB_ENABLED  0x00000000  // LPC Channel Mailbox Arbritration
                                            // enabled.
#define LPC_CHAN_MBARB_DISABLED 0x00008000  // LPC Channel Mailbox Arbritration
                                            // disabled.

#define LPC_CHAN_SIZE_4         0x00000000  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_8         0x00000004  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_16        0x00000008  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_32        0x0000000C  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_64        0x00000010  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_128       0x00000014  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_256       0x00000018  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.
#define LPC_CHAN_SIZE_512       0x0000001C  // Mailbox IO/Memory Window size
                                            // is 4 Bytes.

//*****************************************************************************
//
// Values that can be passed to LCPChannelConfigCOMxSet as the ulCOMxMode
// parameter or returned from LPCChannelConfigGet in the pulCOMxMode
// parameter.
//
//*****************************************************************************
#define LPC_COMx_MODE_FRMHNML   0x00000000  // Normal From Host model.
#define LPC_COMx_MODE_FRMHIGN   0x00020000  // Ignore From Host data.
#define LPC_COMx_MODE_FRMHDMA   0x00040000  // COMx DMA on From Host data to
                                            // memory
#define LPC_COMx_MODE_UARTDMA   0x00060000  // COMx DMA on From Host data to
                                            // UART1

//*****************************************************************************
//
// Additinal values that can be returned from LPCChannelConfigGet in the
// pulCOMxMode parameter.
//
//*****************************************************************************
#define LPC_COMx_ENABLED        0x00010000  // COMx mode enabled.
    
//*****************************************************************************
//
// Values that can be passed to LPCIntEnable, LPCIntDisable, and LPCIntClear
// as the ulIntFlags parameter and returned by LPCIntStatus.
//
//*****************************************************************************
#define LPC_INT_RST             0x80000000  // LPC Bus Enters or Exits
                                            // Reset State.
#define LPC_INT_SLEEP           0x40000000  // LPC Bus Enters or Exits
                                            // Sleep State.
#define LPC_INT_COMx            0x20000000  // COMx has read/written
                                            // data.
#define LPC_INT_SIRQ            0x10000000  // SERIRQ frame has completed
#define LPC_INT_CH6_EP_TO_HOST  (1 << 24)   // To-Host has been read.
#define LPC_INT_CH6_EP_FROM_DATA \
                                (2 << 24)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH6_EP_FROM_CMD (4 << 24)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH6_MB_HOST_WON (1 << 24)   // Host Won (HW1ST)
#define LPC_INT_CH6_MB_HOST_WRITE \
                                (2 << 24)   // Host Wrote Last Byte.
#define LPC_INT_CH6_MB_HOST_READ \
                                (4 << 24)   // Host Read Last Byte
#define LPC_INT_CH6_MB_MCU_LOST (8 << 24)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH5_EP_TO_HOST  (1 << 20)   // To-Host has been read.
#define LPC_INT_CH5_EP_FROM_DATA \
                                (2 << 20)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH5_EP_FROM_CMD (4 << 20)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH5_MB_HOST_WON (1 << 20)   // Host Won (HW1ST)
#define LPC_INT_CH5_MB_HOST_WRITE \
                                (2 << 20)   // Host Wrote Last Byte.
#define LPC_INT_CH5_MB_HOST_READ \
                                (4 << 20)   // Host Read Last Byte
#define LPC_INT_CH5_MB_MCU_LOST (8 << 20)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH4_EP_TO_HOST  (1 << 16)   // To-Host has been read.
#define LPC_INT_CH4_EP_FROM_DATA \
                                (2 << 16)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH4_EP_FROM_CMD (4 << 16)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH4_MB_HOST_WON (1 << 16)   // Host Won (HW1ST)
#define LPC_INT_CH4_MB_HOST_WRITE \
                                (2 << 16)   // Host Wrote Last Byte.
#define LPC_INT_CH4_MB_HOST_READ \
                                (4 << 16)   // Host Read Last Byte
#define LPC_INT_CH4_MB_MCU_LOST (8 << 16)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH3_EP_TO_HOST  (1 << 12)   // To-Host has been read.
#define LPC_INT_CH3_EP_FROM_DATA \
                                (2 << 12)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH3_EP_FROM_CMD (4 << 12)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH3_MB_HOST_WON (1 << 12)   // Host Won (HW1ST)
#define LPC_INT_CH3_MB_HOST_WRITE \
                                (2 << 12)   // Host Wrote Last Byte.
#define LPC_INT_CH3_MB_HOST_READ \
                                (4 << 12)   // Host Read Last Byte
#define LPC_INT_CH3_MB_MCU_LOST (8 << 12)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH2_EP_TO_HOST  (1 <<  8)   // To-Host has been read.
#define LPC_INT_CH2_EP_FROM_DATA \
                                (2 <<  8)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH2_EP_FROM_CMD (4 <<  8)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH2_MB_HOST_WON (1 <<  8)   // Host Won (HW1ST)
#define LPC_INT_CH2_MB_HOST_WRITE \
                                (2 <<  8)   // Host Wrote Last Byte.
#define LPC_INT_CH2_MB_HOST_READ \
                                (4 <<  8)   // Host Read Last Byte
#define LPC_INT_CH2_MB_MCU_LOST (8 <<  8)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH1_EP_TO_HOST  (1 <<  4)   // To-Host has been read.
#define LPC_INT_CH1_EP_FROM_DATA \
                                (2 <<  4)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH1_EP_FROM_CMD (4 <<  4)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH1_MB_HOST_WON (1 <<  4)   // Host Won (HW1ST)
#define LPC_INT_CH1_MB_HOST_WRITE \
                                (2 <<  4)   // Host Wrote Last Byte.
#define LPC_INT_CH1_MB_HOST_READ \
                                (4 <<  4)   // Host Read Last Byte
#define LPC_INT_CH1_MB_MCU_LOST (8 <<  4)   // MCU Lost (when host had HW1ST).
#define LPC_INT_CH0_EP_TO_HOST  (1 <<  0)   // To-Host has been read.
#define LPC_INT_CH0_EP_FROM_DATA \
                                (2 <<  0)   // From-Host has been written as
                                            // data.
#define LPC_INT_CH0_EP_FROM_CMD (4 <<  0)   // From-Host has been written as
                                            // command.
#define LPC_INT_CH0_MB_HOST_WON (1 <<  0)   // Host Won (HW1ST)
#define LPC_INT_CH0_MB_HOST_WRITE \
                                (2 <<  0)   // Host Wrote Last Byte.
#define LPC_INT_CH0_MB_HOST_READ \
                                (4 <<  0)   // Host Read Last Byte
#define LPC_INT_CH0_MB_MCU_LOST (8 <<  0)   // MCU Lost (when host had HW1ST).

//*****************************************************************************
//
// Values that can be passed to LPCCOMxInt... functions as the ulIntFlags
// parameter and returned by LPCIntStatus.
//
//*****************************************************************************
#define LPC_COMx_INT_CX         0x02000000  // Raw Event State for COMx
#define LPC_COMx_INT_CXTX       0x01000000  // Raw Event State for COMx TX
#define LPC_COMx_INT_CXRX       0x00800000  // Raw Event State for COMx RX
#define LPC_COMx_MASK_CX        0x00200000  // Event Mask for COMx
#define LPC_COMx_MASK_CXTX      0x00100000  // Event Mask for COMx TX
#define LPC_COMx_MASK_CXRX      0x00080000  // Event Mask for COMx RX
    
//*****************************************************************************
//
// Values that can be passed to the LPCChannelDMAConfigSet function as part
// of the ulConfig or ulMask parameter, or can be returned from the
// LPCChannelConfigGet function.
//
//*****************************************************************************
#define LPC_DMA_CH3_WEN         0x00000080  // Trigger DMA for "To Host" data
                                            // buffer is empty.
#define LPC_DMA_CH3_REN         0x00000040  // Trigger DMA when "From Host"
                                            // data buffer is full.
#define LPC_DMA_CH2_WEN         0x00000020  // Trigger DMA for "To Host" data
                                            // buffer is empty.
#define LPC_DMA_CH2_REN         0x00000010  // Trigger DMA when "From Host"
                                            // data buffer is full.
#define LPC_DMA_CH1_WEN         0x00000008  // Trigger DMA for "To Host" data
                                            // buffer is empty.
#define LPC_DMA_CH1_REN         0x00000004  // Trigger DMA when "From Host"
                                            // data buffer is full.
#define LPC_DMA_CH0_WEN         0x00000002  // Trigger DMA for "To Host" data
                                            // buffer is empty.
#define LPC_DMA_CH0_REN         0x00000001  // Trigger DMA when "From Host"
                                            // data buffer is full.
//*****************************************************************************
//
// Values that can be passed to the LPCChannelStatusSet and
// LPCChannelStatusClear function, and returned by the LPCChannelStatusGet
// function.
//
//*****************************************************************************
#define LPC_CH_ST_USER0         0x00000100  // User Status Bit 0
#define LPC_CH_ST_USER1         0x00000200  // User Status Bit 1
#define LPC_CH_ST_USER2         0x00000400  // User Status Bit 2
#define LPC_CH_ST_USER3         0x00000800  // User Status Bit 3
#define LPC_CH_ST_USER4         0x00001000  // User Status Bit 4
    
//*****************************************************************************
//
// Additinoal values that can be returned by the LPCChannelStatusGet function.
//
//*****************************************************************************
#define LPC_CH_ST_LASTHW        0x00000080  // Last Host Write
#define LPC_CH_ST_HW1ST         0x00000040  // First Host Write
#define LPC_CH_ST_LASTSW        0x00000020  // Last Slave Write
#define LPC_CH_ST_SW1ST         0x00000010  // First Slave Write
#define LPC_CH_ST_CMD           0x00000008  // Command or Data
#define LPC_CH_ST_FRMH          0x00000002  // From-Host Transaction
#define LPC_CH_ST_TOH           0x00000001  // To-Host Transaction

//*****************************************************************************
//
// Prototypes for the APIs.
//
//*****************************************************************************
extern void LPCConfigSet(unsigned long ulBase, unsigned long ulConfig);
extern unsigned long LPCConfigGet(unsigned long ulBase);
extern unsigned long LPCStatusGet(unsigned long ulBase,
                                  unsigned long *pulCount,
                                  unsigned long *pulPoolSize);
extern void LPCStatusBlockAddressSet(unsigned long ulBase,
                                     unsigned long ulAddress,
                                     tBoolean bEnabled);
extern unsigned LPCStatusBlockAddressGet(unsigned long ulBase);
extern void LPCSCIAssert(unsigned long ulBase, unsigned long ulCount);
extern void LPCIRQConfig(unsigned long ulBase, tBoolean bIRQPulse,
                         tBoolean bIRQOnChange);
extern void LPCIRQSet(unsigned long ulBase, unsigned long ulIRQ);
extern void LPCIRQClear(unsigned long ulBase, unsigned long ulIRQ);
extern unsigned long LPCIRQGet(unsigned long ulBase);
extern void LPCIRQSend(unsigned long ulBase);
extern void LPCIntRegister(unsigned long ulBase, void (*pfnHandler)(void));
extern void LPCIntUnregister(unsigned long ulBase);
extern void LPCIntEnable(unsigned long ulBase, unsigned long ulIntFlags);
extern void LPCIntDisable(unsigned long ulBase, unsigned long ulIntFlags);
extern unsigned long LPCIntStatus(unsigned long ulBase, tBoolean bMasked);
extern void LPCIntClear(unsigned long ulBase, unsigned long ulIntFlags);
extern void LPCChannelEnable(unsigned long ulBase, unsigned long ulChannel);
extern void LPCChannelDisable(unsigned long ulBase, unsigned long ulChannel);
extern void LPCChannelConfigEPSet(unsigned long ulBase,
                                  unsigned long ulChannel,
                                  unsigned long ulConfig,
                                  unsigned long ulAddress,
                                  unsigned long ulOffset);
extern void LPCChannelConfigMBSet(unsigned long ulBase,
                                  unsigned long ulChannel,
                                  unsigned long ulConfig,
                                  unsigned long ulAddress,
                                  unsigned long ulOffset);
extern void LPCChannelConfigCOMxSet(unsigned long ulBase,
                                    unsigned long ulChannel,
                                    unsigned long ulConfig,
                                    unsigned long ulAddress,
                                    unsigned long ulOffset,
                                    unsigned long ulCOMxMode);
extern unsigned long LPCChannelConfigGet(unsigned long ulBase,
                                         unsigned long ulChannel,
                                         unsigned long *pulAddress,
                                         unsigned long *pulOffset,
                                         unsigned long *pulCOMxMode);
extern unsigned long LPCChannelPoolAddressGet(unsigned long ulBase,
                                              unsigned long ulChannel);
extern unsigned long LPCChannelStatusGet(unsigned long ulBase,
                                         unsigned long ulChannel);
extern void LPCChannelStatusSet(unsigned long ulBase, unsigned long ulChannel,
                                unsigned long ulStatus);
extern void LPCChannelStatusClear(unsigned long ulBase,
                                  unsigned long ulChannel,
                                  unsigned long ulStatus);
extern void LPCChannelDMAConfigSet(unsigned long ulBase,
                                   unsigned long ulConfig,
                                   unsigned long ulMask);
extern unsigned long LPCChannelDMAConfigGet(unsigned long ulBase);
extern unsigned char LPCByteRead(unsigned long ulBase, unsigned long ulOffset);
extern void LPCByteWrite(unsigned long ulBase, unsigned long ulOffset,
                         unsigned char ucData);
extern unsigned short LPCHalfWordRead(unsigned long ulBase,
                                      unsigned long ulOffset);
extern void LPCHalfWordWrite(unsigned long ulBase, unsigned long ulOffset,
                             unsigned short usData);
extern unsigned long LPCWordRead(unsigned long ulBase, unsigned long ulOffset);
extern void LPCWordWrite(unsigned long ulBase, unsigned long ulOffset,
                         unsigned long ulData);
extern void LPCCOMxIntEnable(unsigned long ulBase, unsigned long ulIntFlags);
extern void LPCCOMxIntDisable(unsigned long ulBase, unsigned long ulIntFlags);
extern unsigned long LPCCOMxIntStatus(unsigned long ulBase, tBoolean bMasked);
extern void LPCCOMxIntClear(unsigned long ulBase, unsigned long ulIntFlags);

//*****************************************************************************
//
// Mark the end of the C bindings section for C++ compilers.
//
//*****************************************************************************
#ifdef __cplusplus
}
#endif

#endif // __LPC_H__