xref: /netbsd-src/tests/kernel/t_rnd.c (revision 8f4b2a189f2fd8aa2373524e4e947a5ec91e6863)
1*8f4b2a18Sriastradh /*	$NetBSD: t_rnd.c,v 1.13 2023/11/24 16:36:23 riastradh Exp $	*/
21b05a6d8Spooka 
31b05a6d8Spooka /*
41b05a6d8Spooka  * Copyright (c) 2009 The NetBSD Foundation, Inc.
51b05a6d8Spooka  * All rights reserved.
61b05a6d8Spooka  *
71b05a6d8Spooka  * Redistribution and use in source and binary forms, with or without
81b05a6d8Spooka  * modification, are permitted provided that the following conditions
91b05a6d8Spooka  * are met:
101b05a6d8Spooka  * 1. Redistributions of source code must retain the above copyright
111b05a6d8Spooka  *    notice, this list of conditions and the following disclaimer.
121b05a6d8Spooka  * 2. Redistributions in binary form must reproduce the above copyright
131b05a6d8Spooka  *    notice, this list of conditions and the following disclaimer in the
141b05a6d8Spooka  *    documentation and/or other materials provided with the distribution.
151b05a6d8Spooka  *
161b05a6d8Spooka  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
171b05a6d8Spooka  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
181b05a6d8Spooka  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
191b05a6d8Spooka  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
201b05a6d8Spooka  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
211b05a6d8Spooka  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
221b05a6d8Spooka  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
231b05a6d8Spooka  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
241b05a6d8Spooka  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
251b05a6d8Spooka  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
261b05a6d8Spooka  * POSSIBILITY OF SUCH DAMAGE.
271b05a6d8Spooka  */
281b05a6d8Spooka 
291b05a6d8Spooka #include <sys/cdefs.h>
30*8f4b2a18Sriastradh __RCSID("$NetBSD: t_rnd.c,v 1.13 2023/11/24 16:36:23 riastradh Exp $");
311b05a6d8Spooka 
321b05a6d8Spooka #include <sys/types.h>
331b05a6d8Spooka #include <sys/fcntl.h>
341b05a6d8Spooka #include <sys/ioctl.h>
35d1c2f2ccSriastradh #include <sys/rndio.h>
361b05a6d8Spooka 
371b05a6d8Spooka #include <atf-c.h>
38894367afSriastradh #include <unistd.h>
391b05a6d8Spooka 
401b05a6d8Spooka #include <rump/rump.h>
411b05a6d8Spooka #include <rump/rump_syscalls.h>
421b05a6d8Spooka 
43c54cb811Schristos #include "h_macros.h"
441b05a6d8Spooka 
451b05a6d8Spooka ATF_TC(RNDADDDATA);
ATF_TC_HEAD(RNDADDDATA,tc)461b05a6d8Spooka ATF_TC_HEAD(RNDADDDATA, tc)
471b05a6d8Spooka {
48543143cfSjruoho 	atf_tc_set_md_var(tc, "descr",
49543143cfSjruoho 	    "Checks ioctl(RNDADDDATA) (PR kern/42020)");
501b05a6d8Spooka }
511b05a6d8Spooka 
52543143cfSjruoho /* Adapted from example provided by Juho Salminen in the noted PR. */
ATF_TC_BODY(RNDADDDATA,tc)531b05a6d8Spooka ATF_TC_BODY(RNDADDDATA, tc)
541b05a6d8Spooka {
551b05a6d8Spooka 	rnddata_t rd;
561b05a6d8Spooka 	int fd;
571b05a6d8Spooka 
581b05a6d8Spooka 	rump_init();
591b05a6d8Spooka 	fd = rump_sys_open("/dev/random", O_RDWR, 0);
601b05a6d8Spooka 	if (fd == -1)
611b05a6d8Spooka 		atf_tc_fail_errno("cannot open /dev/random");
621b05a6d8Spooka 
631b05a6d8Spooka 	rd.entropy = 1;
641b05a6d8Spooka 	rd.len = 1;
651b05a6d8Spooka 	if (rump_sys_ioctl(fd, RNDADDDATA, &rd) == -1)
661b05a6d8Spooka 		atf_tc_fail_errno("RNDADDDATA");
671b05a6d8Spooka }
681b05a6d8Spooka 
69f6421900Spooka ATF_TC(RNDADDDATA2);
ATF_TC_HEAD(RNDADDDATA2,tc)70f6421900Spooka ATF_TC_HEAD(RNDADDDATA2, tc)
71f6421900Spooka {
72f6421900Spooka 	atf_tc_set_md_var(tc, "descr", "checks ioctl(RNDADDDATA) deals with "
73f6421900Spooka 	    "garbage len field");
74f6421900Spooka }
ATF_TC_BODY(RNDADDDATA2,tc)75f6421900Spooka ATF_TC_BODY(RNDADDDATA2, tc)
76f6421900Spooka {
77f6421900Spooka 	rnddata_t rd;
78f6421900Spooka 	int fd;
79f6421900Spooka 
80f6421900Spooka 	rump_init();
81f6421900Spooka 	fd = rump_sys_open("/dev/random", O_RDWR, 0);
82f6421900Spooka 	if (fd == -1)
83f6421900Spooka 		atf_tc_fail_errno("cannot open /dev/random");
84f6421900Spooka 
85f6421900Spooka 	rd.entropy = 1;
86f6421900Spooka 	rd.len = -1;
87bfb58157Schristos 	ATF_REQUIRE_ERRNO(EINVAL, rump_sys_ioctl(fd, RNDADDDATA, &rd) == -1);
88f6421900Spooka }
89f6421900Spooka 
902d2ae8f1Spooka ATF_TC(read_random);
ATF_TC_HEAD(read_random,tc)912d2ae8f1Spooka ATF_TC_HEAD(read_random, tc)
922d2ae8f1Spooka {
932d2ae8f1Spooka 	atf_tc_set_md_var(tc, "descr", "does reading /dev/random return "
942d2ae8f1Spooka 	    "within reasonable time");
952d2ae8f1Spooka 	atf_tc_set_md_var(tc, "timeout", "10");
962d2ae8f1Spooka }
972d2ae8f1Spooka 
ATF_TC_BODY(read_random,tc)982d2ae8f1Spooka ATF_TC_BODY(read_random, tc)
992d2ae8f1Spooka {
1002d2ae8f1Spooka 	char buf[128];
1012d2ae8f1Spooka 	int fd;
102894367afSriastradh 	unsigned i;
1032d2ae8f1Spooka 
1042d2ae8f1Spooka 	rump_init();
105894367afSriastradh 	for (i = 0; i < 1000; i++) {
106894367afSriastradh 		alarm(2);
107894367afSriastradh 		RL(fd = rump_sys_open("/dev/random", RUMP_O_RDONLY));
1082d2ae8f1Spooka 		RL(rump_sys_read(fd, buf, sizeof(buf)));
109290ca0f2Sriastradh 		RL(rump_sys_close(fd));
110894367afSriastradh 	}
1112d2ae8f1Spooka }
1122d2ae8f1Spooka 
ATF_TP_ADD_TCS(tp)1131b05a6d8Spooka ATF_TP_ADD_TCS(tp)
1141b05a6d8Spooka {
1151b05a6d8Spooka 	ATF_TP_ADD_TC(tp, RNDADDDATA);
116f6421900Spooka 	ATF_TP_ADD_TC(tp, RNDADDDATA2);
1172d2ae8f1Spooka 	ATF_TP_ADD_TC(tp, read_random);
1181b05a6d8Spooka 
1191b05a6d8Spooka 	return atf_no_error();
1201b05a6d8Spooka }
121