1*495782eeSpooka /* $NetBSD: t_modautoload.c,v 1.2 2014/03/10 22:38:53 pooka Exp $ */ 25c21ec6fSpooka 35c21ec6fSpooka #include <sys/types.h> 45c21ec6fSpooka #include <sys/mount.h> 55c21ec6fSpooka #include <sys/module.h> 65c21ec6fSpooka #include <sys/dirent.h> 75c21ec6fSpooka #include <sys/sysctl.h> 85c21ec6fSpooka 95c21ec6fSpooka #include <atf-c.h> 105c21ec6fSpooka #include <err.h> 115c21ec6fSpooka #include <errno.h> 125c21ec6fSpooka #include <fcntl.h> 135c21ec6fSpooka #include <stdio.h> 145c21ec6fSpooka #include <unistd.h> 155c21ec6fSpooka #include <string.h> 165c21ec6fSpooka #include <stdlib.h> 175c21ec6fSpooka 185c21ec6fSpooka #include <rump/rump.h> 195c21ec6fSpooka #include <rump/rump_syscalls.h> 205c21ec6fSpooka 215c21ec6fSpooka #include <miscfs/kernfs/kernfs.h> 225c21ec6fSpooka 235c21ec6fSpooka #include "../../h_macros.h" 245c21ec6fSpooka 255c21ec6fSpooka ATF_TC(modautoload); 265c21ec6fSpooka ATF_TC_HEAD(modautoload, tc) 275c21ec6fSpooka { 285c21ec6fSpooka 295c21ec6fSpooka atf_tc_set_md_var(tc, "descr", "tests that kernel module " 305c21ec6fSpooka "autoload works in rump"); 315c21ec6fSpooka } 325c21ec6fSpooka 335c21ec6fSpooka static void 345c21ec6fSpooka mountkernfs(void) 355c21ec6fSpooka { 365c21ec6fSpooka 37*495782eeSpooka if (!rump_nativeabi_p()) 38*495782eeSpooka atf_tc_skip("host kernel modules not supported"); 395c21ec6fSpooka 405c21ec6fSpooka rump_init(); 415c21ec6fSpooka 425c21ec6fSpooka if (rump_sys_mkdir("/kern", 0777) == -1) 435c21ec6fSpooka atf_tc_fail_errno("mkdir /kern"); 445c21ec6fSpooka if (rump_sys_mount(MOUNT_KERNFS, "/kern", 0, NULL, 0) == -1) 455c21ec6fSpooka atf_tc_fail_errno("could not mount kernfs"); 465c21ec6fSpooka } 475c21ec6fSpooka 485c21ec6fSpooka /* 495c21ec6fSpooka * Why use kernfs here? It talks to plenty of other parts with the 505c21ec6fSpooka * kernel (e.g. vfs_attach() in modcmd), but is still easy to verify 515c21ec6fSpooka * it's working correctly. 525c21ec6fSpooka */ 535c21ec6fSpooka 545c21ec6fSpooka #define MAGICNUM 1323 555c21ec6fSpooka ATF_TC_BODY(modautoload, tc) 565c21ec6fSpooka { 575c21ec6fSpooka extern int rumpns_hz; 585c21ec6fSpooka char buf[64]; 595c21ec6fSpooka int fd; 605c21ec6fSpooka 615c21ec6fSpooka mountkernfs(); 625c21ec6fSpooka rumpns_hz = MAGICNUM; 635c21ec6fSpooka if ((fd = rump_sys_open("/kern/hz", O_RDONLY)) == -1) 645c21ec6fSpooka atf_tc_fail_errno("open /kern/hz"); 655c21ec6fSpooka if (rump_sys_read(fd, buf, sizeof(buf)) <= 0) 665c21ec6fSpooka atf_tc_fail_errno("read"); 675c21ec6fSpooka ATF_REQUIRE(atoi(buf) == MAGICNUM); 685c21ec6fSpooka } 695c21ec6fSpooka 705c21ec6fSpooka ATF_TP_ADD_TCS(tp) 715c21ec6fSpooka { 725c21ec6fSpooka ATF_TP_ADD_TC(tp, modautoload); 735c21ec6fSpooka 745c21ec6fSpooka return atf_no_error(); 755c21ec6fSpooka } 76