flat assembler
Message board for the users of flat assembler.

Index > Windows > DLL Creation Error

Author
Thread Post new topic Reply to topic
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 06 Aug 2006, 22:20
Hi there!

I have this:
Code:
; TPacker Library for Win32 Platform

format PE GUI 4.0 DLL
entry DllEntryPoint

include 'win32ax.inc'

section '.code' code readable executable

proc DllEntryPoint hinstDLL,fdwReason,lpvReserved
        mov     eax,TRUE
        ret
endp

proc tpackw.new file
        invoke CreateFile, [file], GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0
        cmp eax, INVALID_HANDLE_VALUE
        je .error
        
        invoke WriteFile, [eax], __tpack_head, __tpack_head_z, 0
        cmp eax, 0
        je .error2

.error:
        mov eax, TPACK_CREATION_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_WRITE_HEAD_ERROR
.ret:
        ret
endp

proc tpackw.end fd
        invoke CloseHandle, [fd]
        ret
endp

section '.data' readable writable

; Internal Data
__tpack_head            db "tpack2.0",0
__tpack_head_z          = $-__tpack_head-1

; Error constants
TPACK_CREATION_ERROR    equ     1
TPACK_WRITE_HEAD_ERROR  equ     2

section '.idata' import data readable writeable

  library kernel32,'KERNEL32.DLL'

  import kernel32,\
         CreateFile,'CreateFileA',\
         WriteFile,'WriteFile'

section '.edata' export data readable

  export 'TPacker.dll',\
         TPackerW_End,'tpackw.new',\
         TPackerW_End,'tpackw.end'
         CloseHandle.'CloseHandle'

section '.reloc' fixups data discardable
    

But fasm say:

Quote:
C:\Documents and Settings\Thaorius>fasm "D:\TeoX\TeoX Platform\Framework\FileSys
tem\TPACKER.ASM"
flat assembler version 1.67.5
D:\TeoX\TeoX Platform\Framework\FileSystem\TPACKER.ASM [60]:
export 'TPacker.dll',\
c:\fasm\include\macro/export.inc [15] export [10]:
dd RVA label
error: undefined symbol.


But I'm doing it just like the dll example.

Thansk for helping me.
Post 06 Aug 2006, 22:20
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
okasvi



Joined: 18 Aug 2005
Posts: 382
Location: Finland
okasvi 06 Aug 2006, 22:27
you were trying to export CloseHandle where you should have imported it, and anyway it had '.' instead of ',' and line before it was missing ,\
I didnt test this, but I believe this works:
Code:
; TPacker Library for Win32 Platform

format PE GUI 4.0 DLL
entry DllEntryPoint

include 'win32ax.inc'

section '.code' code readable executable

proc DllEntryPoint hinstDLL,fdwReason,lpvReserved
        mov     eax,TRUE
        ret
endp

proc TPackerW_New file
        invoke CreateFile, [file], GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0
        cmp eax, INVALID_HANDLE_VALUE
        je .error
        
        invoke WriteFile, [eax], __tpack_head, __tpack_head_z, 0
        cmp eax, 0
        je .error2

.error:
        mov eax, TPACK_CREATION_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_WRITE_HEAD_ERROR
.ret:
        ret
endp

proc TPackerW_End fd
        invoke CloseHandle, [fd]
        ret
endp

section '.data' readable writable

; Internal Data
__tpack_head            db "tpack2.0",0
__tpack_head_z          = $-__tpack_head-1

; Error constants
TPACK_CREATION_ERROR    equ     1
TPACK_WRITE_HEAD_ERROR  equ     2

section '.idata' import data readable writeable

  library kernel32,'KERNEL32.DLL'

  import kernel32,\
         CreateFile,'CreateFileA',\
         WriteFile,'WriteFile',\
         CloseHandle,'CloseHandle'

section '.edata' export data readable

  export 'TPacker.dll',\
         TPackerW_New,'tpackw.new',\
         TPackerW_End,'tpackw.end'

section '.reloc' fixups data discardable    



edit: code fixed(?)


