/*
 * @brief Error code returned by Boot ROM drivers/library functions
 *
 *  This file contains unified error codes to be used across driver,
 *  middleware, applications, hal and demo software.
 *
 *
 * @note
 * Copyright(C) NXP Semiconductors, 2012
 * All rights reserved.
 *
 * @par
 * Software that is described herein is for illustrative purposes only
 * which provides customers with programming information regarding the
 * LPC products.  This software is supplied "AS IS" without any warranties of
 * any kind, and NXP Semiconductors and its licensor disclaim any and
 * all warranties, express or implied, including all implied warranties of
 * merchantability, fitness for a particular purpose and non-infringement of
 * intellectual property rights.  NXP Semiconductors assumes no responsibility
 * or liability for the use of the software, conveys no license or rights under any
 * patent, copyright, mask work right, or any other intellectual property rights in
 * or to any products. NXP Semiconductors reserves the right to make changes
 * in the software without notification. NXP Semiconductors also makes no
 * representation or warranty that such application will be suitable for the
 * specified use without further testing or modification.
 *
 * @par
 * Permission to use, copy, modify, and distribute this software and its
 * documentation is hereby granted, under NXP Semiconductors' and its
 * licensor's relevant copyrights in the software, without fee, provided that it
 * is used in conjunction with NXP Semiconductors microcontrollers.  This
 * copyright, permission, and disclaimer notice must appear in all copies of
 * this code.
 */

#ifndef __LPC_ERROR_H__
#define __LPC_ERROR_H__

/** Error code returned by Boot ROM drivers/library functions
 *
 *  Error codes are a 32-bit value with :
 *      - The 16 MSB contains the peripheral code number
 *      - The 16 LSB contains an error code number associated to that peripheral
 *
 */
