changeset 3:74e9b3baac1e

Jumbo commit to make things work. Note I have t
author Daniel O'Connor <darius@dons.net.au>
date Sun, 01 Jan 2012 11:01:13 +1030 (2012-01-01)
parents 274e01fa5a4c
children 2c87e30c982d
files .hgignore BSDmakefile BSDmakefile.arm README.txt docs/CD00171190.pdf docs/CD00191185.pdf docs/Strive Mini LCD STM32 Schematic.pdf docs/Strive Mini STM32 Schematic.pdf docs/ili9325-v0.35.pdf lcd.c lcd.h main.c startup_stm32f10x_md_mthomas.c stm32f10x_conf.h syscalls.c
diffstat 15 files changed, 438 insertions(+), 108 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/.hgignore	Sun Jan 01 11:01:13 2012 +1030
@@ -0,0 +1,3 @@
+obj/.*
+.*~
+
--- a/BSDmakefile	Sat Oct 08 20:35:34 2011 +1030
+++ b/BSDmakefile	Sun Jan 01 11:01:13 2012 +1030
@@ -1,22 +1,20 @@
 PROG=		main
 
-SRCS=		main.c \
-		comm.c \
+SRCS=		comm.c \
+		core_cm3.c \
+		lcd.c \
+		main.c \
+		misc.c \
+		startup_stm32f10x_md_mthomas.c \
 		syscalls.c \
-		startup_stm32f10x_md_mthomas.c \
-		core_cm3.c \
 		system_stm32f10x.c \
-		stm32f10x_usart.c \
-		stm32f10x_flash.c \
-		stm32f10x_gpio.c \
-		stm32f10x_rcc.c \
-		stm32f10x_spi.c \
-		stm32f10x_rtc.c \
-		stm32f10x_bkp.c \
-		stm32f10x_pwr.c \
-		stm32f10x_dma.c \
-		stm32f10x_tim.c \
-		misc.c
+
+STM32LIBS=	usart gpio rcc rtc pwr bkp fsmc
+
+.for f in ${STM32LIBS}
+SRCS+=		stm32f10x_${f}.c
+CFLAGS+=	-DSTM32F10X_${f:U}_EN
+.endfor
 
 # Linker file
 LINKFILE=	${.CURDIR}/STM32F10x_512k_64k_flash.ld
@@ -26,7 +24,7 @@
 # Enable thumb code (since the Cortex M3 only does thumb)
 COMMONFLAGS+=	-mthumb
 # Debugging & optimisation
-COMMONFLAGS+= -g -Os
+COMMONFLAGS+= -g -O2
 # Put functions & data in individual sections to allow the linker to optimise (breaks debugging apparently)
 #COMMONFLAGS+=	-ffunction-sections -fdata-sections
 # We aren't using exceptions
@@ -35,15 +33,16 @@
 CFLAGS+=	-I ${.CURDIR}
 
 # Set device type
-CFLAGS+=	-DSTM32F10X_MD
+CFLAGS+=	-DSTM32F10X_HD
 # Set clocks
-CFLAGS+=	-DHSE_VALUE=8000000UL -DSYSCLK_FREQ_72MHz=72000000 
+CFLAGS+=	-DHSE_VALUE=8000000UL -DSYSCLK_FREQ_72MHz=72000000
 # Enable STM peripheral drivers
 CFLAGS+=	-DUSE_STDPERIPH_DRIVER
 # Enable startup delay
 #CFLAGS+=	-DSTARTUP_DELAY
 # Vector table in flash
 CFLAGS+=	-DVECT_TAB_FLASH 
+CFLAGS+=	-mthumb-interwork
 # Enable warnings (disable char-subscripts otherwise ctypes.h generates warnings
 CFLAGS+=	-Wall -Wextra -pedantic -Wimplicit -Wcast-align -Wpointer-arith -Wredundant-decls -Wshadow -Wcast-qual -Wcast-align -Wnested-externs -Wno-char-subscripts -std=gnu99
 
@@ -64,6 +63,9 @@
 .PATH:		${SYSDIR}
 
 debug:
