(root)/
strace-6.5/
tests-mx32/
riscv_flush_icache.c
       1  /*
       2   * Check decoding of riscv_flush_icache syscall.
       3   *
       4   * Copyright (c) 2018-2019 The strace developers.
       5   * All rights reserved.
       6   *
       7   * SPDX-License-Identifier: GPL-2.0-or-later
       8   */
       9  
      10  #include "tests.h"
      11  
      12  
      13  #include "scno.h"
      14  
      15  #ifdef __NR_riscv_flush_icache
      16  
      17  # include <stdint.h>
      18  # include <stdio.h>
      19  # include <unistd.h>
      20  
      21  int main(void)
      22  {
      23  	static struct {
      24  		kernel_ulong_t addr;
      25  		const char *str;
      26  	} addrs[] = {
      27  		{ (kernel_ulong_t) (uintptr_t) ARG_STR(NULL) },
      28  		{ (kernel_ulong_t) 0xbadc0deddeadf157ULL,
      29  			sizeof(kernel_ulong_t) == 8 ? "0xbadc0deddeadf157" :
      30  			"0xdeadf157" },
      31  	};
      32  	static struct {
      33  		kernel_ulong_t val;
      34  		const char *str;
      35  	} flags[] = {
      36  		{ ARG_STR(0) },
      37  		{ 1, "SYS_RISCV_FLUSH_ICACHE_LOCAL" },
      38  		{ (kernel_ulong_t) 0xfacefeedfffffffeULL,
      39  			sizeof(kernel_ulong_t) == 8 ?
      40  			"0xfacefeedfffffffe /* SYS_RISCV_FLUSH_ICACHE_??? */" :
      41  			"0xfffffffe /* SYS_RISCV_FLUSH_ICACHE_??? */" },
      42  		{ (kernel_ulong_t) 0xfacefeedffffffffULL,
      43  			sizeof(kernel_ulong_t) == 8 ?
      44  			"SYS_RISCV_FLUSH_ICACHE_LOCAL|0xfacefeedfffffffe" :
      45  			"SYS_RISCV_FLUSH_ICACHE_LOCAL|0xfffffffe" },
      46  	};
      47  
      48  	for (size_t i = 0; i < ARRAY_SIZE(addrs); i++) {
      49  		for (size_t j = 0; j < ARRAY_SIZE(addrs); j++) {
      50  			for (size_t k = 0; k < ARRAY_SIZE(flags); k++) {
      51  				long rc = syscall(__NR_riscv_flush_icache,
      52  						  addrs[i].addr,
      53  						  addrs[j].addr,
      54  						  flags[k].val);
      55  
      56  				printf("riscv_flush_icache(%s, %s, %s) = %s\n",
      57  				       addrs[i].str, addrs[j].str, flags[k].str,
      58  				       sprintrc(rc));
      59  			}
      60  		}
      61  	}
      62  
      63  	puts("+++ exited with 0 +++");
      64  
      65  	return 0;
      66  }
      67  
      68  #else
      69  
      70  SKIP_MAIN_UNDEFINED("__NR_riscv_flush_icache");
      71  
      72  #endif