#ifndef __XRD_POLL_H__
#define __XRD_POLL_H__
/******************************************************************************/
/* */
/* X r d P o l l . h h */
/* */
/* (c) 2004 by the Board of Trustees of the Leland Stanford, Jr., University */
/* Produced by Andrew Hanushevsky for Stanford University under contract */
/* DE-AC02-76-SFO0515 with the Department of Energy */
/* */
/* This file is part of the XRootD software suite. */
/* */
/* XRootD 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 3 of the License, or (at your */
/* option) any later version. */
/* */
/* XRootD 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 XRootD in a file called COPYING.LESSER (LGPL license) and file */
/* COPYING (GPL license). If not, see . */
/* */
/* The copyright holder's institutional names and contributor's names may not */
/* be used to endorse or promote products derived from this software without */
/* specific prior written permission of the institution or contributor. */
/******************************************************************************/
#include
#include "XrdSys/XrdSysPthread.hh"
#define XRD_NUMPOLLERS 3
class XrdOucTrace;
class XrdSysError;
class XrdLink;
class XrdScheduler;
class XrdSysSemaphore;
class XrdPoll
{
public:
// Attach() is called when a new link needs to be assigned to a poller
//
static int Attach(XrdLink *lp); // Implementation supplied
// Detach() is called when a link is being discarded
//
static void Detach(XrdLink *lp); // Implementation supplied
// Disable() is called when we need to mask interrupts from a link
//
virtual void Disable(XrdLink *lp, const char *etxt=0) = 0;
// Enable() is called when we want to receive interrupts from a link
//
virtual int Enable(XrdLink *lp) = 0;
// Finish() is called to allow a link to gracefully terminate when scheduled
//
static int Finish(XrdLink *lp, const char *etxt=0); //Implementation supplied
// Init() is called to set pointers to external interfaces at config time.
//
static void Init(XrdSysError *eP, XrdOucTrace *tP, XrdScheduler *sP)
{XrdLog = eP; XrdTrace = tP; XrdSched = sP;}
// Poll2Text() converts bits in an revents item to text
//
static char *Poll2Text(short events); // Implementation supplied
// Setup() is called at config time to perform poller configuration
//
static int Setup(int numfd); // Implementation supplied
// Start() is called via a thread for each poller that was created
//
virtual void Start(XrdSysSemaphore *syncp, int &rc) = 0;
// Stats() is called to provide statistics on polling
//
static int Stats(char *buff, int blen, int do_sync=0);
// Identification of the thread handling this object
//
int PID; // Poller ID
pthread_t TID; // Thread ID
// The following table reference the pollers in effect
//
static XrdPoll *Pollers[XRD_NUMPOLLERS];
XrdPoll();
virtual ~XrdPoll() {}
protected:
static const char *TraceID; // For tracing
static XrdOucTrace *XrdTrace;
static XrdSysError *XrdLog;
static XrdScheduler *XrdSched;
// Gets the next request on the poll pipe. This is common to all implentations.
//
int getRequest(); // Implementation supplied
// Exclude() called to exclude a link from a poll set
//
virtual void Exclude(XrdLink *lp) = 0;
// Include() called to include a link in a poll set
//
virtual int Include(XrdLink *lp) = 0;
// newPoller() called to get a new poll object at initialization time
// Even though static, an implementation must be supplied.
//
static XrdPoll *newPoller(int pollid, int numfd) /* = 0 */;
// The following is common to all implementations
//
XrdSysMutex PollPipe;
struct pollfd PipePoll;
int CmdFD; // FD to send PipeData commands
int ReqFD; // FD to recv PipeData requests
struct PipeData {union {XrdSysSemaphore *theSem;
struct {int fd;
int ent;} Arg;
} Parms;
enum cmd {EnFD, DiFD, RmFD, Post};
cmd req;
};
PipeData ReqBuff;
char *PipeBuff;
int PipeBlen;
// The following are statistical counters each implementation must maintain
//
int numEnabled; // Count of Enable() calls
int numEvents; // Count of poll fd's dispatched
int numInterrupts; // Number of interrupts (e.g., signals)
private:
static XrdSysMutex doingAttach;
int numAttached; // Number of fd's attached to poller
};
#endif