我已经编写了以下汇编代码(用于8052软处理器)以在Altera DE-2的8段7段显示器上显示一个数字:
mov HEX0, #0x98 ; show 9
mov HEX1, #0xC0 ; show 0
mov HEX2, #0xF9 ; show 1
mov HEX3, #0xF8 ; show 7
mov HEX4, #0x92 ; show 5
mov HEX5, #0x92 ; show 5
mov HEX6, #0x92 ; show 5
mov HEX7, #0xA4 ; show 2
HEXns定义如下:
HEX0 DATA 091H ; Zero turns the segment on
HEX1 DATA 092H ;
HEX2 DATA 093H ;
HEX3 DATA 094H ;
HEX4 DATA 08EH ;
HEX5 DATA 08FH ;
HEX6 DATA 096H ;
HEX7 DATA 097H ;
上面的代码本身就可以正常工作,但是当我尝试使用以下代码旋转数字时,所有7段显示输出就像HEXn寄存器设置为0x00一样。
M0:
wait(2)
mov A, HEX0 ; store HEX0 in the accumulator
mov HEX0, HEX1
mov HEX1, HEX2
mov HEX2, HEX3
mov HEX3, HEX4
mov HEX4, HEX5
mov HEX5, HEX6
mov HEX6, HEX7
mov HEX7, A
ljmp M0
END
这里wait(2)
是一个宏,它占用了大约两秒钟的时钟周期。有人可以告诉我(甚至推测)为什么HEXn被写入0?
答案 0 :(得分:0)
这是我的教授耶稣卡尔维诺 - 弗拉加的回答:
HEX0至HEX7是只写寄存器。他们无法回读。克服此限制的传统方法是使用变量(或寄存器,如果有足够的可用)。首先让我们定义八个字节变量。这样的事情会做:
dseg at 30H
shex0: ds 1
shex1: ds 1
shex2: ds 1
shex3: ds 1
shex4: ds 1
shex5: ds 1
shex6: ds 1
shex7: ds 1
cseg
然后用数字初始化变量:
mov shex0, #0x98 ; show 9
.
.
.
mov shex7, #0xA4 ; show 2
最后是循环,变量被发送到显示器并旋转:
M0:
; Send to displays
mov hex0, shex0
.
.
mov hex7, shex7
;Rotate
mov A, shex0; store HEX0 in the accumulator
mov shex0, shex1
.
.
.
mov shex6, shex7
mov shex7, A
sjmp M0