📄 init.s
字号:
.module init.c
.area text(rom, con, rel)
.dbfile C:\ATMega8515\看门狗\init.c
.dbfunc e port_init _port_init fV
.even
_port_init::
.dbline -1
.dbline 10
; //ICC-AVR application builder : 2006-4-29 3:07:04
; // Target : M8515
; // Crystal: 11.059Mhz
;
; #include <iom8515v.h>
; #include <macros.h>
;
; #define uchar unsigned char
; void port_init(void)
; {
.dbline 11
; PORTA = 0x00;
clr R2
out 0x1b,R2
.dbline 12
; DDRA = 0xFF;
ldi R24,255
out 0x1a,R24
.dbline 13
; PORTB = 0x00;
out 0x18,R2
.dbline 14
; DDRB = 0x00;
out 0x17,R2
.dbline 15
; PORTC = 0x00;
out 0x15,R2
.dbline 16
; DDRC = 0xC0;
ldi R24,192
out 0x14,R24
.dbline 17
; PORTD = 0x00;
out 0x12,R2
.dbline 18
; DDRD = 0x00;
out 0x11,R2
.dbline 19
; PORTE = 0x00;
out 0x7,R2
.dbline 20
; DDRE = 0x00;
out 0x6,R2
.dbline -2
L1:
.dbline 0 ; func end
ret
.dbend
.dbfunc e watchdog_init _watchdog_init fV
.even
_watchdog_init::
.dbline -1
.dbline 26
; }
;
; //Watchdog initialize
; // prescale: 2048K
; void watchdog_init(void)
; {
.dbline 27
; WDR(); //this prevents a timout on enabling
wdr
.dbline 28
; WDTCR = 0x0F; //WATCHDOG ENABLED - dont forget WDR
ldi R24,15
out 0x21,R24
.dbline -2
L2:
.dbline 0 ; func end
ret
.dbend
.dbfunc e timer1_init _timer1_init fV
.even
_timer1_init::
.dbline -1
.dbline 36
; }
;
; //TIMER1 initialize - prescale:1
; // WGM: 0) Normal, TOP=0xFFFF
; // desired value: 1mSec
; // actual value: 1.000mSec (0.0%)
; void timer1_init(void)
; {
.dbline 37
; TCCR1B = 0x00; //stop
clr R2
out 0x2e,R2
.dbline 38
; TCNT1H = 0xD4; //setup
ldi R24,212
out 0x2d,R24
.dbline 39
; TCNT1L = 0xCE;
ldi R24,206
out 0x2c,R24
.dbline 40
; OCR1AH = 0x2B;
ldi R24,43
out 0x2b,R24
.dbline 41
; OCR1AL = 0x32;
ldi R24,50
out 0x2a,R24
.dbline 42
; OCR1BH = 0x2B;
ldi R24,43
out 0x29,R24
.dbline 43
; OCR1BL = 0x32;
ldi R24,50
out 0x28,R24
.dbline 44
; TCCR1A = 0x00;
out 0x2f,R2
.dbline 45
; TCCR1B = 0x01; //start Timer
ldi R24,1
out 0x2e,R24
.dbline -2
L3:
.dbline 0 ; func end
ret
.dbend
.area data(ram, con, rel)
.dbfile C:\ATMega8515\看门狗\init.c
_count::
.blkb 1
.area idata
.byte 0
.area data(ram, con, rel)
.dbfile C:\ATMega8515\看门狗\init.c
.dbsym e count _count c
.area vector(rom, abs)
.org 12
rjmp _timer1_ovf_isr
.area data(ram, con, rel)
.dbfile C:\ATMega8515\看门狗\init.c
.area text(rom, con, rel)
.dbfile C:\ATMega8515\看门狗\init.c
.dbfunc e timer1_ovf_isr _timer1_ovf_isr fV
.even
_timer1_ovf_isr::
st -y,R2
st -y,R3
st -y,R24
st -y,R25
in R2,0x3f
st -y,R2
.dbline -1
.dbline 52
.dbline 53
ldi R24,212
out 0x2d,R24
.dbline 54
ldi R24,206
out 0x2c,R24
.dbline 55
lds R2,_count
clr R3
mov R24,R2
subi R24,255 ; addi 1
sts _count,R24
mov R24,R2
cpi R24,244
brne L5
.dbline 55
.dbline 55
clr R2
sts _count,R2
.dbline 55
lds R24,_shuma
subi R24,255 ; addi 1
sts _shuma,R24
.dbline 55
L5:
.dbline -2
L4:
ld R2,y+
out 0x3f,R2
ld R25,y+
ld R24,y+
ld R3,y+
ld R2,y+
.dbline 0 ; func end
reti
.dbend
.dbfunc e init_devices _init_devices fV
.even
_init_devices::
.dbline -1
.dbline 60
; }
;
; uchar count=0;
; extern uchar shuma;
; #pragma interrupt_handler timer1_ovf_isr:7
; void timer1_ovf_isr(void)
; {
; TCNT1H = 0xD4; //reload counter high value
; TCNT1L = 0xCE; //reload counter low value
; if(count++==500){count=0;shuma++;}
; }
;
; //call this routine to initialize all peripherals
; void init_devices(void)
; {
.dbline 62
; //stop errant interrupts until set up
; CLI(); //disable all interrupts
cli
.dbline 63
; port_init();
rcall _port_init
.dbline 64
; watchdog_init();
rcall _watchdog_init
.dbline 65
; timer1_init();
rcall _timer1_init
.dbline 67
;
; MCUCR = 0x00;
clr R2
out 0x35,R2
.dbline 68
; EMCUCR = 0x00;
out 0x36,R2
.dbline 69
; GICR = 0x00;
out 0x3b,R2
.dbline 70
; TIMSK = 0x80;
ldi R24,128
out 0x39,R24
.dbline 71
; SEI(); //re-enable interrupts
sei
.dbline -2
L7:
.dbline 0 ; func end
ret
.dbend
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -