1 1.4 simonb /* $NetBSD: t_syscall.c,v 1.4 2021/01/18 05:44:20 simonb Exp $ */ 2 1.1 martin 3 1.1 martin /*- 4 1.1 martin * Copyright (c) 2018 The NetBSD Foundation, Inc. 5 1.1 martin * All rights reserved. 6 1.1 martin * 7 1.1 martin * This code is derived from software contributed to The NetBSD Foundation 8 1.1 martin * by Martin Husemann. 9 1.1 martin * 10 1.1 martin * Redistribution and use in source and binary forms, with or without 11 1.1 martin * modification, are permitted provided that the following conditions 12 1.1 martin * are met: 13 1.1 martin * 1. Redistributions of source code must retain the above copyright 14 1.1 martin * notice, this list of conditions and the following disclaimer. 15 1.1 martin * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 martin * notice, this list of conditions and the following disclaimer in the 17 1.1 martin * documentation and/or other materials provided with the distribution. 18 1.1 martin * 19 1.1 martin * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 martin * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 martin * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 martin * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 martin * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 martin * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 martin * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 martin * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 martin * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 martin * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 martin * POSSIBILITY OF SUCH DAMAGE. 30 1.1 martin */ 31 1.1 martin #include <sys/cdefs.h> 32 1.4 simonb __RCSID("$NetBSD: t_syscall.c,v 1.4 2021/01/18 05:44:20 simonb Exp $"); 33 1.1 martin 34 1.1 martin 35 1.1 martin #include <atf-c.h> 36 1.1 martin #include <stdio.h> 37 1.1 martin #include <unistd.h> 38 1.1 martin #include <fcntl.h> 39 1.1 martin #include <err.h> 40 1.1 martin #include <string.h> 41 1.1 martin #include <stdlib.h> 42 1.1 martin #include <sys/mman.h> 43 1.1 martin #include <sys/endian.h> 44 1.1 martin #include <sys/syscall.h> 45 1.1 martin 46 1.1 martin #if !defined(_LP64) && BYTE_ORDER == _BIG_ENDIAN 47 1.2 martin #define __SYSCALL_TO_UINTPTR_T(V) ((uintptr_t)((V)>>32)) 48 1.1 martin #else 49 1.2 martin #define __SYSCALL_TO_UINTPTR_T(V) ((uintptr_t)(V)) 50 1.1 martin #endif 51 1.1 martin 52 1.1 martin static const char secrect_data[1024] = { 53 1.1 martin "my secret key\n" 54 1.1 martin }; 55 1.1 martin 56 1.1 martin #define FILE_NAME "dummy" 57 1.1 martin 58 1.1 martin #ifndef _LP64 59 1.1 martin ATF_TC(mmap_syscall); 60 1.1 martin 61 1.1 martin ATF_TC_HEAD(mmap_syscall, tc) 62 1.1 martin { 63 1.1 martin atf_tc_set_md_var(tc, "descr", "Tests mmap(2) via syscall(2)"); 64 1.1 martin } 65 1.1 martin 66 1.1 martin ATF_TC_BODY(mmap_syscall, tc) 67 1.1 martin { 68 1.1 martin int fd; 69 1.1 martin const char *p; 70 1.1 martin 71 1.1 martin fd = open(FILE_NAME, O_RDWR|O_CREAT|O_TRUNC, 0666); 72 1.1 martin ATF_REQUIRE(fd != -1); 73 1.1 martin 74 1.1 martin write(fd, secrect_data, sizeof(secrect_data)); 75 1.1 martin 76 1.1 martin p = (const char *)syscall(SYS_mmap, 77 1.1 martin 0, sizeof(secrect_data), PROT_READ, MAP_PRIVATE, fd, 0, 0, 0); 78 1.4 simonb ATF_REQUIRE(p != MAP_FAILED); 79 1.1 martin 80 1.1 martin ATF_REQUIRE(strcmp(p, secrect_data) == 0); 81 1.1 martin } 82 1.1 martin #endif 83 1.1 martin 84 1.1 martin ATF_TC(mmap___syscall); 85 1.1 martin 86 1.1 martin ATF_TC_HEAD(mmap___syscall, tc) 87 1.1 martin { 88 1.1 martin atf_tc_set_md_var(tc, "descr", "Tests mmap(2) via __syscall(2)"); 89 1.1 martin } 90 1.1 martin 91 1.1 martin ATF_TC_BODY(mmap___syscall, tc) 92 1.1 martin { 93 1.1 martin int fd; 94 1.1 martin const char *p; 95 1.1 martin 96 1.1 martin fd = open(FILE_NAME, O_RDWR|O_CREAT|O_TRUNC, 0666); 97 1.1 martin ATF_REQUIRE(fd != -1); 98 1.1 martin 99 1.1 martin write(fd, secrect_data, sizeof(secrect_data)); 100 1.1 martin 101 1.2 martin p = (const char *)__SYSCALL_TO_UINTPTR_T(__syscall(SYS_mmap, 102 1.3 martin 0, sizeof(secrect_data), PROT_READ, MAP_PRIVATE, fd, 103 1.3 martin /* pad*/ 0, (off_t)0)); 104 1.4 simonb ATF_REQUIRE(p != MAP_FAILED); 105 1.1 martin 106 1.1 martin ATF_REQUIRE(strcmp(p, secrect_data) == 0); 107 1.1 martin } 108 1.1 martin 109 1.1 martin ATF_TP_ADD_TCS(tp) 110 1.1 martin { 111 1.1 martin 112 1.1 martin #ifndef _LP64 113 1.1 martin ATF_TP_ADD_TC(tp, mmap_syscall); 114 1.1 martin #endif 115 1.1 martin ATF_TP_ADD_TC(tp, mmap___syscall); 116 1.1 martin 117 1.1 martin return atf_no_error(); 118 1.1 martin } 119