比如: 机器码
SJMP rel 10000000 偏移量8bit
新的目标地址:
PC = 当前PC + 偏移量 [注意偏移量rel的计算]
例:
KK: SJMP K0
设KK的地址 = 0100H, 标号K0 = 00F0H 则偏移量为多少?
rel = 目标地址 - 当前地址
= 00F0 - 0102H(PC指向下一条指令)
= -12H
= EEH(补码)
KK: DJNZ R7,K0
设置KK的地址为 = 0009H, 标号K0 = 0005H 则偏移量为多少?
rel = 目标地址 - 当前地址
= 0005H - 000BH(PC指向下一条指令)
= -06H
= FAH(补码,-06H负数的补码求法:符号位不变,其它部分取反加1)
DJNZ Rn,rel的机器码是 1101 1rrr 相对地址rel8bit [两字节]
则本条指令的机器码为DF FA
则目标地址 = rel + 当前地址(PC指向下一条指令,和本条指令的地址数相关)
所以取得 本条指令的话 需要判断是rel 是正数还是负数,如果是负数则 用当前地址减去偏移地址。如果是整数则用当前地址加上rel
13 0012 DF C5 DJNZ R7,LAB_ffffffd0
出现了此条指令:
在源程序当中把
UINT64 lCurLine = 0;// 修改为下面
UINT16 lCurLine = 0;
则输出的时候为LAB_ffd0