xenserver: ovs-external-ids log to file instead of syslog
[sliver-openvswitch.git] / lib / odp-util.c
1 /*
2  * Copyright (c) 2009, 2010 Nicira Networks.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at:
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #include <config.h>
18 #include "odp-util.h"
19 #include <inttypes.h>
20 #include <stdlib.h>
21 #include <string.h>
22 #include "coverage.h"
23 #include "dynamic-string.h"
24 #include "flow.h"
25 #include "packets.h"
26 #include "timeval.h"
27 #include "util.h"
28
29 union odp_action *
30 odp_actions_add(struct odp_actions *actions, uint16_t type)
31 {
32     union odp_action *a;
33     size_t idx;
34
35     idx = actions->n_actions++ & (MAX_ODP_ACTIONS - 1);
36     a = &actions->actions[idx];
37     memset(a, 0, sizeof *a);
38     a->type = type;
39     return a;
40 }
41
42 void
43 format_odp_action(struct ds *ds, const union odp_action *a)
44 {
45     switch (a->type) {
46     case ODPAT_OUTPUT:
47         ds_put_format(ds, "%"PRIu16, a->output.port);
48         break;
49     case ODPAT_OUTPUT_GROUP:
50         ds_put_format(ds, "g%"PRIu16, a->output_group.group);
51         break;
52     case ODPAT_CONTROLLER:
53         ds_put_format(ds, "ctl(%"PRIu32")", a->controller.arg);
54         break;
55     case ODPAT_SET_TUNNEL:
56         ds_put_format(ds, "set_tunnel(0x%08"PRIx32")", ntohl(a->tunnel.tun_id));
57         break;
58     case ODPAT_SET_VLAN_VID:
59         ds_put_format(ds, "set_vlan(%"PRIu16")", ntohs(a->vlan_vid.vlan_vid));
60         break;
61     case ODPAT_SET_VLAN_PCP:
62         ds_put_format(ds, "set_vlan_pcp(%"PRIu8")", a->vlan_pcp.vlan_pcp);
63         break;
64     case ODPAT_STRIP_VLAN:
65         ds_put_format(ds, "strip_vlan");
66         break;
67     case ODPAT_SET_DL_SRC:
68         ds_put_format(ds, "set_dl_src("ETH_ADDR_FMT")",
69                ETH_ADDR_ARGS(a->dl_addr.dl_addr));
70         break;
71     case ODPAT_SET_DL_DST:
72         ds_put_format(ds, "set_dl_dst("ETH_ADDR_FMT")",
73                ETH_ADDR_ARGS(a->dl_addr.dl_addr));
74         break;
75     case ODPAT_SET_NW_SRC:
76         ds_put_format(ds, "set_nw_src("IP_FMT")",
77                       IP_ARGS(&a->nw_addr.nw_addr));
78         break;
79     case ODPAT_SET_NW_DST:
80         ds_put_format(ds, "set_nw_dst("IP_FMT")",
81                       IP_ARGS(&a->nw_addr.nw_addr));
82         break;
83     case ODPAT_SET_NW_TOS:
84         ds_put_format(ds, "set_nw_tos(%"PRIu8")", a->nw_tos.nw_tos);
85         break;
86     case ODPAT_SET_TP_SRC:
87         ds_put_format(ds, "set_tp_src(%"PRIu16")", ntohs(a->tp_port.tp_port));
88         break;
89     case ODPAT_SET_TP_DST:
90         ds_put_format(ds, "set_tp_dst(%"PRIu16")", ntohs(a->tp_port.tp_port));
91         break;
92     case ODPAT_SET_PRIORITY:
93         ds_put_format(ds, "set_priority(0x%"PRIx32")", a->priority.priority);
94         break;
95     case ODPAT_POP_PRIORITY:
96         ds_put_cstr(ds, "pop_priority");
97         break;
98     default:
99         ds_put_format(ds, "***bad action 0x%"PRIx16"***", a->type);
100         break;
101     }
102 }
103
104 void
105 format_odp_actions(struct ds *ds, const union odp_action *actions,
106                    size_t n_actions)
107 {
108     size_t i;
109     for (i = 0; i < n_actions; i++) {
110         if (i) {
111             ds_put_char(ds, ',');
112         }
113         format_odp_action(ds, &actions[i]);
114     }
115     if (!n_actions) {
116         ds_put_cstr(ds, "drop");
117     }
118 }
119
120 void
121 format_odp_flow_stats(struct ds *ds, const struct odp_flow_stats *s)
122 {
123     ds_put_format(ds, "packets:%llu, bytes:%llu, used:",
124                   (unsigned long long int) s->n_packets,
125                   (unsigned long long int) s->n_bytes);
126     if (s->used_sec) {
127         long long int used = s->used_sec * 1000 + s->used_nsec / 1000000;
128         ds_put_format(ds, "%.3fs", (time_msec() - used) / 1000.0);
129     } else {
130         ds_put_format(ds, "never");
131     }
132 }
133
134 void
135 format_odp_flow(struct ds *ds, const struct odp_flow *f)
136 {
137     flow_format(ds, &f->key);
138     ds_put_cstr(ds, ", ");
139     format_odp_flow_stats(ds, &f->stats);
140     ds_put_cstr(ds, ", actions:");
141     format_odp_actions(ds, f->actions, f->n_actions);
142 }
143