📄 test_c.s
字号:
.module test_c.c
.area text(rom, con, rel)
.even
_main::
; #include <iom8v.h> //和单片机类型相对应的头文件,选择Atmega8做实验;
; #include <macros.h>
; void delay_1ms(void); //函数声明,本实验中会用到这两个函数
; void delay_nms(unsigned int n);
; void main(void) //主函数
; {
; OSCCAL=0X9d;//系统时钟校准,不同的芯片和不同的频率,
ldi R24,157
out 0x31,R24
; DDRB=0B00000011; //定义B口的PB0、PB1为输出口
ldi R24,3
out 0x17,R24
; PORTB=0B00000001; //PB0口输出高电平,PB1口输出低电平,绿灯亮
ldi R24,1
out 0x18,R24
; delay_nms(5000); //延时5秒
ldi R16,5000
ldi R17,19
xcall _delay_nms
; PORTB=0B00000010; //PB1口输出高电平,PB0口输出低电平,关闭绿灯,红灯亮
ldi R24,2
out 0x18,R24
; delay_nms(5000); //延时5秒
ldi R16,5000
ldi R17,19
xcall _delay_nms
xjmp L3
L2:
ldi R24,3
in R2,0x18
eor R2,R24
out 0x18,R2
ldi R16,1000
ldi R17,3
xcall _delay_nms
L3:
; while(1) //程序一直执行该循环
xjmp L2
X0:
; {
; PORTB^=0B00000011; //翻转PB0和PB1口
; delay_nms(1000);
; }
; }
L1:
.dbline 0 ; func end
ret
; i -> R16,R17
.even
_delay_1ms::
; void delay_1ms(void)//1ms延时函数
; {
; unsigned int i;
; for (i=0;i<150;i++)
clr R16
clr R17
xjmp L9
L6:
L7:
subi R16,255 ; offset = 1
sbci R17,255
L9:
cpi R16,150
ldi R30,0
cpc R17,R30
brlo L6
; {
; }
; }
L5:
.dbline 0 ; func end
ret
; i -> R20,R21
; n -> R22,R23
.even
_delay_nms::
xcall push_gset2
movw R22,R16
; void delay_nms(unsigned int n)//延时n毫秒
; {
; unsigned int i;
; for (i=0;i<n;i++)//执行n次1毫秒延时
clr R20
clr R21
xjmp L14
L11:
xcall _delay_1ms
L12:
subi R20,255 ; offset = 1
sbci R21,255
L14:
cp R20,R22
cpc R21,R23
brlo L11
; delay_1ms();
; }
L10:
xcall pop_gset2
.dbline 0 ; func end
ret
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -