blob: 47249f62575a9d53665785e8898d686b080d75f9 [file] [log] [blame]
khenaidoob9203542018-09-17 22:56:37 -04001/*
2 * Copyright 2018-present Open Networking Foundation
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 */
16package core
17
18import (
19 "context"
20 "errors"
21 "github.com/opencord/voltha-go/common/log"
22 "github.com/opencord/voltha-go/db/model"
23 "github.com/opencord/voltha-go/kafka"
khenaidoo19d7b632018-10-30 10:49:50 -040024 "github.com/opencord/voltha-go/protos/openflow_13"
khenaidoob9203542018-09-17 22:56:37 -040025 "github.com/opencord/voltha-go/protos/voltha"
26 "google.golang.org/grpc/codes"
27 "google.golang.org/grpc/status"
khenaidoob9203542018-09-17 22:56:37 -040028 "strings"
29 "sync"
30)
31
32type LogicalDeviceManager struct {
33 logicalDeviceAgents map[string]*LogicalDeviceAgent
Richard Jankowski199fd862019-03-18 14:49:51 -040034 core *Core
khenaidoob9203542018-09-17 22:56:37 -040035 deviceMgr *DeviceManager
Richard Jankowskidbab94a2018-12-06 16:20:25 -050036 grpcNbiHdlr *APIHandler
khenaidoob9203542018-09-17 22:56:37 -040037 adapterProxy *AdapterProxy
khenaidoo43c82122018-11-22 18:38:28 -050038 kafkaICProxy *kafka.InterContainerProxy
khenaidoo9a468962018-09-19 15:33:13 -040039 clusterDataProxy *model.Proxy
khenaidoob9203542018-09-17 22:56:37 -040040 exitChannel chan int
41 lockLogicalDeviceAgentsMap sync.RWMutex
42}
43
Richard Jankowski199fd862019-03-18 14:49:51 -040044func newLogicalDeviceManager(core *Core, deviceMgr *DeviceManager, kafkaICProxy *kafka.InterContainerProxy, cdProxy *model.Proxy) *LogicalDeviceManager {
khenaidoob9203542018-09-17 22:56:37 -040045 var logicalDeviceMgr LogicalDeviceManager
Richard Jankowski199fd862019-03-18 14:49:51 -040046 logicalDeviceMgr.core = core
khenaidoob9203542018-09-17 22:56:37 -040047 logicalDeviceMgr.exitChannel = make(chan int, 1)
48 logicalDeviceMgr.logicalDeviceAgents = make(map[string]*LogicalDeviceAgent)
49 logicalDeviceMgr.deviceMgr = deviceMgr
khenaidoo43c82122018-11-22 18:38:28 -050050 logicalDeviceMgr.kafkaICProxy = kafkaICProxy
khenaidoo9a468962018-09-19 15:33:13 -040051 logicalDeviceMgr.clusterDataProxy = cdProxy
khenaidoob9203542018-09-17 22:56:37 -040052 logicalDeviceMgr.lockLogicalDeviceAgentsMap = sync.RWMutex{}
53 return &logicalDeviceMgr
54}
55
Richard Jankowskidbab94a2018-12-06 16:20:25 -050056func (ldMgr *LogicalDeviceManager) setGrpcNbiHandler(grpcNbiHandler *APIHandler) {
57 ldMgr.grpcNbiHdlr = grpcNbiHandler
58}
59
khenaidoo4d4802d2018-10-04 21:59:49 -040060func (ldMgr *LogicalDeviceManager) start(ctx context.Context) {
khenaidoob9203542018-09-17 22:56:37 -040061 log.Info("starting-logical-device-manager")
62 log.Info("logical-device-manager-started")
63}
64
khenaidoo4d4802d2018-10-04 21:59:49 -040065func (ldMgr *LogicalDeviceManager) stop(ctx context.Context) {
khenaidoob9203542018-09-17 22:56:37 -040066 log.Info("stopping-logical-device-manager")
67 ldMgr.exitChannel <- 1
68 log.Info("logical-device-manager-stopped")
69}
70
khenaidoo19d7b632018-10-30 10:49:50 -040071func sendAPIResponse(ctx context.Context, ch chan interface{}, result interface{}) {
72 if ctx.Err() == nil {
73 // Returned response only of the ctx has not been cancelled/timeout/etc
74 // Channel is automatically closed when a context is Done
75 ch <- result
76 log.Debugw("sendResponse", log.Fields{"result": result})
77 } else {
78 // Should the transaction be reverted back?
79 log.Debugw("sendResponse-context-error", log.Fields{"context-error": ctx.Err()})
80 }
81}
82
khenaidoob9203542018-09-17 22:56:37 -040083func (ldMgr *LogicalDeviceManager) addLogicalDeviceAgentToMap(agent *LogicalDeviceAgent) {
84 ldMgr.lockLogicalDeviceAgentsMap.Lock()
85 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
86 if _, exist := ldMgr.logicalDeviceAgents[agent.logicalDeviceId]; !exist {
87 ldMgr.logicalDeviceAgents[agent.logicalDeviceId] = agent
88 }
89}
90
khenaidoo8c3303d2019-02-13 14:59:39 -050091// getLogicalDeviceAgent returns the logical device agent. If the device is not in memory then the device will
92// be loaded from dB and a logical device agent created to managed it.
khenaidoob9203542018-09-17 22:56:37 -040093func (ldMgr *LogicalDeviceManager) getLogicalDeviceAgent(logicalDeviceId string) *LogicalDeviceAgent {
94 ldMgr.lockLogicalDeviceAgentsMap.Lock()
khenaidoob9203542018-09-17 22:56:37 -040095 if agent, ok := ldMgr.logicalDeviceAgents[logicalDeviceId]; ok {
khenaidoo8c3303d2019-02-13 14:59:39 -050096 ldMgr.lockLogicalDeviceAgentsMap.Unlock()
khenaidoob9203542018-09-17 22:56:37 -040097 return agent
khenaidoo8c3303d2019-02-13 14:59:39 -050098 } else {
99 // Try to load into memory - loading will also create the logical device agent
100 ldMgr.lockLogicalDeviceAgentsMap.Unlock()
101 if err := ldMgr.load(logicalDeviceId); err == nil {
102 ldMgr.lockLogicalDeviceAgentsMap.Lock()
103 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
104 if agent, ok = ldMgr.logicalDeviceAgents[logicalDeviceId]; ok {
105 return agent
106 }
107 }
khenaidoob9203542018-09-17 22:56:37 -0400108 }
109 return nil
110}
111
khenaidoo92e62c52018-10-03 14:02:54 -0400112func (ldMgr *LogicalDeviceManager) deleteLogicalDeviceAgent(logicalDeviceId string) {
113 ldMgr.lockLogicalDeviceAgentsMap.Lock()
114 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
115 delete(ldMgr.logicalDeviceAgents, logicalDeviceId)
116}
117
khenaidoo8c3303d2019-02-13 14:59:39 -0500118// GetLogicalDevice provides a cloned most up to date logical device. If device is not in memory
119// it will be fetched from the dB
khenaidoob9203542018-09-17 22:56:37 -0400120func (ldMgr *LogicalDeviceManager) getLogicalDevice(id string) (*voltha.LogicalDevice, error) {
khenaidoo92e62c52018-10-03 14:02:54 -0400121 log.Debugw("getlogicalDevice", log.Fields{"logicaldeviceid": id})
122 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
khenaidoo19d7b632018-10-30 10:49:50 -0400123 return agent.GetLogicalDevice()
khenaidoob9203542018-09-17 22:56:37 -0400124 }
125 return nil, status.Errorf(codes.NotFound, "%s", id)
126}
127
128func (ldMgr *LogicalDeviceManager) listLogicalDevices() (*voltha.LogicalDevices, error) {
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500129 log.Debug("ListAllLogicalDevices")
khenaidoob9203542018-09-17 22:56:37 -0400130 result := &voltha.LogicalDevices{}
khenaidoo297cd252019-02-07 22:10:23 -0500131 if logicalDevices := ldMgr.clusterDataProxy.List("/logical_devices", 0, false, ""); logicalDevices != nil {
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500132 for _, logicalDevice := range logicalDevices.([]interface{}) {
133 if agent := ldMgr.getLogicalDeviceAgent(logicalDevice.(*voltha.LogicalDevice).Id); agent == nil {
134 agent = newLogicalDeviceAgent(
135 logicalDevice.(*voltha.LogicalDevice).Id,
136 logicalDevice.(*voltha.LogicalDevice).RootDeviceId,
137 ldMgr,
138 ldMgr.deviceMgr,
139 ldMgr.clusterDataProxy,
140 )
141 ldMgr.addLogicalDeviceAgentToMap(agent)
khenaidoo297cd252019-02-07 22:10:23 -0500142 go agent.start(nil, true)
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500143 }
144 result.Items = append(result.Items, logicalDevice.(*voltha.LogicalDevice))
khenaidoob9203542018-09-17 22:56:37 -0400145 }
146 }
147 return result, nil
148}
149
khenaidoo8c3303d2019-02-13 14:59:39 -0500150// List only logical devices that are in memory
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500151//func (ldMgr *LogicalDeviceManager) listLogicalDevices() (*voltha.LogicalDevices, error) {
152// log.Debug("listLogicalDevices")
153// result := &voltha.LogicalDevices{}
154// ldMgr.lockLogicalDeviceAgentsMap.Lock()
155// defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
156// for _, agent := range ldMgr.logicalDeviceAgents {
157// if lDevice, err := agent.GetLogicalDevice(); err == nil {
158// result.Items = append(result.Items, lDevice)
159// }
160// }
161// return result, nil
162//}
163
khenaidoo4d4802d2018-10-04 21:59:49 -0400164func (ldMgr *LogicalDeviceManager) createLogicalDevice(ctx context.Context, device *voltha.Device) (*string, error) {
khenaidoo92e62c52018-10-03 14:02:54 -0400165 log.Debugw("creating-logical-device", log.Fields{"deviceId": device.Id})
khenaidoob9203542018-09-17 22:56:37 -0400166 // Sanity check
167 if !device.Root {
168 return nil, errors.New("Device-not-root")
169 }
170
171 // Create a logical device agent - the logical device Id is based on the mac address of the device
172 // For now use the serial number - it may contain any combination of alphabetic characters and numbers,
173 // with length varying from eight characters to a maximum of 14 characters. Mac Address is part of oneof
174 // in the Device model. May need to be moved out.
175 macAddress := device.MacAddress
176 id := strings.Replace(macAddress, ":", "", -1)
khenaidoo92e62c52018-10-03 14:02:54 -0400177 if id == "" {
178 log.Errorw("mac-address-not-set", log.Fields{"deviceId": device.Id})
179 return nil, errors.New("mac-address-not-set")
180 }
181 log.Debugw("logical-device-id", log.Fields{"logicaldeviceId": id})
khenaidoob9203542018-09-17 22:56:37 -0400182
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500183 agent := newLogicalDeviceAgent(id, device.Id, ldMgr, ldMgr.deviceMgr, ldMgr.clusterDataProxy)
khenaidoob9203542018-09-17 22:56:37 -0400184 ldMgr.addLogicalDeviceAgentToMap(agent)
khenaidoo297cd252019-02-07 22:10:23 -0500185 go agent.start(ctx, false)
khenaidoob9203542018-09-17 22:56:37 -0400186
Richard Jankowski199fd862019-03-18 14:49:51 -0400187 // Set device ownership
188 ldMgr.core.deviceOwnership.OwnedByMe(id)
189
khenaidoo92e62c52018-10-03 14:02:54 -0400190 log.Debug("creating-logical-device-ends")
khenaidoob9203542018-09-17 22:56:37 -0400191 return &id, nil
192}
193
khenaidoo297cd252019-02-07 22:10:23 -0500194// load loads a logical device manager in memory
195func (ldMgr *LogicalDeviceManager) load(lDeviceId string) error {
khenaidoofc1314d2019-03-14 09:34:21 -0400196 //log.Debugw("loading-logical-device", log.Fields{"lDeviceId": lDeviceId})
197 log.Errorw("loading-logical-device", log.Fields{"lDeviceId": lDeviceId})
khenaidoo297cd252019-02-07 22:10:23 -0500198 // To prevent a race condition, let's hold the logical device agent map lock. This will prevent a loading and
199 // a create logical device callback from occurring at the same time.
200 ldMgr.lockLogicalDeviceAgentsMap.Lock()
201 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
202 if ldAgent, _ := ldMgr.logicalDeviceAgents[lDeviceId]; ldAgent == nil {
203 // Logical device not in memory - create a temp logical device Agent and let it load from memory
204 agent := newLogicalDeviceAgent(lDeviceId, "", ldMgr, ldMgr.deviceMgr, ldMgr.clusterDataProxy)
205 if err := agent.start(nil, true); err != nil {
khenaidoo8c3303d2019-02-13 14:59:39 -0500206 //agent.stop(nil)
khenaidoo297cd252019-02-07 22:10:23 -0500207 return err
208 }
209 ldMgr.logicalDeviceAgents[agent.logicalDeviceId] = agent
210 }
211 // TODO: load the child device
212 return nil
213}
214
khenaidoo4d4802d2018-10-04 21:59:49 -0400215func (ldMgr *LogicalDeviceManager) deleteLogicalDevice(ctx context.Context, device *voltha.Device) error {
khenaidoo92e62c52018-10-03 14:02:54 -0400216 log.Debugw("deleting-logical-device", log.Fields{"deviceId": device.Id})
217 // Sanity check
218 if !device.Root {
219 return errors.New("Device-not-root")
220 }
221 logDeviceId := device.ParentId
222 if agent := ldMgr.getLogicalDeviceAgent(logDeviceId); agent != nil {
223 // Stop the logical device agent
khenaidoo4d4802d2018-10-04 21:59:49 -0400224 agent.stop(ctx)
khenaidoo92e62c52018-10-03 14:02:54 -0400225 //Remove the logical device agent from the Map
226 ldMgr.deleteLogicalDeviceAgent(logDeviceId)
Richard Jankowski199fd862019-03-18 14:49:51 -0400227 ldMgr.core.deviceOwnership.AbandonDevice(logDeviceId)
khenaidoo92e62c52018-10-03 14:02:54 -0400228 }
229
230 log.Debug("deleting-logical-device-ends")
231 return nil
232}
233
234func (ldMgr *LogicalDeviceManager) getLogicalDeviceId(device *voltha.Device) (*string, error) {
235 // Device can either be a parent or a child device
236 if device.Root {
237 // Parent device. The ID of a parent device is the logical device ID
238 return &device.ParentId, nil
239 }
240 // Device is child device
241 // retrieve parent device using child device ID
242 if parentDevice := ldMgr.deviceMgr.getParentDevice(device); parentDevice != nil {
243 return &parentDevice.ParentId, nil
244 }
245 return nil, status.Errorf(codes.NotFound, "%s", device.Id)
246}
247
khenaidoo19d7b632018-10-30 10:49:50 -0400248func (ldMgr *LogicalDeviceManager) getLogicalPortId(device *voltha.Device) (*voltha.LogicalPortId, error) {
249 // Get the logical device where this device is attached
250 var lDeviceId *string
251 var err error
252 if lDeviceId, err = ldMgr.getLogicalDeviceId(device); err != nil {
253 return nil, err
254 }
255 var lDevice *voltha.LogicalDevice
256 if lDevice, err = ldMgr.getLogicalDevice(*lDeviceId); err != nil {
257 return nil, err
258 }
259 // Go over list of ports
260 for _, port := range lDevice.Ports {
261 if port.DeviceId == device.Id {
262 return &voltha.LogicalPortId{Id: *lDeviceId, PortId: port.Id}, nil
263 }
264 }
265 return nil, status.Errorf(codes.NotFound, "%s", device.Id)
266}
267
268func (ldMgr *LogicalDeviceManager) ListLogicalDevicePorts(ctx context.Context, id string) (*voltha.LogicalPorts, error) {
269 log.Debugw("ListLogicalDevicePorts", log.Fields{"logicaldeviceid": id})
270 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
271 return agent.ListLogicalDevicePorts()
272 }
273 return nil, status.Errorf(codes.NotFound, "%s", id)
274
275}
276
277func (ldMgr *LogicalDeviceManager) getLogicalPort(lPortId *voltha.LogicalPortId) (*voltha.LogicalPort, error) {
278 // Get the logical device where this device is attached
279 var err error
280 var lDevice *voltha.LogicalDevice
281 if lDevice, err = ldMgr.getLogicalDevice(lPortId.Id); err != nil {
282 return nil, err
283 }
284 // Go over list of ports
285 for _, port := range lDevice.Ports {
286 if port.Id == lPortId.PortId {
287 return port, nil
288 }
289 }
290 return nil, status.Errorf(codes.NotFound, "%s-$s", lPortId.Id, lPortId.PortId)
291}
292
khenaidoofc1314d2019-03-14 09:34:21 -0400293// addLogicalPort sets up a logical port on the logical device based on the device port
294// information.
295func (ldMgr *LogicalDeviceManager) addLogicalPort(device *voltha.Device, port *voltha.Port) error {
296 if ldID, err := ldMgr.getLogicalDeviceId(device); err != nil {
297 // This is not an error as the logical device may not have been created at this time. In such a case,
298 // the ports will be created when the logical device is ready.
299 return nil
300 } else {
301 if agent := ldMgr.getLogicalDeviceAgent(*ldID); agent != nil {
302 if err := agent.addLogicalPort(device, port); err != nil {
303 return err
304 }
305 }
306 }
307 return nil
308}
309
khenaidoo19d7b632018-10-30 10:49:50 -0400310// deleteLogicalPort removes the logical port associated with a child device
311func (ldMgr *LogicalDeviceManager) deleteLogicalPort(ctx context.Context, lPortId *voltha.LogicalPortId) error {
312 log.Debugw("deleting-logical-port", log.Fields{"LDeviceId": lPortId.Id})
313 // Get logical port
314 var logicalPort *voltha.LogicalPort
315 var err error
316 if logicalPort, err = ldMgr.getLogicalPort(lPortId); err != nil {
317 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": lPortId.PortId})
318 return err
319 }
khenaidoo92e62c52018-10-03 14:02:54 -0400320 // Sanity check
khenaidoo19d7b632018-10-30 10:49:50 -0400321 if logicalPort.RootPort {
khenaidoo92e62c52018-10-03 14:02:54 -0400322 return errors.New("Device-root")
323 }
khenaidoo19d7b632018-10-30 10:49:50 -0400324 if agent := ldMgr.getLogicalDeviceAgent(lPortId.Id); agent != nil {
325 agent.deleteLogicalPort(logicalPort)
khenaidoo92e62c52018-10-03 14:02:54 -0400326 }
327
328 log.Debug("deleting-logical-port-ends")
329 return nil
330}
331
khenaidoofc1314d2019-03-14 09:34:21 -0400332func (ldMgr *LogicalDeviceManager) setupUNILogicalPorts(ctx context.Context, childDevice *voltha.Device) error {
333 log.Debugw("setupUNILogicalPorts", log.Fields{"childDeviceId": childDevice.Id, "parentDeviceId": childDevice.ParentId})
khenaidoob9203542018-09-17 22:56:37 -0400334 // Sanity check
335 if childDevice.Root {
336 return errors.New("Device-root")
337 }
338
339 // Get the logical device id parent device
340 parentId := childDevice.ParentId
341 logDeviceId := ldMgr.deviceMgr.GetParentDeviceId(parentId)
342
khenaidoofc1314d2019-03-14 09:34:21 -0400343 log.Debugw("setupUNILogicalPorts", log.Fields{"logDeviceId": logDeviceId, "parentId": parentId})
khenaidoob9203542018-09-17 22:56:37 -0400344
khenaidoo5e677ae2019-02-28 17:26:29 -0500345 if parentId == "" || logDeviceId == nil {
346 return errors.New("Device-in-invalid-state")
347 }
348
khenaidoob9203542018-09-17 22:56:37 -0400349 if agent := ldMgr.getLogicalDeviceAgent(*logDeviceId); agent != nil {
khenaidoofc1314d2019-03-14 09:34:21 -0400350 if err := agent.setupUNILogicalPorts(ctx, childDevice); err != nil {
khenaidoobcf205b2019-01-25 22:21:14 -0500351 return err
352 }
353 // Update the device routes - let it run in its own go routine as it can take time
354 go agent.updateRoutes()
khenaidoob9203542018-09-17 22:56:37 -0400355 }
khenaidoo21d51152019-02-01 13:48:37 -0500356 return nil
khenaidoob9203542018-09-17 22:56:37 -0400357}
khenaidoo19d7b632018-10-30 10:49:50 -0400358
359func (ldMgr *LogicalDeviceManager) updateFlowTable(ctx context.Context, id string, flow *openflow_13.OfpFlowMod, ch chan interface{}) {
360 log.Debugw("updateFlowTable", log.Fields{"logicalDeviceId": id})
361 var res interface{}
362 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
363 res = agent.updateFlowTable(ctx, flow)
364 log.Debugw("updateFlowTable-result", log.Fields{"result": res})
365 } else {
366 res = status.Errorf(codes.NotFound, "%s", id)
367 }
368 sendAPIResponse(ctx, ch, res)
369}
370
371func (ldMgr *LogicalDeviceManager) updateGroupTable(ctx context.Context, id string, groupMod *openflow_13.OfpGroupMod, ch chan interface{}) {
372 log.Debugw("updateGroupTable", log.Fields{"logicalDeviceId": id})
373 var res interface{}
374 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
375 res = agent.updateGroupTable(ctx, groupMod)
376 log.Debugw("updateGroupTable-result", log.Fields{"result": res})
377 } else {
378 res = status.Errorf(codes.NotFound, "%s", id)
379 }
380 sendAPIResponse(ctx, ch, res)
381}
382
383func (ldMgr *LogicalDeviceManager) enableLogicalPort(ctx context.Context, id *voltha.LogicalPortId, ch chan interface{}) {
384 log.Debugw("enableLogicalPort", log.Fields{"logicalDeviceId": id})
385 var res interface{}
386 // Get logical port
387 var logicalPort *voltha.LogicalPort
388 var err error
389 if logicalPort, err = ldMgr.getLogicalPort(id); err != nil {
390 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": id.PortId})
391 res = err
392 }
393 if agent := ldMgr.getLogicalDeviceAgent(id.Id); agent != nil {
394 res = agent.enableLogicalPort(logicalPort)
395 log.Debugw("enableLogicalPort-result", log.Fields{"result": res})
396 } else {
397 res = status.Errorf(codes.NotFound, "%s", id.Id)
398 }
399 sendAPIResponse(ctx, ch, res)
400}
401
402func (ldMgr *LogicalDeviceManager) disableLogicalPort(ctx context.Context, id *voltha.LogicalPortId, ch chan interface{}) {
403 log.Debugw("disableLogicalPort", log.Fields{"logicalDeviceId": id})
404 var res interface{}
405 // Get logical port
406 var logicalPort *voltha.LogicalPort
407 var err error
408 if logicalPort, err = ldMgr.getLogicalPort(id); err != nil {
409 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": id.PortId})
410 res = err
411 }
412 if agent := ldMgr.getLogicalDeviceAgent(id.Id); agent != nil {
413 res = agent.disableLogicalPort(logicalPort)
414 log.Debugw("disableLogicalPort-result", log.Fields{"result": res})
415 } else {
416 res = status.Errorf(codes.NotFound, "%s", id.Id)
417 }
418 sendAPIResponse(ctx, ch, res)
419}
khenaidoofdbad6e2018-11-06 22:26:38 -0500420
khenaidoo43c82122018-11-22 18:38:28 -0500421func (ldMgr *LogicalDeviceManager) packetOut(packetOut *openflow_13.PacketOut) {
khenaidoofdbad6e2018-11-06 22:26:38 -0500422 log.Debugw("packetOut", log.Fields{"logicalDeviceId": packetOut.Id})
423 if agent := ldMgr.getLogicalDeviceAgent(packetOut.Id); agent != nil {
424 agent.packetOut(packetOut.PacketOut)
425 } else {
426 log.Error("logical-device-not-exist", log.Fields{"logicalDeviceId": packetOut.Id})
427 }
428}
429
khenaidoo297cd252019-02-07 22:10:23 -0500430func (ldMgr *LogicalDeviceManager) packetIn(logicalDeviceId string, port uint32, transactionId string, packet []byte) error {
khenaidoofdbad6e2018-11-06 22:26:38 -0500431 log.Debugw("packetIn", log.Fields{"logicalDeviceId": logicalDeviceId, "port": port})
432 if agent := ldMgr.getLogicalDeviceAgent(logicalDeviceId); agent != nil {
khenaidoo297cd252019-02-07 22:10:23 -0500433 agent.packetIn(port, transactionId, packet)
khenaidoofdbad6e2018-11-06 22:26:38 -0500434 } else {
435 log.Error("logical-device-not-exist", log.Fields{"logicalDeviceId": logicalDeviceId})
436 }
437 return nil
438}