/* * lib/route/qdisc_api.c Queueing Discipline Module API * * 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 version 2.1 * of the License. * * Copyright (c) 2003-2006 Thomas Graf <tgraf@suug.ch> */ /** * @ingroup qdisc * @defgroup qdisc_api Queueing Discipline Modules * @{ */ #include <netlink-local.h> #include <netlink-tc.h> #include <netlink/netlink.h> #include <netlink/utils.h> #include <netlink/route/link.h> #include <netlink/route/tc.h> #include <netlink/route/qdisc.h> #include <netlink/route/class.h> #include <netlink/route/classifier.h> #include <netlink/route/qdisc-modules.h> static struct rtnl_qdisc_ops *qdisc_ops_list; /** * @name Module API * @{ */ /** * Register a qdisc module * @arg qops qdisc module operations */ int rtnl_qdisc_register(struct rtnl_qdisc_ops *qops) { struct rtnl_qdisc_ops *o, **op; if (!qops->qo_kind[0]) BUG(); for (op = &qdisc_ops_list; (o = *op) != NULL; op = &o->qo_next) if (!strcasecmp(qops->qo_kind, o->qo_kind)) return nl_errno(EEXIST); qops->qo_next = NULL; *op = qops; return 0; } /** * Unregister a qdisc module * @arg qops qdisc module operations */ int rtnl_qdisc_unregister(struct rtnl_qdisc_ops *qops) { struct rtnl_qdisc_ops *o, **op; for (op = &qdisc_ops_list; (o = *op) != NULL; op = &o->qo_next) if (!strcasecmp(qops->qo_kind, o->qo_kind)) break; if (!o) return nl_errno(ENOENT); *op = qops->qo_next; return 0; } struct rtnl_qdisc_ops *__rtnl_qdisc_lookup_ops(const char *kind) { struct rtnl_qdisc_ops *qops; for (qops = qdisc_ops_list; qops; qops = qops->qo_next) if (!strcmp(kind, qops->qo_kind)) return qops; return NULL; } struct rtnl_qdisc_ops *rtnl_qdisc_lookup_ops(struct rtnl_qdisc *qdisc) { if (!qdisc->q_ops) qdisc->q_ops = __rtnl_qdisc_lookup_ops(qdisc->q_kind); return qdisc->q_ops; } /** @} */ /** @} */