* Using C Libraries From Assembly
@ 2005-08-29 19:13 Landon Blake
2005-08-29 19:32 ` Tim Hoolihan
2005-08-30 9:17 ` Stephen Pelc
0 siblings, 2 replies; 5+ messages in thread
From: Landon Blake @ 2005-08-29 19:13 UTC (permalink / raw)
To: linux-assembly
Linux Assembly Programmers,
I had posted an earlier message about adding graphics to an assembly
language program. After some research the past couple of days it seems
that most available, open source graphics libraries provide a C API. I
would like to add graphics capabilities to the simple programming
language I want to write in assembly.
So, my next question is this:
Can you call C functions from a program written in assembly language?
I've googled this subject, but was only able to find one paragraph that
didn't seem to help much. Most information seems to deal with going the
other direction, that is, calling assembly from C functions. However,
I'm guessing that it is possible, since both languages end up as machine
code at some point. Are there any resources that explain how to do this?
Thanks for all the help.
Landon
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Using C Libraries From Assembly
2005-08-29 19:13 Using C Libraries From Assembly Landon Blake
@ 2005-08-29 19:32 ` Tim Hoolihan
2005-08-29 20:37 ` Stephen Ray
2005-08-30 9:17 ` Stephen Pelc
1 sibling, 1 reply; 5+ messages in thread
From: Tim Hoolihan @ 2005-08-29 19:32 UTC (permalink / raw)
To: Landon Blake; +Cc: linux-assembly
Try googling on "printf assembly". I found a few good examples there.
I'm not sure what assembler or syntax style you're using, so it's
probably best to dig through the search results yourself.
-Tim
Landon Blake wrote:
>Linux Assembly Programmers,
>
>I had posted an earlier message about adding graphics to an assembly
>language program. After some research the past couple of days it seems
>that most available, open source graphics libraries provide a C API. I
>would like to add graphics capabilities to the simple programming
>language I want to write in assembly.
>
>So, my next question is this:
>
>Can you call C functions from a program written in assembly language?
>I've googled this subject, but was only able to find one paragraph that
>didn't seem to help much. Most information seems to deal with going the
>other direction, that is, calling assembly from C functions. However,
>I'm guessing that it is possible, since both languages end up as machine
>code at some point. Are there any resources that explain how to do this?
>
>Thanks for all the help.
>
>Landon
>-
>To unsubscribe from this list: send the line "unsubscribe linux-assembly" in
>the body of a message to majordomo@vger.kernel.org
>More majordomo info at http://vger.kernel.org/majordomo-info.html
>
>
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Using C Libraries From Assembly
2005-08-29 19:32 ` Tim Hoolihan
@ 2005-08-29 20:37 ` Stephen Ray
0 siblings, 0 replies; 5+ messages in thread
From: Stephen Ray @ 2005-08-29 20:37 UTC (permalink / raw)
To: Tim Hoolihan; +Cc: Landon Blake, linux-assembly
If you can find a copy of Jeff Duntemann's "Assembly Language
Step-by-Step, 2nd Ed.", the second section deals with using assembly and
C together. A lot of this stuff is covered in G. Adam Stanislav's
tutorial on using assembly and FreeBSD, available at
http://www.int80h.org/bsdasm/
Pay careful attention to the bit on the calling convention, what
registers you have to save, setting up a stack frame, etc. That's the
bulk of what you'll need to know. The trickiest part seems to be
getting your assembler to produce an object file in the correct format.
After you have an object file, you can link it all together with gcc.
A short example exerpted from Duntemann follows:
; Build using these commands:
; nasm -f elf eatlinux.asm
; gcc eatlinux.o -o eatlinux
[SECTION .txt]
extern puts
global main ;required so linker can find entry point
main:
push ebp ;Set up stack frame for debugger
mov ebp, esp
push ebx ; Program must preserve ebp, ebx, esi, & edi
push esi
push edi
;;; everything before this is boilerplate; use it for all ordinary
apps!
push dword eatmsg ; push a 32-bit pointer to the message on the stack
call puts ; call the clib function for displaying strings
add esp, 4 ; clean stack by adjusting esp back 4 bytes
;;; everything after this is boilerplate; use it for all ordinary apps!
pop edi ; restore saved registers
pop esi
pop ebx
mov esp, ebp ; destroy stack frame before returning
pop ebp
ret
[SECTION .data] ; section containing initialized data
eatmsg: db "Eat at Joe's!",10,0
[SECTION .bss] ; section containing uninitialized data
If I recall correctly, underscores may have to be placed before function
names when coding for Windows.
A few points to remember (from Duntemann):
- Functions have to preserve the contents of EBX, ESP, EBP, ESI and
EDI. You usually do this by not using them, or saving them on the stack
and restoring them when done.
- C functions return their values in EAX if they're 32-bit, or EAX and
EDX, with the low bits in EAX and the high bits in EDX. Anything else
is returned via a pointer in EAX
- you pass parameters to a c function by pushing them in reverse order
(right to left) onto the stack.
- C functions do not clean their parameters off the stack. If you
call a C function and pass parameters onto the stack, you are
responsible for cleaning up afterwards.
If you want to call C code, or have C code call your function, just
follow these rules. With C code calling your functions, you will have
to follow these rules scrupulously, and may have to experiment with
underscores preceding your function. Once you get it figured out,
though, it's not that hard.
Stephen
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Using C Libraries From Assembly
2005-08-29 19:13 Using C Libraries From Assembly Landon Blake
2005-08-29 19:32 ` Tim Hoolihan
@ 2005-08-30 9:17 ` Stephen Pelc
2005-08-30 14:23 ` Richard Cooper
1 sibling, 1 reply; 5+ messages in thread
From: Stephen Pelc @ 2005-08-30 9:17 UTC (permalink / raw)
To: linux-assembly
From: "Landon Blake" <lblake@ksninc.com>
> Can you call C functions from a program written in assembly
> language? I've googled this subject, but was only able to find
> one paragraph that didn't seem to help much. Most information
> seems to deal with going the other direction, that is, calling
> assembly from C functions. However, I'm guessing that it is
> possible, since both languages end up as machine code at some
> point. Are there any resources that explain how to do this?
We've been going through the same exercise porting one of our
products. I've kept all my notes in one place so that I can
publish them as "The Compiler Writer's Guide to Linux". The
current set of notes includes a complete program that calls
printf from the libc shared library.
The notes are at
http://www.mpeforth.com/arena/cwgtLinux.txt
At this stage I can't say that everything is 100%, but so far so
good. The next task is to set up signal handlers from assembly.
All feedback, criticism and help is welcome. The final book will
be available as a free PDF from our website. Printed copies with
an accompaying CD will also be available.
Stephen
--
Stephen Pelc, stephen@mpeltd.demon.co.uk
MicroProcessor Engineering Ltd - More Real, Less Time
133 Hill Lane, Southampton SO15 5AF, England
tel: +44 23 80 631441, fax: +44 23 80 339691
web: http://www.mpeltd.demon.co.uk - free VFX Forth downloads
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Using C Libraries From Assembly
2005-08-30 9:17 ` Stephen Pelc
@ 2005-08-30 14:23 ` Richard Cooper
0 siblings, 0 replies; 5+ messages in thread
From: Richard Cooper @ 2005-08-30 14:23 UTC (permalink / raw)
To: Stephen Pelc; +Cc: linux-assembly
> The next task is to set up signal handlers from assembly.
That's not too difficult. From your guide, it looks like you've got it
mostly figured out already.
%idefine sys_signal 48
%idefine SIG_SEGV 11
mov eax, sys_signal
mov ebx, SIG_SEGV
mov ecx, signal_handler
int 0x80
signal_handler
printf "We crashed!!!\n";
ret
Well, actually, you wouldn't want to return with SIG_SEGV, but...as long
as you don't re-register the handler, I imagine returning would terminate
your program.
One thing you have to keep in mind that I didn't see in your guide is that
you have to re-register the signal hander every time the signal gets
called. Also, if your program recieves a signal that it doesn't have a
handler set up for it will be terminated "kill -9" style.
The real trick is figuring out the register contents at the time of the
crash.
pushfd; pop dword [r.flags]; cld
mov eax, [esp + 13 * 4]; mov [r.eax], eax
mov eax, [esp + 10 * 4]; mov [r.ebx], eax
mov eax, [esp + 12 * 4]; mov [r.ecx], eax
mov eax, [esp + 11 * 4]; mov [r.edx], eax
mov eax, [esp + 7 * 4]; mov [r.esi], eax
mov eax, [esp + 6 * 4]; mov [r.edi], eax
mov eax, [esp + 8 * 4]; mov [r.ebp], eax
mov eax, [esp + 9 * 4]; mov [r.esp], eax
mov eax, [esp + 16 * 4]; mov [r.eip], eax
Since I'm using pushfd, I guess I didn't find the flags saved anywhere.
Took me a while to figure that out. There's another set of registers on
the stack in front of that set, but they aren't the right ones, and where
they come from, I have no idea. I also have no idea if that works on any
kernel other than my own.
I'll have to have a look at that third argument to the signal handler some
time, if it points to where I'm getting the registers from now, then I'll
go ahead and use it.
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2005-08-30 14:23 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-08-29 19:13 Using C Libraries From Assembly Landon Blake
2005-08-29 19:32 ` Tim Hoolihan
2005-08-29 20:37 ` Stephen Ray
2005-08-30 9:17 ` Stephen Pelc
2005-08-30 14:23 ` Richard Cooper
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).