2007-06-26 19:11:00 +00:00
/*
* event . h : event loop for monitoring file handles
*
* Copyright ( C ) 2007 Daniel P . Berrange
* Copyright ( C ) 2007 Red Hat , Inc .
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*
* Author : Daniel P . Berrange < berrange @ redhat . com >
*/
# ifndef __VIRTD_EVENT_H__
# define __VIRTD_EVENT_H__
2007-06-26 22:51:01 +00:00
# include "../src/event.h"
2007-06-26 19:11:00 +00:00
/**
2007-06-26 22:51:01 +00:00
* virEventAddHandleImpl : register a callback for monitoring file handle events
2007-06-26 19:11:00 +00:00
*
* @ fd : file handle to monitor for events
2008-02-29 12:53:10 +00:00
* @ events : bitset of events to watch from POLLnnn constants
* @ cb : callback to invoke when an event occurs
2007-06-26 19:11:00 +00:00
* @ opaque : user data to pass to callback
*
* returns - 1 if the file handle cannot be registered , 0 upon success
*/
2007-06-26 22:51:01 +00:00
int virEventAddHandleImpl ( int fd , int events , virEventHandleCallback cb , void * opaque ) ;
2007-06-26 19:11:00 +00:00
2007-09-19 01:27:32 +00:00
/**
* virEventUpdateHandleImpl : change event set for a monitored file handle
*
* @ fd : file handle to monitor for events
2008-02-29 12:53:10 +00:00
* @ events : bitset of events to watch from POLLnnn constants
2007-09-19 01:27:32 +00:00
*
* Will not fail if fd exists
*/
void virEventUpdateHandleImpl ( int fd , int events ) ;
2007-06-26 19:11:00 +00:00
/**
2007-06-26 22:51:01 +00:00
* virEventRemoveHandleImpl : unregister a callback from a file handle
2007-06-26 19:11:00 +00:00
*
* @ fd : file handle to stop monitoring for events
*
* returns - 1 if the file handle was not registered , 0 upon success
*/
2007-06-26 22:51:01 +00:00
int virEventRemoveHandleImpl ( int fd ) ;
2007-06-26 19:11:00 +00:00
/**
2007-06-26 22:51:01 +00:00
* virEventAddTimeoutImpl : register a callback for a timer event
2007-06-26 19:11:00 +00:00
*
2007-09-19 01:27:32 +00:00
* @ frequency : time between events in milliseconds
2008-02-29 12:53:10 +00:00
* @ cb : callback to invoke when an event occurs
2007-06-26 19:11:00 +00:00
* @ opaque : user data to pass to callback
*
2007-09-19 01:27:32 +00:00
* Setting frequency to - 1 will disable the timer . Setting the frequency
* to zero will cause it to fire on every event loop iteration .
*
2007-06-26 19:11:00 +00:00
* returns - 1 if the file handle cannot be registered , a positive
* integer timer id upon success
*/
2007-09-19 01:27:32 +00:00
int virEventAddTimeoutImpl ( int frequency , virEventTimeoutCallback cb , void * opaque ) ;
/**
* virEventUpdateTimeoutImpl : change frequency for a timer
*
* @ timer : timer id to change
* @ frequency : time between events in milliseconds
*
* Setting frequency to - 1 will disable the timer . Setting the frequency
* to zero will cause it to fire on every event loop iteration .
*
* Will not fail if timer exists
*/
void virEventUpdateTimeoutImpl ( int timer , int frequency ) ;
2007-06-26 19:11:00 +00:00
/**
2007-06-26 22:51:01 +00:00
* virEventRemoveTimeoutImpl : unregister a callback for a timer
2007-06-26 19:11:00 +00:00
*
* @ timer : the timer id to remove
*
* returns - 1 if the timer was not registered , 0 upon success
*/
2007-06-26 22:51:01 +00:00
int virEventRemoveTimeoutImpl ( int timer ) ;
2007-06-26 19:11:00 +00:00
/**
* virEventRunOnce : run a single iteration of the event loop .
*
* Blocks the caller until at least one file handle has an
* event or the first timer expires .
*
* returns - 1 if the event monitoring failed
*/
int virEventRunOnce ( void ) ;
# endif /* __VIRTD_EVENT_H__ */