Home | History | Annotate | Line # | Download | only in sysmon
sysmonvar.h revision 1.8.2.2
      1  1.8.2.2    skrll /*	$NetBSD: sysmonvar.h,v 1.8.2.2 2004/08/03 10:51:29 skrll Exp $	*/
      2      1.1  thorpej 
      3      1.1  thorpej /*-
      4      1.1  thorpej  * Copyright (c) 2000 Zembu Labs, Inc.
      5      1.1  thorpej  * All rights reserved.
      6      1.1  thorpej  *
      7      1.1  thorpej  * Author: Jason R. Thorpe <thorpej (at) zembu.com>
      8      1.1  thorpej  *
      9      1.1  thorpej  * Redistribution and use in source and binary forms, with or without
     10      1.1  thorpej  * modification, are permitted provided that the following conditions
     11      1.1  thorpej  * are met:
     12      1.1  thorpej  * 1. Redistributions of source code must retain the above copyright
     13      1.1  thorpej  *    notice, this list of conditions and the following disclaimer.
     14      1.1  thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     15      1.1  thorpej  *    notice, this list of conditions and the following disclaimer in the
     16      1.1  thorpej  *    documentation and/or other materials provided with the distribution.
     17      1.1  thorpej  * 3. All advertising materials mentioning features or use of this software
     18      1.1  thorpej  *    must display the following acknowledgement:
     19      1.1  thorpej  *	This product includes software developed by Zembu Labs, Inc.
     20      1.1  thorpej  * 4. Neither the name of Zembu Labs nor the names of its employees may
     21      1.1  thorpej  *    be used to endorse or promote products derived from this software
     22      1.1  thorpej  *    without specific prior written permission.
     23      1.1  thorpej  *
     24      1.1  thorpej  * THIS SOFTWARE IS PROVIDED BY ZEMBU LABS, INC. ``AS IS'' AND ANY EXPRESS
     25      1.1  thorpej  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAR-
     26      1.1  thorpej  * RANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DIS-
     27      1.1  thorpej  * CLAIMED.  IN NO EVENT SHALL ZEMBU LABS BE LIABLE FOR ANY DIRECT, INDIRECT,
     28      1.1  thorpej  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     29      1.1  thorpej  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     30      1.1  thorpej  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     31      1.1  thorpej  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     32      1.1  thorpej  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     33      1.1  thorpej  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     34      1.1  thorpej  */
     35      1.1  thorpej 
     36      1.1  thorpej #ifndef _DEV_SYSMON_SYSMONVAR_H_
     37      1.1  thorpej #define	_DEV_SYSMON_SYSMONVAR_H_
     38      1.1  thorpej 
     39      1.1  thorpej #include <sys/envsys.h>
     40      1.2  thorpej #include <sys/wdog.h>
     41      1.6  thorpej #include <sys/power.h>
     42      1.1  thorpej #include <sys/queue.h>
     43      1.1  thorpej 
     44  1.8.2.1  darrenr struct lwp;
     45      1.4  thorpej struct proc;
     46      1.6  thorpej struct knote;
     47      1.6  thorpej struct uio;
     48      1.4  thorpej 
     49      1.3  thorpej #define	SYSMON_MINOR_ENVSYS	0
     50      1.3  thorpej #define	SYSMON_MINOR_WDOG	1
     51      1.6  thorpej #define	SYSMON_MINOR_POWER	2
     52      1.3  thorpej 
     53      1.4  thorpej /*****************************************************************************
     54      1.4  thorpej  * Environmental sensor support
     55      1.4  thorpej  *****************************************************************************/
     56      1.4  thorpej 
     57      1.1  thorpej struct sysmon_envsys {
     58      1.1  thorpej 	int32_t sme_envsys_version;	/* ENVSYS API version */
     59      1.1  thorpej 
     60      1.1  thorpej 	LIST_ENTRY(sysmon_envsys) sme_list;
     61      1.1  thorpej 
     62      1.1  thorpej 	const struct envsys_range *sme_ranges;
     63      1.1  thorpej 	struct envsys_basic_info *sme_sensor_info;
     64      1.1  thorpej 	struct envsys_tre_data *sme_sensor_data;
     65      1.1  thorpej 	void *sme_cookie;		/* for ENVSYS back-end */
     66      1.1  thorpej 
     67      1.1  thorpej 	/* Callbacks */
     68      1.1  thorpej 	int (*sme_gtredata)(struct sysmon_envsys *, struct envsys_tre_data *);
     69      1.1  thorpej 	int (*sme_streinfo)(struct sysmon_envsys *, struct envsys_basic_info *);
     70      1.1  thorpej 
     71      1.1  thorpej 	u_int sme_fsensor;		/* sensor index base, from sysmon */
     72      1.1  thorpej 	u_int sme_nsensors;		/* sensor count, from driver */
     73  1.8.2.2    skrll 	int sme_flags;			/* SME_FLAG_ flags defined below */
     74      1.1  thorpej };
     75      1.1  thorpej 
     76  1.8.2.2    skrll #define	SME_FLAG_BUSY	0x00000001		/* sme is busy */
     77  1.8.2.2    skrll #define	SME_FLAG_WANTED	0x00000002		/* someone waiting for this */
     78  1.8.2.2    skrll 
     79      1.1  thorpej #define	SME_SENSOR_IDX(sme, idx)	((idx) - (sme)->sme_fsensor)
     80      1.1  thorpej 
     81  1.8.2.1  darrenr int	sysmonopen_envsys(dev_t, int, int, struct lwp *);
     82  1.8.2.1  darrenr int	sysmonclose_envsys(dev_t, int, int, struct lwp *);
     83  1.8.2.1  darrenr int	sysmonioctl_envsys(dev_t, u_long, caddr_t, int, struct lwp *);
     84      1.4  thorpej 
     85      1.4  thorpej int	sysmon_envsys_register(struct sysmon_envsys *);
     86      1.4  thorpej void	sysmon_envsys_unregister(struct sysmon_envsys *);
     87      1.4  thorpej 
     88      1.4  thorpej /*****************************************************************************
     89      1.4  thorpej  * Watchdog timer support
     90      1.4  thorpej  *****************************************************************************/
     91      1.4  thorpej 
     92      1.2  thorpej struct sysmon_wdog {
     93      1.2  thorpej 	const char *smw_name;		/* watchdog device name */
     94      1.2  thorpej 
     95      1.2  thorpej 	LIST_ENTRY(sysmon_wdog) smw_list;
     96      1.2  thorpej 
     97      1.2  thorpej 	void *smw_cookie;		/* for watchdog back-end */
     98      1.2  thorpej 	int (*smw_setmode)(struct sysmon_wdog *);
     99      1.2  thorpej 	int (*smw_tickle)(struct sysmon_wdog *);
    100      1.2  thorpej 	u_int smw_period;		/* timer period (in seconds) */
    101      1.2  thorpej 	int smw_mode;			/* timer mode */
    102      1.2  thorpej 	u_int smw_refcnt;		/* references */
    103      1.2  thorpej 	pid_t smw_tickler;		/* last process to tickle */
    104      1.2  thorpej };
    105      1.3  thorpej 
    106  1.8.2.1  darrenr int	sysmonopen_wdog(dev_t, int, int, struct lwp *);
    107  1.8.2.1  darrenr int	sysmonclose_wdog(dev_t, int, int, struct lwp *);
    108  1.8.2.1  darrenr int	sysmonioctl_wdog(dev_t, u_long, caddr_t, int, struct lwp *);
    109      1.2  thorpej 
    110  1.8.2.1  darrenr int     sysmon_wdog_register(struct sysmon_wdog *);
    111  1.8.2.1  darrenr void    sysmon_wdog_unregister(struct sysmon_wdog *);
    112      1.5  thorpej 
    113      1.5  thorpej /*****************************************************************************
    114      1.5  thorpej  * Power management support
    115      1.5  thorpej  *****************************************************************************/
    116      1.5  thorpej 
    117      1.5  thorpej struct sysmon_pswitch {
    118      1.5  thorpej 	const char *smpsw_name;		/* power switch name */
    119      1.5  thorpej 	int smpsw_type;			/* power switch type */
    120      1.5  thorpej 
    121      1.5  thorpej 	LIST_ENTRY(sysmon_pswitch) smpsw_list;
    122      1.5  thorpej };
    123      1.5  thorpej 
    124  1.8.2.1  darrenr int	sysmonopen_power(dev_t, int, int, struct lwp *);
    125  1.8.2.1  darrenr int	sysmonclose_power(dev_t, int, int, struct lwp *);
    126      1.6  thorpej int	sysmonread_power(dev_t, struct uio *, int);
    127  1.8.2.1  darrenr int	sysmonpoll_power(dev_t, int, struct lwp *);
    128      1.6  thorpej int	sysmonkqfilter_power(dev_t, struct knote *);
    129  1.8.2.1  darrenr int	sysmonioctl_power(dev_t, u_long, caddr_t, int, struct lwp *);
    130      1.5  thorpej 
    131      1.6  thorpej void	sysmon_power_settype(const char *);
    132      1.5  thorpej 
    133      1.5  thorpej int	sysmon_pswitch_register(struct sysmon_pswitch *);
    134      1.5  thorpej void	sysmon_pswitch_unregister(struct sysmon_pswitch *);
    135      1.5  thorpej 
    136      1.5  thorpej void	sysmon_pswitch_event(struct sysmon_pswitch *, int);
    137  1.8.2.1  darrenr 
    138      1.1  thorpej #endif /* _DEV_SYSMON_SYSMONVAR_H_ */
    139