(root)/
strace-6.5/
src/
linux/
sparc64/
raw_syscall.h
       1  /*
       2   * Raw syscalls.
       3   *
       4   * Copyright (c) 2018-2021 The strace developers.
       5   * All rights reserved.
       6   *
       7   * SPDX-License-Identifier: LGPL-2.1-or-later
       8   */
       9  
      10  #ifndef STRACE_RAW_SYSCALL_H
      11  # define STRACE_RAW_SYSCALL_H
      12  
      13  # include "kernel_types.h"
      14  
      15  static inline kernel_ulong_t
      16  raw_syscall_0(const kernel_ulong_t nr, kernel_ulong_t *err)
      17  {
      18  	register kernel_ulong_t g1 __asm__("g1") = nr;
      19  	register kernel_ulong_t rval __asm__("o0");
      20  	__asm__ __volatile__("ta 0x6d\n\t"
      21  			     "bcc,pt %%xcc, 1f\n\t"
      22  			     "mov 0, %0\n\t"
      23  			     "mov 1, %0\n\t"
      24  			     "1:"
      25  			     : "+r"(g1), "=r"(rval)
      26  			     :
      27  			     : "memory", "cc", "f0", "f1", "f2", "f3", "f4",
      28  			       "f5", "f6", "f7", "f8", "f9", "f10", "f11",
      29  			       "f12", "f13", "f14", "f15", "f16", "f17",
      30  			       "f18", "f19", "f20", "f21", "f22", "f23",
      31  			       "f24", "f25", "f26", "f27", "f28", "f29",
      32  			       "f30", "f31", "f32", "f34", "f36", "f38",
      33  			       "f40", "f42", "f44", "f46", "f48", "f50",
      34  			       "f52", "f54", "f56", "f58", "f60", "f62");
      35  	*err = g1;
      36  	return rval;
      37  }
      38  # define raw_syscall_0 raw_syscall_0
      39  
      40  #endif /* !STRACE_RAW_SYSCALL_H */