blob: aaa393256976221ab5d23d5d0534e5c9ee94cf5d [file] [log] [blame]
Elliott Hughes39bac052017-05-25 16:56:11 -07001/*
Elliott Hughesb7556142018-02-20 17:03:16 -08002 * RISC-V-specific syscall decoders.
3 *
4 * Copyright (c) 2018 The strace developers.
Elliott Hughes39bac052017-05-25 16:56:11 -07005 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
Elliott Hughesb7556142018-02-20 17:03:16 -080030#include "defs.h"
Elliott Hughes39bac052017-05-25 16:56:11 -070031
Elliott Hughesb7556142018-02-20 17:03:16 -080032#ifdef RISCV
33
34# include "xlat/riscv_flush_icache_flags.h"
35
36SYS_FUNC(riscv_flush_icache)
37{
38 /* uintptr_t start */
39 printaddr(tcp->u_arg[0]);
40
41 /* uintptr_t end */
42 tprints(", ");
43 printaddr(tcp->u_arg[1]);
44
45 /* uintptr_t flags */
46 tprints(", ");
47 printflags64(riscv_flush_icache_flags, tcp->u_arg[2],
48 "SYS_RISCV_FLUSH_ICACHE_???");
49
50 return RVAL_DECODED;
Elliott Hughes39bac052017-05-25 16:56:11 -070051}
Elliott Hughesb7556142018-02-20 17:03:16 -080052
53#endif /* RISCV */