1*57718be8SEnji Cooper /* $NetBSD: t_sched.c,v 1.5 2012/03/25 04:11:42 christos Exp $ */ 2*57718be8SEnji Cooper 3*57718be8SEnji Cooper /*- 4*57718be8SEnji Cooper * Copyright (c) 2011 The NetBSD Foundation, Inc. 5*57718be8SEnji Cooper * All rights reserved. 6*57718be8SEnji Cooper * 7*57718be8SEnji Cooper * This code is derived from software contributed to The NetBSD Foundation 8*57718be8SEnji Cooper * by Jukka Ruohonen. 9*57718be8SEnji Cooper * 10*57718be8SEnji Cooper * Redistribution and use in source and binary forms, with or without 11*57718be8SEnji Cooper * modification, are permitted provided that the following conditions 12*57718be8SEnji Cooper * are met: 13*57718be8SEnji Cooper * 1. Redistributions of source code must retain the above copyright 14*57718be8SEnji Cooper * notice, this list of conditions and the following disclaimer. 15*57718be8SEnji Cooper * 2. Redistributions in binary form must reproduce the above copyright 16*57718be8SEnji Cooper * notice, this list of conditions and the following disclaimer in the 17*57718be8SEnji Cooper * documentation and/or other materials provided with the distribution. 18*57718be8SEnji Cooper * 19*57718be8SEnji Cooper * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20*57718be8SEnji Cooper * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21*57718be8SEnji Cooper * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22*57718be8SEnji Cooper * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23*57718be8SEnji Cooper * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24*57718be8SEnji Cooper * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25*57718be8SEnji Cooper * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26*57718be8SEnji Cooper * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27*57718be8SEnji Cooper * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28*57718be8SEnji Cooper * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29*57718be8SEnji Cooper * POSSIBILITY OF SUCH DAMAGE. 30*57718be8SEnji Cooper */ 31*57718be8SEnji Cooper #include <sys/cdefs.h> 32*57718be8SEnji Cooper __RCSID("$NetBSD: t_sched.c,v 1.5 2012/03/25 04:11:42 christos Exp $"); 33*57718be8SEnji Cooper 34*57718be8SEnji Cooper #include <sched.h> 35*57718be8SEnji Cooper #include <limits.h> 36*57718be8SEnji Cooper #include <unistd.h> 37*57718be8SEnji Cooper 38*57718be8SEnji Cooper #include <atf-c.h> 39*57718be8SEnji Cooper 40*57718be8SEnji Cooper static void sched_priority_set(int, int); 41*57718be8SEnji Cooper 42*57718be8SEnji Cooper ATF_TC(sched_getparam); 43*57718be8SEnji Cooper ATF_TC_HEAD(sched_getparam, tc) 44*57718be8SEnji Cooper { 45*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "A basic test of sched_getparam(3)"); 46*57718be8SEnji Cooper } 47*57718be8SEnji Cooper 48*57718be8SEnji Cooper ATF_TC_BODY(sched_getparam, tc) 49*57718be8SEnji Cooper { 50*57718be8SEnji Cooper struct sched_param s1, s2; 51*57718be8SEnji Cooper pid_t p = getpid(); 52*57718be8SEnji Cooper 53*57718be8SEnji Cooper /* 54*57718be8SEnji Cooper * IEEE Std 1003.1-2008: if the supplied pid is zero, 55*57718be8SEnji Cooper * the parameters for the calling process are returned. 56*57718be8SEnji Cooper */ 57*57718be8SEnji Cooper ATF_REQUIRE(sched_getparam(0, &s1) == 0); 58*57718be8SEnji Cooper ATF_REQUIRE(sched_getparam(p, &s2) == 0); 59*57718be8SEnji Cooper 60*57718be8SEnji Cooper ATF_CHECK_EQ(s1.sched_priority, s2.sched_priority); 61*57718be8SEnji Cooper 62*57718be8SEnji Cooper /* 63*57718be8SEnji Cooper * The behavior is undefined but should error 64*57718be8SEnji Cooper * out in case the supplied PID is negative. 65*57718be8SEnji Cooper */ 66*57718be8SEnji Cooper ATF_REQUIRE(sched_getparam(-1, &s1) != 0); 67*57718be8SEnji Cooper } 68*57718be8SEnji Cooper 69*57718be8SEnji Cooper ATF_TC(sched_priority); 70*57718be8SEnji Cooper ATF_TC_HEAD(sched_priority, tc) 71*57718be8SEnji Cooper { 72*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "Test sched(3) priority ranges"); 73*57718be8SEnji Cooper } 74*57718be8SEnji Cooper 75*57718be8SEnji Cooper ATF_TC_BODY(sched_priority, tc) 76*57718be8SEnji Cooper { 77*57718be8SEnji Cooper static const int pol[3] = { SCHED_OTHER, SCHED_FIFO, SCHED_RR }; 78*57718be8SEnji Cooper int pmax, pmin; 79*57718be8SEnji Cooper size_t i; 80*57718be8SEnji Cooper 81*57718be8SEnji Cooper /* 82*57718be8SEnji Cooper * Test that bogus values error out. 83*57718be8SEnji Cooper */ 84*57718be8SEnji Cooper if (INT_MAX > SCHED_RR) 85*57718be8SEnji Cooper ATF_REQUIRE(sched_get_priority_max(INT_MAX) != 0); 86*57718be8SEnji Cooper 87*57718be8SEnji Cooper if (-INT_MAX < SCHED_OTHER) 88*57718be8SEnji Cooper ATF_REQUIRE(sched_get_priority_max(-INT_MAX) != 0); 89*57718be8SEnji Cooper 90*57718be8SEnji Cooper /* 91*57718be8SEnji Cooper * Test that we have a valid range. 92*57718be8SEnji Cooper */ 93*57718be8SEnji Cooper for (i = 0; i < __arraycount(pol); i++) { 94*57718be8SEnji Cooper 95*57718be8SEnji Cooper pmax = sched_get_priority_max(pol[i]); 96*57718be8SEnji Cooper pmin = sched_get_priority_min(pol[i]); 97*57718be8SEnji Cooper 98*57718be8SEnji Cooper ATF_REQUIRE(pmax != -1); 99*57718be8SEnji Cooper ATF_REQUIRE(pmin != -1); 100*57718be8SEnji Cooper ATF_REQUIRE(pmax > pmin); 101*57718be8SEnji Cooper } 102*57718be8SEnji Cooper } 103*57718be8SEnji Cooper 104*57718be8SEnji Cooper static void 105*57718be8SEnji Cooper sched_priority_set(int pri, int pol) 106*57718be8SEnji Cooper { 107*57718be8SEnji Cooper struct sched_param sched; 108*57718be8SEnji Cooper 109*57718be8SEnji Cooper sched.sched_priority = pri; 110*57718be8SEnji Cooper 111*57718be8SEnji Cooper ATF_REQUIRE(pri >= 0); 112*57718be8SEnji Cooper ATF_REQUIRE(sched_setscheduler(0, pol, &sched) == 0); 113*57718be8SEnji Cooper 114*57718be8SEnji Cooper /* 115*57718be8SEnji Cooper * Test that the policy was changed. 116*57718be8SEnji Cooper */ 117*57718be8SEnji Cooper ATF_CHECK_EQ(sched_getscheduler(0), pol); 118*57718be8SEnji Cooper 119*57718be8SEnji Cooper /* 120*57718be8SEnji Cooper * And that sched_getparam(3) returns the new priority. 121*57718be8SEnji Cooper */ 122*57718be8SEnji Cooper sched.sched_priority = -1; 123*57718be8SEnji Cooper 124*57718be8SEnji Cooper ATF_REQUIRE(sched_getparam(0, &sched) == 0); 125*57718be8SEnji Cooper ATF_CHECK_EQ(sched.sched_priority, pri); 126*57718be8SEnji Cooper } 127*57718be8SEnji Cooper 128*57718be8SEnji Cooper ATF_TC(sched_setscheduler_1); 129*57718be8SEnji Cooper ATF_TC_HEAD(sched_setscheduler_1, tc) 130*57718be8SEnji Cooper { 131*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "sched_setscheduler(3), max, RR"); 132*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 133*57718be8SEnji Cooper } 134*57718be8SEnji Cooper 135*57718be8SEnji Cooper ATF_TC_BODY(sched_setscheduler_1, tc) 136*57718be8SEnji Cooper { 137*57718be8SEnji Cooper int pri; 138*57718be8SEnji Cooper 139*57718be8SEnji Cooper pri = sched_get_priority_max(SCHED_RR); 140*57718be8SEnji Cooper sched_priority_set(pri, SCHED_RR); 141*57718be8SEnji Cooper } 142*57718be8SEnji Cooper 143*57718be8SEnji Cooper ATF_TC(sched_setscheduler_2); 144*57718be8SEnji Cooper ATF_TC_HEAD(sched_setscheduler_2, tc) 145*57718be8SEnji Cooper { 146*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "sched_setscheduler(3), min, RR"); 147*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 148*57718be8SEnji Cooper } 149*57718be8SEnji Cooper 150*57718be8SEnji Cooper ATF_TC_BODY(sched_setscheduler_2, tc) 151*57718be8SEnji Cooper { 152*57718be8SEnji Cooper int pri; 153*57718be8SEnji Cooper 154*57718be8SEnji Cooper pri = sched_get_priority_min(SCHED_RR); 155*57718be8SEnji Cooper sched_priority_set(pri, SCHED_RR); 156*57718be8SEnji Cooper } 157*57718be8SEnji Cooper 158*57718be8SEnji Cooper ATF_TC(sched_setscheduler_3); 159*57718be8SEnji Cooper ATF_TC_HEAD(sched_setscheduler_3, tc) 160*57718be8SEnji Cooper { 161*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "sched_setscheduler(3), max, FIFO"); 162*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 163*57718be8SEnji Cooper } 164*57718be8SEnji Cooper 165*57718be8SEnji Cooper ATF_TC_BODY(sched_setscheduler_3, tc) 166*57718be8SEnji Cooper { 167*57718be8SEnji Cooper int pri; 168*57718be8SEnji Cooper 169*57718be8SEnji Cooper pri = sched_get_priority_max(SCHED_FIFO); 170*57718be8SEnji Cooper sched_priority_set(pri, SCHED_FIFO); 171*57718be8SEnji Cooper } 172*57718be8SEnji Cooper 173*57718be8SEnji Cooper ATF_TC(sched_setscheduler_4); 174*57718be8SEnji Cooper ATF_TC_HEAD(sched_setscheduler_4, tc) 175*57718be8SEnji Cooper { 176*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "sched_setscheduler(3), min, FIFO"); 177*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 178*57718be8SEnji Cooper } 179*57718be8SEnji Cooper 180*57718be8SEnji Cooper ATF_TC_BODY(sched_setscheduler_4, tc) 181*57718be8SEnji Cooper { 182*57718be8SEnji Cooper int pri; 183*57718be8SEnji Cooper 184*57718be8SEnji Cooper pri = sched_get_priority_min(SCHED_FIFO); 185*57718be8SEnji Cooper sched_priority_set(pri, SCHED_FIFO); 186*57718be8SEnji Cooper } 187*57718be8SEnji Cooper 188*57718be8SEnji Cooper ATF_TC(sched_rr_get_interval_1); 189*57718be8SEnji Cooper ATF_TC_HEAD(sched_rr_get_interval_1, tc) 190*57718be8SEnji Cooper { 191*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "Test sched_rr_get_interval(3), #1" 192*57718be8SEnji Cooper " (PR lib/44768)"); 193*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 194*57718be8SEnji Cooper } 195*57718be8SEnji Cooper 196*57718be8SEnji Cooper ATF_TC_BODY(sched_rr_get_interval_1, tc) 197*57718be8SEnji Cooper { 198*57718be8SEnji Cooper struct timespec tv; 199*57718be8SEnji Cooper int pri; 200*57718be8SEnji Cooper 201*57718be8SEnji Cooper pri = sched_get_priority_min(SCHED_RR); 202*57718be8SEnji Cooper sched_priority_set(pri, SCHED_RR); 203*57718be8SEnji Cooper 204*57718be8SEnji Cooper /* 205*57718be8SEnji Cooper * This should fail with ESRCH for invalid PID. 206*57718be8SEnji Cooper */ 207*57718be8SEnji Cooper ATF_REQUIRE(sched_rr_get_interval(-INT_MAX, &tv) != 0); 208*57718be8SEnji Cooper } 209*57718be8SEnji Cooper 210*57718be8SEnji Cooper ATF_TC(sched_rr_get_interval_2); 211*57718be8SEnji Cooper ATF_TC_HEAD(sched_rr_get_interval_2, tc) 212*57718be8SEnji Cooper { 213*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "Test sched_rr_get_interval(3), #2"); 214*57718be8SEnji Cooper atf_tc_set_md_var(tc, "require.user", "root"); 215*57718be8SEnji Cooper } 216*57718be8SEnji Cooper 217*57718be8SEnji Cooper ATF_TC_BODY(sched_rr_get_interval_2, tc) 218*57718be8SEnji Cooper { 219*57718be8SEnji Cooper struct timespec tv1, tv2; 220*57718be8SEnji Cooper int pri; 221*57718be8SEnji Cooper 222*57718be8SEnji Cooper pri = sched_get_priority_min(SCHED_RR); 223*57718be8SEnji Cooper sched_priority_set(pri, SCHED_RR); 224*57718be8SEnji Cooper 225*57718be8SEnji Cooper tv1.tv_sec = tv2.tv_sec = -1; 226*57718be8SEnji Cooper tv1.tv_nsec = tv2.tv_nsec = -1; 227*57718be8SEnji Cooper 228*57718be8SEnji Cooper ATF_REQUIRE(sched_rr_get_interval(0, &tv1) == 0); 229*57718be8SEnji Cooper ATF_REQUIRE(sched_rr_get_interval(getpid(), &tv2) == 0); 230*57718be8SEnji Cooper 231*57718be8SEnji Cooper ATF_REQUIRE(tv1.tv_sec != -1); 232*57718be8SEnji Cooper ATF_REQUIRE(tv2.tv_sec != -1); 233*57718be8SEnji Cooper 234*57718be8SEnji Cooper ATF_REQUIRE(tv1.tv_nsec != -1); 235*57718be8SEnji Cooper ATF_REQUIRE(tv2.tv_nsec != -1); 236*57718be8SEnji Cooper 237*57718be8SEnji Cooper ATF_REQUIRE(tv1.tv_sec == tv2.tv_sec); 238*57718be8SEnji Cooper ATF_REQUIRE(tv1.tv_nsec == tv2.tv_nsec); 239*57718be8SEnji Cooper } 240*57718be8SEnji Cooper 241*57718be8SEnji Cooper ATF_TP_ADD_TCS(tp) 242*57718be8SEnji Cooper { 243*57718be8SEnji Cooper 244*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_getparam); 245*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_priority); 246*57718be8SEnji Cooper 247*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_setscheduler_1); 248*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_setscheduler_2); 249*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_setscheduler_3); 250*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_setscheduler_4); 251*57718be8SEnji Cooper 252*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_rr_get_interval_1); 253*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sched_rr_get_interval_2); 254*57718be8SEnji Cooper 255*57718be8SEnji Cooper return atf_no_error(); 256*57718be8SEnji Cooper } 257