; Hardware initialisation, disk, mmc, timer, DRAM test
;
; Copyright (C) 2010 Sprite_tm
-; Copyright (C) 2010 Leo C.
+; Copyright (C) 2010-2013 Leo C.
;
; This file is part of avrcpm.
;
regval_tab_e:
start:
- ldi temp,low(RAMEND) ; top of memory
+ ldi temp,low(RAMEND) ; top of memory; vim:set ts=8 noet nowrap
+
out SPL,temp ; init stack pointer
ldi temp,high(RAMEND) ; top of memory
out SPH,temp ; init stack pointer
; - Setup Ports
- ldi temp,(1<<PUD) ;disable pullups
- outm8 P_PUD,temp
- out PORTD,_255 ;all pins high
+; ldi temp,(1<<PUD) ;disable pullups
+; outm8 P_PUD,temp
+ out PORTD,_255 ;all pins high (enables pullup on input ports)
out PORTB,_255
out PORTC,_255
out DDRD,_255 ; all outputs
ldiw z,SRAM_START
ldi temp2,high(ramtop)
-clr_l:
+clr_loop:
st z+,_0
cpi zl,low(ramtop)
cpc zh,temp2
- brne clr_l
+ brne clr_loop
+
+; - Fill unused RAM (stack)
+
+ ldi temp2,high(RAMEND+1)
+ ldi temp,SRAMFILL_VAL
+fill_loop:
+ st z+,temp
+ cpi zl,low(RAMEND+1)
+ cpc zh,temp2
+ brne fill_loop
; Init clock/timer system
rcall uart_init
-;Init timer2. Refresh-call should happen every (8ms/512)=312 cycles.
+;Init timer2. Refresh-call should happen every (8ms/512) cycles.
ldi temp,REFR_CNT*2 ; 2 cycles per int
outm8 OCR2A,temp
sei
-#if I2C
+#if I2C_SUPPORT
rcall i2c_init ; Init I2C master
rcall rtc_get
#endif
rcall printstr
.db 13,13,"CPM on an AVR, v"
db_version VMAJOR, VMINOR
- printstring " r" SVN_REVSTR
+ printstring " r" SVN_REVSTR " " TESTSTR
.if MEMTEST
printnewline
ldiw x,0
clr temp3 ;Error counter
ramtestr:
- mem_read
+ rcall dram_read
; ori temp,0x04 ;simulate error
; andi temp,0xF7
printstring "Addr xx yy "
ramtestr1:
printnewline
- mov temp4,temp
+ mov zl,temp
movw temp,x
rcall printhexw
rcall printspace
mov temp2,temp
rcall printhex
rcall printspace
- mov temp,temp4
+ mov temp,zl
rcall printhex
rcall printspace
mov temp,temp2
- eor temp,temp4
+ eor temp,zl
and temp,temp2
rcall printxbits
rcall printspace
mov temp,temp2
- eor temp,temp4
+ eor temp,zl
com temp2
and temp,temp2
rcall printxbits
halted_loop:
rjmp halted_loop ;keep AVR in an endless loop
+printxbits:
+ push temp2
+ push temp3
+ mov temp2,temp
+ ldi temp3,8
+prntxb0:
+ ldi temp,'-'
+ lsl temp2
+ brcc prntxb1
+ ldi temp,'X'
+prntxb1:
+ rcall uartPutc
+ dec temp3
+ brne prntxb0
+ pop temp3
+ pop temp2
+ ret
+
ramtestend:
.endif
.if MEMFILL
ldiw x,0
+ ldi temp,MEMFILL_VAL
ramfillw:
- ldi temp,MEMFILL_VAL
rcall dram_write_pp
brcc ramfillw
.endif
printnewline
printstring "Partinit done."
- lcall dsk_inval_hostbuf ;init (de)blocking buffer
+; Init (de)blocking buffer
+
+ lcall dsk_inval_hostbuf
; Read first sector of first CP/M partition (ipl)
+ ldiw y,fsys_vars
+
; Disk 0
- sts seekdsk,_0
+ std y+o_seekdsk,_0
; Track 0
- sts seektrk,_0
- sts seektrk+1,_0
+ std y+o_seektrk, _0
+ std y+o_seektrk+1,_0
; Sector 0
- sts seeksec,_0
+ std y+o_seeksec,_0
; Destination
ldiw x,IPLADDR
- stsw dmaadr,x
+ std y+o_dmaadr+0,xl
+ std y+o_dmaadr+1,xh
- lcall dsk_read
+ ldi temp,1<<READ_FUNC
+ lcall dskDoIt
; lift off
ljmp z80_init
-printspace:
- push temp
- ldi temp,' '
- rcall uartputc
- pop temp
- ret
-
-printxbits:
- push temp2
- push temp3
- mov temp2,temp
- ldi temp3,8
-prntxb0:
- ldi temp,'-'
- lsl temp2
- brcc prntxb1
- ldi temp,'X'
-prntxb1:
- rcall uartPutc
- dec temp3
- brne prntxb0
- pop temp3
- pop temp2
- ret
-
-
-
+; vim:set ts=8 noet nowrap