Sponsored Content
Top Forums UNIX for Dummies Questions & Answers x86 Interrupts and system calls Post 302606462 by shamrock on Sunday 11th of March 2012 03:25:44 PM
Old 03-11-2012
Quote:
Originally Posted by ab_tall
I recently went through Understanding the linux kernel, to get an idea of how system calls and interrupts function in an x86 based machine.

However, the level of detail has left me slightly confused. Here's what I understand.
I dont know which Linux kernel book you are referring to...but the book from the creators of BSD is a good one as it goes throgh those details in a simple and conceptual manner...so check it out.
Quote:
Originally Posted by ab_tall
System call process:

User mode:
User code calls a library function -> library function involves making a system call -> the int 0x80 instruction is executed causing transfer to kernel mode

Kernel mode:
Dispatch table is looked up for validity of the system call no. passed via eax register and if valid, backs up remaining structures onto kernel mode stack->system call routine calls the actual system call service routine.

Interrupt handling:
interrupt vector used to get into the IDT and the segment selector is retrieved after suitable privelege checks.-> After backing up registers, CS EIP obtained from the contents of the Gate descriptor and control jumps to 1st instruction of handler.

What I am not able to wrap my head around is how the above two : system call and interrupt handling tie in or overlap..

What i think happens is:
USER MODE | Kernel mode
User code->API->wrapper(0x80) -> Interrupt handling-> System call lookup(dispatch table)->System call routine.

Could someone help confirm / correct my understanding?
The API is the wrapper...0x80 isnt a wrapper...it is a software interrupt that is used to switch mode from user to kernel.

Quote:
Originally Posted by ab_tall
p.s the main area where i am fuzzy is what happens once the wrapper routine in the library does the system call. What location does the interrupt handler point to?
That location is known only to the kernel as then the process is running in kernel mode...which could be a physical or logical address based on the mem mgmt policy the kernel uses.
Quote:
Originally Posted by ab_tall
And how is the system call no. used post it being put in EAX.?
The system call no that is loaded into the eax register is used to index into the dispatch table...the kernel retrieves the address of the routine to service the interrupt based on the system call no found in eax...and then control is transferred to the first instruction at that address.

Last edited by shamrock; 03-11-2012 at 04:34 PM..
 

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

System Calls

What does the system call "dup" do? What is the difference between dup and dup2 I have a fair idea of what it does but I am confused when its coming down to the exact details... Please help me!:confused: (2 Replies)
Discussion started by: clickonline1
2 Replies

2. UNIX for Dummies Questions & Answers

System calls for cp and mv

Which system calls are made for operations cp and mv (2 Replies)
Discussion started by: gaurava99
2 Replies

3. UNIX for Dummies Questions & Answers

System calls?

open, creat, read, write, lseek and close Are they all primitive? :confused: *Another Question: is there a different between a system call, and an i/o system call? (2 Replies)
Discussion started by: PlunderBunny
2 Replies

4. Solaris

System calls ?

where can i find the differences in System calls between solaris and aix? also is it possible to find a comprehensive list of them? (1 Reply)
Discussion started by: TECHRAMESH
1 Replies

5. UNIX Desktop Questions & Answers

Using system calls

Hi, I'm new to UNIX system calls. Can someone share your knowledge as to how exactly system calls should be executed? Can they be typed like commands such as mkdir on the terminal itself? Also, are there any websites which will show me an example of the output to expect when a system call like... (1 Reply)
Discussion started by: ilavenil
1 Replies

6. Programming

System calls

why user is not able to switch from user to kernel mode by writing the function whose code is identical to system call. (1 Reply)
Discussion started by: joshighanshyam
1 Replies

7. BSD

system calls

what is the functions and relationship between fork,exec,wait system calls as i am a beginer just want the fundamentals. (1 Reply)
Discussion started by: sangramdas
1 Replies

8. UNIX for Dummies Questions & Answers

About system calls.

Hi all, I am new here . I want to know about system call in detail. As system calls are also function .How system identifies it.:) (2 Replies)
Discussion started by: vishwasrao
2 Replies

9. UNIX for Dummies Questions & Answers

system calls in C

Hello, how would i be able to call ps in C programming? thanks, ---------- Post updated at 01:39 AM ---------- Previous update was at 01:31 AM ---------- here's the complete system call, ps -o pid -p %d, getpit() (2 Replies)
Discussion started by: l flipboi l
2 Replies

10. UNIX for Dummies Questions & Answers

System calls in UNIX

Hi i am very new to programming in UNIX and don't understand the difference between a system call and a normal function call. Also can I implement system calls from within a program? If so could someone please give me an example of a system call from within a program. Lastly, when creating a... (1 Reply)
Discussion started by: bjhum33
1 Replies
All times are GMT -4. The time now is 11:18 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy