source: rtems/c/src/lib/libbsp/m68k/gen68360/startup/bspstart.c @ 6ea100c1

4.104.114.95
Last change on this file since 6ea100c1 was 6ea100c1, checked in by Joel Sherrill <joel.sherrill@…>, on 05/12/08 at 18:43:55

2008-05-12 Joel Sherrill <joel.sherrill@…>

  • startup/bspstart.c: Refactored and renamed initialization routines to rtems_initialize_data_structures, rtems_initialize_before_drivers, rtems_initialize_device_drivers, and rtems_initialize_start_multitasking. This opened the sequence up so that bootcard() could provide a more robust and flexible framework which is easier to explain and understand. This also lays the groundwork for sharing the division of available memory between the RTEMS workspace and heap and the C library initialization across all BSPs.
  • Property mode set to 100644
File size: 1.8 KB
Line 
1/*
2 *  This routine starts the application.  It includes application,
3 *  board, and monitor specific initialization and configuration.
4 *  The generic CPU dependent initialization has been performed
5 *  before this routine is invoked.
6 *
7 *  COPYRIGHT (c) 1989-1999.
8 *  On-Line Applications Research Corporation (OAR).
9 *
10 *  The license and distribution terms for this file may be
11 *  found in the file LICENSE in this distribution or at
12 *  http://www.rtems.com/license/LICENSE.
13 *
14 *  $Id$
15 */
16
17#include <string.h>
18
19#include <bsp.h>
20#include <rtems/libio.h>
21#include <rtems/libcsupport.h>
22
23/* Amount of RAM on this board. Dynamically set in start.S */
24unsigned long _M68K_RamSize;
25
26/*
27 *  Use the shared implementations of the following routines
28 */
29
30void bsp_libc_init( void *, uint32_t, int );
31void bsp_pretasking_hook(void);               /* m68k version */
32
33/*
34 *  bsp_start
35 *
36 *  This routine does the bulk of the system initialization.
37 */
38
39void bsp_start( void )
40{
41  extern void *_WorkspaceBase;
42
43  /*
44   *  _M68k_Ramsize is the amount of RAM on this board and
45   *  is set by many m68k BSPs at this point.  With this
46   *  BSP, it is dynamically set in start.S.
47   */
48
49  /*
50   *  Allocate the memory for the RTEMS Work Space.  This can come from
51   *  a variety of places: hard coded address, malloc'ed from outside
52   *  RTEMS world (e.g. simulator or primitive memory manager), or (as
53   *  typically done by stock BSPs) by subtracting the required amount
54   *  of work space from the last physical address on the CPU board.
55   */
56
57  /*
58   *  Need to "allocate" the memory for the RTEMS Workspace and
59   *  tell the RTEMS configuration where it is.  This memory is
60   *  not malloc'ed.  It is just "pulled from the air".
61   */
62
63  Configuration.work_space_start = (void *)&_WorkspaceBase;
64}
Note: See TracBrowser for help on using the repository browser.