blob: 623f990b0a51bd807334c332152a410d57f96d79 [file] [log] [blame]
Daniel Park95f73312018-07-31 15:48:34 +09001/*
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 org.onosproject.openstacknetworking.cli;
17
Ray Milkey86ad7bb2018-09-27 12:32:28 -070018import org.apache.karaf.shell.api.action.Argument;
19import org.apache.karaf.shell.api.action.Command;
Jian Lidb521c12018-11-19 17:42:35 +090020import org.apache.karaf.shell.api.action.Completion;
Ray Milkey7a2dee52018-09-28 10:58:28 -070021import org.apache.karaf.shell.api.action.lifecycle.Service;
Daniel Park95f73312018-07-31 15:48:34 +090022import org.onosproject.cli.AbstractShellCommand;
23import org.onosproject.net.device.DeviceService;
24import org.onosproject.openstacknetworking.api.OpenstackNetworkService;
25import org.onosproject.openstacknetworking.util.OpenstackNetworkingUtil;
26import org.onosproject.openstacknode.api.OpenstackNode;
27import org.onosproject.openstacknode.api.OpenstackNodeService;
28import org.openstack4j.model.network.Port;
29
30import java.util.Optional;
31
Jian Li5ecfd1a2018-12-10 11:41:03 +090032import static org.onosproject.cli.AbstractShellCommand.get;
Daniel Parkec9d1132018-08-19 11:18:03 +090033import static org.onosproject.openstacknetworking.api.Constants.UNSUPPORTED_VENDOR;
34import static org.onosproject.openstacknetworking.util.OpenstackNetworkingUtil.getIntfNameFromPciAddress;
Daniel Park95f73312018-07-31 15:48:34 +090035import static org.onosproject.openstacknode.api.OpenstackNode.NodeType.COMPUTE;
36
37/**
38 * When SR-IOV-based VM is instantiated while the ovsdb connection to the device is lost,
39 * VM is instantiated but the related VF port can't be added.
40 * After recovering ovsdb connection, you can manually add VF ports by this CLI.
41 */
Ray Milkey7a2dee52018-09-28 10:58:28 -070042@Service
Daniel Park95f73312018-07-31 15:48:34 +090043@Command(scope = "onos", name = "openstack-direct-port-add",
44 description = "Manually adds OpenStack direct ports to the device")
45public class OpenstackDirectPortAddCommand extends AbstractShellCommand {
46 @Argument(index = 0, name = "port ID", description = "port ID", required = true)
Jian Lidb521c12018-11-19 17:42:35 +090047 @Completion(DirectPortListCompleter.class)
Daniel Park95f73312018-07-31 15:48:34 +090048 private String portId = null;
49
50 @Override
Ray Milkey86ad7bb2018-09-27 12:32:28 -070051 protected void doExecute() {
Jian Li5ecfd1a2018-12-10 11:41:03 +090052 OpenstackNetworkService osNetService = get(OpenstackNetworkService.class);
53 OpenstackNodeService osNodeService = get(OpenstackNodeService.class);
54 DeviceService deviceService = get(DeviceService.class);
Daniel Park95f73312018-07-31 15:48:34 +090055
56 Port port = osNetService.port(portId);
57 if (port == null) {
58 log.error("There's no port that matches the port ID {}", portId);
59 return;
60 }
61
62 Optional<OpenstackNode> osNode = osNodeService.completeNodes(COMPUTE).stream()
63 .filter(node -> node.hostname().equals(port.getHostId()))
64 .findAny();
65 if (!osNode.isPresent()) {
66 log.error("There's no openstackNode that matches hostname {}",
67 port.getHostId());
68 return;
69 }
70
Daniel Parkec9d1132018-08-19 11:18:03 +090071 String intfName = getIntfNameFromPciAddress(port);
Daniel Park95f73312018-07-31 15:48:34 +090072 if (intfName == null) {
73 log.error("Failed to retrieve interface name from a port {}", portId);
74 return;
Daniel Parkec9d1132018-08-19 11:18:03 +090075 } else if (intfName.equals(UNSUPPORTED_VENDOR)) {
Daniel Parkec9d1132018-08-19 11:18:03 +090076 return;
Daniel Park95f73312018-07-31 15:48:34 +090077 }
78
79 if (OpenstackNetworkingUtil.hasIntfAleadyInDevice(osNode.get().intgBridge(),
80 intfName, deviceService)) {
81 log.error("Interface {} is already added to the device {}", osNode.get().intgBridge());
82 return;
83 }
84
85 log.info("Adding interface {} to the device {}..", intfName,
86 osNode.get().intgBridge());
87
88 osNodeService.addVfPort(osNode.get(), intfName);
89 }
90}