linux/scripts/checksyscalls.sh
<<
>>
Prefs
   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