On Linux i386, the int $0x80 syscall ABI makes it easy to perform syscalls without having a valid userspace stack. The vdso/vsyscall interface, on the other hand, requires access to a stack. How do other Linux ports fare in this regard, especially x86_64? Do they have ways to make syscalls without a stack? Is there a reference on the available syscall methods for each arch?
Making syscalls on Linux without a stack
1.1k Views Asked by R.. GitHub STOP HELPING ICE At
1
There are 1 best solutions below
Related Questions in C
- How to call a C language function from x86 assembly code?
- What does: "char *argv[]" mean?
- User input sanitization program, which takes a specific amount of arguments and passes the execution to a bash script
- How to crop a BMP image in half using C
- How can I get the difference in minutes between two dates and hours?
- Why will this code compile although it defines two variables with the same name?
- Compiling eBPF program in Docker fails due to missing '__u64' type
- Why can't I use the file pointer after the first read attempt fails?
- #include Header files in C with definition too
- OpenCV2 on CLion
- What is causing the store latency in this program?
- How to refer to the filepath of test data in test sourcecode?
- 9 Digit Addresses in Hexadecimal System in MacOS
- My server TCP doesn't receive messages from the client in C
- Printing the characters obtained from the array s using printf?
Related Questions in LINUX
- Is there some way to use printf to print a horizontal list of decrementing hex digits in NASM assembly on Linux
- Why does Hugo generate different taxonomy-related HTML on different OS's?
- Writes in io_uring do not advance the file offset
- Why `set -o pipefail` gives different output even though the pipe is not failing
- what really controls the permissions: UID or eUID?
- Compiling eBPF program in Docker fails due to missing '__u64' type
- Docker container unable to make HTTPS requests to external API
- Whow to use callback_query_handler in Python 3.10
- Create kea runtime directory at startup in Yocto image
- Problem on CPU scheduling algorithms in OS
- How to copy files into the singularity sandbox?
- Android kernel error: undefined reference to `get_hw_version_platform'
- Is there a need for BPF Linux namespace?
- Error when trying to execute a binary compiled in a Kali Linux machine on an Ubuntu system
- Issue with launching application after updating ElectronJs to version 28.0.0 on Windows and Linux
Related Questions in ASSEMBLY
- Is there some way to use printf to print a horizontal list of decrementing hex digits in NASM assembly on Linux
- How to call a C language function from x86 assembly code?
- Binary Bomb Phase 2 - Decoding Assembly
- AVR Assembly Clock Cycle
- Understanding the differences between mov and lea instructions in x86 assembly
- ARM Assembly code is not executing in Vitis IDE
- Which version of ARM does the M1 chip run on?
- Why would %rbp not be equal to the value of %rsp, which is 0x28?
- Move immediate 8-bit value into RSI, RDI, RSP or RBP
- Unable to run get .exe file from assembly NASM
- DOSbox automatically freezes and crashes without any prompt warnings
- Load function written in amd64 assembly into memory and call it
- link.exe unresolved external symbol _mainCRTStartup
- x86 Wrote a boot loader that prints a message to the screen but the characters are completely different to what I expected
- running an imf file using dosbox in parallel to a game
Related Questions in SYSTEM-CALLS
- seccomp_unotify can't catch syscall more than once
- Why do register arg values need to be re-assigned in NASM after an int 0x80 system call?
- How to use mmap iteratively to map data in small chunks from a large file
- I want to use toilet to modify hook_function
- Finding total RAM consumption of process, including swap
- Why is the write system call printing an incorrect number of characters?
- Why is fork() accepted in strace if the actual syscall is clone()?
- Why does sudo kill -15 on sh and docker-compose PIDs not stop Docker containers?
- How to know if a syscall returned an error?
- Why does the assembly after my sys_clone call affect the cloned process?
- Why does mov fail to set dynamic section sizes when used on a function using GCC
- undefined reference to `sys_getprocs' when getting number of processes in Xv6
- Hello World in assembly on x86-64 Windows vs. Linux with int 0x80 system call
- C semaphore and shared memory
- Nginx tries to read config file in one pread() and fails on specific AMI on Amazon
Related Questions in ABI
- Copy constructors and const& versus the ARM ABI
- Reason for (win) x64-calling convention restrictions in epilogues
- How to generate multi hop swap path with ethers.js?
- Managing Relocation Order Dependencies in ELF Shared Libraries
- Differences in .s assembly between GCC and mingw: How to compile QBE output on windows?
- Where is the order in which ELF relocations are applied specified?
- Is there a database of C function signatures?
- How to mark a C++ type as not "trivially_copyable", while keeping it "trivial for the purposes of calls" in the Itanium C++ ABI?
- Win32 Wide-Character String Alignment Requirements
- Compatibility rules to follow if we want to modify a function definition in a shared library used by our program
- Aarch64 is there a Red Zone on Linux, If so 16 or 128 bytes?
- Binary compatibility libraries same compiler and compiler version, different OS version
- Getting Mangled C++ symbols from uncalled functions
- How to install pytorch=1.0 and why pytorch installing command no longer work
- What distribution has the best cross compatibility on Amazon AWS Graviton?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
In general: no idea. Even on i386, if there is a 6th argument, it must be passed on the stack (e.g. for
mmap).For x86_64 specifically: put the syscall number in
%rax(beware: the syscall numbers are allocated completely differently to the 32-bit ones), up to 6 arguments in%rdi,%rsi,%rdx,%r10,%r8and%r9(which is almost, but not quite, the same as the usual ABI for parameter passing in registers - note use of%r10instead of%rcx), and use thesyscallinstruction. The result is returned in%rax, and%rcxand%r11are clobbered.x86_64 ABI information can be found at http://www.x86-64.org/documentation/abi.pdf; the Linux ABI is documented in the appendix. (And if looking around elsewhere for x86_64 ABI info, be aware that 64-bit Windows uses its own different ABI.)
I don't believe there is any requirement on the user stack frame for
syscallto work properly. In the case of being interrupted by a signal, a sane stack is obviously required for the handler; but the following experiment, which uses an alternate signal stack and deliberately trashes%rsparound thesyscall, works fine for me: