From be9f3bc2e95ea51b58ca3bc380d3770e8e150654 Mon Sep 17 00:00:00 2001 From: Ray Milkey Date: Thu, 10 May 2018 12:42:51 -0700 Subject: [PATCH] Fix NPE in OFDPA driver Change-Id: Iebfff73d88c5cd7a673876af7c58d33e99e895a4 --- .../driver/pipeline/ofdpa/CpqdOfdpa2Pipeline.java | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/drivers/default/src/main/java/org/onosproject/driver/pipeline/ofdpa/CpqdOfdpa2Pipeline.java b/drivers/default/src/main/java/org/onosproject/driver/pipeline/ofdpa/CpqdOfdpa2Pipeline.java index 2e714273aa..caee9a0e1b 100644 --- a/drivers/default/src/main/java/org/onosproject/driver/pipeline/ofdpa/CpqdOfdpa2Pipeline.java +++ b/drivers/default/src/main/java/org/onosproject/driver/pipeline/ofdpa/CpqdOfdpa2Pipeline.java @@ -184,14 +184,16 @@ public class CpqdOfdpa2Pipeline extends Ofdpa2Pipeline { // ofdpa cannot match on ALL portnumber, so we need to use separate // rules for each port. List portnums = new ArrayList<>(); - if (portCriterion != null && portCriterion.port() == PortNumber.ALL) { - for (Port port : deviceService.getPorts(deviceId)) { - if (port.number().toLong() > 0 && port.number().toLong() < OFPP_MAX) { - portnums.add(port.number()); + if (portCriterion != null) { + if (portCriterion.port() == PortNumber.ALL) { + for (Port port : deviceService.getPorts(deviceId)) { + if (port.number().toLong() > 0 && port.number().toLong() < OFPP_MAX) { + portnums.add(port.number()); + } } + } else { + portnums.add(portCriterion.port()); } - } else { - portnums.add(portCriterion.port()); } for (PortNumber pnum : portnums) {