Updated with latest changes
[hackover2013-badge-firmware.git] / projectconfig.h
index 28269c8..e59629a 100644 (file)
     different pin configuration, you will need to specify which board you
     are using by enabling one of the following definitions. The code base
     will then try to configure itself accordingly for that board.
     different pin configuration, you will need to specify which board you
     are using by enabling one of the following definitions. The code base
     will then try to configure itself accordingly for that board.
+
+    CFG_BRD_LPC1343_REFDESIGN   
+    =========================
+
+        microBuilder.eu LPC1343 Reference Design base board with
+        on-board peripherals initialised (EEPROM, USB or UART CLI, etc.)
+               
+               This is the recommended starting point for new development
+               since it makes it easy to send printf output to USB CDC, access
+               the on-board EEPROM, etc.
+
+    CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+    =================================
+
+        microBuilder.eu LPC1343 Reference Design base board with 
+        only the most common peripherals initialised by default.  
+        
+        Results in smallest code since EEPROM, USB, etc., are not
+        initialised on startup.  By default, only the following
+        peripherals are initialised by systemInit():
+        
+              - CPU (Configures the PLL, etc.)
+              - GPIO
+              - SysTick Timer
+              - UART (with printf support) *
+    
+        * Can be removed to save 0.8kb in debug and 0.3 kb in
+        release. Comment out 'CFG_PRINTF_UART' to disable it.
+  
+        The code size can be further reduced by several KB by removing
+        any IRQ Handlers that are not used.  The I2C IRQHandler, for
+        example, uses ~1KB of flash in debug and ~400KB in release mode,
+        but because it is referenced in the startup code it is always
+        included even if I2C is never used in the project.
+
+        Other IRQ Handlers that you might be able to comment out
+        to save some space are:
+
+        IRQ Handler               Debug   Release
+        ------------------------- ------  -------
+        I2C_IRQHandler            1160 b    400 b
+        SSP_IRQHandler             160 b     76 b
+        UART_IRQHandler            246 b    116 b
+        WAKEUP_IRQHandler          160 b    100 b
+        WDT_IRQHandler              50 b     28 b
+
+    CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
+    ====================================
+
+        microBuilder.eu/Adafruit Stand-Alone "Smart LCD" with USB enabled
+        for the CLI interface.
+
+    CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
+    =====================================
+
+        microBuilder.eu/Adafruit Stand-Alone "Smart LCD" with UART enabled
+        for the CLI interface.
+
+    CFG_BRD_LPC1343_802154USBSTICK
+    ==============================
+
+        microBuilder.eu USB stick 802.15.4 868/915MHz RF transceiver
+
     -----------------------------------------------------------------------*/
     #define CFG_BRD_LPC1343_REFDESIGN
     -----------------------------------------------------------------------*/
     #define CFG_BRD_LPC1343_REFDESIGN
+    // #define CFG_BRD_LPC1343_REFDESIGN_MINIMAL
     // #define CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
     // #define CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
     // #define CFG_BRD_LPC1343_802154USBSTICK
     // #define CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
     // #define CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
     // #define CFG_BRD_LPC1343_802154USBSTICK
     ILI9325/8   X X  X  X     X X X X X X X X X     . . . X
     ST7565      X X  X  X     X X X X X X X X X     . . . X
     ST7735      . .  .  .     X X X X X X . . .     . . . .
     ILI9325/8   X X  X  X     X X X X X X X X X     . . . X
     ST7565      X X  X  X     X X X X X X X X X     . . . X
     ST7735      . .  .  .     X X X X X X . . .     . . . .
+    SHARPMEM    . .  .  .     X X X X . . . . .     . . . .
     SSD1306     . .  .  .     X X X . X X . . .     . . . .
     MCP121      . .  .  .     . . . . . . . . .     . X . .
 
     SSD1306     . .  .  .     X X X . X X . . .     . . . .
     MCP121      . .  .  .     . . . . . . . . .     . X . .
 
     ILI9325/8   .     .     .     .       .       X X X X     .
     ST7565      .     .     .     .       .       X X X X     .
     ST7535      .     .     .     .       .       . . . .     .
     ILI9325/8   .     .     .     .       .       X X X X     .
     ST7565      .     .     .     .       .       X X X X     .
     ST7535      .     .     .     .       .       . . . .     .