-	${GDB} --eval-command="target remote 10.211.55.3:61234" --eval-command "load" ${PROG}.elf
+	${GDB} --eval-command="target remote 127.0.0.1:61234" ${PROG}.elf
+
+load:
+	${GDB} --eval-command="target remote 127.0.0.1:61234" --eval-command "load" ${PROG}.elf
 
 .include "${.CURDIR}/BSDmakefile.arm"
--- a/BSDmakefile.arm	Sat Oct 08 20:35:34 2011 +1030
+++ b/BSDmakefile.arm	Sun Jan 01 11:01:13 2012 +1030
@@ -4,7 +4,7 @@
 
 .MAIN:		${PROG}.bin
 
-TCHAIN=		arm-none-eabi
+TCHAIN=		${HOME}/sat/bin/arm-none-eabi
 #TCHAIN=		arm-elf
 #TCHAINSF=	-4.6
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/README.txt	Sun Jan 01 11:01:13 2012 +1030
@@ -0,0 +1,34 @@
+Board
+=====
+Board is a http://ourstm.5d6d.com STM32 Strive mini with a touchscreen
+LCD board which has a STM32F103VET (512k flash, 64k RAM).
+
+Unfortunately the CD that came with it is in Chinese, this page has a review
+http://www.deeplyembedded.net/index.php/categories/8-hardware-reviews/5-strive-mini-stm32?showall=&limitstart=
+
+The RTC is powered by a CR1220 battery.
+
+It has a SST25VF016B connected to SPI and a micro SD slot connected to
+SDIO.
+
+The LCD is driven by an ILI9325 connected in parallel 16 bit mode via
+the FSMC controller.
+
+Toolchain
+=========
+Created from https://github.com/MikeSmith/summon-arm-toolchain run
+as..
+/summon-arm-toolchain DARWIN_OPT_PATH=/opt/local LIBSTM32_EN=1 LIBSTM32_EN=1
+
+MacPorts tools did not work properly - it generated code which jumped
+to 0x00 in random places.
+
+Debug tool
+==========
+mkdir /tmp/stlink
+cp darwin/Info.plist /tmp/stlink
+sudo chown -R root: /tmp/stlink
+sudo kextload /tmp/stlink
+
+~/projects/stlink32/build/st-util 61234 /dev/dummy
+
Binary file docs/CD00171190.pdf has changed
Binary file docs/CD00191185.pdf has changed
Binary file docs/Strive Mini LCD STM32 Schematic.pdf has changed
Binary file docs/Strive Mini STM32 Schematic.pdf has changed
Binary file docs/ili9325-v0.35.pdf has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/lcd.c	Sun Jan 01 11:01:13 2012 +1030
@@ -0,0 +1,122 @@
+/*
+ * Example code (I think)
+ * ~/projects/STM32Strive/奋斗STM32开发板例程/奋斗STM32开发板例程/奋斗STM32开发板MINI/STM32奋斗版ucOS II V2.86 uCGUI 3.9 DEMO-V2/STM32奋斗版ucOS II V2.86 uCGUI 3.9 DEMO
+ *
+ * Schematics
+ * Main board ~/Downloads/Strive\ Mini\ STM32\ Schematic.pdf 
+ * LCD board ~/Downloads/Strive Mini LCD STM32 Schematic.pdf
+ * MCU reference manual
+ * ~/Downloads/CD00171190.pdf
+ * MCU Data sheet (pinout)
+ * ~/Downloads/CD00191185.pdf
+ * LCD data sheet
+ * 
+ */
+/*	LCD board	MCU
+  1	VCC		
+  2	TC_SCK		PA5/SPI1_SCK
+  3	GND		
+  4	TC_CS		PB7/SPI1_CS3
+  5	RST		PE1 FSMC_NBL1? (unlikely)
+  6	TC_DIN		PA7/SPI1_MOSI
+  7	nOE		PD4/FSMC_nOE
+  8    	TC_DOUT		PA6/SPI1_MISO
+  9	nWR		PD5/FSMC_nWE
+  10	TC_INT		PB6
+  11	CS		PD7/FSMC_NE1/FSMC_NCE2
+  12	NC		
+  13	RS		PD11/FSMC_A16
+  14	NC		
+  15	D7		PE10/FSMC_D7
+  16	NC		
+  17	D6		PE9/FSMC_D6
+  18	NC		
+  19	D3		PD1/FSMC_D3
+  20	D13		PD8/FSMC_D13
+  21	D5		PE8/FSMC_D5
+  22	D12		PE15/FSMC_D12
+  23	D4		PE7/FSMC_D4
+  24	GND		
+  25	NC		
+  26	D11		PE14/FSMC_D11
+  27	D2		PD0/FSMC_D2
+  28	D10		PE13/FSMC_D10
+  29	D1		PD15/FSMC_D1
+  30	D9		PE12/FSMC_D9
+  31	D0		PD14/FSMC_D0
+  32	D14		PD9/FSMC_D9
+  33	NC		
+  34	D8		PE11/FSMC_D8
+  35	NC		
+  36	NC		
+  37	NC		
+  38	LCD_PWM		PD13/TIM4_CH2
+  39	NC		
+  40	D15		PD10/FSMC_D15
+*/
+
+#include "stm32f10x.h"
+#include "lcd.h"
+
+void
+LCD_init(void) {
+    GPIO_InitTypeDef			GPIO_InitStructure;
+    FSMC_NORSRAMInitTypeDef		FSMC_NORSRAMInitStructure;
+    FSMC_NORSRAMTimingInitTypeDef	p;
+
+    /* Configures LCD Control lines (FSMC Pins) in alternate function Push-Pull mode.
+     *
+     * PD0(D2), PD1(D3), PD4(NOE), PD5(NWE), PD7(NE1/CS), PD8(D13), PD9(D14),
+     * PD10(D15), PD11(A16/RS) PD14(D0), PD15(D1)
+     */
+    GPIO_InitStructure.GPIO_Pin = (GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_7 |
+				   GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_14 | GPIO_Pin_15);
+    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
+    GPIO_Init(GPIOD, &GPIO_InitStructure);
+
+    /* PE7(D4), PE8(D5), PE9(D6), PE10(D7), PE11(D8), PE12(D9), PE13(D10),
+     * PE14(D11), PE15(D12)
+     */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | 
+    GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;
+    GPIO_Init(GPIOE, &GPIO_InitStructure);
+
+    /* Configures the Parallel interface (FSMC) for LCD (Parallel mode) */
+    /* FSMC_Bank1_NORSRAM4 timing configuration */
+    p.FSMC_AddressSetupTime = 1;
+    p.FSMC_AddressHoldTime = 0;
+    p.FSMC_DataSetupTime = 2;
+    p.FSMC_BusTurnAroundDuration = 0;
+    p.FSMC_CLKDivision = 0;
+    p.FSMC_DataLatency = 0;
+    p.FSMC_AccessMode = FSMC_AccessMode_A;
+
+    /* FSMC_Bank1_NORSRAM4 configured as follows:
+       - Data/Address MUX = Disable
+       - Memory Type = SRAM
+       - Data Width = 16bit
+       - Write Operation = Enable
+       - Extended Mode = Disable
+       - Asynchronous Wait = Disable */
+    FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM4;
+    FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;
+    FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;
+    FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
+    FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
+    FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;
+    FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;
+    FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
+
+    FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);  
+
+    /* Enable FSMC_Bank1_NORSRAM4 */
+    FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM4, ENABLE);
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/lcd.h	Sun Jan 01 11:01:13 2012 +1030
@@ -0,0 +1,7 @@
+#ifndef LCD_H_
+#define LCD_H_
+
+void	LCD_init(void);
+
+#endif
+
--- a/main.c	Sat Oct 08 20:35:34 2011 +1030
+++ b/main.c	Sun Jan 01 11:01:13 2012 +1030
@@ -1,25 +1,43 @@
 #include <ctype.h>
