"setf", not "nop", for common_v10_v32 compatibility. Move out interrupt table to irqtable.S. Include here for non-ELF. * cris/irqtable.S: Extracted from cris/crt0.S. Provide per-entry weak default stub definitions. * cris/crtn.c: Use "setf", not "nop", for common_v10_v32 compatibility. * cris/setup.S [__arch_common_v10_v32]: Return. * cris/Makefile.in (BSP_OBJS): Add irqtable.o.
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* Generic simplistic start-up-stub for CRIS/CRISv32.
 | |
|    Copyright (C) 1993-2005, 2007 Axis Communications.
 | |
|    All rights reserved.
 | |
| 
 | |
|    Redistribution and use in source and binary forms, with or without
 | |
|    modification, are permitted provided that the following conditions
 | |
|    are met:
 | |
| 
 | |
|    1. Redistributions of source code must retain the above copyright
 | |
|       notice, this list of conditions and the following disclaimer.
 | |
| 
 | |
|    2. Neither the name of Axis Communications nor the names of its
 | |
|       contributors may be used to endorse or promote products derived
 | |
|       from this software without specific prior written permission.
 | |
| 
 | |
|    THIS SOFTWARE IS PROVIDED BY AXIS COMMUNICATIONS AND ITS CONTRIBUTORS
 | |
|    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | |
|    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 | |
|    A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL AXIS
 | |
|    COMMUNICATIONS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
 | |
|    INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | |
|    (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 | |
|    SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | |
|    HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 | |
|    STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
 | |
|    IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 | |
|    POSSIBILITY OF SUCH DAMAGE.  */
 | |
| 
 | |
| #undef cris
 | |
| #undef L
 | |
| #ifdef __NO_UNDERSCORES__
 | |
| #define L(x) x
 | |
| #else
 | |
| #define L(x) _ ## x
 | |
| #endif
 | |
| 
 | |
| ; Rudimentary v0..v32-compatible startup stub.
 | |
| 
 | |
| #ifdef __ELF__
 | |
|  .section .startup,"ax"
 | |
| #endif
 | |
|  .global __start
 | |
|  nop
 | |
| __start:
 | |
|  move.d 0f,$r9
 | |
|  jump $r9
 | |
|  setf
 | |
| 
 | |
| #ifndef __ELF__
 | |
| 
 | |
| ; For a.out, everything read-only and code-wise goes into a
 | |
| ; single section, so we can't separate the interrupt table from
 | |
| ; the startup code if we want to have files in-between.
 | |
| #define IN_CRT0
 | |
| #include "irqtable.S"
 | |
| 
 | |
| #else
 | |
| 
 | |
| ; The interrupt table (at offset 12, irq #3) is expected here.
 | |
| ; The simplest way to make sure we link it in, is to sacrifice
 | |
| ; some memory and refer to it with a relocation.
 | |
|  .text
 | |
|  .dword __irqtable_at_irq3
 | |
| 
 | |
| #endif /* __ELF__ */
 | |
| 
 | |
| 0:
 | |
|  move.d __setup,$r9
 | |
|  jsr $r9
 | |
|  nop
 | |
| #ifdef __ELF__
 | |
|  jsr L(_init)
 | |
|  nop
 | |
|  move.d L(_fini),$r10
 | |
|  jsr L(atexit)
 | |
|  nop
 | |
| #endif
 | |
|  jsr L(main)
 | |
|  nop
 | |
|  jsr L(exit)
 | |
|  nop
 | |
| 0:
 | |
|  nop
 | |
|  ba 0b
 | |
|  nop
 |