blob: 4eeda8c247e25cd809091addbbaa06fdb0727ba0 [file] [log] [blame]
Dan Talaycoc0e802e2013-05-18 23:52:39 -07001// Copyright 2013, Big Switch Networks, Inc.
2//
Dan Talaycof76f7112013-05-19 23:32:12 -07003// LoxiGen is licensed under the Eclipse Public License,
Dan Talaycoba506722013-05-21 14:33:33 -07004// version 1.0 (EPL), with the following special exception:
Dan Talaycoc0e802e2013-05-18 23:52:39 -07005//
6// LOXI Exception
7//
Dan Talaycof76f7112013-05-19 23:32:12 -07008// As a special exception to the terms of the EPL, you may
9// distribute libraries generated by LoxiGen (LoxiGen Libraries)
10// under the terms of your choice, provided that copyright and
11// licensing notices generated by LoxiGen are not altered or removed
12// from the LoxiGen Libraries and the notice provided below is (i)
13// included in the LoxiGen Libraries, if distributed in source code
14// form and (ii) included in any documentation for the LoxiGen
15// Libraries, if distributed in binary form.
Dan Talaycoc0e802e2013-05-18 23:52:39 -070016//
Dan Talaycof76f7112013-05-19 23:32:12 -070017// Notice: "Copyright 2013, Big Switch Networks, Inc.
18// This library was generated by the LoxiGen Compiler."
Dan Talaycoc0e802e2013-05-18 23:52:39 -070019//
Dan Talaycof76f7112013-05-19 23:32:12 -070020// You may not use this file except in compliance with the EPL or
21// LOXI Exception. You may obtain a copy of the EPL at:
Dan Talaycoc0e802e2013-05-18 23:52:39 -070022//
23// http://www.eclipse.org/legal/epl-v10.html
24//
Dan Talaycof76f7112013-05-19 23:32:12 -070025// Unless required by applicable law or agreed to in writing,
26// software distributed under the License is distributed on an "AS
27// IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
28// express or implied. See the EPL for the specific language
29// governing permissions and limitations under the EPL.
Dan Talaycoc0e802e2013-05-18 23:52:39 -070030
31#version any
32
Kiran Poola8ecd3f12013-07-09 17:58:12 -070033enum ofp_bsn_vport_status {
Kiran Poola747339a2013-07-09 17:45:22 -070034 OF_BSN_VPORT_STATUS_OK = 0,
35 OF_BSN_VPORT_STATUS_FAILED = 1,
36};
37
Dan Talayco78654ff2013-05-24 11:41:55 -070038// When the ingress or egress VID has this value, no outer tag should be used.
39// In this case, the corresponding TPID is ignored.
40
Andreas Wundsam4ee51462013-07-30 11:00:37 -070041enum ofp_bsn_vport_q_in_q_untagged(wire_type=uint16_t, complete=False) {
Dan Talayco78654ff2013-05-24 11:41:55 -070042 OF_BSN_VPORT_Q_IN_Q_UNTAGGED = 0xffff,
43};
44
Dan Talaycoc0e802e2013-05-18 23:52:39 -070045// BSN Virtual port object header
46// FIXME For now, inheritance is not exercised. See below.
Rich Laned0714672013-05-29 14:22:35 -070047struct of_bsn_vport {
Andreas Wundsam70411bf2013-08-02 22:26:38 -070048 uint16_t type == ?; /* Discriminate virtual port type */
Dan Talaycoc0e802e2013-05-18 23:52:39 -070049 uint16_t length; /* Length in bytes of this structure with this header */
50 /* Remainder of data is specific to the port type */
51};
52
53
Dan Talaycoc0e802e2013-05-18 23:52:39 -070054// Q-in-Q virtual port specification
55
Rich Lanee9c37db2013-06-21 18:30:24 -070056struct of_bsn_vport_q_in_q : of_bsn_vport {
Rich Laned0714672013-05-29 14:22:35 -070057 uint16_t type == 0;
Kiran Poolaa9167ff2013-09-19 16:34:54 -070058 uint16_t length; /* 32 */
Dan Talaycoc0e802e2013-05-18 23:52:39 -070059 uint32_t port_no; /* OF port number of parent; usually phys port */
60 uint16_t ingress_tpid;
61 uint16_t ingress_vlan_id;
62 uint16_t egress_tpid;
63 uint16_t egress_vlan_id;
Kiran Poola4d83d652013-09-20 13:28:31 -070064 of_port_name_t if_name; /* Name to use in create operation */
Dan Talaycoc0e802e2013-05-18 23:52:39 -070065};
66
67// Request from controller to switch to create vport
Rich Lanee9c37db2013-06-21 18:30:24 -070068struct of_bsn_virtual_port_create_request : of_bsn_header {
Dan Talaycoc0e802e2013-05-18 23:52:39 -070069 uint8_t version;
Rich Laned0714672013-05-29 14:22:35 -070070 uint8_t type == 4;
Dan Talaycoc0e802e2013-05-18 23:52:39 -070071 uint16_t length;
72 uint32_t xid;
Rich Laned0714672013-05-29 14:22:35 -070073 uint32_t experimenter == 0x5c16c7;
74 uint32_t subtype == 15;
Dan Talaycoc0e802e2013-05-18 23:52:39 -070075 // FIXME This should be an instance of the inheritance superclass
76 of_bsn_vport_q_in_q_t vport; // Description of vport to create
77 // Additional data follows depending on header type
78};
79
80// Reply from switch to controller indicating port number created
81// vport_no must be 16 bits to be compatible with 1.0
Rich Lanee9c37db2013-06-21 18:30:24 -070082struct of_bsn_virtual_port_create_reply : of_bsn_header {
Dan Talaycoc0e802e2013-05-18 23:52:39 -070083 uint8_t version;
Rich Laned0714672013-05-29 14:22:35 -070084 uint8_t type == 4;
Dan Talaycoc0e802e2013-05-18 23:52:39 -070085 uint16_t length;
86 uint32_t xid; // Must match create_request
Rich Laned0714672013-05-29 14:22:35 -070087 uint32_t experimenter == 0x5c16c7;
88 uint32_t subtype == 16;
Dan Talaycob392f6b2013-06-12 10:48:17 -070089 uint32_t status; // 0 means success
Dan Talaycoc0e802e2013-05-18 23:52:39 -070090 uint32_t vport_no; // The OF port number created. 16-bits for OF 1.0
91};
92
93// Request from controller to switch to remove a vport
Rich Lanee9c37db2013-06-21 18:30:24 -070094struct of_bsn_virtual_port_remove_request : of_bsn_header {
Dan Talaycoc0e802e2013-05-18 23:52:39 -070095 uint8_t version;
Rich Laned0714672013-05-29 14:22:35 -070096 uint8_t type == 4;
Dan Talaycoc0e802e2013-05-18 23:52:39 -070097 uint16_t length;
98 uint32_t xid;
Rich Laned0714672013-05-29 14:22:35 -070099 uint32_t experimenter == 0x5c16c7;
100 uint32_t subtype == 17;
Dan Talaycoc0e802e2013-05-18 23:52:39 -0700101 uint32_t vport_no; // The OF port number to be removed
102};
Dan Talaycob392f6b2013-06-12 10:48:17 -0700103
104// Request from controller to switch to remove a vport
Rich Lanee9c37db2013-06-21 18:30:24 -0700105struct of_bsn_virtual_port_remove_reply : of_bsn_header {
Dan Talaycob392f6b2013-06-12 10:48:17 -0700106 uint8_t version;
107 uint8_t type == 4;
108 uint16_t length;
109 uint32_t xid; // Must match request xid
110 uint32_t experimenter == 0x5c16c7;
111 uint32_t subtype == 26;
112 uint32_t status; // 0 means success
113};