+#include <malloc.h>
 #include <stdio.h>
 #include <stdint.h>
+#include <time.h>
+#include <string.h>
+#include <sys/time.h>
+#include <stdlib.h>
+
 #include "stm32f10x.h"
+#include "lcd.h"
 #include "main.h"
 #include "comm.h"
 
-typedef volatile struct {
-    char	buf[40];
-    uint8_t	state;
-    uint8_t	len;
+typedef struct {
+    char		buf[40];
+    volatile uint8_t	state;
+    uint8_t		len;
 } consbuf_t;
 
 void Setup_HW(void);
 void NVIC_Configuration(void);
 
-/* Called every millisecond */
+
+/* Called every 1 / TICK_FREQ */
+#define TICK_FREQ 10000
 RAMFUNC void
 SysTick_Handler(void) {
     static uint32_t	tick = 0;
-   
+    static int		led = 0;
+    
     tick++;
+    if (tick % 10000 == 0) {
+	led = !led;
+	if (led)
+	    GPIO_SetBits(GPIOB, GPIO_Pin_5);
+	else
+	    GPIO_ResetBits(GPIOB, GPIO_Pin_5);
+    }
+    
 }
 
 consbuf_t	cmd;
@@ -81,6 +99,10 @@
 
 int
 main(void) {
+    char	buf[40];
+    struct tm	nowtm;
+    time_t	now;
+    
     cmd.state = cmd.len = 0;
     
     /* Setup USART etc */
@@ -89,27 +111,54 @@
     /* NVIC configuration */
     NVIC_Configuration();
 
-    /* Setup SysTick Timer for 1 millisecond interrupts, also enables Systick and Systick-Interrupt */
-    if (SysTick_Config(SystemCoreClock / 1000)) {
+    /* Setup SysTick Timer rate, also enables Systick and Systick-Interrupt */
+    if (SysTick_Config(SystemCoreClock / TICK_FREQ)) {
 	/* Capture error */
 	comm_puts("Can't setup SysTick\r\n");
 	while (1)
 	    ;
     }
 
+    /* Init LCD interface */
+    LCD_init();
+
+    /* Set stdout to unbuffered */
     setvbuf(stdout, NULL, _IONBF, 0);
     
     /* Say hello */
     fputs("\r\nHello world\r\n", stdout);
     
+#define Bank1_LCD_D    ((uint32_t)0x60020000)    //disp Data ADDR
+#define Bank1_LCD_C    ((uint32_t)0x60000000)    //disp Reg ADDR
+    
     while (1) {
 	fputs("> ", stdout);
 	
 	while (cmd.state != 255)
 	    ;
 	
-	if (cmd.len > 0)
-	    printf("Got command '%s'\r\n", cmd.buf);
+	if (cmd.len > 0) {
+	    if (!strncmp("gc", cmd.buf, 2)) {
+		now = time(NULL);
+		gmtime_r(&now, &nowtm);
+		strftime(buf, sizeof(buf) - 1, "Time is %Y/%m/%d %H:%M:%S UTC", &nowtm);
+		printf("Time is %s (%d)\r\n", buf, (int)now);
+	    } else if (!strncmp("sc ", cmd.buf, 3)) {
+		struct timeval tv;
+		tv.tv_sec = atoi(cmd.buf + 3);
+		tv.tv_usec = 0;
+		settimeofday(&tv, NULL);
+	    } else if (!strncmp("lcd", cmd.buf, 3)) {
+		*(__IO uint16_t *) (Bank1_LCD_C) = 0x00;
+		printf("LCD ID = %hx\r\n", *(__IO uint16_t *) (Bank1_LCD_D));
+	    } else if (!strncmp("read", cmd.buf, 4)) {
+		printf("PB5 = %d\r\n", GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_15));
+	    } else if (!strncmp("zz", cmd.buf, 2)) {
+		NVIC_SystemReset();
+	    } else {
+		printf("Unknown command\r\n");
+	    }
+	}
 	cmd.state = 0;
     }
 }
@@ -120,15 +169,54 @@
     GPIO_InitTypeDef GPIO_InitStructure;
     USART_InitTypeDef USART_InitStructure;
 
-    /* Enable USART1, GPIOA, GPIOD and AFIO clocks */
-    RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA |RCC_APB2Periph_GPIOD
-			   | RCC_APB2Periph_AFIO, ENABLE);
-    /* Enable USART2 clock */
-    RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
+    /* RTC stuff */
+    /* Enable PWR and BKP clocks */
+    RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);
+
+    /* Allow access to BKP Domain */
+    PWR_BackupAccessCmd(ENABLE);
+
+    /* Reset Backup Domain
+     *
+     * This resets the RTC etc back to 0 so probably only useful under user command
+     BKP_DeInit();
+    */
+
+    /* Enable LSE */
+    RCC_LSEConfig(RCC_LSE_ON);
+
+    /* Wait till LSE is ready */
+    while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET)
+	;
+
+    /* Select LSE as RTC Clock Source */
+    RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE);
 
