m68k: add malloc memory for early malloc
authorangelo@sysam.it <angelo@sysam.it>
Wed, 27 Apr 2016 19:50:44 +0000 (21:50 +0200)
committerSimon Glass <sjg@chromium.org>
Tue, 17 May 2016 15:54:43 +0000 (09:54 -0600)
To use serial uclass and DM, CONFIG_SYS_MALLOC_F must be used.
So CONFIG_SYS_GENERIC_GLOBAL_DATA has been undefined and
call to board_init_f_mem() is added for all cpu's.

Signed-off-by: Angelo Dureghello <angelo@sysam.it>
Acked-by: Simon Glass <sjg@chromium.org>
arch/m68k/cpu/mcf5227x/start.S
arch/m68k/cpu/mcf523x/start.S
arch/m68k/cpu/mcf52x2/start.S
arch/m68k/cpu/mcf530x/cpu_init.c
arch/m68k/cpu/mcf530x/start.S
arch/m68k/cpu/mcf532x/start.S
arch/m68k/cpu/mcf5445x/start.S
arch/m68k/cpu/mcf547x_8x/start.S
arch/m68k/include/asm/config.h

index 23024f94c8586a6d4cff8f754f9b84e57fb57a56..13c036f746edd5d3750bb87515785b72f4472220 100644 (file)
@@ -372,14 +372,29 @@ _start:
        move.l %d0, (%a1)
        move.l %d0, (%a2)
 
-       /* set stackpointer to end of internal ram to get some stackspace for
-          the first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
+
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       bsr     board_init_f_alloc_reserve
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
 
-       move.l #__got_start, %a5        /* put relocation table address to a5 */
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       bsr     board_init_f_init_reserve
 
        bsr cpu_init_f                  /* run low-level CPU init code (from flash) */
+       clr.l   %sp@-
        bsr board_init_f                /* run low-level board init code (from flash) */
 
        /* board_init_f() does not return */
index 1702f98ab1f11c97d7369a476da9722206e327c0..3aa4dd61faaa8b1894d6fc5ff83fd4e2ccca947d 100644 (file)
@@ -134,17 +134,34 @@ _start:
        move.l %d0, (%a1)
        move.l %d0, (%a2)
 
-       /* set stackpointer to end of internal ram to get some stackspace for the
-          first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
 
-       move.l #__got_start, %a5        /* put relocation table address to a5 */
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       move.l  #board_init_f_alloc_reserve, %a1
+       jsr     (%a1)
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       move.l  #board_init_f_init_reserve, %a1
+       jsr     (%a1)
 
        /* run low-level CPU init code (from flash) */
        move.l #cpu_init_f, %a1
        jsr (%a1)
        /* run low-level board init code (from flash) */
+       clr.l   %sp@-
        move.l #board_init_f, %a1
        jsr (%a1)
 
index 4af691f5aff7f4ff49845b48463746e2c627044a..a048884f6ce455c0129ff6bf6f08acb59e2989ba 100644 (file)
@@ -192,16 +192,34 @@ _after_flashbar_copy:
        move.l %d0, (%a1)
        move.l %d0, (%a2)
 
-       /* set stackpointer to end of internal ram to get some stackspace for the first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
 
-       move.l #__got_start, %a5                /* put relocation table address to a5 */
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       move.l  #board_init_f_alloc_reserve, %a1
+       jsr (%a1)
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       move.l  #board_init_f_init_reserve, %a1
+       jsr (%a1)
 
        /* run low-level CPU init code (from flash) */
        move.l #cpu_init_f, %a1
        jsr (%a1)
        /* run low-level board init code (from flash) */
+       clr.l   %sp@-
        move.l #board_init_f, %a1
        jsr (%a1)
 
index 80dc23910e095cf50300b37fe61ec7cb29d425b0..b09eed80240341e810b3090a5fa911eda4cb15b2 100644 (file)
@@ -142,7 +142,7 @@ int cpu_init_r(void)
        return 0;
 }
 
-void uart_port_conf(void)
+void uart_port_conf(int port)
 {
 }
 
