mirror of
https://github.com/opennetworkinglab/onos.git
synced 2025-10-25 14:21:33 +02:00
Fixed Ciena Waveserver device/port discovery.
Change-Id: If531f01549209e6557acef4326629822ea41bbab
This commit is contained in:
parent
6de27f41ce
commit
f381876a1c
@ -33,7 +33,6 @@ import org.onosproject.net.device.DeviceDescription;
|
||||
import org.onosproject.net.device.DeviceDescriptionDiscovery;
|
||||
import org.onosproject.net.device.PortDescription;
|
||||
import org.onosproject.net.driver.AbstractHandlerBehaviour;
|
||||
import org.onosproject.net.driver.DriverHandler;
|
||||
import org.onosproject.protocol.rest.RestSBController;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
@ -53,29 +52,19 @@ public class CienaWaveserverDeviceDescription extends AbstractHandlerBehaviour
|
||||
|
||||
private final Logger log = getLogger(getClass());
|
||||
|
||||
private static final String SPEED = "speed";
|
||||
private static final String GBPS = "Gbps";
|
||||
private static final String PORT_ID = "port-id";
|
||||
private static final String PORT_ID = "ptp-index";
|
||||
private static final String XML = "xml";
|
||||
private static final String ENABLED = "enabled";
|
||||
private static final String EMPTY_STRING = "";
|
||||
private static final String NAME = "name";
|
||||
private static final String ADMIN_STATE = "admin-state";
|
||||
private static final String ADMIN_STATE = "state.admin-state";
|
||||
private static final String PORTS = "ws-ptps.ptps";
|
||||
private static final String PORT_IN = "properties.line-system.cmd.port-in";
|
||||
private static final String PORT_OUT = "properties.line-system.cmd.port-out";
|
||||
|
||||
private static final ArrayList<String> LINESIDE_PORT_ID = Lists.newArrayList(
|
||||
"4", "48");
|
||||
|
||||
private static final String GENERAL_PORT_REQUEST =
|
||||
"ws-ports?config=true&format=xml&depth=unbounded";
|
||||
private static final String SPECIFIC_PORT_PATH = "ws-ptps/ptp/";
|
||||
private static final String SPECIFIC_PORT_CONFIG =
|
||||
"/ptp-config?config=true&format=xml&depth=unbounded";
|
||||
//HTTP strings
|
||||
// private static final String GENERAL_PORT_REQUEST =
|
||||
// "/yang-api/datastore/ws-ports?config=true&format=xml&depth=unbounded";
|
||||
// private static final String SPECIFIC_PORT_PATH = "/yang-api/datastore/ws-ptps/ptp/";
|
||||
// private static final String SPECIFIC_PORT_CONFIG =
|
||||
// "/ptp-config?config=true&format=xml&depth=unbounded";
|
||||
private static final String PORT_REQUEST =
|
||||
"ciena-ws-ptp:ws-ptps?config=true&format=xml&depth=unbounded";
|
||||
|
||||
@Override
|
||||
public DeviceDescription discoverDeviceDetails() {
|
||||
@ -91,84 +80,69 @@ public class CienaWaveserverDeviceDescription extends AbstractHandlerBehaviour
|
||||
|
||||
private List<PortDescription> getPorts() {
|
||||
List<PortDescription> ports = Lists.newArrayList();
|
||||
DriverHandler handler = handler();
|
||||
RestSBController controller = checkNotNull(handler.get(RestSBController.class));
|
||||
DeviceId deviceId = handler.data().deviceId();
|
||||
|
||||
RestSBController controller = checkNotNull(handler().get(RestSBController.class));
|
||||
DeviceId deviceId = handler().data().deviceId();
|
||||
|
||||
HierarchicalConfiguration config = XmlConfigParser.
|
||||
loadXml(controller.get(deviceId, GENERAL_PORT_REQUEST, XML));
|
||||
loadXml(controller.get(deviceId, PORT_REQUEST, XML));
|
||||
List<HierarchicalConfiguration> portsConfig =
|
||||
parseWaveServerCienaPorts(config);
|
||||
portsConfig.forEach(sub -> {
|
||||
String portId = sub.getString(PORT_ID);
|
||||
String name = sub.getString(NAME);
|
||||
DefaultAnnotations.Builder annotations = DefaultAnnotations.builder();
|
||||
|
||||
if (LINESIDE_PORT_ID.contains(portId)) {
|
||||
String txName = name + " Tx";
|
||||
DefaultAnnotations.Builder annotations = DefaultAnnotations.builder()
|
||||
.set(AnnotationKeys.PORT_NAME, txName);
|
||||
String wsportInfoRequest = SPECIFIC_PORT_PATH + portId +
|
||||
SPECIFIC_PORT_CONFIG;
|
||||
// TX port
|
||||
annotations.set(AnnotationKeys.PORT_NAME, portId + " TX");
|
||||
ports.add(parseWaveServerCienaOchPorts(
|
||||
sub.getLong(PORT_ID),
|
||||
toGbps(Long.parseLong(sub.getString(SPEED).replace(GBPS, EMPTY_STRING)
|
||||
.replace(" ", EMPTY_STRING))),
|
||||
XmlConfigParser.loadXml(controller.get(deviceId, wsportInfoRequest, XML)),
|
||||
sub.getLong(PORT_OUT),
|
||||
sub,
|
||||
annotations.build()));
|
||||
//adding corresponding opposite side port
|
||||
String rxName = name.replace(".1", ".2") + " Rx";
|
||||
|
||||
// RX port
|
||||
annotations.set(AnnotationKeys.PORT_NAME, portId + " RX");
|
||||
ports.add(parseWaveServerCienaOchPorts(
|
||||
sub.getLong(PORT_ID) + 1,
|
||||
toGbps(Long.parseLong(sub.getString(SPEED).replace(GBPS, EMPTY_STRING)
|
||||
.replace(" ", EMPTY_STRING))),
|
||||
XmlConfigParser.loadXml(controller.get(deviceId, wsportInfoRequest, XML)),
|
||||
annotations.set(AnnotationKeys.PORT_NAME, rxName)
|
||||
.build()));
|
||||
} else if (!"5".equals(portId) && !"49".equals(portId)) {
|
||||
DefaultAnnotations.Builder annotations = DefaultAnnotations.builder()
|
||||
.set(AnnotationKeys.PORT_NAME, name);
|
||||
sub.getLong(PORT_IN),
|
||||
sub,
|
||||
annotations.build()));
|
||||
} else if (!portId.equals("5") && !portId.equals("49")) {
|
||||
DefaultAnnotations.builder()
|
||||
.set(AnnotationKeys.PORT_NAME, portId);
|
||||
//FIXME change when all optical types have two way information methods, see jira tickets
|
||||
final int speed100GbpsinMbps = 100000;
|
||||
CltSignalType cltType = toGbps(Long.parseLong(
|
||||
sub.getString(SPEED).replace(GBPS, EMPTY_STRING)
|
||||
.replace(" ", EMPTY_STRING))) == speed100GbpsinMbps ?
|
||||
CltSignalType.CLT_100GBE : null;
|
||||
ports.add(oduCltPortDescription(PortNumber.portNumber(sub.getLong(PORT_ID)),
|
||||
sub.getString(ADMIN_STATE).equals(ENABLED),
|
||||
cltType, annotations.build()));
|
||||
CltSignalType.CLT_100GBE, annotations.build()));
|
||||
}
|
||||
});
|
||||
return ImmutableList.copyOf(ports);
|
||||
}
|
||||
|
||||
public static List<HierarchicalConfiguration> parseWaveServerCienaPorts(HierarchicalConfiguration cfg) {
|
||||
return cfg.configurationsAt("ws-ports.port-interface");
|
||||
return cfg.configurationsAt(PORTS);
|
||||
}
|
||||
|
||||
public static PortDescription parseWaveServerCienaOchPorts(long portNumber, long oduPortSpeed,
|
||||
public static PortDescription parseWaveServerCienaOchPorts(long portNumber,
|
||||
HierarchicalConfiguration config,
|
||||
SparseAnnotations annotations) {
|
||||
final List<String> tunableType = Lists.newArrayList("Performance-Optimized", "Accelerated");
|
||||
final String transmitterPath = "ptp-config.transmitter-state";
|
||||
final String tunablePath = "ptp-config.adv-config.tx-tuning-mode";
|
||||
final String gridTypePath = "ptp-config.adv-config.wl-spacing";
|
||||
final String frequencyPath = "ptp-config.adv-config.frequency";
|
||||
final List<String> tunableType = Lists.newArrayList("performance-optimized", "accelerated");
|
||||
final String flexGrid = "flex-grid";
|
||||
final String state = "properties.transmitter.state";
|
||||
final String tunable = "properties.modem.tx-tuning-mode";
|
||||
final String spacing = "properties.line-system.wavelength-spacing";
|
||||
final String frequency = "properties.transmitter.frequency.value";
|
||||
|
||||
boolean isEnabled = "enabled".equals(config.getString(transmitterPath));
|
||||
boolean isTunable = tunableType.contains(config.getString(tunablePath));
|
||||
boolean isEnabled = config.getString(state).equals(ENABLED);
|
||||
boolean isTunable = tunableType.contains(config.getString(tunable));
|
||||
|
||||
//FIXME change when all optical types have two way information methods, see jira tickets
|
||||
final int speed100GbpsinMbps = 100000;
|
||||
OduSignalType oduSignalType = oduPortSpeed == speed100GbpsinMbps ? OduSignalType.ODU4 : null;
|
||||
GridType gridType = "FlexGrid".equals(config.getString(gridTypePath)) ? GridType.FLEX : null;
|
||||
GridType gridType = config.getString(spacing).equals(flexGrid) ? GridType.FLEX : null;
|
||||
ChannelSpacing chSpacing = gridType == GridType.FLEX ? ChannelSpacing.CHL_6P25GHZ : null;
|
||||
|
||||
//Working in Ghz //(Nominal central frequency - 193.1)/channelSpacing = spacingMultiplier
|
||||
final int baseFrequency = 193100;
|
||||
int spacingMult = (int) (toGbps((Integer.parseInt(config.getString(frequencyPath)) -
|
||||
int spacingMult = (int) (toGbps(((int) config.getDouble(frequency) -
|
||||
baseFrequency)) / toGbpsFromHz(chSpacing.frequency().asHz())); //FIXME is there a better way ?
|
||||
|
||||
return ochPortDescription(PortNumber.portNumber(portNumber), isEnabled, oduSignalType, isTunable,
|
||||
return ochPortDescription(PortNumber.portNumber(portNumber), isEnabled, OduSignalType.ODU4, isTunable,
|
||||
new OchSignal(gridType, chSpacing, spacingMult, 1), annotations);
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user