X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ofproto%2Fconnmgr.h;h=7f69d4f5ad3706bfffec42b70748967f37e97607;hb=HEAD;hp=505a757ee186ed69f288ed80904fc1d5e667d146;hpb=093f56c5c5c8b0891e837beb1defd84bc165ac6a;p=sliver-openvswitch.git diff --git a/ofproto/connmgr.h b/ofproto/connmgr.h index 505a757ee..7f69d4f5a 100644 --- a/ofproto/connmgr.h +++ b/ofproto/connmgr.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2010, 2011, 2012, 2013 Nicira, Inc. + * Copyright (c) 2009, 2010, 2011, 2012, 2013, 2014 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -22,6 +22,7 @@ #include "list.h" #include "match.h" #include "ofp-errors.h" +#include "ofp-util.h" #include "ofproto.h" #include "openflow/nicira-ext.h" #include "openvswitch/types.h" @@ -29,9 +30,6 @@ struct nlattr; struct ofconn; struct ofopgroup; -struct ofputil_flow_removed; -struct ofputil_packet_in; -struct ofputil_phy_port; struct rule; struct simap; struct sset; @@ -64,6 +62,34 @@ enum ofconn_async_msg_type { OAM_N_TYPES }; +enum ofproto_packet_in_miss_type { + /* Not generated by a flow miss or table-miss flow. */ + OFPROTO_PACKET_IN_NO_MISS, + + /* The packet_in was generated directly by a table-miss flow, that is, a + * flow with priority 0 that wildcards all fields. See OF1.3.3 section + * 5.4. + * + * (Our interpretation of "directly" is "not via groups". Packet_ins + * generated by table-miss flows via groups use + * OFPROTO_PACKET_IN_NO_MISS.) */ + OFPROTO_PACKET_IN_MISS_FLOW, + + /* The packet-in was generated directly by a table-miss, but not a + * table-miss flow. That is, it was generated by the OpenFlow 1.0, 1.1, or + * 1.2 table-miss behavior. */ + OFPROTO_PACKET_IN_MISS_WITHOUT_FLOW, +}; + +/* A packet_in, with extra members to assist in queuing and routing it. */ +struct ofproto_packet_in { + struct ofputil_packet_in up; + struct list list_node; /* For queuing. */ + uint16_t controller_id; /* Controller ID to send to. */ + int send_len; /* Length that the action requested sending. */ + enum ofproto_packet_in_miss_type miss_type; +}; + /* Basics. */ struct connmgr *connmgr_create(struct ofproto *ofproto, const char *dpif_name, const char *local_name); @@ -135,13 +161,18 @@ void ofconn_add_opgroup(struct ofconn *, struct list *); void ofconn_remove_opgroup(struct ofconn *, struct list *, const struct ofp_header *request, int error); +struct hmap *ofconn_get_bundles(struct ofconn *ofconn); + /* Sending asynchronous messages. */ -void connmgr_send_port_status(struct connmgr *, +bool connmgr_wants_packet_in_on_miss(struct connmgr *mgr); +void connmgr_send_port_status(struct connmgr *, struct ofconn *source, const struct ofputil_phy_port *, uint8_t reason); void connmgr_send_flow_removed(struct connmgr *, const struct ofputil_flow_removed *); void connmgr_send_packet_in(struct connmgr *, - const struct ofputil_packet_in *); + const struct ofproto_packet_in *); +void ofconn_send_role_status(struct ofconn *ofconn, uint32_t role, + uint8_t reason); /* Fail-open settings. */ enum ofproto_fail_mode connmgr_get_fail_mode(const struct connmgr *);