d6fb76416a
Added declaration and implementations of `void abort (void)` to jerry-libc. As the linux implementation relies on the `getpid` syscall - which has no arguments - `syscall_0` implementations have been added as well. `libc_fatal` has been adapted to use the new `abort` function instead of `exit`. This also made the definition of `LIBC_FATAL_ERROR_EXIT_CODE` unnecessary. Finally, the syscall fatal error message was fixed. JerryScript-DCO-1.0-Signed-off-by: Akos Kiss akiss@inf.u-szeged.hu
79 lines
1.6 KiB
C
79 lines
1.6 KiB
C
/* Copyright 2014-2015 Samsung Electronics Co., Ltd.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef ASM_X64_H
|
|
#define ASM_X64_H
|
|
|
|
/*
|
|
* mov syscall_no (%rdi) -> %rax
|
|
* syscall
|
|
*/
|
|
#define SYSCALL_0 \
|
|
mov %rdi, %rax; \
|
|
syscall; \
|
|
ret;
|
|
|
|
/*
|
|
* mov syscall_no (%rdi) -> %rax
|
|
* mov arg1 (%rsi) -> %rdi
|
|
* syscall
|
|
*/
|
|
#define SYSCALL_1 \
|
|
mov %rdi, %rax; \
|
|
mov %rsi, %rdi; \
|
|
syscall; \
|
|
ret;
|
|
|
|
/*
|
|
* mov syscall_no (%rdi) -> %rax
|
|
* mov arg1 (%rsi) -> %rdi
|
|
* mov arg2 (%rdx) -> %rsi
|
|
* syscall
|
|
*/
|
|
#define SYSCALL_2 \
|
|
mov %rdi, %rax; \
|
|
mov %rsi, %rdi; \
|
|
mov %rdx, %rsi; \
|
|
syscall; \
|
|
ret;
|
|
|
|
/*
|
|
* mov syscall_no (%rdi) -> %rax
|
|
* mov arg1 (%rsi) -> %rdi
|
|
* mov arg2 (%rdx) -> %rsi
|
|
* mov arg3 (%rcx) -> %rdx
|
|
* syscall
|
|
*/
|
|
#define SYSCALL_3 \
|
|
mov %rdi, %rax; \
|
|
mov %rsi, %rdi; \
|
|
mov %rdx, %rsi; \
|
|
mov %rcx, %rdx; \
|
|
syscall; \
|
|
ret;
|
|
|
|
#define _START \
|
|
mov (%rsp), %rdi; \
|
|
mov %rsp, %rsi; \
|
|
add $8, %rsi; \
|
|
callq main; \
|
|
\
|
|
mov %rax, %rdi; \
|
|
callq exit; \
|
|
1: \
|
|
jmp 1b
|
|
|
|
#endif /* !ASM_X64_H */
|