+    SHARPMEM    .     .     .     .       .       . . . .     .
     SSD1306     .     .     .     .       .       . . . .     .
     INTERFACE   .     .     .     .       .       . . . .     X[2]
 
     SSD1306     .     .     .     .       .       . . . .     .
     INTERFACE   .     .     .     .       .       . . . .     X[2]
 
     -----------------------------------------------------------------------*/
     #define CFG_FIRMWARE_VERSION_MAJOR            (0)
     #define CFG_FIRMWARE_VERSION_MINOR            (9)
     -----------------------------------------------------------------------*/
     #define CFG_FIRMWARE_VERSION_MAJOR            (0)
     #define CFG_FIRMWARE_VERSION_MINOR            (9)
-    #define CFG_FIRMWARE_VERSION_REVISION         (2)
+    #define CFG_FIRMWARE_VERSION_REVISION         (8)
 /*=========================================================================*/
 
 
 /*=========================================================================*/
 
 
 /*=========================================================================*/
 
 
 /*=========================================================================*/
 
 
+/*=========================================================================
+    ALTERNATE RESET PIN
+    -----------------------------------------------------------------------
+
+    CFG_ALTRESET        If defined, indicates that a GPIO pin should be
+                        configured as an alternate reset pin in addition
+                        to the dedicated reset pin.
+    CFG_ALTRESET_PORT   The GPIO port where the alt reset pin is located
+    CFG_ALTRESET_PIN    The GPIO pin where the alt reset pin is located
+
+    -----------------------------------------------------------------------*/
+    #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
+      #define CFG_ALTRESET
+      #define CFG_ALTRESET_PORT         (1)
+      #define CFG_ALTRESET_PIN          (5)   // P1.5 = RTS
+    #endif
+/*=========================================================================*/
+
+
 /*=========================================================================
     UART
     -----------------------------------------------------------------------
 /*=========================================================================
     UART
     -----------------------------------------------------------------------
       #define CFG_UART_BUFSIZE            (512)
     #endif
 
       #define CFG_UART_BUFSIZE            (512)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      #define CFG_UART_BAUDRATE           (115200)
+      #define CFG_UART_BUFSIZE            (512)
+    #endif
+
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       #define CFG_UART_BAUDRATE           (115200)
       #define CFG_UART_BUFSIZE            (512)
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       #define CFG_UART_BAUDRATE           (115200)
       #define CFG_UART_BUFSIZE            (512)
       // #define CFG_SSP0_SCKPIN_0_6
     #endif
 
       // #define CFG_SSP0_SCKPIN_0_6
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      #define CFG_SSP0_SCKPIN_2_11
+      // #define CFG_SSP0_SCKPIN_0_6
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_SSP0_SCKPIN_2_11
       // #define CFG_SSP0_SCKPIN_0_6
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_SSP0_SCKPIN_2_11
       // #define CFG_SSP0_SCKPIN_0_6
       #define CFG_LED_OFF                 (1)
     #endif
 
       #define CFG_LED_OFF                 (1)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      #define CFG_LED_PORT                (2)
+      #define CFG_LED_PIN                 (10)
+      #define CFG_LED_ON                  (0)
+      #define CFG_LED_OFF                 (1)
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_LED_PORT                (2)
       #define CFG_LED_PIN                 (10)
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_LED_PORT                (2)
       #define CFG_LED_PIN                 (10)
       #define CFG_SDCARD_CDPIN            (0)
     #endif
 
       #define CFG_SDCARD_CDPIN            (0)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_SDCARD
+      #define CFG_SDCARD_READONLY         (1)   // Must be 0 or 1
+      #define CFG_SDCARD_CDPORT           (3)
+      #define CFG_SDCARD_CDPIN            (0)
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_SDCARD
       #define CFG_SDCARD_READONLY         (1)   // Must be 0 or 1
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_SDCARD
       #define CFG_SDCARD_READONLY         (1)   // Must be 0 or 1
       #define CFG_USBCDC_BUFFERSIZE       (256)
     #endif
 
       #define CFG_USBCDC_BUFFERSIZE       (256)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_USBHID
+      // #define CFG_USBCDC
+      #define CFG_USBCDC_BAUDRATE         (115200)
+      #define CFG_USBCDC_INITTIMEOUT      (5000)
+      #define CFG_USBCDC_BUFFERSIZE       (256)
+    #endif
+
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       // #define CFG_USBHID
       #define CFG_USBCDC
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       // #define CFG_USBHID
       #define CFG_USBCDC
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       // #define CFG_USBHID
       // #define CFG_USBCDC
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       // #define CFG_USBHID
       // #define CFG_USBCDC
-      #define CFG_USBCDC_BAUDRATE         (115200)
+      #define CFG_USBCDC_BAUDRATE         (57600)
       #define CFG_USBCDC_INITTIMEOUT      (5000)
       #define CFG_USBCDC_BUFFERSIZE       (256)
     #endif
       #define CFG_USBCDC_INITTIMEOUT      (5000)
       #define CFG_USBCDC_BUFFERSIZE       (256)
     #endif
                               "\n" for *nix
 
     Note: If no printf redirection definitions are present, all printf
                               "\n" for *nix
 
     Note: If no printf redirection definitions are present, all printf
-    output will be ignored, though this will also save ~350 bytes flash.
-
-    NOTE: PRINTF Support =    ~350 bytes Flash (-Os)
+    output will be ignored.
     -----------------------------------------------------------------------*/
     #ifdef CFG_BRD_LPC1343_REFDESIGN
       // #define CFG_PRINTF_UART
     -----------------------------------------------------------------------*/
     #ifdef CFG_BRD_LPC1343_REFDESIGN
       // #define CFG_PRINTF_UART
       #define CFG_PRINTF_NEWLINE          "\r\n"
     #endif
 
       #define CFG_PRINTF_NEWLINE          "\r\n"
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      #define CFG_PRINTF_UART
+      // #define CFG_PRINTF_USBCDC
+      #define CFG_PRINTF_NEWLINE          "\r\n"
+    #endif
+
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       // #define CFG_PRINTF_UART
       #define CFG_PRINTF_USBCDC
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       // #define CFG_PRINTF_UART
       #define CFG_PRINTF_USBCDC
       #define CFG_INTERFACE_CONFIRMREADY  (0)
     #endif
 
       #define CFG_INTERFACE_CONFIRMREADY  (0)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_INTERFACE
+      #define CFG_INTERFACE_MAXMSGSIZE    (256)
+      #define CFG_INTERFACE_PROMPT        "LPC1343 >> "
+      #define CFG_INTERFACE_SILENTMODE    (0)
+      #define CFG_INTERFACE_DROPCR        (0)
+      #define CFG_INTERFACE_ENABLEIRQ     (0)
+      #define CFG_INTERFACE_IRQPORT       (0)
+      #define CFG_INTERFACE_IRQPIN        (7)
+      #define CFG_INTERFACE_SHORTERRORS   (0)
+      #define CFG_INTERFACE_CONFIRMREADY  (0)
+    #endif
+
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       #define CFG_INTERFACE
       #define CFG_INTERFACE_MAXMSGSIZE    (256)
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB
       #define CFG_INTERFACE
       #define CFG_INTERFACE_MAXMSGSIZE    (256)
-      #define CFG_INTERFACE_PROMPT        "LCD >> "
+      #define CFG_INTERFACE_PROMPT        "CMD >> "
       #define CFG_INTERFACE_SILENTMODE    (0)
       #define CFG_INTERFACE_DROPCR        (0)
       #define CFG_INTERFACE_ENABLEIRQ     (0)
       #define CFG_INTERFACE_SILENTMODE    (0)
       #define CFG_INTERFACE_DROPCR        (0)
       #define CFG_INTERFACE_ENABLEIRQ     (0)
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_INTERFACE
       #define CFG_INTERFACE_MAXMSGSIZE    (256)
     #ifdef CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_INTERFACE
       #define CFG_INTERFACE_MAXMSGSIZE    (256)
-      #define CFG_INTERFACE_PROMPT        "LCD >> "
+      #define CFG_INTERFACE_PROMPT        ">>"
       #define CFG_INTERFACE_SILENTMODE    (1)
       #define CFG_INTERFACE_DROPCR        (1)
       #define CFG_INTERFACE_ENABLEIRQ     (1)
       #define CFG_INTERFACE_SILENTMODE    (1)
       #define CFG_INTERFACE_DROPCR        (1)
       #define CFG_INTERFACE_ENABLEIRQ     (1)
       #define CFG_I2CEEPROM_SIZE          (3072)
     #endif
 
       #define CFG_I2CEEPROM_SIZE          (3072)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_I2CEEPROM
+      #define CFG_I2CEEPROM_SIZE          (3072)
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_I2CEEPROM
       #define CFG_I2CEEPROM_SIZE          (3072)
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_I2CEEPROM
       #define CFG_I2CEEPROM_SIZE          (3072)
       #define CFG_CHIBI_BUFFERSIZE        (128)
     #endif
 
       #define CFG_CHIBI_BUFFERSIZE        (128)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_CHIBI
