NAR-5050/5070 Series User
’
s Manual
40
; Bit1 of Ch start ------------------------------
; GPIO33 : JP7 of test module
; EBX_Bit[31..24] : GPDI3 = 09h,
; EBX_Bit[23..16] : MASK bit ( which bit ) , GPIO33 --> 03h
; EBX_Bit[15..8] : GPCFG1(LDN07_Index_F1h) Data = ( read value ) or 06h
; EBX_Bit[7..0] : GPSEL (LDN07_Index_F0h) Data , Port# and Pin# = 33h
; Call LOOP_GET_GPI_CARRY , get the bit to CARRY flag.
mov bl,33h ; EBX_Bit[7..0] = 33h
mov dx,Index_IO_Port ; Read Index F1h first
mov al,GPCFG1
out dx,al
mov dx,Data_IO_Port
in al,dx
or al,06h ; OR 06h
mov bh,al ; EBX_Bit[15..8]
ror ebx,10h ; Swap EBX high and low word
mov bl,03h ; EBX_Bit[23..16]
mov bh,GPDI3 ; EBX_Bit[31..24]
rol ebx,10h ; Restore the Swap of EBX high and low word
call LOOP_GET_GPI_CARRY ; call get GPDI
jc set_bit1 ; if carry , then Bit1=1
and ch,0FDh ; else Bit1=0
jmp next_bit0
set_bit1 :
or Ch,02h
next_bit0 :
; Bit1 of Ch end ---------------------------------
; Bit0 of Ch start ------------------------------
; GPIO34 : JP8 of test module
; EBX_Bit[31..24] : GPDI3 = 09h,
; EBX_Bit[23..16] : MASK bit ( which bit ) , GPIO34 --> 04h
; EBX_Bit[15..8] : GPCFG1(LDN07_Index_F1h) Data = ( read value ) or 46h
; EBX_Bit[7..0] : GPSEL (LDN07_Index_F0h) Data , Port# and Pin# = 34h
; Call LOOP_GET_GPI_CARRY , get the bit to CARRY flag.
mov bl,34h ; EBX_Bit[7..0] = 34h
mov dx,Index_IO_Port ; Read Index F1h first
mov al,GPCFG1
out dx,al
mov dx,Data_IO_Port
in al,dx
or al,06h ; OR 06h