Annotation of embedaddon/bmon/src/in_dummy.c, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * in_dummy.c                Dummy Input Method
                      3:  *
                      4:  * Copyright (c) 2001-2004 Thomas Graf <tgraf@suug.ch>
                      5:  *
                      6:  * Permission is hereby granted, free of charge, to any person obtaining a
                      7:  * copy of this software and associated documentation files (the "Software"),
                      8:  * to deal in the Software without restriction, including without limitation
                      9:  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
                     10:  * and/or sell copies of the Software, and to permit persons to whom the
                     11:  * Software is furnished to do so, subject to the following conditions:
                     12:  *
                     13:  * The above copyright notice and this permission notice shall be included
                     14:  * in all copies or substantial portions of the Software.
                     15:  *
                     16:  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
                     17:  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
                     18:  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
                     19:  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
                     20:  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
                     21:  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
                     22:  * DEALINGS IN THE SOFTWARE.
                     23:  */
                     24: 
                     25: #include <bmon/bmon.h>
                     26: #include <bmon/input.h>
                     27: #include <bmon/node.h>
                     28: #include <bmon/item.h>
                     29: #include <bmon/utils.h>
                     30: 
                     31: static b_cnt_t c_rx_b_inc = 1000000000;
                     32: static b_cnt_t c_tx_b_inc = 80000000;
                     33: static b_cnt_t c_rx_p_inc = 1000;
                     34: static b_cnt_t c_tx_p_inc = 800;
                     35: static int c_numdev = 5;
                     36: static int c_randomize = 0;
                     37: static int c_mtu = 1540;
                     38: static int c_maxpps = 100000;
                     39: 
                     40: static void dummy_read(void)
                     41: {
                     42:        int n;
                     43: 
                     44:        for (n = 0; n < c_numdev; n++) {
                     45:                char ifname[IFNAMSIZ];
                     46:                item_t *it;
                     47: 
                     48:                snprintf(ifname, sizeof(ifname), "dummy%d", n);
                     49:                
                     50:                it = lookup_item(get_local_node(), ifname, 0, 0);
                     51:                if (it == NULL)
                     52:                        return;
                     53: 
                     54:                it->i_major_attr = BYTES;
                     55:                it->i_minor_attr = PACKETS;
                     56: 
                     57:                if (c_randomize) {
                     58:                        b_cnt_t rx = rand() % c_maxpps;
                     59:                        b_cnt_t tx = rand() % c_maxpps;
                     60:                        
                     61:                        update_attr(it, PACKETS, rx, tx, RX_PROVIDED | TX_PROVIDED);
                     62:                        update_attr(it, BYTES, rx * (rand() % c_mtu),
                     63:                                    tx * (rand() % c_mtu), RX_PROVIDED | TX_PROVIDED);
                     64:                } else {
                     65:                        update_attr(it, PACKETS, c_rx_p_inc, c_tx_p_inc,
                     66:                                    RX_PROVIDED | TX_PROVIDED);
                     67:                        update_attr(it, BYTES, c_rx_b_inc, c_tx_b_inc,
                     68:                                    RX_PROVIDED | TX_PROVIDED);
                     69:                }
                     70: 
                     71:                notify_update(it, NULL);
                     72:                increase_lifetime(it, 1);
                     73:        }
                     74: }
                     75: 
                     76: static void print_help(void)
                     77: {
                     78:        printf(
                     79:        "dummy - Statistic generator module (dummy)\n" \
                     80:        "\n" \
                     81:        "  Basic statistic generator for testing purposes. Can produce a\n" \
                     82:        "  constant or random statistic flow with configurable parameters.\n" \
                     83:        "  Author: Thomas Graf <tgraf@suug.ch>\n" \
                     84:        "\n" \
                     85:        "  Options:\n" \
                     86:        "    rxb=NUM        RX bytes increment amount (default: 10^9)\n" \
                     87:        "    txb=NUM        TX bytes increment amount (default: 8*10^7)\n" \
                     88:        "    rxp=NUM        RX packets increment amount (default: 1K)\n" \
                     89:        "    txp=NUM        TX packets increment amount (default: 800)\n" \
                     90:        "    num=NUM        Number of devices (default: 5)\n" \
                     91:        "    randomize      Randomize counters (default: off)\n" \
                     92:        "    seed=NUM       Seed for randomizer (default: time(0))\n" \
                     93:        "    mtu=NUM        Maximal Transmission Unit (default: 1540)\n" \
                     94:        "    maxpps=NUM     Upper limit for packets per second (default: 100K)\n" \
                     95:        "\n" \
                     96:        "  Randomizer:\n" \
                     97:        "    RX-packets := Rand() %% maxpps\n" \
                     98:        "    TX-packets := Rand() %% maxpps\n" \
                     99:        "    RX-bytes   := RX-packets * (Rand() %% mtu)\n" \
                    100:        "    TX-bytes   := TX-packets * (Rand() %% mtu)\n");
                    101: }
                    102: 
                    103: static void dummy_set_opts(tv_t *attrs)
                    104: {
                    105:        while (attrs) {
                    106:                if (!strcasecmp(attrs->type, "rxb") && attrs->value)
                    107:                        c_rx_b_inc = strtol(attrs->value, NULL, 0);
                    108:                else if (!strcasecmp(attrs->type, "txb") && attrs->value)
                    109:                        c_tx_b_inc = strtol(attrs->value, NULL, 0);
                    110:                else if (!strcasecmp(attrs->type, "rxp") && attrs->value)
                    111:                        c_rx_p_inc = strtol(attrs->value, NULL, 0);
                    112:                else if (!strcasecmp(attrs->type, "txp") && attrs->value)
                    113:                        c_tx_p_inc = strtol(attrs->value, NULL, 0);
                    114:                else if (!strcasecmp(attrs->type, "num") && attrs->value)
                    115:                        c_numdev = strtol(attrs->value, NULL, 0);
                    116:                else if (!strcasecmp(attrs->type, "randomize")) {
                    117:                        c_randomize = 1;
                    118:                        srand(time(0));
                    119:                } else if (!strcasecmp(attrs->type, "seed") && attrs->value)
                    120:                        srand(strtol(attrs->value, NULL, 0));
                    121:                else if (!strcasecmp(attrs->type, "mtu") && attrs->value)
                    122:                        c_mtu = strtol(attrs->value, NULL, 0);
                    123:                else if (!strcasecmp(attrs->type, "maxpps") && attrs->value)
                    124:                        c_maxpps = strtol(attrs->value, NULL, 0);
                    125:                else if (!strcasecmp(attrs->type, "help")) {
                    126:                        print_help();
                    127:                        exit(0);
                    128:                }
                    129:                
                    130:                attrs = attrs->next;
                    131:        }
                    132: }
                    133: 
                    134: static int dummy_probe(void)
                    135: {
                    136:        return 1;
                    137: }
                    138: 
                    139: static struct input_module dummy_ops = {
                    140:        .im_name = "dummy",
                    141:        .im_read = dummy_read,
                    142:        .im_set_opts = dummy_set_opts,
                    143:        .im_probe = dummy_probe,
                    144:        .im_no_default = 1,
                    145: };
                    146: 
                    147: static void __init dummy_init(void)
                    148: {
                    149:        register_input_module(&dummy_ops);
                    150: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>