// -*- c-basic-offset: 4 -*-
/*
 * rrsched.{cc,hh} -- round robin scheduler element
 * Robert Morris, Eddie Kohler
 *
 * Copyright (c) 1999-2000 Massachusetts Institute of Technology
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, subject to the conditions
 * listed in the Click LICENSE file. These conditions include: you must
 * preserve this copyright notice, and you cannot mention the copyright
 * holders in advertising related to the Software without their permission.
 * The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This
 * notice is a summary of the Click LICENSE file; the license in that file is
 * legally binding.
 */

#include <click/config.h>
#include <click/error.hh>
#include "rrsched.hh"
CLICK_DECLS

RRSched::RRSched()
    : _next(0), _signals(0)
{
}

RRSched::~RRSched()
{
}

int 
RRSched::initialize(ErrorHandler *errh)
{
    if (!(_signals = new NotifierSignal[ninputs()]))
	return errh->error("out of memory!");
    for (int i = 0; i < ninputs(); i++)
	_signals[i] = Notifier::upstream_empty_signal(this, i, 0);
    return 0;
}

void
RRSched::cleanup(CleanupStage)
{
    delete[] _signals;
}

Packet *
RRSched::pull(int)
{
    int n = ninputs();
    int i = _next;
    for (int j = 0; j < n; j++) {
	Packet *p = (_signals[i] ? input(i).pull() : 0);
	i++;
	if (i >= n)
	    i = 0;
	if (p) {
	    _next = i;
	    return p;
	}
    }
    return 0;
}

CLICK_ENDDECLS
EXPORT_ELEMENT(RRSched)


syntax highlighted by Code2HTML, v. 0.9.1