1#!/bin/sh 2# SPDX-License-Identifier: GPL-2.0 3# 4# Check if current architecture are missing any function calls compared 5# to i386. 6# i386 define a number of legacy system calls that are i386 specific 7# and listed below so they are ignored. 8# 9# Usage: 10# checksyscalls.sh gcc gcc-options 11# 12 13ignore_list() { 14cat << EOF 15#include <asm/types.h> 16#include <asm/unistd.h> 17 18/* *at */ 19#define __IGNORE_open /* openat */ 20#define __IGNORE_link /* linkat */ 21#define __IGNORE_unlink /* unlinkat */ 22#define __IGNORE_mknod /* mknodat */ 23#define __IGNORE_chmod /* fchmodat */ 24#define __IGNORE_chown /* fchownat */ 25#define __IGNORE_mkdir /* mkdirat */ 26#define __IGNORE_rmdir /* unlinkat */ 27#define __IGNORE_lchown /* fchownat */ 28#define __IGNORE_access /* faccessat */ 29#define __IGNORE_rename /* renameat2 */ 30#define __IGNORE_readlink /* readlinkat */ 31#define __IGNORE_symlink /* symlinkat */ 32#define __IGNORE_utimes /* futimesat */ 33#define __IGNORE_stat /* fstatat */ 34#define __IGNORE_lstat /* fstatat */ 35#define __IGNORE_stat64 /* fstatat64 */ 36#define __IGNORE_lstat64 /* fstatat64 */ 37 38#ifndef __ARCH_WANT_SET_GET_RLIMIT 39#define __IGNORE_getrlimit /* getrlimit */ 40#define __IGNORE_setrlimit /* setrlimit */ 41#endif 42 43/* Missing flags argument */ 44#define __IGNORE_renameat /* renameat2 */ 45 46/* CLOEXEC flag */ 47#define __IGNORE_pipe /* pipe2 */ 48#define __IGNORE_dup2 /* dup3 */ 49#define __IGNORE_epoll_create /* epoll_create1 */ 50#define __IGNORE_inotify_init /* inotify_init1 */ 51#define __IGNORE_eventfd /* eventfd2 */ 52#define __IGNORE_signalfd /* signalfd4 */ 53 54/* MMU */ 55#ifndef CONFIG_MMU 56#define __IGNORE_madvise 57#define __IGNORE_mbind 58#define __IGNORE_mincore 59#define __IGNORE_mlock 60#define __IGNORE_mlockall 61#define __IGNORE_munlock 62#define __IGNORE_munlockall 63#define __IGNORE_mprotect 64#define __IGNORE_msync 65#define __IGNORE_migrate_pages 66#define __IGNORE_move_pages 67#define __IGNORE_remap_file_pages 68#define __IGNORE_get_mempolicy 69#define __IGNORE_set_mempolicy 70#define __IGNORE_swapoff 71#define __IGNORE_swapon 72#endif 73 74/* System calls for 32-bit kernels only */ 75#if BITS_PER_LONG == 64 76#define __IGNORE_sendfile64 77#define __IGNORE_ftruncate64 78#define __IGNORE_truncate64 79#define __IGNORE_stat64 80#define __IGNORE_lstat64 81#define __IGNORE_fstat64 82#define __IGNORE_fcntl64 83#define __IGNORE_fadvise64_64 84#define __IGNORE_fstatat64 85#define __IGNORE_fstatfs64 86#define __IGNORE_statfs64 87#define __IGNORE_llseek 88#define __IGNORE_mmap2 89#define __IGNORE_clock_gettime64 90#define __IGNORE_clock_settime64 91#define __IGNORE_clock_adjtime64 92#define __IGNORE_clock_getres_time64 93#define __IGNORE_clock_nanosleep_time64 94#define __IGNORE_timer_gettime64 95#define __IGNORE_timer_settime64 96#define __IGNORE_timerfd_gettime64 97#define __IGNORE_timerfd_settime64 98#define __IGNORE_utimensat_time64 99#define __IGNORE_pselect6_time64 100#define __IGNORE_ppoll_time64 101#define __IGNORE_io_pgetevents_time64 102#define __IGNORE_recvmmsg_time64 103#define __IGNORE_mq_timedsend_time64 104#define __IGNORE_mq_timedreceive_time64 105#define __IGNORE_semtimedop_time64 106#define __IGNORE_rt_sigtimedwait_time64 107#define __IGNORE_futex_time64 108#define __IGNORE_sched_rr_get_interval_time64 109#else 110#define __IGNORE_sendfile 111#define __IGNORE_ftruncate 112#define __IGNORE_truncate 113#define __IGNORE_stat 114#define __IGNORE_lstat 115#define __IGNORE_fstat 116#define __IGNORE_fcntl 117#define __IGNORE_fadvise64 118#define __IGNORE_newfstatat 119#define __IGNORE_fstatfs 120#define __IGNORE_statfs 121#define __IGNORE_lseek 122#define __IGNORE_mmap 123#define __IGNORE_clock_gettime 124#define __IGNORE_clock_settime 125#define __IGNORE_clock_adjtime 126#define __IGNORE_clock_getres 127#define __IGNORE_clock_nanosleep 128#define __IGNORE_timer_gettime 129#define __IGNORE_timer_settime 130#define __IGNORE_timerfd_gettime 131#define __IGNORE_timerfd_settime 132#define __IGNORE_utimensat 133#define __IGNORE_pselect6 134#define __IGNORE_ppoll 135#define __IGNORE_io_pgetevents 136#define __IGNORE_recvmmsg 137#define __IGNORE_mq_timedsend 138#define __IGNORE_mq_timedreceive 139#define __IGNORE_semtimedop 140#define __IGNORE_rt_sigtimedwait 141#define __IGNORE_futex 142#define __IGNORE_sched_rr_get_interval 143#define __IGNORE_gettimeofday 144#define __IGNORE_settimeofday 145#define __IGNORE_wait4 146#define __IGNORE_adjtimex 147#define __IGNORE_nanosleep 148#define __IGNORE_io_getevents 149#define __IGNORE_recvmmsg 150#endif 151 152/* i386-specific or historical system calls */ 153#define __IGNORE_break 154#define __IGNORE_stty 155#define __IGNORE_gtty 156#define __IGNORE_ftime 157#define __IGNORE_prof 158#define __IGNORE_lock 159#define __IGNORE_mpx 160#define __IGNORE_ulimit 161#define __IGNORE_profil 162#define __IGNORE_ioperm 163#define __IGNORE_iopl 164#define __IGNORE_idle 165#define __IGNORE_modify_ldt 166#define __IGNORE_ugetrlimit 167#define __IGNORE_vm86 168#define __IGNORE_vm86old 169#define __IGNORE_set_thread_area 170#define __IGNORE_get_thread_area 171#define __IGNORE_madvise1 172#define __IGNORE_oldstat 173#define __IGNORE_oldfstat 174#define __IGNORE_oldlstat 175#define __IGNORE_oldolduname 176#define __IGNORE_olduname 177#define __IGNORE_umount 178#define __IGNORE_waitpid 179#define __IGNORE_stime 180#define __IGNORE_nice 181#define __IGNORE_signal 182#define __IGNORE_sigaction 183#define __IGNORE_sgetmask 184#define __IGNORE_sigsuspend 185#define __IGNORE_sigpending 186#define __IGNORE_ssetmask 187#define __IGNORE_readdir 188#define __IGNORE_socketcall 189#define __IGNORE_ipc 190#define __IGNORE_sigreturn 191#define __IGNORE_sigprocmask 192#define __IGNORE_bdflush 193#define __IGNORE__llseek 194#define __IGNORE__newselect 195#define __IGNORE_create_module 196#define __IGNORE_query_module 197#define __IGNORE_get_kernel_syms 198#define __IGNORE_sysfs 199#define __IGNORE_uselib 200#define __IGNORE__sysctl 201#define __IGNORE_arch_prctl 202#define __IGNORE_nfsservctl 203 204/* ... including the "new" 32-bit uid syscalls */ 205#define __IGNORE_lchown32 206#define __IGNORE_getuid32 207#define __IGNORE_getgid32 208#define __IGNORE_geteuid32 209#define __IGNORE_getegid32 210#define __IGNORE_setreuid32 211#define __IGNORE_setregid32 212#define __IGNORE_getgroups32 213#define __IGNORE_setgroups32 214#define __IGNORE_fchown32 215#define __IGNORE_setresuid32 216#define __IGNORE_getresuid32 217#define __IGNORE_setresgid32 218#define __IGNORE_getresgid32 219#define __IGNORE_chown32 220#define __IGNORE_setuid32 221#define __IGNORE_setgid32 222#define __IGNORE_setfsuid32 223#define __IGNORE_setfsgid32 224 225/* these can be expressed using other calls */ 226#define __IGNORE_alarm /* setitimer */ 227#define __IGNORE_creat /* open */ 228#define __IGNORE_fork /* clone */ 229#define __IGNORE_futimesat /* utimensat */ 230#define __IGNORE_getpgrp /* getpgid */ 231#define __IGNORE_getdents /* getdents64 */ 232#define __IGNORE_pause /* sigsuspend */ 233#define __IGNORE_poll /* ppoll */ 234#define __IGNORE_select /* pselect6 */ 235#define __IGNORE_epoll_wait /* epoll_pwait */ 236#define __IGNORE_time /* gettimeofday */ 237#define __IGNORE_uname /* newuname */ 238#define __IGNORE_ustat /* statfs */ 239#define __IGNORE_utime /* utimes */ 240#define __IGNORE_vfork /* clone */ 241 242/* sync_file_range had a stupid ABI. Allow sync_file_range2 instead */ 243#ifdef __NR_sync_file_range2 244#define __IGNORE_sync_file_range 245#endif 246 247/* Unmerged syscalls for AFS, STREAMS, etc. */ 248#define __IGNORE_afs_syscall 249#define __IGNORE_getpmsg 250#define __IGNORE_putpmsg 251#define __IGNORE_vserver 252EOF 253} 254 255syscall_list() { 256 grep '^[0-9]' "$1" | sort -n | 257 while read nr abi name entry ; do 258 echo "#if !defined(__NR_${name}) && !defined(__IGNORE_${name})" 259 echo "#warning syscall ${name} not implemented" 260 echo "#endif" 261 done 262} 263 264(ignore_list && syscall_list $(dirname $0)/../arch/x86/entry/syscalls/syscall_32.tbl) | \ 265$* -E -x c - > /dev/null 266