flat assembler
Message board for the users of flat assembler.
  
|  Index
      > High Level Languages > Return values | 
| Author | 
 | 
| vid 13 Dec 2006, 22:18 in 32bit code, return values are simply stored in EAX. so it's just something like:      Code: call c_func cmp eax, 0 je error | |||
|  13 Dec 2006, 22:18 | 
 | 
| kohlrak 14 Dec 2006, 01:36 Is that for all return types such as char, pointer, and such? And what about doubles? Is a pointer passed to eax, or should i expect that to be placed on ebx before the return? | |||
|  14 Dec 2006, 01:36 | 
 | 
| f0dder 14 Dec 2006, 01:53 For 32bit code, quantities larger than 32bit can be returned in various ways... like EDX:EAX for 64bit integers, and ST(0) for floating-point results. Will depend on compiler though... but EDX:EAX and ST(0) are good bets. | |||
|  14 Dec 2006, 01:53 | 
 | 
| kohlrak 14 Dec 2006, 01:58 So, essentually, as long as the data can fit in eax, i can expect it to be in eax (or al for a single char). I don't know much about microsoft's little pet, the HANDLE, but i'll assume that's a 32bit value that is sent to eax, because if it's only an id tag, it shoudn't be any bigger than that. lol
 And thank you both. | |||
|  14 Dec 2006, 01:58 | 
 | 
| Plue 14 Dec 2006, 16:28 kohlrak wrote: So, essentually, as long as the data can fit in eax, i can expect it to be in eax (or al for a single char). HANDLEs are returned in eax, no problem there. Edit: CHARs are also returned in eax, NOT al. _________________ Roses are red Violets are blue Some poems rhyme And some don't. | |||
|  14 Dec 2006, 16:28 | 
 | 
| kohlrak 14 Dec 2006, 23:40 Well, it's safe to say that if it is returned to eax it'll be restricted to al, anyway, because it's only 1 byte. | |||
|  14 Dec 2006, 23:40 | 
 | 
| f0dder 15 Dec 2006, 00:30 Plue wrote: 
 Iirc Watcom returned floats in EAX... at least I'm pretty sure I've seen some compiler do that. | |||
|  15 Dec 2006, 00:30 | 
 | 
| kohlrak 15 Dec 2006, 00:47 Well, C++'s method for returning values has to be standard, otherwise DLLs wouldn't work well. | |||
|  15 Dec 2006, 00:47 | 
 | 
| madmatt 15 Dec 2006, 09:59 You could pass an address to a Double float and store it that way:
 mov eax, [addresstoDouble] fstp qword [eax] You could pass a struct the same way, just use pointers. mov eax, [pointertobitmapstruct] mov ecx, [eax + BITMAPFILEHEADER.bfSize] | |||
|  15 Dec 2006, 09:59 | 
 | 
| Plue 21 Dec 2006, 11:54 kohlrak wrote: Well, it's safe to say that if it is returned to eax it'll be restricted to al, anyway, because it's only 1 byte. Code: call ProcedureReturnsAByte mov dword [v_Long], eax and v_Long will have the correct value. So a procedure that returns a byte must clear eax completely first and extend the sign bit of the byte to a long if it is declared as signed. _________________ Roses are red Violets are blue Some poems rhyme And some don't. | |||
|  21 Dec 2006, 11:54 | 
 | 
| kohlrak 22 Dec 2006, 02:37 But if it did that, well.. Let's take the following code for example:
 Code: proc charfunc mov eax, 244 add eax, eax ;... accidental add instead of xor ret endp Then you have the same idiot under visual studio... Code: #pragma comment(lib, "charfuncdll.lib") //insert directive to import function as a char here, since i forget it. void main(){ //Yes, i'm making him a complete idiot. char a=charfuc; return; } //Yes, does absolutely nothing with it... I guess a would have a (no pun intended) value of E8 or 0C? Nice warning, Plue. | |||
|  22 Dec 2006, 02:37 | 
 | 
| f0dder 22 Dec 2006, 03:11 It would of course be E8.
 Or well, with the code above you'd get a compiler error   What you want is the following: Code: extern char charfunc(void); int main() { volatile char a = charfunc(); } Which produces the following assembly ("cl /c /Ox /FAs blabla.c" for MSVC 14.00.50727.42, aka .net2005): Code: _main PROC push ecx call _charfunc mov BYTE PTR _a$[esp+4], al xor eax, eax pop ecx ret 0 _main ENDP Now why the hell it does push/pop ecx I don't know, but it might be the "volatile" that messes something up. Without volatile, no code is produced, because of optimizations. | |||
|  22 Dec 2006, 03:11 | 
 | 
| kohlrak 22 Dec 2006, 03:13 woops. lol I don't do that one often, but i did it recently in my C++ class... lol Then i wondered why i got these really weird numbers (pointers XD). | |||
|  22 Dec 2006, 03:13 | 
 | 
| < Last Thread | Next Thread > | 
| Forum Rules: 
 | 
Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.
Website powered by rwasa.