index 097958afda3eccfc6e9d94d5df4566a6cf869b57..ca8bb320630187713e6d991673ff5a387f795ab1 100644 (file)
@@ -126,21 +126,32 @@ _start:
        move.l  %d0, (%a1)
        move.l  %d0, (%a2)
 
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
+
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
        /*
-        * set stackpointer to internal sram end - 80
-        * (global data struct size + some bytes)
-        * get some stackspace for the first c-code,
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
         */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l   %sp@-
+       move.l  %sp, -(%sp)
+       bsr     board_init_f_alloc_reserve
 
-       /* put relocation table address to a5 */
-       move.l #__got_start, %a5
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       bsr     board_init_f_init_reserve
 
        /* run low-level CPU init code (from flash) */
        bsr cpu_init_f
 
        /* run low-level board init code (from flash) */
+       clr.l   %sp@-
        bsr board_init_f
 
        /* board_init_f() does not return */
index 131ad6e392e9c48fabe730f46baf97222951528e..f25bc541be7cf6f1110b55d3c5d15669395ce15d 100644 (file)
@@ -148,17 +148,34 @@ _start:
        move.l %d0, (%a1)
        move.l %d0, (%a2)
 
-       /* set stackpointer to end of internal ram to get some stackspace for the
-          first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
 
-       move.l #__got_start, %a5        /* put relocation table address to a5 */
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       move.l  #board_init_f_alloc_reserve, %a1
+       jsr     (%a1)
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       move.l  #board_init_f_init_reserve, %a1
+       jsr     (%a1)
 
        /* run low-level CPU init code (from flash) */
        move.l #cpu_init_f, %a1
        jsr (%a1)
        /* run low-level board init code (from flash) */
+       clr.l   %sp@-
        move.l #board_init_f, %a1
        jsr (%a1)
 
index f50f147a4f3e6c4fb1722095998556519ff5e5a1..ba38678be3c1e79dc757df78f99ea960db513957 100644 (file)
@@ -657,17 +657,34 @@ _start:
        movec   %d0, %RAMBAR1
 #endif
 
-       /* set stackpointer to end of internal ram to get some stackspace for
-          the first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
+
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
 
-       move.l #__got_start, %a5        /* put relocation table address to a5 */
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       move.l  #board_init_f_alloc_reserve, %a1
+       jsr     (%a1)
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       move.l  #board_init_f_init_reserve, %a1
+       jsr     (%a1)
 
        /* run low-level CPU init code (from flash) */
        move.l #cpu_init_f, %a1
        jsr (%a1)
        /* run low-level board init code (from flash) */
+       clr.l   %sp@-
        move.l #board_init_f, %a1
        jsr (%a1)
 
index 75de22d37c8a71dbbf10ac19797a5a1d94bf6997..9a87a0da230af6beb465f7dfecbf4fa3eab4f455 100644 (file)
@@ -141,14 +141,29 @@ _start:
        move.l %d0, (%a1)
        move.l %d0, (%a2)
 
-       /* set stackpointer to end of internal ram to get some stackspace for the
-          first c-code */
-       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp
-       clr.l %sp@-
+       /* put relocation table address to a5 */
+       move.l #__got_start, %a5
 
-       move.l #__got_start, %a5        /* put relocation table address to a5 */
+       /* setup stack initially on top of internal static ram  */
+       move.l  #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE), %sp
+
+       /*
+        * if configured, malloc_f arena will be reserved first,
+        * then (and always) gd struct space will be reserved
+        */
+       move.l  %sp, -(%sp)
+       bsr     board_init_f_alloc_reserve
+
+       /* update stack and frame-pointers */
+       move.l  %d0, %sp
+       move.l  %sp, %fp
+
+       /* initialize reserved area */
+       move.l  %d0, -(%sp)
+       bsr     board_init_f_init_reserve
 
        jbsr cpu_init_f                 /* run low-level CPU init code (from flash) */
+       clr.l   %sp@-
        jbsr board_init_f               /* run low-level board init code (from flash) */
 
        /* board_init_f() does not return */
index e1458acd2c76091b5217f163e72e0654973236d0..9c4d3fb8fd7e905fe9ba2bf598d095fea86e8e43 100644 (file)
@@ -7,8 +7,6 @@
 #ifndef _ASM_CONFIG_H_
 #define _ASM_CONFIG_H_
 
-#define CONFIG_SYS_GENERIC_GLOBAL_DATA
-
 #define CONFIG_NEEDS_MANUAL_RELOC
 
 #define CONFIG_LMB