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