-    /* DMA1 clock enable */
-    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
+    /* Enable RTC Clock */
+    RCC_RTCCLKCmd(ENABLE);
+
+    /* Wait for RTC registers synchronization */
+    RTC_WaitForSynchro();
+
+    /* Wait until last write operation on RTC registers has finished */
+    RTC_WaitForLastTask();
+
+    /* Wait until last write operation on RTC registers has finished */
+    RTC_WaitForLastTask();
 
+    /* Set RTC prescaler: set RTC period to 1sec */
+    RTC_SetPrescaler(32767); /* RTC period = RTCCLK/RTC_PR = (32.768 KHz)/(32767+1) */
+
+    /* Wait until last write operation on RTC registers has finished */
+    RTC_WaitForLastTask();
+
+    /* Clock setup */
+    /* Enable clocks we need */
+    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);
+    RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB |
+			   RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE | RCC_APB2Periph_AFIO, ENABLE);
+
+    /* Port configuration */
     /* Configure USART1 TX (PA.09) as alternate function push-pull */
     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
@@ -140,21 +228,32 @@
     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
     GPIO_Init(GPIOA, &GPIO_InitStructure);
 
-    /* Init UART1 - 115200 8n1, no flow control TX & RX enabled */
+    /* Configure PB5 as output push-pull */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
+    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
+    GPIO_Init(GPIOB, &GPIO_InitStructure);
+
+    /* Configure PB15 as input pull-up push-pull */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_15;
+    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
+    GPIO_Init(GPIOB, &GPIO_InitStructure);
+
+    /* USART configuration */
+    /* USART1 - 115200 8n1, no flow control TX & RX enabled */
     USART_InitStructure.USART_BaudRate = 115200;
     USART_InitStructure.USART_WordLength = USART_WordLength_8b;
     USART_InitStructure.USART_StopBits = USART_StopBits_1;
     USART_InitStructure.USART_Parity = USART_Parity_No;
     USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
     USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
-
-    /* Configure USART1 */
     USART_Init(USART1, &USART_InitStructure);
 
     /* Enable interrupts on receive data */
     USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
 
-    /* Enable the USART1 */
+    /* Enable USART */
     USART_Cmd(USART1, ENABLE);
 }
 
--- a/startup_stm32f10x_md_mthomas.c	Sat Oct 08 20:35:34 2011 +1030
+++ b/startup_stm32f10x_md_mthomas.c	Sun Jan 01 11:01:13 2012 +1030
@@ -161,7 +161,7 @@
 void (* const g_pfnVectorsStartup[])(void) =
 {
     (intfunc)((unsigned long)&_estack), /* The initial stack pointer during startup */
-    Reset_Handler,             /* The reset handler during startup */
+    Reset_Handler,              /* The reset handler during startup */
     HardFault_Handler,          /* Hard Fault Handler */
     MemManage_Handler,          /* MPU Fault Handler */
     BusFault_Handler,           /* Bus Fault Handler */
@@ -262,10 +262,7 @@
 
   /* Call CTORS of static objects, not needed for "pure C": */
   /* __libc_init_array(); */
-  /* if ( __libc_init_array )
-    __libc_init_array()
-  } */
-  
+
   /* Setup the microcontroller system. Initialize the Embedded Flash Interface,
      initialize the PLL and update the SystemFrequency variable. */
   SystemInit();
@@ -273,7 +270,8 @@
   /* Call the application's entry point.*/
   main();
 
-  while(1) { ; }
+  while(1) {
+  }
 }
 
 /**
@@ -282,25 +280,22 @@
  * @retval : None
 */
 
