发布于 2011-03-27 06:56:39
91楼
四书五经网友提出“大于32位的循环移位的问题,如何实现”
下面是我编的程序,MD10和MD14组成64位的数据,MD10在高32位。I0.0的上升沿64位数据被循环左移一位。
A I 0.0
FN M 1.0
JCN _001
L MD 10
RLD 1 //双字左移一位
T MD 10
L MD 14
RLD 1
T MD 14
A M 13.0
= M 1.1 //暂存M13.0
A M 17.0
S M 13.0 //以下程序交换M13.0和M17.0的值
AN M 17.0
R M 13.0
A M 1.1
S M 17.0
AN M 1.1
R M 17.0
_001: NOP 0
已用仿真验证。用同样的方法可实现小于32位的循环移位。
追求完美