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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [newlib-1.17.0/] [libgloss/] [m68k/] [cf-crt0.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
/* Initial boot
/* Initial boot
 *
 *
 * Copyright (c) 2006 CodeSourcery Inc
 * Copyright (c) 2006 CodeSourcery Inc
 *
 *
 * 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.
 */
 */
        #include "asm.h"
        #include "asm.h"
        .text
        .text
        .extern __stack
        .extern __stack
        .extern __heap_end
        .extern __heap_end
        .weak __heap_end
        .weak __heap_end
        .extern __start1
        .extern __start1
        /* __reset should cause a HALT in a hosted executable and
        /* __reset should cause a HALT in a hosted executable and
           fall into __start for an unhosted executable.  The user is
           fall into __start for an unhosted executable.  The user is
           free to override this with their own declaration.  */
           free to override this with their own declaration.  */
        .globl __reset
        .globl __reset
        .weak __reset
        .weak __reset
__reset:
__reset:
#if HOSTED
#if HOSTED
        HALT
        HALT
#endif
#endif
        .globl __start
        .globl __start
__start:
__start:
        /* Initialize stack */
        /* Initialize stack */
        move.l IMM(__stack), sp
        move.l IMM(__stack), sp
        move.l IMM(0), fp
        move.l IMM(0), fp
        move.l IMM(__heap_end), d1
        move.l IMM(__heap_end), d1
#if HOSTED
#if HOSTED
        /* INIT_SIM syscall.  Allows changing sp & d1.  */
        /* INIT_SIM syscall.  Allows changing sp & d1.  */
        move.l IMM(1),d0
        move.l IMM(1),d0
        /* The semihosting sequence is 'nop; halt;sentinel' aligned to
        /* The semihosting sequence is 'nop; halt;sentinel' aligned to
           a 4 byte boundary.  The sentinel is an ill formed instruction
           a 4 byte boundary.  The sentinel is an ill formed instruction
           (movec %sp,0).  The debugger will adjust the pc, so it is never
           (movec %sp,0).  The debugger will adjust the pc, so it is never
            executed.  */
            executed.  */
        .balignw 4,0x4e71
        .balignw 4,0x4e71
        nop
        nop
        halt
        halt
        .long 0x4e7bf000
        .long 0x4e7bf000
#endif
#endif
        move.l d1,sp@-
        move.l d1,sp@-
        move.l fp,sp@-  /* Dummy return address */
        move.l fp,sp@-  /* Dummy return address */
        jmp __start1
        jmp __start1
 
 

powered by: WebSVN 2.1.0

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