OpenCores
URL https://opencores.org/ocsvn/ion/ion/trunk

Subversion Repositories ion

[/] [ion/] [trunk/] [src/] [common/] [c_startup.s] - Rev 248

Go to most recent revision | Compare with Previous | Blame | View Log

#-------------------------------------------------------------------------------
# startup.s -- C startup code common to all C programs.
#
# This code does the following:
# 1.- Initialize the stack at the end of the bss area
# 2.- Clear the bss area
# 3.- Move the data section from FLASH to RAM (if applicable)
# 4.- Call main()
# 5.- Freeze in endless loop after main() returns, if it does
#
# The code does not initialize the caches or the hardware and does not include
# the reset or trap vectors.
#
# This code was inherited from OpenCores' Plasma project.
#-------------------------------------------------------------------------------
 
    # The stack size can be defined from the assembler command line
    # FIXME should use info from the link script
    .ifndef STACK_SIZE
    .set    STACK_SIZE,         1024        # by default, reserve 1KB
    .endif
 
    # Reserve space for regular stack (BSS segment)
    .comm init_stack, STACK_SIZE
 
    .text
    .align 2
    .global entry
    .ent    entry
entry:
    .set noreorder
 
    # (The linker script defined these symbols)
    la      $gp, _gp                # initialize global pointer
    la      $5, __bss_start         # $5 = .sbss_start
    la      $4, _end                # $2 = .bss_end
    la      $sp, init_stack+STACK_SIZE-24 #initialize stack pointer
 
    # Clear BSS area
$BSS_CLEAR:
    sw      $0, 0($5)
    slt     $3, $5, $4
    bnez    $3, $BSS_CLEAR
    addiu   $5, $5, 4
 
    # Move data section image from flash to RAM, if necessary.
    la      $a0,data_start
    la      $a1,data_load_start
    beq     $a1,$a0,move_data_section_done
    nop
    la      $s0,data_size
    beqz    $s0,move_data_section_done
    nop
move_data_section_loop:
    lw      $t0,0($a1)
    addiu   $a1,$a1,4
    sw      $t0,0($a0)
    addiu   $a0,$a0,4
    bgtz    $s0,move_data_section_loop
    addiu   $s0,$s0,-4
move_data_section_done:
 
    jal     main                    # init done; call main()
    nop
$L1:
    j       $L1
    nop
 
    .end     entry
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.