home *** CD-ROM | disk | FTP | other *** search
/ World of Shareware - Software Farm 2 / wosw_2.zip / wosw_2 / CPROG / CEXPRESS.ZIP / BITS.ASM / BITCPY16.ASM < prev    next >
Assembly Source File  |  1989-05-03  |  2KB  |  70 lines

  1. ;void  bit_copy_16(target,source,t_start,s_start,number);
  2. ;  unsigned short  *target,source;
  3. ;  unsigned char   t_start,s_start,number;
  4.  
  5.     EXTRN  _memory_model:byte
  6.     EXTRN  _error_code:byte
  7.  
  8. _TEXT    SEGMENT  BYTE PUBLIC 'CODE'
  9.     ASSUME CS:_TEXT
  10.     PUBLIC _bit_copy_16
  11. _bit_copy_16 proc near
  12.     push bp            ;
  13.     mov  bp,sp        ;set up stack frame
  14.     push di            ;
  15.     push si            ;
  16.     mov  _error_code,0    ;clear _error_code
  17.     cmp  _memory_model,0    ;near or far?
  18.     jle  begin        ;jump if near
  19.     inc  bp            ;else add 2 to BP
  20.     inc  bp            ;
  21. begin:    cmp  _memory_model,2    ;data near or far?
  22.     jb   L0            ;jump if near
  23.     les  di,dword ptr[bp+4] ;point to Target
  24.     inc  bp            ;add 2 to bp since dword
  25.     inc  bp            ;
  26.     jmp  short L00        ;jump ahead
  27. L0:    mov  ax,es        ;ES = DS
  28.     mov  ds,ax        ;
  29.     mov  di,[bp+4]        ;
  30. L00:    mov  dx,es:[di]        ;move to DX
  31.     mov  ax,[bp+6]        ;source to AX
  32.     mov  bx,1        ;bit mask for target
  33.     mov  si,bx        ;bit mask for source
  34.     mov  ch,[bp+12]        ;number bits
  35.     inc  _error_code    ;1 = zero bits
  36.     or   ch,ch        ;check for zero bits
  37.     jz   L4            ;quit if zero
  38.     mov  cl,ch        ;copy to CL for error chk
  39.     add  cl,[bp+8]        ;add to target start bit
  40.     inc  _error_code    ;2 = field out of range
  41.     cmp  cl,16        ;in range?
  42.     ja   L4            ;quit if out of range
  43.     mov  cl,[bp+10]        ;source start bit
  44.     shl  si,cl        ;mask bit to start pt
  45.     mov  cl,[bp+8]        ;target start bit
  46.     shl  bx,cl        ;mask bit to start pt
  47. L1:    test ax,si        ;test source bit
  48.     jnz  L2            ;jump if '1'
  49.     not  bx            ;reverse mask
  50.     and  dx,bx        ;zero out bit
  51.     not  bx            ;re-reverse mask
  52.     jmp  short L3        ;jump ahead
  53. L2:    or   dx,bx        ;set bit
  54. L3:    shl  si,1        ;shift mask up by one
  55.     shl  bx,1        ;ditto
  56.     dec  ch            ;dec bit field counter
  57.     jnz  L1            ;loop till finished
  58.     mov  es:[di],dx        ;set value for return
  59.     mov  _error_code,0    ;success, return 0
  60. L4:    pop  si            ;
  61.     pop  di            ;
  62.     pop  bp            ;restore BP and quit
  63.     cmp  _memory_model,0    ;quit
  64.     jle  quit        ;
  65.     db   0CBh        ;RET far
  66. quit:    ret            ;RET near
  67. _bit_copy_16 endp
  68. _TEXT    ENDS
  69.     END
  70.