-void __Init_Data_and_BSS(void)
-{
-  unsigned long *pulSrc, *pulDest;
+void
+__Init_Data_and_BSS(void) {
+    unsigned long	*pulSrc, *pulDest;
 
-  /* Copy the data segment initializers from flash to SRAM */
-  pulSrc  = &_sidata;
-  pulDest = &_sdata;
-  if ( pulSrc != pulDest )
-  {
-    for(; pulDest < &_edata; )
-    {
-      *(pulDest++) = *(pulSrc++);
+    /* Copy the data segment initializers from flash to SRAM */
+    pulSrc = &_sidata;
+    pulDest = &_sdata;
+    if (pulSrc != pulDest) {
+	for(; pulDest < &_edata; ) {
+	    *(pulDest++) = *(pulSrc++);
+	}
     }
-  }
-  /* Zero fill the bss segment. */
-  for(pulDest = &_sbss; pulDest < &_ebss; )
-  {
-    *(pulDest++) = 0;
-  }
+    /* Zero fill the bss segment. */
+    for(pulDest = &_sbss; pulDest < &_ebss; ) {
+	*(pulDest++) = 0;
+    }
 }
 
 /*******************************************************************************
@@ -371,11 +366,10 @@
  * @retval : None
 */
 
-void Default_Handler(void)
-{
+void
+Default_Handler(void) {
   /* Go into an infinite loop. */
-  while (1)
-  {
+  while (1) {
   }
 }
 
--- a/stm32f10x_conf.h	Sat Oct 08 20:35:34 2011 +1030
+++ b/stm32f10x_conf.h	Sun Jan 01 11:01:13 2012 +1030
@@ -1,22 +1,4 @@
-/**
-  ******************************************************************************
-  * @file USART/Polling/stm32f10x_conf.h
-  * @author  MCD Application Team, mod. Martin Thomas for this project
-  * @version  V3.0.0
-  * @date  04/18/2009
-  * @brief  Library configuration file.
-  ******************************************************************************
-  * @copy
-  *
-  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
-  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
-  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
-  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
-  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
-  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
-  *
-  * <h2><center>&copy; COPYRIGHT 2009 STMicroelectronics</center></h2>
-  */
+/* Used to control which peripheral code is used */
 
 /* Define to prevent recursive inclusion -------------------------------------*/
 #ifndef __STM32F10x_CONF_H
@@ -24,29 +6,73 @@
 
 /* Includes ------------------------------------------------------------------*/
 /* Uncomment the line below to enable peripheral header file inclusion */
-/* #include "stm32f10x_adc.h" */
+#ifdef STM32F10X_ADC_EN
+#include "stm32f10x_adc.h"
+#endif
+#ifdef STM32F10X_BKP_EN
 #include "stm32f10x_bkp.h"
-/* #include "stm32f10x_can.h" */
-/* #include "stm32f10x_crc.h" */
-/* #include "stm32f10x_dac.h" */
-/* #include "stm32f10x_dbgmcu.h" */
+#endif
+#ifdef STM32F10X_CAN_EN
+#include "stm32f10x_can.h"
+#endif
+#ifdef STM32F10X_CRC_EN
+#include "stm32f10x_crc.h"
+#endif
+#ifdef STM32F10X_DAC_EN
+#include "stm32f10x_dac.h"
+#endif
+#ifdef STM32F10X_DBGMCU_EN
+#include "stm32f10x_dbgmcu.h"
+#endif
+#ifdef STM32F10X_DMA_EN
 #include "stm32f10x_dma.h"
-/* #include "stm32f10x_exti.h" */
+#endif
+#ifdef STM32F10X_EXTI_EN
+#include "stm32f10x_exti.h"
+#endif
+#ifdef STM32F10X_FLASH_EN
 #include "stm32f10x_flash.h"
-/* #include "stm32f10x_fsmc.h" */
+#endif
+#ifdef STM32F10X_FSMC_EN
+#include "stm32f10x_fsmc.h"
+#endif
+#ifdef STM32F10X_GPIO_EN
 #include "stm32f10x_gpio.h"
-/* #include "stm32f10x_i2c.h" */
-/* #include "stm32f10x_iwdg.h" */
+#endif
+#ifdef STM32F10X_I2C_EN
+#include "stm32f10x_i2c.h"
+#endif
+#ifdef STM32F10X_IWDG_EN
+#include "stm32f10x_iwdg.h"
+#endif
+#ifdef STM32F10X_PWR_EN
 #include "stm32f10x_pwr.h"
+#endif
+#ifdef STM32F10X_RCC_EN
 #include "stm32f10x_rcc.h"
+#endif
+#ifdef STM32F10X_RTC_EN
 #include "stm32f10x_rtc.h"
-/* #include "stm32f10x_sdio.h" */
+#endif
+#ifdef STM32F10X_SDIO_EN
+#include "stm32f10x_sdio.h"
+#endif
+#ifdef STM32F10X_SPI_EN
 #include "stm32f10x_spi.h"
+#endif
+#ifdef STM32F10X_TIM_EN
 #include "stm32f10x_tim.h"
+#endif
+#ifdef STM32F10X_USART_EN
 #include "stm32f10x_usart.h"
-/* #include "stm32f10x_wwdg.h" */
+#endif
+#ifdef STM32F10X_WWDG_EN
+#include "stm32f10x_wwdg.h"
+#endif
+
 #include "misc.h"  /* High level functions for NVIC and SysTick (add-on to CMSIS functions) */
 
+
 /* Exported types ------------------------------------------------------------*/
 /* Exported constants --------------------------------------------------------*/
 /* Uncomment the line below to expanse the "assert_param" macro in the
--- a/syscalls.c	Sat Oct 08 20:35:34 2011 +1030
+++ b/syscalls.c	Sun Jan 01 11:01:13 2012 +1030
@@ -5,14 +5,13 @@
  *      Author: Martin Thomas, 3BSD license
  */
 
-//#define SBRK_VERBOSE 1
-
 #include <stdio.h>
 #include <reent.h>
 #include <errno.h>
 #include <stdlib.h> /* abort */
 #include <sys/types.h>
 #include <sys/stat.h>
+#include <sys/time.h>
 
 #include "comm.h"
 #include "stm32f10x.h" /* for _get_PSP() from core_cm3.h*/
@@ -27,7 +26,8 @@
     return -1;
 }
 
-void _exit(int status) {
+void
+_exit(int status) {
     printf("_exit called with parameter %d\n", status);
     while(1)
 	;
@@ -38,7 +38,6 @@
     return 1;
 }
 
-
 extern char _end; /* Defined by the linker */
 static char *heap_end;
 
@@ -49,26 +48,24 @@
 
 char *
 get_stack_top(void) {
+    /* Use MSP (vs PSP) - the processor is in Thread mode out of reset */
     return (char*) __get_MSP();
-    //return (char*) __get_PSP();
 }
 
 caddr_t
 _sbrk(int incr) {
     char *prev_heap_end;
-#if SBRK_VERBOSE
-    printf("_sbrk called with incr %d\n", incr);
-#endif
+
     if (heap_end == 0) {
 	heap_end = &_end;
     }
     prev_heap_end = heap_end;
-#if 1
+
     if (heap_end + incr > get_stack_top()) {
 	printf("Heap and stack collision\n");
 	abort();
     }
-#endif
+
     heap_end += incr;
     return (caddr_t) prev_heap_end;
 }
@@ -118,3 +115,49 @@
     }
     return len;
 }
+
+int
+_gettimeofday_r(struct _reent *reent __attribute__((unused)), struct timeval *tp, void *tzp __attribute__((unused))) {
+    tp->tv_sec = RTC_GetCounter();
+    tp->tv_usec = 0;
+
+    return 0;
+}
+
+int
+settimeofday(const struct timeval *tp, const struct timezone *tzp __attribute__((unused))) {
+    RTC_SetCounter(tp->tv_sec);
+
+    return 0;
+}
+
+clock_t 
+_clock (void) {
+    return RTC_GetCounter();
+}
+
+void
+__tz_lock (void) {
+}
+
+
+void
+__tz_unlock (void) {
+}
+
+static __tzinfo_type tzinfo = {1, 0,
+    { {'J', 0, 0, 0, 0, (time_t)0, 0L },
+      {'J', 0, 0, 0, 0, (time_t)0, 0L } 
+    } 
+};
+
+__tzinfo_type *
+__gettzinfo (void) {
+  return &tzinfo;
+}
+
+/* Stub, required for strftime?! */
+int
+_open(const char *name __attribute__((unused)), int mode __attribute__((unused)), ...) {
+    return -1;
+}