blob: e9b5a4fe1adb73983d22782b19f25e80aafde681 [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"
William Kurkiandaa6bb22019-03-07 12:26:28 -050024 "github.com/opencord/voltha-protos/go/openflow_13"
25 "github.com/opencord/voltha-protos/go/voltha"
khenaidoob9203542018-09-17 22:56:37 -040026 "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
khenaidoo2c6a0992019-04-29 13:46:56 -040042 defaultTimeout int64
khenaidoob9203542018-09-17 22:56:37 -040043}
44
khenaidoo2c6a0992019-04-29 13:46:56 -040045func newLogicalDeviceManager(core *Core, deviceMgr *DeviceManager, kafkaICProxy *kafka.InterContainerProxy, cdProxy *model.Proxy, timeout int64) *LogicalDeviceManager {
khenaidoob9203542018-09-17 22:56:37 -040046 var logicalDeviceMgr LogicalDeviceManager
Richard Jankowski199fd862019-03-18 14:49:51 -040047 logicalDeviceMgr.core = core
khenaidoob9203542018-09-17 22:56:37 -040048 logicalDeviceMgr.exitChannel = make(chan int, 1)
49 logicalDeviceMgr.logicalDeviceAgents = make(map[string]*LogicalDeviceAgent)
50 logicalDeviceMgr.deviceMgr = deviceMgr
khenaidoo43c82122018-11-22 18:38:28 -050051 logicalDeviceMgr.kafkaICProxy = kafkaICProxy
khenaidoo9a468962018-09-19 15:33:13 -040052 logicalDeviceMgr.clusterDataProxy = cdProxy
khenaidoob9203542018-09-17 22:56:37 -040053 logicalDeviceMgr.lockLogicalDeviceAgentsMap = sync.RWMutex{}
khenaidoo2c6a0992019-04-29 13:46:56 -040054 logicalDeviceMgr.defaultTimeout = timeout
khenaidoob9203542018-09-17 22:56:37 -040055 return &logicalDeviceMgr
56}
57
Richard Jankowskidbab94a2018-12-06 16:20:25 -050058func (ldMgr *LogicalDeviceManager) setGrpcNbiHandler(grpcNbiHandler *APIHandler) {
59 ldMgr.grpcNbiHdlr = grpcNbiHandler
60}
61
khenaidoo4d4802d2018-10-04 21:59:49 -040062func (ldMgr *LogicalDeviceManager) start(ctx context.Context) {
khenaidoob9203542018-09-17 22:56:37 -040063 log.Info("starting-logical-device-manager")
64 log.Info("logical-device-manager-started")
65}
66
khenaidoo4d4802d2018-10-04 21:59:49 -040067func (ldMgr *LogicalDeviceManager) stop(ctx context.Context) {
khenaidoob9203542018-09-17 22:56:37 -040068 log.Info("stopping-logical-device-manager")
69 ldMgr.exitChannel <- 1
70 log.Info("logical-device-manager-stopped")
71}
72
khenaidoo19d7b632018-10-30 10:49:50 -040073func sendAPIResponse(ctx context.Context, ch chan interface{}, result interface{}) {
74 if ctx.Err() == nil {
75 // Returned response only of the ctx has not been cancelled/timeout/etc
76 // Channel is automatically closed when a context is Done
77 ch <- result
78 log.Debugw("sendResponse", log.Fields{"result": result})
79 } else {
80 // Should the transaction be reverted back?
81 log.Debugw("sendResponse-context-error", log.Fields{"context-error": ctx.Err()})
82 }
83}
84
khenaidoob9203542018-09-17 22:56:37 -040085func (ldMgr *LogicalDeviceManager) addLogicalDeviceAgentToMap(agent *LogicalDeviceAgent) {
86 ldMgr.lockLogicalDeviceAgentsMap.Lock()
87 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
88 if _, exist := ldMgr.logicalDeviceAgents[agent.logicalDeviceId]; !exist {
89 ldMgr.logicalDeviceAgents[agent.logicalDeviceId] = agent
90 }
91}
92
khenaidoo8c3303d2019-02-13 14:59:39 -050093// getLogicalDeviceAgent returns the logical device agent. If the device is not in memory then the device will
94// be loaded from dB and a logical device agent created to managed it.
khenaidoob9203542018-09-17 22:56:37 -040095func (ldMgr *LogicalDeviceManager) getLogicalDeviceAgent(logicalDeviceId string) *LogicalDeviceAgent {
khenaidoo1ce37ad2019-03-24 22:07:24 -040096 ldMgr.lockLogicalDeviceAgentsMap.RLock()
khenaidoob9203542018-09-17 22:56:37 -040097 if agent, ok := ldMgr.logicalDeviceAgents[logicalDeviceId]; ok {
khenaidoo1ce37ad2019-03-24 22:07:24 -040098 ldMgr.lockLogicalDeviceAgentsMap.RUnlock()
khenaidoob9203542018-09-17 22:56:37 -040099 return agent
khenaidoo8c3303d2019-02-13 14:59:39 -0500100 } else {
101 // Try to load into memory - loading will also create the logical device agent
khenaidoo1ce37ad2019-03-24 22:07:24 -0400102 ldMgr.lockLogicalDeviceAgentsMap.RUnlock()
khenaidoo8c3303d2019-02-13 14:59:39 -0500103 if err := ldMgr.load(logicalDeviceId); err == nil {
khenaidoo1ce37ad2019-03-24 22:07:24 -0400104 ldMgr.lockLogicalDeviceAgentsMap.RLock()
105 defer ldMgr.lockLogicalDeviceAgentsMap.RUnlock()
khenaidoo8c3303d2019-02-13 14:59:39 -0500106 if agent, ok = ldMgr.logicalDeviceAgents[logicalDeviceId]; ok {
107 return agent
108 }
109 }
khenaidoob9203542018-09-17 22:56:37 -0400110 }
111 return nil
112}
113
khenaidoo92e62c52018-10-03 14:02:54 -0400114func (ldMgr *LogicalDeviceManager) deleteLogicalDeviceAgent(logicalDeviceId string) {
115 ldMgr.lockLogicalDeviceAgentsMap.Lock()
116 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
117 delete(ldMgr.logicalDeviceAgents, logicalDeviceId)
118}
119
khenaidoo8c3303d2019-02-13 14:59:39 -0500120// GetLogicalDevice provides a cloned most up to date logical device. If device is not in memory
121// it will be fetched from the dB
khenaidoob9203542018-09-17 22:56:37 -0400122func (ldMgr *LogicalDeviceManager) getLogicalDevice(id string) (*voltha.LogicalDevice, error) {
khenaidoo92e62c52018-10-03 14:02:54 -0400123 log.Debugw("getlogicalDevice", log.Fields{"logicaldeviceid": id})
124 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
khenaidoo19d7b632018-10-30 10:49:50 -0400125 return agent.GetLogicalDevice()
khenaidoob9203542018-09-17 22:56:37 -0400126 }
127 return nil, status.Errorf(codes.NotFound, "%s", id)
128}
129
130func (ldMgr *LogicalDeviceManager) listLogicalDevices() (*voltha.LogicalDevices, error) {
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500131 log.Debug("ListAllLogicalDevices")
khenaidoob9203542018-09-17 22:56:37 -0400132 result := &voltha.LogicalDevices{}
khenaidoo297cd252019-02-07 22:10:23 -0500133 if logicalDevices := ldMgr.clusterDataProxy.List("/logical_devices", 0, false, ""); logicalDevices != nil {
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500134 for _, logicalDevice := range logicalDevices.([]interface{}) {
135 if agent := ldMgr.getLogicalDeviceAgent(logicalDevice.(*voltha.LogicalDevice).Id); agent == nil {
136 agent = newLogicalDeviceAgent(
137 logicalDevice.(*voltha.LogicalDevice).Id,
138 logicalDevice.(*voltha.LogicalDevice).RootDeviceId,
139 ldMgr,
140 ldMgr.deviceMgr,
141 ldMgr.clusterDataProxy,
khenaidoo2c6a0992019-04-29 13:46:56 -0400142 ldMgr.defaultTimeout,
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500143 )
144 ldMgr.addLogicalDeviceAgentToMap(agent)
khenaidoo297cd252019-02-07 22:10:23 -0500145 go agent.start(nil, true)
Stephane Barbarie1ab43272018-12-08 21:42:13 -0500146 }
147 result.Items = append(result.Items, logicalDevice.(*voltha.LogicalDevice))
khenaidoob9203542018-09-17 22:56:37 -0400148 }
149 }
150 return result, nil
151}
152
khenaidoo4d4802d2018-10-04 21:59:49 -0400153func (ldMgr *LogicalDeviceManager) createLogicalDevice(ctx context.Context, device *voltha.Device) (*string, error) {
khenaidoo92e62c52018-10-03 14:02:54 -0400154 log.Debugw("creating-logical-device", log.Fields{"deviceId": device.Id})
khenaidoob9203542018-09-17 22:56:37 -0400155 // Sanity check
156 if !device.Root {
khenaidoo2c6a0992019-04-29 13:46:56 -0400157 return nil, errors.New("device-not-root")
khenaidoob9203542018-09-17 22:56:37 -0400158 }
159
160 // Create a logical device agent - the logical device Id is based on the mac address of the device
161 // For now use the serial number - it may contain any combination of alphabetic characters and numbers,
162 // with length varying from eight characters to a maximum of 14 characters. Mac Address is part of oneof
163 // in the Device model. May need to be moved out.
164 macAddress := device.MacAddress
165 id := strings.Replace(macAddress, ":", "", -1)
khenaidoo92e62c52018-10-03 14:02:54 -0400166 if id == "" {
167 log.Errorw("mac-address-not-set", log.Fields{"deviceId": device.Id})
168 return nil, errors.New("mac-address-not-set")
169 }
170 log.Debugw("logical-device-id", log.Fields{"logicaldeviceId": id})
khenaidoob9203542018-09-17 22:56:37 -0400171
khenaidoo2c6a0992019-04-29 13:46:56 -0400172 agent := newLogicalDeviceAgent(id, device.Id, ldMgr, ldMgr.deviceMgr, ldMgr.clusterDataProxy, ldMgr.defaultTimeout)
khenaidoob9203542018-09-17 22:56:37 -0400173 ldMgr.addLogicalDeviceAgentToMap(agent)
khenaidoo297cd252019-02-07 22:10:23 -0500174 go agent.start(ctx, false)
khenaidoob9203542018-09-17 22:56:37 -0400175
khenaidoo92e62c52018-10-03 14:02:54 -0400176 log.Debug("creating-logical-device-ends")
khenaidoob9203542018-09-17 22:56:37 -0400177 return &id, nil
178}
179
khenaidoo297cd252019-02-07 22:10:23 -0500180// load loads a logical device manager in memory
181func (ldMgr *LogicalDeviceManager) load(lDeviceId string) error {
khenaidoo1ce37ad2019-03-24 22:07:24 -0400182 log.Debugw("loading-logical-device", log.Fields{"lDeviceId": lDeviceId})
khenaidoo297cd252019-02-07 22:10:23 -0500183 // To prevent a race condition, let's hold the logical device agent map lock. This will prevent a loading and
184 // a create logical device callback from occurring at the same time.
185 ldMgr.lockLogicalDeviceAgentsMap.Lock()
186 defer ldMgr.lockLogicalDeviceAgentsMap.Unlock()
187 if ldAgent, _ := ldMgr.logicalDeviceAgents[lDeviceId]; ldAgent == nil {
188 // Logical device not in memory - create a temp logical device Agent and let it load from memory
khenaidoo2c6a0992019-04-29 13:46:56 -0400189 agent := newLogicalDeviceAgent(lDeviceId, "", ldMgr, ldMgr.deviceMgr, ldMgr.clusterDataProxy, ldMgr.defaultTimeout)
khenaidoo297cd252019-02-07 22:10:23 -0500190 if err := agent.start(nil, true); err != nil {
khenaidoo8c3303d2019-02-13 14:59:39 -0500191 //agent.stop(nil)
khenaidoo297cd252019-02-07 22:10:23 -0500192 return err
193 }
194 ldMgr.logicalDeviceAgents[agent.logicalDeviceId] = agent
195 }
196 // TODO: load the child device
197 return nil
198}
199
khenaidoo4d4802d2018-10-04 21:59:49 -0400200func (ldMgr *LogicalDeviceManager) deleteLogicalDevice(ctx context.Context, device *voltha.Device) error {
khenaidoo92e62c52018-10-03 14:02:54 -0400201 log.Debugw("deleting-logical-device", log.Fields{"deviceId": device.Id})
202 // Sanity check
203 if !device.Root {
khenaidoo2c6a0992019-04-29 13:46:56 -0400204 return errors.New("device-not-root")
khenaidoo92e62c52018-10-03 14:02:54 -0400205 }
206 logDeviceId := device.ParentId
207 if agent := ldMgr.getLogicalDeviceAgent(logDeviceId); agent != nil {
208 // Stop the logical device agent
khenaidoo4d4802d2018-10-04 21:59:49 -0400209 agent.stop(ctx)
khenaidoo92e62c52018-10-03 14:02:54 -0400210 //Remove the logical device agent from the Map
211 ldMgr.deleteLogicalDeviceAgent(logDeviceId)
Richard Jankowski199fd862019-03-18 14:49:51 -0400212 ldMgr.core.deviceOwnership.AbandonDevice(logDeviceId)
khenaidoo92e62c52018-10-03 14:02:54 -0400213 }
214
215 log.Debug("deleting-logical-device-ends")
216 return nil
217}
218
219func (ldMgr *LogicalDeviceManager) getLogicalDeviceId(device *voltha.Device) (*string, error) {
220 // Device can either be a parent or a child device
221 if device.Root {
222 // Parent device. The ID of a parent device is the logical device ID
223 return &device.ParentId, nil
224 }
225 // Device is child device
226 // retrieve parent device using child device ID
227 if parentDevice := ldMgr.deviceMgr.getParentDevice(device); parentDevice != nil {
228 return &parentDevice.ParentId, nil
229 }
230 return nil, status.Errorf(codes.NotFound, "%s", device.Id)
231}
232
khenaidoo3ab34882019-05-02 21:33:30 -0400233func (ldMgr *LogicalDeviceManager) getLogicalDeviceIdFromDeviceId(deviceId string) (*string, error) {
234 // Get the device
235 var device *voltha.Device
236 var err error
237 if device, err = ldMgr.deviceMgr.GetDevice(deviceId); err != nil {
238 return nil, err
239 }
240 return ldMgr.getLogicalDeviceId(device)
241}
242
khenaidoo19d7b632018-10-30 10:49:50 -0400243func (ldMgr *LogicalDeviceManager) getLogicalPortId(device *voltha.Device) (*voltha.LogicalPortId, error) {
244 // Get the logical device where this device is attached
245 var lDeviceId *string
246 var err error
247 if lDeviceId, err = ldMgr.getLogicalDeviceId(device); err != nil {
248 return nil, err
249 }
250 var lDevice *voltha.LogicalDevice
251 if lDevice, err = ldMgr.getLogicalDevice(*lDeviceId); err != nil {
252 return nil, err
253 }
254 // Go over list of ports
255 for _, port := range lDevice.Ports {
256 if port.DeviceId == device.Id {
257 return &voltha.LogicalPortId{Id: *lDeviceId, PortId: port.Id}, nil
258 }
259 }
260 return nil, status.Errorf(codes.NotFound, "%s", device.Id)
261}
262
263func (ldMgr *LogicalDeviceManager) ListLogicalDevicePorts(ctx context.Context, id string) (*voltha.LogicalPorts, error) {
264 log.Debugw("ListLogicalDevicePorts", log.Fields{"logicaldeviceid": id})
265 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
266 return agent.ListLogicalDevicePorts()
267 }
268 return nil, status.Errorf(codes.NotFound, "%s", id)
269
270}
271
272func (ldMgr *LogicalDeviceManager) getLogicalPort(lPortId *voltha.LogicalPortId) (*voltha.LogicalPort, error) {
273 // Get the logical device where this device is attached
274 var err error
275 var lDevice *voltha.LogicalDevice
276 if lDevice, err = ldMgr.getLogicalDevice(lPortId.Id); err != nil {
277 return nil, err
278 }
279 // Go over list of ports
280 for _, port := range lDevice.Ports {
281 if port.Id == lPortId.PortId {
282 return port, nil
283 }
284 }
Kent Hagerman0ab4cb22019-04-24 13:13:35 -0400285 return nil, status.Errorf(codes.NotFound, "%s-%s", lPortId.Id, lPortId.PortId)
khenaidoo19d7b632018-10-30 10:49:50 -0400286}
287
khenaidoo2c6a0992019-04-29 13:46:56 -0400288// updateLogicalPort sets up a logical port on the logical device based on the device port
289// information, if needed
290func (ldMgr *LogicalDeviceManager) updateLogicalPort(device *voltha.Device, port *voltha.Port) error {
291 if ldID, err := ldMgr.getLogicalDeviceId(device); err != nil || *ldID == "" {
292 // This is not an error as the logical device may not have been created at this time. In such a case,
293 // the ports will be created when the logical device is ready.
294 return nil
295 } else {
296 if agent := ldMgr.getLogicalDeviceAgent(*ldID); agent != nil {
297 if err := agent.updateLogicalPort(device, port); err != nil {
298 return err
299 }
300 }
301 }
302 return nil
303}
304
khenaidoofc1314d2019-03-14 09:34:21 -0400305// addLogicalPort sets up a logical port on the logical device based on the device port
306// information.
307func (ldMgr *LogicalDeviceManager) addLogicalPort(device *voltha.Device, port *voltha.Port) error {
Stephane Barbarie40fd3b22019-04-23 21:50:47 -0400308 if ldID, err := ldMgr.getLogicalDeviceId(device); err != nil || *ldID == "" {
khenaidoofc1314d2019-03-14 09:34:21 -0400309 // This is not an error as the logical device may not have been created at this time. In such a case,
310 // the ports will be created when the logical device is ready.
311 return nil
312 } else {
313 if agent := ldMgr.getLogicalDeviceAgent(*ldID); agent != nil {
314 if err := agent.addLogicalPort(device, port); err != nil {
315 return err
316 }
317 }
318 }
319 return nil
320}
321
khenaidoo19d7b632018-10-30 10:49:50 -0400322// deleteLogicalPort removes the logical port associated with a child device
323func (ldMgr *LogicalDeviceManager) deleteLogicalPort(ctx context.Context, lPortId *voltha.LogicalPortId) error {
324 log.Debugw("deleting-logical-port", log.Fields{"LDeviceId": lPortId.Id})
325 // Get logical port
326 var logicalPort *voltha.LogicalPort
327 var err error
328 if logicalPort, err = ldMgr.getLogicalPort(lPortId); err != nil {
329 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": lPortId.PortId})
330 return err
331 }
khenaidoo92e62c52018-10-03 14:02:54 -0400332 // Sanity check
khenaidoo19d7b632018-10-30 10:49:50 -0400333 if logicalPort.RootPort {
khenaidoo2c6a0992019-04-29 13:46:56 -0400334 return errors.New("device-root")
khenaidoo92e62c52018-10-03 14:02:54 -0400335 }
khenaidoo19d7b632018-10-30 10:49:50 -0400336 if agent := ldMgr.getLogicalDeviceAgent(lPortId.Id); agent != nil {
337 agent.deleteLogicalPort(logicalPort)
khenaidoo92e62c52018-10-03 14:02:54 -0400338 }
339
340 log.Debug("deleting-logical-port-ends")
341 return nil
342}
343
khenaidoofc1314d2019-03-14 09:34:21 -0400344func (ldMgr *LogicalDeviceManager) setupUNILogicalPorts(ctx context.Context, childDevice *voltha.Device) error {
345 log.Debugw("setupUNILogicalPorts", log.Fields{"childDeviceId": childDevice.Id, "parentDeviceId": childDevice.ParentId})
khenaidoob9203542018-09-17 22:56:37 -0400346 // Sanity check
347 if childDevice.Root {
348 return errors.New("Device-root")
349 }
350
351 // Get the logical device id parent device
352 parentId := childDevice.ParentId
353 logDeviceId := ldMgr.deviceMgr.GetParentDeviceId(parentId)
354
khenaidoofc1314d2019-03-14 09:34:21 -0400355 log.Debugw("setupUNILogicalPorts", log.Fields{"logDeviceId": logDeviceId, "parentId": parentId})
khenaidoob9203542018-09-17 22:56:37 -0400356
khenaidoo5e677ae2019-02-28 17:26:29 -0500357 if parentId == "" || logDeviceId == nil {
khenaidoo2c6a0992019-04-29 13:46:56 -0400358 return errors.New("device-in-invalid-state")
khenaidoo5e677ae2019-02-28 17:26:29 -0500359 }
360
khenaidoob9203542018-09-17 22:56:37 -0400361 if agent := ldMgr.getLogicalDeviceAgent(*logDeviceId); agent != nil {
khenaidoofc1314d2019-03-14 09:34:21 -0400362 if err := agent.setupUNILogicalPorts(ctx, childDevice); err != nil {
khenaidoobcf205b2019-01-25 22:21:14 -0500363 return err
364 }
khenaidoob9203542018-09-17 22:56:37 -0400365 }
khenaidoo21d51152019-02-01 13:48:37 -0500366 return nil
khenaidoob9203542018-09-17 22:56:37 -0400367}
khenaidoo19d7b632018-10-30 10:49:50 -0400368
khenaidoo3ab34882019-05-02 21:33:30 -0400369func (ldMgr *LogicalDeviceManager) updatePortsState(device *voltha.Device, state voltha.AdminState_AdminState) error {
370 log.Debugw("updatePortsState", log.Fields{"deviceId": device.Id, "state": state})
371
372 var ldId *string
373 var err error
374 //Get the logical device Id for this device
375 if ldId, err = ldMgr.getLogicalDeviceId(device); err != nil {
376 log.Warnw("no-logical-device-found", log.Fields{"deviceId": device.Id, "error": err})
377 return err
378 }
379 if agent := ldMgr.getLogicalDeviceAgent(*ldId); agent != nil {
380 if err := agent.updatePortsState(device, state); err != nil {
381 return err
382 }
383 }
384 return nil
385}
386
khenaidoo19d7b632018-10-30 10:49:50 -0400387func (ldMgr *LogicalDeviceManager) updateFlowTable(ctx context.Context, id string, flow *openflow_13.OfpFlowMod, ch chan interface{}) {
388 log.Debugw("updateFlowTable", log.Fields{"logicalDeviceId": id})
389 var res interface{}
390 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
391 res = agent.updateFlowTable(ctx, flow)
392 log.Debugw("updateFlowTable-result", log.Fields{"result": res})
393 } else {
394 res = status.Errorf(codes.NotFound, "%s", id)
395 }
396 sendAPIResponse(ctx, ch, res)
397}
398
399func (ldMgr *LogicalDeviceManager) updateGroupTable(ctx context.Context, id string, groupMod *openflow_13.OfpGroupMod, ch chan interface{}) {
400 log.Debugw("updateGroupTable", log.Fields{"logicalDeviceId": id})
401 var res interface{}
402 if agent := ldMgr.getLogicalDeviceAgent(id); agent != nil {
403 res = agent.updateGroupTable(ctx, groupMod)
404 log.Debugw("updateGroupTable-result", log.Fields{"result": res})
405 } else {
406 res = status.Errorf(codes.NotFound, "%s", id)
407 }
408 sendAPIResponse(ctx, ch, res)
409}
410
411func (ldMgr *LogicalDeviceManager) enableLogicalPort(ctx context.Context, id *voltha.LogicalPortId, ch chan interface{}) {
412 log.Debugw("enableLogicalPort", log.Fields{"logicalDeviceId": id})
413 var res interface{}
414 // Get logical port
415 var logicalPort *voltha.LogicalPort
416 var err error
417 if logicalPort, err = ldMgr.getLogicalPort(id); err != nil {
418 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": id.PortId})
419 res = err
420 }
421 if agent := ldMgr.getLogicalDeviceAgent(id.Id); agent != nil {
422 res = agent.enableLogicalPort(logicalPort)
423 log.Debugw("enableLogicalPort-result", log.Fields{"result": res})
424 } else {
425 res = status.Errorf(codes.NotFound, "%s", id.Id)
426 }
427 sendAPIResponse(ctx, ch, res)
428}
429
430func (ldMgr *LogicalDeviceManager) disableLogicalPort(ctx context.Context, id *voltha.LogicalPortId, ch chan interface{}) {
431 log.Debugw("disableLogicalPort", log.Fields{"logicalDeviceId": id})
432 var res interface{}
433 // Get logical port
434 var logicalPort *voltha.LogicalPort
435 var err error
436 if logicalPort, err = ldMgr.getLogicalPort(id); err != nil {
437 log.Debugw("no-logical-device-port-present", log.Fields{"logicalPortId": id.PortId})
438 res = err
439 }
440 if agent := ldMgr.getLogicalDeviceAgent(id.Id); agent != nil {
441 res = agent.disableLogicalPort(logicalPort)
442 log.Debugw("disableLogicalPort-result", log.Fields{"result": res})
443 } else {
444 res = status.Errorf(codes.NotFound, "%s", id.Id)
445 }
446 sendAPIResponse(ctx, ch, res)
447}
khenaidoofdbad6e2018-11-06 22:26:38 -0500448
khenaidoo43c82122018-11-22 18:38:28 -0500449func (ldMgr *LogicalDeviceManager) packetOut(packetOut *openflow_13.PacketOut) {
khenaidoofdbad6e2018-11-06 22:26:38 -0500450 log.Debugw("packetOut", log.Fields{"logicalDeviceId": packetOut.Id})
451 if agent := ldMgr.getLogicalDeviceAgent(packetOut.Id); agent != nil {
452 agent.packetOut(packetOut.PacketOut)
453 } else {
454 log.Error("logical-device-not-exist", log.Fields{"logicalDeviceId": packetOut.Id})
455 }
456}
457
khenaidoo297cd252019-02-07 22:10:23 -0500458func (ldMgr *LogicalDeviceManager) packetIn(logicalDeviceId string, port uint32, transactionId string, packet []byte) error {
khenaidoofdbad6e2018-11-06 22:26:38 -0500459 log.Debugw("packetIn", log.Fields{"logicalDeviceId": logicalDeviceId, "port": port})
460 if agent := ldMgr.getLogicalDeviceAgent(logicalDeviceId); agent != nil {
khenaidoo297cd252019-02-07 22:10:23 -0500461 agent.packetIn(port, transactionId, packet)
khenaidoofdbad6e2018-11-06 22:26:38 -0500462 } else {
463 log.Error("logical-device-not-exist", log.Fields{"logicalDeviceId": logicalDeviceId})
464 }
465 return nil
466}