Last edited by okasvi on 06 Aug 2006, 23:22; edited 1 time in total
Post 06 Aug 2006, 22:27
View user's profile Send private message MSN Messenger Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 06 Aug 2006, 22:39
I get the same message Sad.

Why else it could be?

Thanks
Post 06 Aug 2006, 22:39
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
okasvi



Joined: 18 Aug 2005
Posts: 382
Location: Finland
okasvi 06 Aug 2006, 23:25
changed the code above, try again, I was skipping everything else expect the obvious last time...
when you import in your other app where you use this dll from,
use these as function names:
'tpackw.new'
&
'tpackw.end'
Post 06 Aug 2006, 23:25
View user's profile Send private message MSN Messenger Reply with quote
UCM



Joined: 25 Feb 2005
Posts: 285
Location: Canada
UCM 07 Aug 2006, 00:07
Plus you have to move the error constants before the functions, or declare them with '=' instead of 'equ'.
Post 07 Aug 2006, 00:07
View user's profile Send private message Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 07 Aug 2006, 00:11
I did the both things, now it works in some way. The file is created without troubles but the head "tpack2.0" is never written.

The code, after a the changes is this:
Code:
; TPacker Library for Win32 Platform

format PE GUI 4.0 DLL
entry DllEntryPoint

include 'win32ax.inc'

section '.data' readable writable

; Internal Data
__tpack_head            db "tpack2.0",0
__tpack_head_z          = $-__tpack_head-1

; Error constants
TPACK_CREATION_ERROR    equ     1
TPACK_WRITE_HEAD_ERROR  equ     2

section '.idata' import data readable writeable

  library kernel32,'KERNEL32.DLL'

  import kernel32,\
         CreateFile,'CreateFileA',\
         WriteFile,'WriteFile',\
         CloseHandle,'CloseHandle'

section '.code' code readable executable

proc DllEntryPoint hinstDLL,fdwReason,lpvReserved
        mov     eax,TRUE
        ret
endp

proc TPackerW_New file
        invoke CreateFile, [file], GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0
        cmp eax, INVALID_HANDLE_VALUE
        je .error
        
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, 0
        cmp eax, 0
        je .error2

.error:
        mov eax, TPACK_CREATION_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_WRITE_HEAD_ERROR
.ret:
        ret
endp

proc TPackerW_End fd
        invoke CloseHandle, [fd]
        ret
endp

section '.edata' export data readable

  export 'TPacker.dll',\
         TPackerW_New,'TPackerW_New',\
         TPackerW_End,'TPackerW_End'

section '.reloc' fixups data discardable    


I'm testing it with this:
Code:
format PE GUI 4.0
entry start

include 'win32a.inc'

section '.code' code readable executable

  start:
        invoke TPackerW_New, _path
        invoke TPackerW_End, eax
        invoke  ExitProcess,0
section '.data' readable writeable
_path   db      "C:\file.file",0

section '.idata' import data readable writeable

library kernel,'KERNEL32.DLL',\
        tpacker,'TPacker.dll'

import kernel,\
        ExitProcess,'ExitProcess'

import tpacker,\
        TPackerW_New,'TPackerW_New',\
        TPackerW_End,'TPackerW_End'
    


I'm making bad use of WriteFile api?

Thanks
Post 07 Aug 2006, 00:11
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
UCM



Joined: 25 Feb 2005
Posts: 285
Location: Canada
UCM 07 Aug 2006, 14:15
Code:
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, 0 
    

you need to have 1 more parameter.. You will have to specify the address of a 32-bit variable right before the '0' (to receive the number of bytes written). However, if you don't need it, considering you are using win32ax, you can use this:
Code:
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, addr esp-4, 0
    
which stores the value in esp-4.
Post 07 Aug 2006, 14:15
View user's profile Send private message Reply with quote
vid
Verbosity in development


Joined: 05 Sep 2003
Posts: 7105
Location: Slovakia
vid 07 Aug 2006, 14:21
UCM wrote:
Code:
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, addr esp-4, 0
    
which stores the value in esp-4.

but don't forget that value remains pushed on stack then, so better use it liek this:
Code:
invoke WriteFile, eax, __tpack_head, __tpack_head_z, addr esp-4, 0
add esp,4    

and then, you don't need to obfuscate code:
Code:
push dword 0
invoke WriteFile, eax, __tpack_head, __tpack_head_z, addr esp-4
add esp,4    


btw, i am not sure if "addr esp-4" shouldn't be just "addr esp"
Post 07 Aug 2006, 14:21
View user's profile Send private message Visit poster's website AIM Address MSN Messenger ICQ Number Reply with quote
UCM



Joined: 25 Feb 2005
Posts: 285
Location: Canada
UCM 07 Aug 2006, 15:50
vid: Sorry, my method was slightly incorrect, but your last one is even more so, since the stack will be imbalanced.
Post 07 Aug 2006, 15:50
View user's profile Send private message Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 07 Aug 2006, 19:56
Wow, I have it like this right now
Code:
; TPacker Library for Win32 Platform

format PE GUI 4.0 DLL
entry DllEntryPoint

include 'win32ax.inc'

section '.data' readable writable

; Internal Data
__tpack_head            db "tpack2.0",0
__tpack_head_z          = $-__tpack_head-1
__tpack_ehead           db "epack",0
__tpack_ehead_z         = $-__tpack_ehead-1
__tpack_handler         dd 0
__tpack_write_report    dd 0

; Error constants
TPACK_CREATION_ERROR    equ     1
TPACK_WRITE_HEAD_ERROR  equ     2
TPACK_WRITE_EHEAD_ERROR equ     3
TPACK_FD_CLODE_ERROR    equ     4

section '.idata' import data readable writeable

  library kernel32,'KERNEL32.DLL'

  import kernel32,\
         CreateFile,'CreateFileA',\
         WriteFile,'WriteFile',\
         CloseHandle,'CloseHandle'

section '.code' code readable executable

;===========================================================================

proc DllEntryPoint hinstDLL,fdwReason,lpvReserved
        mov     eax,TRUE
        ret
endp

;===========================================================================
; HANDLE TPacker_New(char *file);
;===========================================================================

proc TPackerW_New file
        invoke CreateFile, [file], GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0
        cmp eax, INVALID_HANDLE_VALUE
        je .error
        
        mov [__tpack_handler], eax
        
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, __tpack_write_report, 0
        cmp [__tpack_write_report], __tpack_head_z
        je .error2

        cmp eax, 0
        je .error2
        
        mov eax, [__tpack_handler]
        jmp .ret
.error:
        mov eax, TPACK_CREATION_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_WRITE_HEAD_ERROR
.ret:
        ret
endp

;===========================================================================
; int TPacker_End(HANDLE fd);
;===========================================================================

proc TPackerW_End fd
        invoke WriteFile, addr fd, __tpack_ehead, __tpack_ehead_z, __tpack_write_report, 0
        cmp [__tpack_write_report], __tpack_ehead_z
        je .error

        cmp eax, 0
        je .error
        
        invoke CloseHandle, [fd]
        cmp eax, TPACK_FD_CLODE_ERROR
        je .error2
        
        mov eax, dword 0
        jmp .ret
.error:
        mov eax, TPACK_WRITE_EHEAD_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_FD_CLODE_ERROR
.ret:
        ret
endp

;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================



;===========================================================================
;===========================================================================

section '.edata' export data readable

  export 'TPacker.dll',\
         TPackerW_New,'TPackerW_New',\
         TPackerW_End,'TPackerW_End'

section '.reloc' fixups data discardable    


Now it write all the data, but when i call TPackerW_End it doesn't write the 'epack' and the hadnle is closed(see my test application avobe).

Thanks
Post 07 Aug 2006, 19:56
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
UCM



Joined: 25 Feb 2005
Posts: 285
Location: Canada
UCM 07 Aug 2006, 20:38
You don't use 'addr fd', but instead 'fd', since 'addr fd' is the pointer to the handle. (In the TPackerW_End) You got it right with CloseHandle, though.
Post 07 Aug 2006, 20:38
View user's profile Send private message Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 07 Aug 2006, 20:59
No changes Sad, it still doesn't write the header :sniff:

Any other idea?

Thanks
Post 07 Aug 2006, 20:59
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
okasvi



Joined: 18 Aug 2005
Posts: 382
Location: Finland
okasvi 07 Aug 2006, 23:22
try this:
Code:
;....
proc TPackerW_End fd
        invoke WriteFile, [fd], __tpack_ehead, __tpack_ehead_z, __tpack_write_report, 0
;....
    
Post 07 Aug 2006, 23:22
View user's profile Send private message MSN Messenger Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 08 Aug 2006, 01:41
2 Things:
1) okasvi: I have it just like that
2) I also make a copy of the FileWrite call in TPackerW_New and put one call and in the next line the other:
Code:
proc TPackerW_New file
        invoke CreateFile, [file], GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0
        cmp eax, INVALID_HANDLE_VALUE
        je .error
        
        mov [__tpack_handler], eax
        
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, __tpack_write_report, 0
        invoke WriteFile, eax, __tpack_head, __tpack_head_z, __tpack_write_report, 0
        cmp [__tpack_write_report], __tpack_head_z
        je .error2

        cmp eax, 0
        je .error2
        
        mov eax, [__tpack_handler]
        jmp .ret
.error:
        mov eax, TPACK_CREATION_ERROR
        jmp .ret
.error2:
        mov eax, TPACK_WRITE_HEAD_ERROR
.ret:
        ret
endp
    


But it doesn't write, it just write the first time :S :S :S

Is possible that the __tpack_write_report once is used it can't be reused? or simething like that?

Thanks
Post 08 Aug 2006, 01:41
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 08 Aug 2006, 02:01
I been testing, and if i put inteast of __tpack_head, __tpack_ehead in TPackerW_New then it write 2 times 'epack'(1xfunction) wich is ok, but if i put __tpack_head it doesn't, later I put the inmediate values inteast of storing them on buffer's, like:
Code:
invoke WriteFile, eax, "tpackv2.0", 9, __tpack_write_report, 0    


Later i figured that if i put just the size in numerical mode it write everything ok:
Code:
invoke WriteFile, [fd], __tpack_ehead, 5, __tpack_write_report, 0    


P/D: If i take out the '-1' at the end of __tpack_head_z and __tpack_ehead_z there are no changes.

Suggestions?Sad
Post 08 Aug 2006, 02:01
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
vid
Verbosity in development


Joined: 05 Sep 2003
Posts: 7105
Location: Slovakia
vid 08 Aug 2006, 07:20
UCM, whoops, i thought that WriteFile takes 4 params, not 5, and you were using last "0" to define stack variable for "bytes writen" variable, like this:

Code:
invoke WriteFile, ebx, edu, ecx, addr esp+4, 0, 0  ;last 0 is stack variable definition
cmp [esp], ecx
pushf
add esp,4
popf
...etc...    


sorry for confusion
Post 08 Aug 2006, 07:20
View user's profile Send private message Visit poster's website AIM Address MSN Messenger ICQ Number Reply with quote
UCM



Joined: 25 Feb 2005
Posts: 285
Location: Canada
UCM 08 Aug 2006, 13:10
Thaorius: You must remember, the Win32 API functions only save ebx,esi,edi and ebp. So, when you WriteFile the second time, 'eax' was already overwritten with the first WriteFile's return value.
Post 08 Aug 2006, 13:10
View user's profile Send private message Reply with quote
Thaorius



Joined: 27 Jul 2006
Posts: 42
Thaorius 08 Aug 2006, 13:37
Yes thats true(it explain about the 2 calls), but why it write one time in the first funcion and not in the second function? But if I specify the size's with a number inteast of the __tpack_head_z and __tpack_ehead_z it write everything ok Sad

Thanks
Post 08 Aug 2006, 13:37
View user's profile Send private message Visit poster's website MSN Messenger Reply with quote
Display posts from previous:
Post new topic Reply to topic

Jump to:  


< Last Thread | Next Thread >
Forum Rules:
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.

Website powered by rwasa.