+      #define CFG_CHIBI_MODE              (0)                 // OQPSK_868MHZ
+      #define CFG_CHIBI_POWER             (0xE9)              // CHB_PWR_EU2_3DBM
+      #define CFG_CHIBI_CHANNEL           (0)                 // 868-868.6 MHz
+      #define CFG_CHIBI_PANID             (0x1234)
+      #define CFG_CHIBI_PROMISCUOUS       (0)
+      #define CFG_CHIBI_BUFFERSIZE        (128)
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       // #define CFG_CHIBI
       #define CFG_CHIBI_MODE              (0)                 // OQPSK_868MHZ
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       // #define CFG_CHIBI
       #define CFG_CHIBI_MODE              (0)                 // OQPSK_868MHZ
       #define CFG_TFTLCD_TS_KEYPADDELAY      (100)
     #endif
 
       #define CFG_TFTLCD_TS_KEYPADDELAY      (100)
     #endif
 
+    #ifdef CFG_BRD_LPC1343_REFDESIGN_MINIMAL
+      // #define CFG_TFTLCD
+      #define CFG_TFTLCD_INCLUDESMALLFONTS   (0)
+      #define CFG_TFTLCD_TS_DEFAULTTHRESHOLD (50)
+      #define CFG_TFTLCD_TS_KEYPADDELAY      (100)
+    #endif
+
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_TFTLCD
       #define CFG_TFTLCD_INCLUDESMALLFONTS   (0)
     #if defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB || defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART
       #define CFG_TFTLCD
       #define CFG_TFTLCD_INCLUDESMALLFONTS   (0)
 
 
 /*=========================================================================
 
 
 /*=========================================================================
-    128x64 Graphic LCDs
+    Monochrome/Bitmap Graphic LCDs
     -----------------------------------------------------------------------
 
     CFG_ST7565                If defined, this will cause drivers for
     -----------------------------------------------------------------------
 
     CFG_ST7565                If defined, this will cause drivers for
     CFG_SSD1306               If defined, this will cause drivers for
                               the 128x64 pixel SSD1306 OLED display to be
                               included
     CFG_SSD1306               If defined, this will cause drivers for
                               the 128x64 pixel SSD1306 OLED display to be
                               included
-
-    Note:                     LPC1114 @ 36MHz and the ST7565 with the
-                              backlight enabled consumes ~35mA
+    CFG_SHARPMEM              If defined, this will cause drivers for
+                              Sharp Memory Displays to be included
 
     DEPENDENCIES:             ST7565 requires the use of pins 2.1-6.
     DEPENDENCIES:             SSD1306 requires the use of pins 2.1-6.
 
     DEPENDENCIES:             ST7565 requires the use of pins 2.1-6.
     DEPENDENCIES:             SSD1306 requires the use of pins 2.1-6.
+    DEPENDENCIES:             SHARPMEM requires the use of pins 2.1-4.
     -----------------------------------------------------------------------*/
     // #define CFG_ST7565
     // #define CFG_SSD1306
     -----------------------------------------------------------------------*/
     // #define CFG_ST7565
     // #define CFG_SSD1306
+    // #define CFG_SHARPMEM
 /*=========================================================================*/
 
 
 /*=========================================================================*/
 
 
 
   =========================================================================*/
 
 
   =========================================================================*/
 
-#if !defined CFG_BRD_LPC1343_REFDESIGN && !defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB && !defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART && !defined CFG_BRD_LPC1343_802154USBSTICK
-  #error "You must defined a target board (CFG_BRD_LPC1343_REFDESIGN or CFG_BRD_LPC1343_TFTLCDSTANDALONE or CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART or CFG_BRD_LPC1343_802154USBSTICK)"
+#if !defined CFG_BRD_LPC1343_REFDESIGN && !defined CFG_BRD_LPC1343_REFDESIGN_MINIMAL && !defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_USB && !defined CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART && !defined CFG_BRD_LPC1343_802154USBSTICK
+  #error "You must defined a target board (CFG_BRD_LPC1343_REFDESIGN or CFG_BRD_LPC1343_REFDESIGN_MINIMAL or CFG_BRD_LPC1343_TFTLCDSTANDALONE or CFG_BRD_LPC1343_TFTLCDSTANDALONE_UART or CFG_BRD_LPC1343_802154USBSTICK)"
 #endif
 
 #if defined CFG_PRINTF_USBCDC && defined CFG_PRINTF_UART
 #endif
 
 #if defined CFG_PRINTF_USBCDC && defined CFG_PRINTF_UART
This page took 0.02978 seconds and 4 git commands to generate.