X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=lib%2Fodp-util.c;h=e57a7cb090204a1cf86707d76136af7fe4915fa7;hb=8321fb9c570bd25bb8925e7b5116ab90662113b5;hp=49d9d34d5ca133d245f1db25cb18762f929e0ee1;hpb=14608a1539b73f8f9812e0e791adb60825fee38b;p=openvswitch diff --git a/lib/odp-util.c b/lib/odp-util.c index 49d9d34d..e57a7cb0 100644 --- a/lib/odp-util.c +++ b/lib/odp-util.c @@ -42,10 +42,17 @@ odp_actions_add(struct odp_actions *actions, uint16_t type) void format_odp_flow_key(struct ds *ds, const struct odp_flow_key *key) { - ds_put_format(ds, "in_port%04x:vlan%d:pcp%d mac"ETH_ADDR_FMT - "->"ETH_ADDR_FMT" type%04x proto%"PRId8" tos%"PRIu8 - " ip"IP_FMT"->"IP_FMT" port%d->%d", - key->in_port, ntohs(key->dl_vlan), key->dl_vlan_pcp, + ds_put_format(ds, "tun_id0x%08x in_port%d tci(", + key->tun_id, key->in_port); + if (key->dl_tci) { + ds_put_format(ds, "vlan%"PRIu16",pcp%d", + vlan_tci_to_vid(key->dl_tci), + vlan_tci_to_pcp(key->dl_tci)); + } else { + ds_put_char(ds, '0'); + } + ds_put_format(ds, ") mac"ETH_ADDR_FMT"->"ETH_ADDR_FMT" type%04x " + "proto%"PRId8" tos%"PRIu8" ip"IP_FMT"->"IP_FMT" port%d->%d", ETH_ADDR_ARGS(key->dl_src), ETH_ADDR_ARGS(key->dl_dst), ntohs(key->dl_type), key->nw_proto, key->nw_tos, IP_ARGS(&key->nw_src), IP_ARGS(&key->nw_dst), @@ -65,11 +72,10 @@ format_odp_action(struct ds *ds, const union odp_action *a) case ODPAT_SET_TUNNEL: ds_put_format(ds, "set_tunnel(0x%08"PRIx32")", ntohl(a->tunnel.tun_id)); break; - case ODPAT_SET_VLAN_VID: - ds_put_format(ds, "set_vlan(%"PRIu16")", ntohs(a->vlan_vid.vlan_vid)); - break; - case ODPAT_SET_VLAN_PCP: - ds_put_format(ds, "set_vlan_pcp(%"PRIu8")", a->vlan_pcp.vlan_pcp); + case ODPAT_SET_DL_TCI: + ds_put_format(ds, "set_tci(vid=%"PRIu16",pcp=%d)", + vlan_tci_to_vid(a->dl_tci.tci), + vlan_tci_to_pcp(a->dl_tci.tci)); break; case ODPAT_STRIP_VLAN: ds_put_format(ds, "strip_vlan"); @@ -161,32 +167,43 @@ odp_flow_key_from_flow(struct odp_flow_key *key, const struct flow *flow) key->nw_src = flow->nw_src; key->nw_dst = flow->nw_dst; key->in_port = flow->in_port; - key->dl_vlan = flow->dl_vlan; + if (flow->dl_vlan == htons(OFP_VLAN_NONE)) { + key->dl_tci = htons(0); + } else { + uint16_t vid = flow->dl_vlan & htons(VLAN_VID_MASK); + uint16_t pcp = htons((flow->dl_vlan_pcp << VLAN_PCP_SHIFT) + & VLAN_PCP_MASK); + key->dl_tci = vid | pcp | htons(ODP_TCI_PRESENT); + } key->dl_type = flow->dl_type; key->tp_src = flow->tp_src; key->tp_dst = flow->tp_dst; memcpy(key->dl_src, flow->dl_src, ETH_ADDR_LEN); memcpy(key->dl_dst, flow->dl_dst, ETH_ADDR_LEN); key->nw_proto = flow->nw_proto; - key->dl_vlan_pcp = flow->dl_vlan_pcp; key->nw_tos = flow->nw_tos; - memset(key->reserved, 0, sizeof key->reserved); } void odp_flow_key_to_flow(const struct odp_flow_key *key, struct flow *flow) { + memset(flow->regs, 0, sizeof flow->regs); flow->tun_id = key->tun_id; flow->nw_src = key->nw_src; flow->nw_dst = key->nw_dst; flow->in_port = key->in_port; - flow->dl_vlan = key->dl_vlan; + if (key->dl_tci) { + flow->dl_vlan = htons(vlan_tci_to_vid(key->dl_tci)); + flow->dl_vlan_pcp = vlan_tci_to_pcp(key->dl_tci); + } else { + flow->dl_vlan = htons(OFP_VLAN_NONE); + flow->dl_vlan_pcp = 0; + } flow->dl_type = key->dl_type; flow->tp_src = key->tp_src; flow->tp_dst = key->tp_dst; memcpy(flow->dl_src, key->dl_src, ETH_ADDR_LEN); memcpy(flow->dl_dst, key->dl_dst, ETH_ADDR_LEN); flow->nw_proto = key->nw_proto; - flow->dl_vlan_pcp = key->dl_vlan_pcp; flow->nw_tos = key->nw_tos; }