blob: c89edfd64d45e7fc06693e9a3c23f6b072ec611d [file] [log] [blame]
Rich Lane2e672012015-01-02 15:39:22 -08001// Copyright 2015, Big Switch Networks, Inc.
2//
3// LoxiGen is licensed under the Eclipse Public License,
4// version 1.0 (EPL), with the following special exception:
5//
6// LOXI Exception
7//
8// 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.
16//
17// Notice: "Copyright 2013, Big Switch Networks, Inc.
18// This library was generated by the LoxiGen Compiler."
19//
20// 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:
22//
23// http://www.eclipse.org/legal/epl-v10.html
24//
25// 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.
30
31// IVS supports running sandboxed Lua code as the forwarding pipeline.
Rich Lane45597072015-01-09 15:38:25 -080032// This extension allows the controller to upload the Lua code, send
33// commands to it, and receive async notifications.
34//
35// Most of the data passed between the controller and the Lua code is
36// opaque to the rest of the switch. It's assumed that the controller
37// is tightly coupled to the Lua code it uploaded, so there's no need
38// to version the protocol between them.
Rich Lane2e672012015-01-02 15:39:22 -080039
40#version 4
41#version 5
Murat Parlakisikf95672c2016-12-05 00:53:17 -080042#version 6
Rich Lane2e672012015-01-02 15:39:22 -080043
44// Upload chunks of Lua code to the switch
45//
46// If the MORE flag is not set, the old VM will be cleaned up and
47// a new VM will be initialized with the uploaded code. Each chunk
48// of code is executed in the VM in the order it was received.
49//
50// If the FORCE flag is not set, the switch will check to see if the
51// old and new code is identical. If they are identical the message
52// will be ignored.
53//
54// As part of the VM cleanup, all gentables registered by Lua code
55// will be unregistered.
56//
57// Consecutive messages with the same filename are concatenated,
58// to support chunks larger than 64K.
59
60enum ofp_bsn_lua_upload_flags(wire_type=uint16_t, bitmask=True) {
61 OFP_BSN_LUA_UPLOAD_MORE = 0x1,
62 OFP_BSN_LUA_UPLOAD_FORCE = 0x2,
63};
64
65struct of_bsn_lua_upload : of_bsn_header {
66 uint8_t version;
67 uint8_t type == 4;
68 uint16_t length;
69 uint32_t xid;
70 uint32_t experimenter == 0x5c16c7;
71 uint32_t subtype == 64;
72 enum ofp_bsn_lua_upload_flags flags;
73 of_str64_t filename;
74 of_octets_t data;
75};
Rich Lane45597072015-01-09 15:38:25 -080076
77// Send a command to Lua
78
79struct of_bsn_lua_command_request : of_bsn_header {
80 uint8_t version;
81 uint8_t type == 4;
82 uint16_t length;
83 uint32_t xid;
84 uint32_t experimenter == 0x5c16c7;
85 uint32_t subtype == 65;
86 of_octets_t data;
87};
88
89struct of_bsn_lua_command_reply : of_bsn_header {
90 uint8_t version;
91 uint8_t type == 4;
92 uint16_t length;
93 uint32_t xid;
94 uint32_t experimenter == 0x5c16c7;
95 uint32_t subtype == 66;
96 of_octets_t data;
97};
98
99// Async message from Lua to the controller
100
101struct of_bsn_lua_notification : of_bsn_header {
102 uint8_t version;
103 uint8_t type == 4;
104 uint16_t length;
105 uint32_t xid;
106 uint32_t experimenter == 0x5c16c7;
107 uint32_t subtype == 67;
108 of_octets_t data;
109};