typedef enum
{
  /**\b 0x00000000*/ LPC_OK=0, /**< enum value returned on Success */
  /**\b 0xFFFFFFFF*/ ERR_FAILED = -1, /**< enum value returned on general failure */
  /**\b 0xFFFFFFFE*/ ERR_TIME_OUT = -2, /**< enum value returned on general timeout */
  /**\b 0xFFFFFFFD*/ ERR_BUSY = -3,	/**< enum value returned when resource is busy */

  /* ISP related errors */
  ERR_ISP_BASE = 0x00000000,
  /*0x00000001*/ ERR_ISP_INVALID_COMMAND = ERR_ISP_BASE + 1,
  /*0x00000002*/ ERR_ISP_SRC_ADDR_ERROR, /* Source address not on word boundary */
  /*0x00000003*/ ERR_ISP_DST_ADDR_ERROR, /* Destination address not on word or 256 byte boundary */
  /*0x00000004*/ ERR_ISP_SRC_ADDR_NOT_MAPPED,
  /*0x00000005*/ ERR_ISP_DST_ADDR_NOT_MAPPED,
  /*0x00000006*/ ERR_ISP_COUNT_ERROR, /* Byte count is not multiple of 4 or is not a permitted value */
  /*0x00000007*/ ERR_ISP_INVALID_SECTOR,
  /*0x00000008*/ ERR_ISP_SECTOR_NOT_BLANK,
  /*0x00000009*/ ERR_ISP_SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION,
  /*0x0000000A*/ ERR_ISP_COMPARE_ERROR,
  /*0x0000000B*/ ERR_ISP_BUSY, /* Flash programming hardware interface is busy */
  /*0x0000000C*/ ERR_ISP_PARAM_ERROR, /* Insufficient number of parameters */
  /*0x0000000D*/ ERR_ISP_ADDR_ERROR, /* Address not on word boundary */
  /*0x0000000E*/ ERR_ISP_ADDR_NOT_MAPPED,
  /*0x0000000F*/ ERR_ISP_CMD_LOCKED, /* Command is locked */
  /*0x00000010*/ ERR_ISP_INVALID_CODE, /* Unlock code is invalid */
  /*0x00000011*/ ERR_ISP_INVALID_BAUD_RATE,
  /*0x00000012*/ ERR_ISP_INVALID_STOP_BIT,
  /*0x00000013*/ ERR_ISP_CODE_READ_PROTECTION_ENABLED,
  /*0x00000014*/ ERR_ISP_INVALID_FLASH_UNIT,
  /*0x00000015*/ ERR_ISP_USER_CODE_CHECKSUM,
  /*0x00000016*/ ERR_ISP_SETTING_ACTIVE_PARTITION,
  /*0x00000017*/ ERR_ISP_IRC_NO_POWER,
  /*0x00000018*/ ERR_ISP_FLASH_NO_POWER,
  /*0x00000019*/ ERR_ISP_EEPROM_NO_POWER,
  /*0x0000001A*/ ERR_ISP_EEPROM_NO_CLOCK,
  /*0x0000001B*/ ERR_ISP_FLASH_NO_CLOCK,
  /*0x0000001C*/ ERR_ISP_REINVOKE_ISP_CONFIG,
  
  /* ROM API related errors */
  ERR_API_BASE = 0x00010000,
  /**\b 0x00010001*/ ERR_API_INVALID_PARAMS = ERR_API_BASE + 1, /**< Invalid parameters*/
  /**\b 0x00010002*/ ERR_API_INVALID_PARAM1, /**< PARAM1 is invalid */
  /**\b 0x00010003*/ ERR_API_INVALID_PARAM2, /**< PARAM2 is invalid */
  /**\b 0x00010004*/ ERR_API_INVALID_PARAM3, /**< PARAM3 is invalid */
  /**\b 0x00010005*/ ERR_API_MOD_INIT, /**< API is called before module init */

  /* SPIFI API related errors */
  ERR_SPIFI_BASE = 0x00020000,
  /*0x00020001*/ ERR_SPIFI_DEVICE_ERROR =ERR_SPIFI_BASE+1,  
  /*0x00020002*/ ERR_SPIFI_INTERNAL_ERROR,		    
  /*0x00020003*/ ERR_SPIFI_TIMEOUT,			    
  /*0x00020004*/ ERR_SPIFI_OPERAND_ERROR,		    
  /*0x00020005*/ ERR_SPIFI_STATUS_PROBLEM,		    
  /*0x00020006*/ ERR_SPIFI_UNKNOWN_EXT, 		    
  /*0x00020007*/ ERR_SPIFI_UNKNOWN_ID,  		    
  /*0x00020008*/ ERR_SPIFI_UNKNOWN_TYPE,		    
  /*0x00020009*/ ERR_SPIFI_UNKNOWN_MFG, 		    
  /*0x0002000A*/ ERR_SPIFI_NO_DEVICE,
  /*0x0002000B*/ ERR_SPIFI_ERASE_NEEDED, 		    

  SEC_AES_NO_ERROR=0,
  /* Security API related errors */
  ERR_SEC_AES_BASE = 0x00030000,
  /*0x00030001*/ ERR_SEC_AES_WRONG_CMD=ERR_SEC_AES_BASE+1,
  /*0x00030002*/ ERR_SEC_AES_NOT_SUPPORTED,
  /*0x00030003*/ ERR_SEC_AES_KEY_ALREADY_PROGRAMMED,
  /*0x00030004*/ ERR_SEC_AES_DMA_CHANNEL_CFG,
  /*0x00030005*/ ERR_SEC_AES_DMA_MUX_CFG,
  /*0x00030006*/ SEC_AES_DMA_BUSY,      

  /* USB device stack related errors */
  ERR_USBD_BASE = 0x00040000,
  /**\b 0x00040001*/ ERR_USBD_INVALID_REQ = ERR_USBD_BASE + 1, /**< invalid request */
  /**\b 0x00040002*/ ERR_USBD_UNHANDLED, /**< Callback did not process the event */
  /**\b 0x00040003*/ ERR_USBD_STALL,     /**< Stall the endpoint on which the call back is called */
  /**\b 0x00040004*/ ERR_USBD_SEND_ZLP,  /**< Send ZLP packet on the endpoint on which the call back is called */
  /**\b 0x00040005*/ ERR_USBD_SEND_DATA, /**< Send data packet on the endpoint on which the call back is called */
  /**\b 0x00040006*/ ERR_USBD_BAD_DESC,  /**< Bad descriptor*/
  /**\b 0x00040007*/ ERR_USBD_BAD_CFG_DESC,/**< Bad config descriptor*/
  /**\b 0x00040008*/ ERR_USBD_BAD_INTF_DESC,/**< Bad interface descriptor*/
  /**\b 0x00040009*/ ERR_USBD_BAD_EP_DESC,/**< Bad endpoint descriptor*/
  /**\b 0x0004000a*/ ERR_USBD_BAD_MEM_BUF, /**< Bad alignment of buffer passed. */
  /**\b 0x0004000b*/ ERR_USBD_TOO_MANY_CLASS_HDLR, /**< Too many class handlers. */

  /* CGU  related errors */
  ERR_CGU_BASE = 0x00050000,
  /*0x00050001*/ ERR_CGU_NOT_IMPL=ERR_CGU_BASE+1,
  /*0x00050002*/ ERR_CGU_INVALID_PARAM,
  /*0x00050003*/ ERR_CGU_INVALID_SLICE,
  /*0x00050004*/ ERR_CGU_OUTPUT_GEN,
  /*0x00050005*/ ERR_CGU_DIV_SRC,
  /*0x00050006*/ ERR_CGU_DIV_VAL,
  /*0x00050007*/ ERR_CGU_SRC, 

  /*  I2C related errors   */
  ERR_I2C_BASE = 0x00060000,
  /*0x00060000*/ ERR_I2C_BUSY = ERR_I2C_BASE,
  /*0x00060001*/ ERR_I2C_NAK,
  /*0x00060002*/ ERR_I2C_BUFFER_OVERFLOW,    
  /*0x00060003*/ ERR_I2C_BYTE_COUNT_ERR,     
  /*0x00060004*/ ERR_I2C_LOSS_OF_ARBRITRATION,    
  /*0x00060005*/ ERR_I2C_SLAVE_NOT_ADDRESSED,     
  /*0x00060006*/ ERR_I2C_LOSS_OF_ARBRITRATION_NAK_BIT,   
  /*0x00060007*/ ERR_I2C_GENERAL_FAILURE,         
  /*0x00060008*/ ERR_I2C_REGS_SET_TO_DEFAULT,
  /*0x00060009*/ ERR_I2C_TIMEOUT,
  /*0x0006000A*/ ERR_I2C_BUFFER_UNDERFLOW,
  /*0x0006000B*/ ERR_I2C_PARAM,
  
   /* OTP  related errors */
  ERR_OTP_BASE = 0x00070000,
  /*0x00070001*/ ERR_OTP_WR_ENABLE_INVALID = ERR_OTP_BASE+1,
  /*0x00070002*/ ERR_OTP_SOME_BITS_ALREADY_PROGRAMMED,
  /*0x00070003*/ ERR_OTP_ALL_DATA_OR_MASK_ZERO,
  /*0x00070004*/ ERR_OTP_WRITE_ACCESS_LOCKED,
  /*0x00070005*/ ERR_OTP_READ_DATA_MISMATCH,
  /*0x00070006*/ ERR_OTP_USB_ID_ENABLED,
  /*0x00070007*/ ERR_OTP_ETH_MAC_ENABLED,
  /*0x00070008*/ ERR_OTP_AES_KEYS_ENABLED,
  /*0x00070009*/ ERR_OTP_ILLEGAL_BANK,

  /*  UART related errors   */
  ERR_UART_BASE = 0x00080000,
  /*0x00080001*/ ERR_UART_RXD_BUSY = ERR_UART_BASE+1,   //UART rxd is busy
  /*0x00080002*/ ERR_UART_TXD_BUSY,   //UART txd is busy
  /*0x00080003*/ ERR_UART_OVERRUN_FRAME_PARITY_NOISE, //overrun err, frame err, parity err, RxNoise err
  /*0x00080004*/ ERR_UART_UNDERRUN,    //underrun err    
  /*0x00080005*/ ERR_UART_PARAM,       //parameter is error
  /*0x00080006*/ ERR_UART_BAUDRATE,    //baudrate setting is error

  /*  CAN related errors   */
  ERR_CAN_BASE = 0x00090000,
  /*0x00090001*/ ERR_CAN_BAD_MEM_BUF = ERR_CAN_BASE+1,
  /*0x00090002*/ ERR_CAN_INIT_FAIL,
  /*0x00090003*/ ERR_CANOPEN_INIT_FAIL,

  /* SPIFI Lite API related errors */
  ERR_SPIFI_LITE_BASE = 0x000A0000,
  /*0x000A0001*/ ERR_SPIFI_LITE_INVALID_ARGUMENTS = ERR_SPIFI_LITE_BASE+1,  
  /*0x000A0002*/ ERR_SPIFI_LITE_BUSY,		    
  /*0x000A0003*/ ERR_SPIFI_LITE_MEMORY_MODE_ON,			    
  /*0x000A0004*/ ERR_SPIFI_LITE_MEMORY_MODE_OFF,
  /*0x000A0005*/ ERR_SPIFI_LITE_IN_DMA,
  /*0x000A0006*/ ERR_SPIFI_LITE_NOT_IN_DMA,
  /*0x000A0100*/ PENDING_SPIFI_LITE,

  /* CLK related errors */
  ERR_CLK_BASE = 0x000B0000,
  /*0x000B0001*/ ERR_CLK_NOT_IMPL=ERR_CLK_BASE+1,
  /*0x000B0002*/ ERR_CLK_INVALID_PARAM,
  /*0x000B0003*/ ERR_CLK_INVALID_SLICE,
  /*0x000B0004*/ ERR_CLK_OUTPUT_GEN,
  /*0x000B0005*/ ERR_CLK_DIV_SRC,
  /*0x000B0006*/ ERR_CLK_DIV_VAL,
  /*0x000B0007*/ ERR_CLK_SRC,
  /*0x000B0008*/ ERR_CLK_PLL_FIN_TOO_SMALL,
  /*0x000B0009*/ ERR_CLK_PLL_FIN_TOO_LARGE,
  /*0x000B000A*/ ERR_CLK_PLL_FOUT_TOO_SMALL,
  /*0x000B000B*/ ERR_CLK_PLL_FOUT_TOO_LARGE,
  /*0x000B000C*/ ERR_CLK_PLL_NO_SOLUTION,
  /*0x000B000D*/ ERR_CLK_PLL_MIN_PCT,
  /*0x000B000E*/ ERR_CLK_PLL_MAX_PCT,
  /*0x000B000F*/ ERR_CLK_OSC_FREQ,
  /*0x000B0010*/ ERR_CLK_CFG,
  /*0x000B0011*/ ERR_CLK_TIMEOUT,
  /*0x000B0012*/ ERR_CLK_BASE_OFF,
  /*0x000B0013*/ ERR_CLK_OFF_DEADLOCK,
    
  /*Power API*/
  ERR_PWR_BASE = 0x000C0000,
  /*0x000C0001*/  PWR_ERROR_ILLEGAL_MODE=ERR_PWR_BASE+1,
  /*0x000C0002*/  PWR_ERROR_CLOCK_FREQ_TOO_HIGH,
  /*0x000C0003*/  PWR_ERROR_INVALID_STATE,
  /*0x000C0004*/  PWR_ERROR_INVALID_CFG,
  /*0x000C0005*/  PWR_ERROR_PVT_DETECT,

  /* DMA related errors */
  ERR_DMA_BASE = 0x000D0000,
  /*0x000D0001*/	 ERR_DMA_ERROR_INT=ERR_DMA_BASE+1,
  /*0x000D0002*/	 ERR_DMA_CHANNEL_NUMBER,
  /*0x000D0003*/	 ERR_DMA_CHANNEL_DISABLED,
  /*0x000D0004*/	 ERR_DMA_BUSY,
  /*0x000D0005*/	 ERR_DMA_NOT_ALIGNMENT,
  /*0x000D0006*/	 ERR_DMA_PING_PONG_EN,
  /*0x000D0007*/	 ERR_DMA_CHANNEL_VALID_PENDING,
  /*0x000D0008*/	 ERR_DMA_PARAM,
  /*0x000D0009*/	 ERR_DMA_QUEUE_EMPTY,
  /*0x000D000A*/	 ERR_DMA_GENERAL,

  /* SPI related errors */
  ERR_SPI_BASE = 0x000E0000,
  /*0x000E0000*/	 ERR_SPI_BUSY=ERR_SPI_BASE,
  /*0x000E0001*/	 ERR_SPI_RXOVERRUN,
  /*0x000E0002*/	 ERR_SPI_TXUNDERRUN,
  /*0x000E0003*/	 ERR_SPI_SELNASSERT,
  /*0x000E0004*/	 ERR_SPI_SELNDEASSERT,
  /*0x000E0005*/	 ERR_SPI_CLKSTALL,
  /*0x000E0006*/	 ERR_SPI_PARAM,
  /*0x000E0007*/	 ERR_SPI_INVALID_LENGTH,

  /* ADC related errors */
  ERR_ADC_BASE = 0x000F0000,
  /*0x000F0001*/	 ERR_ADC_OVERRUN=ERR_ADC_BASE+1,
  /*0x000F0002*/	 ERR_ADC_INVALID_CHANNEL,
  /*0x000F0003*/	 ERR_ADC_INVALID_SEQUENCE,
  /*0x000F0004*/	 ERR_ADC_INVALID_SETUP,
  /*0x000F0005*/	 ERR_ADC_PARAM,
  /*0x000F0006*/	 ERR_ADC_INVALID_LENGTH,
  /*0x000F0007*/	 ERR_ADC_NO_POWER,

  /* Debugger Mailbox related errors */
  ERR_DM_BASE = 0x00100000,
  /*0x00100001*/	 ERR_DM_NOT_ENTERED=ERR_DM_BASE+1,
  /*0x00100002*/	 ERR_DM_UNKNOWN_CMD,
  /*0x00100003*/	 ERR_DM_COMM_FAIL
  
} ErrorCode_t;

#ifndef offsetof
#define offsetof(s, m)   (int) &(((s *) 0)->m)
#endif

#define COMPILE_TIME_ASSERT(pred)    switch (0) { \
	case 0:	\
	case pred:; }

#endif /* __LPC_ERROR_H__ */