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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [newlib-1.17.0/] [libgloss/] [mn10300/] [crt0-eval.S] - Diff between revs 158 and 816

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 158 Rev 816
##==============================================================================
##==============================================================================
##
##
##      crt0-eval.S
##      crt0-eval.S
##
##
##      MN10300 Series Evaluation Board C startup code
##      MN10300 Series Evaluation Board C startup code
##
##
##==============================================================================
##==============================================================================
######COPYRIGHTBEGIN####
######COPYRIGHTBEGIN####
##
##
## Copyright (c) 1995, 1996, 1997, 1998 Cygnus Solutions
## Copyright (c) 1995, 1996, 1997, 1998 Cygnus Solutions
##
##
## The authors hereby grant permission to use, copy, modify, distribute,
## The authors hereby grant permission to use, copy, modify, distribute,
## and license this software and its documentation for any purpose, provided
## and license this software and its documentation for any purpose, provided
## that existing copyright notices are retained in all copies and that this
## that existing copyright notices are retained in all copies and that this
## notice is included verbatim in any distributions. No written agreement,
## notice is included verbatim in any distributions. No written agreement,
## license, or royalty fee is required for any of the authorized uses.
## license, or royalty fee is required for any of the authorized uses.
## Modifications to this software may be copyrighted by their authors
## Modifications to this software may be copyrighted by their authors
## and need not follow the licensing terms described here, provided that
## and need not follow the licensing terms described here, provided that
## the new terms are clearly indicated on the first page of each file where
## the new terms are clearly indicated on the first page of each file where
## they apply.
## they apply.
##
##
######COPYRIGHTEND####
######COPYRIGHTEND####
##------------------------------------------------------------------------------
##------------------------------------------------------------------------------
        .file   "crt0-eval.S"
        .file   "crt0-eval.S"
##------------------------------------------------------------------------------
##------------------------------------------------------------------------------
## Startup code
## Startup code
        .equ    DRAM_TOP,0x48100000
        .equ    DRAM_TOP,0x48100000
        .text
        .text
        .globl  __start
        .globl  __start
__start:
__start:
        # Set up stack.  Leave 4K at top for use by Cygmon.
        # Set up stack.  Leave 4K at top for use by Cygmon.
        mov     DRAM_TOP - 0x1000,a0
        mov     DRAM_TOP - 0x1000,a0
        sub     8,a0
        sub     8,a0
        mov     a0,sp
        mov     a0,sp
        # Clear BSS
        # Clear BSS
        mov     __bss_start,a0
        mov     __bss_start,a0
        mov     _end,a1
        mov     _end,a1
        cmp     a0,a1
        cmp     a0,a1
        beq     8f
        beq     8f
        clr     d0
        clr     d0
1:
1:
        movbu   d0,(a0)
        movbu   d0,(a0)
        inc     a0
        inc     a0
        cmp     a0,a1
        cmp     a0,a1
        bne     1b
        bne     1b
8:
8:
        # Call constructors
        # Call constructors
        .extern ___main
        .extern ___main
        call    ___main,[],0
        call    ___main,[],0
        # Call main
        # Call main
        clr     d0
        clr     d0
        clr     d1
        clr     d1
        mov     d0,(4,sp)
        mov     d0,(4,sp)
9:
9:
        or      0x0800,psw      # Enable interrupts
        or      0x0800,psw      # Enable interrupts
        .extern _main
        .extern _main
        call    _main,[],0
        call    _main,[],0
        .extern __exit
        .extern __exit
        call    __exit,[],0
        call    __exit,[],0
#       bra     9b              # Loop if we return
#       bra     9b              # Loop if we return
##------------------------------------------------------------------------------
##------------------------------------------------------------------------------
## end of crt0-eval.S
## end of crt0-eval.S
 
 

powered by: WebSVN 2.1.0

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