فراخوان های سیستمی (System Calls) در زبان اسمبلی
System Calls در اسمبلی API هایی هستند که به منظور برقرار رابطه بین کاربر و هسته استفاده می شوند. ما قبلا از این API ها استفاده کرده ایم (مانند sys_write و sys_exit).
فراخوان های سیستمی در لینوکس
شما می توانید از فراخوانی های سیستمی لینوکس در برنامه های اسمبلی خود استفاده کنید. برای انجام این کار مراحل زیر را دنبال کنید:
- شماره System Call را در ثبات EAX قرار دهید.
- آرگومان های مربوط به System Call را در EBX، ECX و غیره ذخیره کنید.
- وقفه مربوطه را فراخوانی کنید (80h).
- نتیجه معمولا در ثبت نام EAX ثبت می شود.
به طور کلی 6 ثبات وجود دارد که آرگومان های مورد استفاده توسط System Call را ذخیره می کند. این ثبات ها عبارت اند از: EBX، ECX، EDX، ESI، EDI و EBP.
مثال زیر نحوه استفاده از فراخوان سیستمی sys_exit در اسمبلی را نشان می دهد:
1 2 | mov eax,1 ; system call number (sys_exit) int 0x80 ; call kernel |
مثال زیر نحوه استفاده از فراخوان سیستمی sys_write در اسمبلی را نشان می دهد:
1 2 3 4 5 | mov edx,4 ; message length mov ecx,msg ; message to write mov ebx,1 ; file descriptor (stdout) mov eax,4 ; system call number (sys_write) int 0x80 ; call kernel |
در جدول زیر برخی از System Call های مورد استفاده در این آموزش را مشاهده می کنید:
%eax | Name | %ebx | %ecx | %edx | %esx | %edi |
1 | sys_exit | int | – | – | – | – |
2 | sys_fork | struct pt_regs | – | – | – | – |
3 | sys_read | unsigned int | char * | size_t | – | – |
4 | sys_write | unsigned int | const char * | size_t | – | – |
5 | sys_open | const char * | int | int | – | – |
6 | sys_close | unsigned int | – | – | – |
مثال
مثال زیر یک عدد از ورودی خوانده و آن را نمایش می دهد:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | section .data ;Data segment userMsg db 'Please enter a number: ' ;Ask the user to enter a number lenUserMsg equ $-userMsg ;The length of the message dispMsg db 'You have entered: ' lenDispMsg equ $-dispMsg section .bss ;Uninitialized data num resb 5 section .text ;Code Segment global _start _start: ;User prompt mov eax, 4 mov ebx, 1 mov ecx, userMsg mov edx, lenUserMsg int 80h ;Read and store the user input mov eax, 3 mov ebx, 2 mov ecx, num mov edx, 5 ;5 bytes (numeric, 1 for sign) of that information int 80h ;Output the message 'The entered number is: ' mov eax, 4 mov ebx, 1 mov ecx, dispMsg mov edx, lenDispMsg int 80h ;Output the number entered mov eax, 4 mov ebx, 1 mov ecx, num mov edx, 5 int 80h ; Exit code mov eax, 1 mov ebx, 0 int 80h |
زمانی که کد بالا توسط کامپایلر اسمبلی و اجرا شود، نتیجه زیر را تولید خواهد کرد:
1 2 3 | Please enter a number: 1234 You have entered:1234 |
هیچ نظری ثبت نشده است