/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright 2009 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #include "lint.h" #include #include #include #include #include #include int _pset(int, ...); /* subcode wrappers for _pset system call */ int pset_create(psetid_t *npset) { return (_pset(PSET_CREATE, npset)); } int pset_destroy(psetid_t pset) { return (_pset(PSET_DESTROY, pset)); } int pset_assign(psetid_t pset, processorid_t cpu, psetid_t *opset) { return (_pset(PSET_ASSIGN, pset, cpu, opset)); } int pset_assign_forced(psetid_t pset, processorid_t cpu, psetid_t *opset) { return (_pset(PSET_ASSIGN_FORCED, pset, cpu, opset)); } int pset_info(psetid_t pset, int *type, uint_t *numcpus, processorid_t *cpulist) { return (_pset(PSET_INFO, pset, type, numcpus, cpulist)); } int pset_bind(psetid_t pset, idtype_t idtype, id_t id, psetid_t *opset) { return (_pset(PSET_BIND, pset, idtype, id, opset)); } int pset_bind_lwp(psetid_t pset, id_t id, pid_t pid, psetid_t *opset) { return (_pset(PSET_BIND_LWP, pset, id, pid, opset)); } /* * Get the per-processor-set load average. */ int pset_getloadavg(psetid_t pset, double loadavg[], int nelem) { int i, buf[LOADAVG_NSTATS]; if (nelem > LOADAVG_NSTATS) nelem = LOADAVG_NSTATS; if (_pset(PSET_GETLOADAVG, pset, buf, nelem) == -1) return (-1); for (i = 0; i < nelem; i++) loadavg[i] = (double)buf[i] / FSCALE; return (nelem); } int pset_list(psetid_t *psetlist, uint_t *numpsets) { return (_pset(PSET_LIST, psetlist, numpsets)); } int pset_setattr(psetid_t pset, uint_t attr) { return (_pset(PSET_SETATTR, pset, attr)); } int pset_getattr(psetid_t pset, uint_t *attr) { return (_pset(PSET_GETATTR, pset, attr)); }