123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- /*
- * lib/route/cls/police.c Policer
- *
- * 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-2013 Thomas Graf <tgraf@suug.ch>
- */
- #include <netlink-private/netlink.h>
- #include <netlink-private/tc.h>
- #include <netlink/netlink.h>
- #include <netlink/utils.h>
- #include <netlink-private/route/tc-api.h>
- #include <netlink/route/classifier.h>
- #include <netlink/route/cls/police.h>
- /**
- * @name Policer Type
- * @{
- */
- static const struct trans_tbl police_types[] = {
- __ADD(TC_POLICE_UNSPEC,unspec)
- __ADD(TC_POLICE_OK,ok)
- __ADD(TC_POLICE_RECLASSIFY,reclassify)
- __ADD(TC_POLICE_SHOT,shot)
- #ifdef TC_POLICE_PIPE
- __ADD(TC_POLICE_PIPE,pipe)
- #endif
- };
- /**
- * Transform a policer type number into a character string (Reentrant).
- * @arg type policer type
- * @arg buf destination buffer
- * @arg len buffer length
- *
- * Transforms a policer type number into a character string and stores
- * it in the provided buffer.
- *
- * @return The destination buffer or the type encoded in hex if no match was found.
- */
- char * nl_police2str(int type, char *buf, size_t len)
- {
- return __type2str(type, buf, len, police_types,
- ARRAY_SIZE(police_types));
- }
- /**
- * Transform a character string into a policer type number
- * @arg name policer type name
- *
- * Transform the provided character string specifying a policer
- * type into the corresponding numeric value
- *
- * @return Policer type number or a negative value.
- */
- int nl_str2police(const char *name)
- {
- return __str2type(name, police_types, ARRAY_SIZE(police_types));
- }
- /** @} */
|