Assembly 什么';这是在汇编代码中添加偶数或奇数的正确方法

Assembly 什么';这是在汇编代码中添加偶数或奇数的正确方法,assembly,numbers,add,68hc12,Assembly,Numbers,Add,68hc12,例如,我有一个包含这些代码NUM的文件(codes.txt) CODE1 fcc "3392236" CODE2 fcc "1234550" CODE3 fcc "7654361" CODE4 fcc "1212223" CODE5 fcc "1233211" CODE6 fcc "1232343" 接下来是一个名为readCode_Driver的子程序,其任务是使用另一个名为toInteger.asm的子程序帮助读取这些数字。readCode_Driver.asm文件

例如,我有一个包含这些代码NUM的文件(codes.txt)

CODE1   fcc "3392236"
CODE2   fcc "1234550"
CODE3   fcc "7654361"
CODE4   fcc "1212223"
CODE5   fcc "1233211"
CODE6   fcc "1232343"
接下来是一个名为readCode_Driver的子程序,其任务是使用另一个名为toInteger.asm的子程序帮助读取这些数字。readCode_Driver.asm文件如下所示:

NUMBEROFCODES   equ     6       ; Six CODEs to process
LENGTHOFCODE    equ     7       ; Each code is 7 digits
PROGRAMSTART    equ     $2000   ; Executable code as in (programming code) starts here
STORAGE1        equ     $1000   ; Storage starts here for original code numbers

org     STORAGE1
CODES
#include codes.txt

    org     ProgramStart
    lds     #ProgramStart

                            ; Setup to use toInterger
    ldx     #CODES           ; point to first digit of NUM1 ex: 3
    ldab    #LENGTHOFCODE    ; code's length
    clra                    ; loop counter



ConvertCODEs

    psha                    
    pshb                    

    jsr     toInteger         ; Convert from ASCII to Integer


    pulb                    ; Retrieve CODE's Length (called a POP)
    pula                    ; Retrieve Loop Counter

    inca                    ; Setup to loop again
    cmpa    #NUMBEROFCODES   ; All six codes converted?
    bne     ConvertCODEs     ; No, so continue on looping
    swi                     ; All six CODEs converted?

#include toInteger.asm            ; subroutine to test with this driver
    end
这是我的toInteger.asm文件及其内容:

toInteger ldaa    0,x                             ; get ASCII value
    suba    #$30                            ; convert to an integer
    staa    0,x                             ; store integer
    inx                                     ; point to next value
    decb                                    ; one less value to do
    cmpb    #0                              ; Is this the last ASCII value?
    bne     toInteger                         ; No, more to do
    rts                                     ; Yes, so we're done
为了验证这些代码,我需要另一个名为addeven.asm的子程序。假设此子例程在代码中添加偶数。例如,代码1有3392236。偶数是从这个位置0 1 2 3 4 5 6选择的。在代码1中,偶数为3(位置0)、9(位置2)、2(位置4)和6(位置6)。赔率数字为3(post1),2(pos3),3(pos5)


问题是,我如何在代码1中取偶数,将每个偶数乘以2,然后用汇编语言将它们相加。它是这样的2*3,2*9,2*2,2*6,然后像这样加上它们6+1+8+4+1+2。对于这些代码,18是1和8,所以我将它们添加为1+8。微控制器是dragon 12 68hc12

不知怎的,68xx系列出现在脑海中

通过移位和每秒钟跳过一个字节,可以很容易地实现2的乘法 可以用与转换相同的方法完成,除了两次插入x。
对于奇数字节,在调用之前加x。

这是什么类型的程序集?我能猜出单个指令的作用,但我以前没有见过。你必须用适当的体系结构来标记这个问题,否则几乎没有人知道这是哪个组件68HC12是板和微控制器