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

Subversion Repositories softavrcore

[/] [softavrcore/] [trunk/] [build/] [crt0.s] - Rev 2

Compare with Previous | Blame | View Log

;=============================================================================;
 
.set    PINB,   0x16
 
.set	VECTOR_SIZE,	2
.set	VECTOR_WIDTH,	2
 
.set	VECTOR_NUM,	1<<VECTOR_WIDTH
.set	AVR_REG_SIZE,	0x0020
.set	AVR_IO_SIZE,	0x0040
.set	RAM_SIZE, 	0x0200
 
;=============================================================================;
 
.set	_RAMEND_ADDR, 	AVR_REG_SIZE + AVR_IO_SIZE + RAM_SIZE
.set	_VECTORS_SIZE,	VECTOR_SIZE * VECTOR_NUM
.set    __stack_pointer, _RAMEND_ADDR - 1
.set	AVR_STACK_POINTER_LO_ADDR, 0x3d
.set	AVR_STACK_POINTER_HI_ADDR, 0x3e
.set	AVR_SREG_ADDR, 0x3f
 
.macro	XJMP name
	.if (VECTOR_SIZE == 2)
	rjmp	\name
	.elseif (VECTOR_SIZE == 4)
	jmp	\name
	.else
	nop
	.endif
.endm
 
.macro	XCALL name
	.if (VECTOR_SIZE == 2)
	rcall	\name
	.elseif (VECTOR_SIZE == 4)
	call	\name
	.else
	nop
	.endif
.endm
 
.macro  vector name
	.if (. - __vectors < _VECTORS_SIZE)
	.weak	\name
	.set	\name, __bad_interrupt
	XJMP	\name
	.endif
.endm
 
.section .vectors,"ax",@progbits
	.global __vectors
	.func   __vectors
 
__vectors:
 
	;in	r16, PINB
	;ldi	r16, 0xC0
	;out	0x04, r16
	;rjmp	__vectors
 
	XJMP	__init
	vector  __vector_1
	vector  __vector_2
	vector  __vector_3
	vector  __vector_4
	vector  __vector_5
	vector  __vector_6
	vector  __vector_7
	vector  __vector_8
	vector  __vector_9
	vector  __vector_10
	vector  __vector_11
	vector  __vector_12
	vector  __vector_13
	vector  __vector_14
	vector  __vector_15
	.endfunc
 
	.global __bad_interrupt
	.func   __bad_interrupt
__bad_interrupt:
	.weak   __vector_default
	.set    __vector_default, __bad_interrupt
	rjmp	__vector_default
	.endfunc
 
__init:
 
	eor	r1, r1
	out	AVR_SREG_ADDR, r1
	ldi     r28,lo8(__stack_pointer)
	out     AVR_STACK_POINTER_LO_ADDR, r28
	ldi     r29,hi8(__stack_pointer)
	out     AVR_STACK_POINTER_HI_ADDR, r29
 
.section .init9,"ax",@progbits
 
        XCALL   main
        XJMP    exit
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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