NAR-5050/5070 Series User
’
s Manual
48
mov bl,ch
and bl,20h ; Other bits = 0 except Bit5
ror bl,04h ; Bit5 rotate to Bit1 for EBX_Bit[23..16]
add bh,bl ; Add BIt5 of ch in BH
mov bl,ch
and bl,40h ; Other bits = 0 except Bit6
rol bl,01h ; Bit6 rotate to Bit7 for EBX_Bit[23..16]
add bh,bl ; Add BIt6 of ch in BH
mov bl,ch ; Bit7 of Ch needs to be saved since Programmed
and bl,80h ; Other bits = 0 except Bit7
ror bl,07h ; Bit7 rotate to Bit0 for EBX_Bit[23..16]
; Keep bit7,6,5,4 end -----------------------
add bl,bh ; Bit7,Bit6,Bit5,Bit4 and Bit3 of Ch programmed
mov bh,GPDO3 ; EBX_Bit[31..24]
rol ebx,10h ; Restore the Swap of EBX high and low word
call LOOP_GPO_BITS ; call output GPDO
; Bit3 of Ch end ---------------------------------
; Bit2 of Ch start ------------------------------
; GPIO35
; EBX_Bit[31..24] : GPDO Offset value = 08h,
; EBX_Bit[23..16] : GPO Data = Bit2 of Ch ---> Bit5 , other bits --> 0
; EBX_Bit[15..8] : GPCFG1(LDN07_Index_F1h) Data = ( read value ) or 07h
; EBX_Bit[7..0] : GPSEL (LDN07_Index_F0h) Data , Port# and Pin# = 35h
mov bl,35h ; EBX_Bit[7..0] = 35h
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,07h ; OR 07h
mov bh,al ; EBX_Bit[15..8]
ror ebx,10h ; Swap EBX high and low word
mov bl,ch
and bl,04h ; Other bits = 0 except Bit2
rol bl,03h ; Bit2 rotate to Bit5 for EBX_Bit[23..16]
mov bh,bl ; Temperoary save in BH
; Keep bit7,6,5,4,3 start ---------------------
mov bl,ch