Search in sources :

Example 31 with FilteringObjective

use of org.onosproject.net.flowobjective.FilteringObjective in project onos by opennetworkinglab.

the class FabricUtils method isValidSrMetadata.

/**
 * Check metadata passed from SegmentRouting app.
 *
 * @param obj the objective containing the metadata
 * @return true if the objective contains valid metadata, false otherwise
 */
public static boolean isValidSrMetadata(Objective obj) {
    long meta = 0;
    if (obj instanceof FilteringObjective) {
        FilteringObjective filtObj = (FilteringObjective) obj;
        if (filtObj.meta() == null) {
            return true;
        }
        Instructions.MetadataInstruction metaIns = filtObj.meta().writeMetadata();
        if (metaIns == null) {
            return true;
        }
        meta = metaIns.metadata() & metaIns.metadataMask();
    } else if (obj instanceof ForwardingObjective) {
        ForwardingObjective fwdObj = (ForwardingObjective) obj;
        if (fwdObj.meta() == null) {
            return true;
        }
        MetadataCriterion metaCrit = (MetadataCriterion) fwdObj.meta().getCriterion(Criterion.Type.METADATA);
        if (metaCrit == null) {
            return true;
        }
        meta = metaCrit.metadata();
    }
    return meta != 0 && ((meta ^ METADATA_MASK) <= METADATA_MASK);
}
Also used : MetadataCriterion(org.onosproject.net.flow.criteria.MetadataCriterion) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective) Instructions(org.onosproject.net.flow.instructions.Instructions) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective)

Example 32 with FilteringObjective

use of org.onosproject.net.flowobjective.FilteringObjective in project onos by opennetworkinglab.

the class FabricUtils method isSrMetadataSet.

/**
 * Verify if a given flag has been set into the metadata.
 *
 * @param obj the objective containing the metadata
 * @param flag the flag to verify
 * @return true if the flag is set, false otherwise
 */
public static boolean isSrMetadataSet(Objective obj, long flag) {
    long meta = 0;
    if (obj instanceof FilteringObjective) {
        FilteringObjective filtObj = (FilteringObjective) obj;
        if (filtObj.meta() == null) {
            return false;
        }
        Instructions.MetadataInstruction metaIns = filtObj.meta().writeMetadata();
        if (metaIns == null) {
            return false;
        }
        meta = metaIns.metadata() & metaIns.metadataMask();
    } else if (obj instanceof ForwardingObjective) {
        ForwardingObjective fwdObj = (ForwardingObjective) obj;
        if (fwdObj.meta() == null) {
            return false;
        }
        MetadataCriterion metaCrit = (MetadataCriterion) fwdObj.meta().getCriterion(Criterion.Type.METADATA);
        if (metaCrit == null) {
            return false;
        }
        meta = metaCrit.metadata();
    }
    return (meta & flag) == flag;
}
Also used : MetadataCriterion(org.onosproject.net.flow.criteria.MetadataCriterion) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective) Instructions(org.onosproject.net.flow.instructions.Instructions) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective)

Example 33 with FilteringObjective

use of org.onosproject.net.flowobjective.FilteringObjective in project onos by opennetworkinglab.

the class LinkCollectionIntentFlowObjectiveCompiler method createRules.

@Override
protected List<Objective> createRules(LinkCollectionIntent intent, DeviceId deviceId, Set<PortNumber> inPorts, Set<PortNumber> outPorts, Map<ConnectPoint, Identifier<?>> labels) {
    List<Objective> objectives = new ArrayList<>(inPorts.size() * 2);
    /*
         * Looking for the encapsulation constraint
         */
    Optional<EncapsulationConstraint> encapConstraint = this.getIntentEncapConstraint(intent);
    inPorts.forEach(inPort -> {
        ForwardingInstructions instructions = this.createForwardingInstruction(encapConstraint, intent, inPort, outPorts, deviceId, labels);
        Set<TrafficTreatment> treatmentsWithDifferentPort = Sets.newHashSet();
        TrafficTreatment.Builder treatmentBuilder = DefaultTrafficTreatment.builder();
        for (Instruction inst : instructions.treatment().allInstructions()) {
            if (inst.type() == OUTPUT) {
                treatmentBuilder.add(inst);
                treatmentsWithDifferentPort.add(treatmentBuilder.build());
                treatmentBuilder = DefaultTrafficTreatment.builder();
            } else {
                treatmentBuilder.add(inst);
            }
        }
        EthCriterion ethDst = (EthCriterion) intent.selector().getCriterion(Criterion.Type.ETH_DST);
        boolean broadcastObjective = ethDst != null && (ethDst.mac().isBroadcast() || ethDst.mac().isMulticast());
        FilteringObjective filteringObjective = buildFilteringObjective(intent, instructions.selector(), deviceId, inPort);
        if (filteringObjective != null) {
            objectives.add(filteringObjective);
        }
        if (treatmentsWithDifferentPort.size() < 2 && !broadcastObjective) {
            objectives.addAll(createSimpleNextObjective(instructions, intent));
        } else {
            objectives.addAll(createBroadcastObjective(instructions, treatmentsWithDifferentPort, intent));
        }
    });
    return objectives;
}
Also used : EncapsulationConstraint(org.onosproject.net.intent.constraint.EncapsulationConstraint) EthCriterion(org.onosproject.net.flow.criteria.EthCriterion) ArrayList(java.util.ArrayList) DefaultTrafficTreatment(org.onosproject.net.flow.DefaultTrafficTreatment) TrafficTreatment(org.onosproject.net.flow.TrafficTreatment) Instruction(org.onosproject.net.flow.instructions.Instruction) DefaultNextObjective(org.onosproject.net.flowobjective.DefaultNextObjective) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective) NextObjective(org.onosproject.net.flowobjective.NextObjective) DefaultFilteringObjective(org.onosproject.net.flowobjective.DefaultFilteringObjective) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective) DefaultForwardingObjective(org.onosproject.net.flowobjective.DefaultForwardingObjective) Objective(org.onosproject.net.flowobjective.Objective) DefaultFilteringObjective(org.onosproject.net.flowobjective.DefaultFilteringObjective) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective)

Example 34 with FilteringObjective

use of org.onosproject.net.flowobjective.FilteringObjective in project onos by opennetworkinglab.

the class InOrderFlowObjectiveManager method dequeue.

/**
 * Dequeue flow objective. Execute the next flow objective in the queue, if any.
 *
 * @param deviceId Device ID
 * @param obj Flow objective
 * @param error ObjectiveError that triggers this dequeue. Null if this is not triggered by an error.
 */
private synchronized void dequeue(DeviceId deviceId, Objective obj, ObjectiveError error) {
    List<Objective> remaining;
    int priority = obj.priority();
    LogLevel logLevel = (obj.op() == Objective.Operation.VERIFY) ? LogLevel.TRACE : LogLevel.DEBUG;
    Tools.log(log, logLevel, "Dequeue {}", obj);
    if (obj instanceof FilteringObjective) {
        FilteringObjQueueKey k = new FilteringObjQueueKey(deviceId, priority, ((FilteringObjective) obj).key());
        if (!Objects.equals(ObjectiveError.INSTALLATIONTIMEOUT, error)) {
            filtObjQueueHead.invalidate(k);
        }
        filtObjQueue.remove(k, obj);
        remaining = filtObjQueue.get(k);
    } else if (obj instanceof ForwardingObjective) {
        ForwardingObjQueueKey k = new ForwardingObjQueueKey(deviceId, priority, ((ForwardingObjective) obj).selector());
        if (!Objects.equals(ObjectiveError.INSTALLATIONTIMEOUT, error)) {
            fwdObjQueueHead.invalidate(k);
        }
        fwdObjQueue.remove(k, obj);
        remaining = fwdObjQueue.get(k);
    } else if (obj instanceof NextObjective) {
        if (error != null) {
            // Remove pendingForwards and pendingNexts if next objective failed
            Set<PendingFlowObjective> removedForwards = pendingForwards.remove(obj.id());
            List<PendingFlowObjective> removedNexts = pendingNexts.remove(obj.id());
            if (removedForwards != null) {
                removedForwards.stream().map(PendingFlowObjective::flowObjective).forEach(pendingObj -> pendingObj.context().ifPresent(c -> c.onError(pendingObj, error)));
            }
            if (removedNexts != null) {
                removedNexts.stream().map(PendingFlowObjective::flowObjective).forEach(pendingObj -> pendingObj.context().ifPresent(c -> c.onError(pendingObj, error)));
            }
        }
        NextObjQueueKey k = new NextObjQueueKey(deviceId, obj.id());
        if (!Objects.equals(ObjectiveError.INSTALLATIONTIMEOUT, error)) {
            nextObjQueueHead.invalidate(k);
        }
        nextObjQueue.remove(k, obj);
        remaining = nextObjQueue.get(k);
    } else {
        log.error("Unknown flow objective instance: {}", obj.getClass().getName());
        return;
    }
    log.trace("{} queue size {}", obj.getClass().getSimpleName(), remaining.size());
    // Submit the next one in the queue, if any
    if (remaining.size() > 0) {
        execute(deviceId, remaining.get(0));
    }
}
Also used : NextObjective(org.onosproject.net.flowobjective.NextObjective) ArrayListMultimap(com.google.common.collect.ArrayListMultimap) ObjectiveEvent(org.onosproject.net.flowobjective.ObjectiveEvent) ListMultimap(com.google.common.collect.ListMultimap) Tools(org.onlab.util.Tools) IFOM_OBJ_TIMEOUT_MS_DEFAULT(org.onosproject.net.OsgiPropertyConstants.IFOM_OBJ_TIMEOUT_MS_DEFAULT) NextObjQueueKey(org.onosproject.net.flowobjective.NextObjQueueKey) ComponentContext(org.osgi.service.component.ComponentContext) LoggerFactory(org.slf4j.LoggerFactory) Tools.groupedThreads(org.onlab.util.Tools.groupedThreads) AtomicBoolean(java.util.concurrent.atomic.AtomicBoolean) Strings.isNullOrEmpty(com.google.common.base.Strings.isNullOrEmpty) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective) Multimaps(com.google.common.collect.Multimaps) FlowObjectiveService(org.onosproject.net.flowobjective.FlowObjectiveService) ObjectiveError(org.onosproject.net.flowobjective.ObjectiveError) Component(org.osgi.service.component.annotations.Component) Executors.newSingleThreadScheduledExecutor(java.util.concurrent.Executors.newSingleThreadScheduledExecutor) ObjectiveQueueKey(org.onosproject.net.flowobjective.ObjectiveQueueKey) Map(java.util.Map) NextObjective(org.onosproject.net.flowobjective.NextObjective) ScheduledExecutorService(java.util.concurrent.ScheduledExecutorService) Activate(org.osgi.service.component.annotations.Activate) ForwardingObjQueueKey(org.onosproject.net.flowobjective.ForwardingObjQueueKey) LogLevel(org.onlab.util.Tools.LogLevel) ExecutorService(java.util.concurrent.ExecutorService) FlowObjectiveStoreDelegate(org.onosproject.net.flowobjective.FlowObjectiveStoreDelegate) Logger(org.slf4j.Logger) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective) Deactivate(org.osgi.service.component.annotations.Deactivate) IFOM_OBJ_TIMEOUT_MS(org.onosproject.net.OsgiPropertyConstants.IFOM_OBJ_TIMEOUT_MS) Set(java.util.Set) FilteringObjQueueKey(org.onosproject.net.flowobjective.FilteringObjQueueKey) Executors.newSingleThreadExecutor(java.util.concurrent.Executors.newSingleThreadExecutor) Objects(java.util.Objects) TimeUnit(java.util.concurrent.TimeUnit) List(java.util.List) RemovalListeners(com.google.common.cache.RemovalListeners) ObjectiveContext(org.onosproject.net.flowobjective.ObjectiveContext) Objective(org.onosproject.net.flowobjective.Objective) Optional(java.util.Optional) RemovalListener(com.google.common.cache.RemovalListener) CacheBuilder(com.google.common.cache.CacheBuilder) Cache(com.google.common.cache.Cache) DeviceId(org.onosproject.net.DeviceId) ForwardingObjQueueKey(org.onosproject.net.flowobjective.ForwardingObjQueueKey) FilteringObjQueueKey(org.onosproject.net.flowobjective.FilteringObjQueueKey) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective) LogLevel(org.onlab.util.Tools.LogLevel) NextObjQueueKey(org.onosproject.net.flowobjective.NextObjQueueKey) ForwardingObjective(org.onosproject.net.flowobjective.ForwardingObjective) NextObjective(org.onosproject.net.flowobjective.NextObjective) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective) Objective(org.onosproject.net.flowobjective.Objective) FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective)

Example 35 with FilteringObjective

use of org.onosproject.net.flowobjective.FilteringObjective in project onos by opennetworkinglab.

the class FlowObjectiveCompositionManager method filter.

@Override
public void filter(DeviceId deviceId, FilteringObjective filteringObjective) {
    checkPermission(FLOWRULE_WRITE);
    List<FilteringObjective> filteringObjectives = this.deviceCompositionTreeMap.get(deviceId).updateFilter(filteringObjective);
    for (FilteringObjective tmp : filteringObjectives) {
        executorService.execute(new ObjectiveInstaller(deviceId, tmp));
    }
}
Also used : FilteringObjective(org.onosproject.net.flowobjective.FilteringObjective)

Aggregations

FilteringObjective (org.onosproject.net.flowobjective.FilteringObjective)51 DefaultFilteringObjective (org.onosproject.net.flowobjective.DefaultFilteringObjective)35 Test (org.junit.Test)32 ForwardingObjective (org.onosproject.net.flowobjective.ForwardingObjective)21 DefaultFlowRule (org.onosproject.net.flow.DefaultFlowRule)20 FlowRule (org.onosproject.net.flow.FlowRule)20 TrafficTreatment (org.onosproject.net.flow.TrafficTreatment)19 DefaultTrafficTreatment (org.onosproject.net.flow.DefaultTrafficTreatment)18 NextObjective (org.onosproject.net.flowobjective.NextObjective)17 Objective (org.onosproject.net.flowobjective.Objective)15 TrafficSelector (org.onosproject.net.flow.TrafficSelector)13 DefaultTrafficSelector (org.onosproject.net.flow.DefaultTrafficSelector)12 FlowObjectiveIntent (org.onosproject.net.intent.FlowObjectiveIntent)9 Intent (org.onosproject.net.intent.Intent)9 DefaultLink (org.onosproject.net.DefaultLink)8 DeviceId (org.onosproject.net.DeviceId)8 Link (org.onosproject.net.Link)8 FilteredConnectPoint (org.onosproject.net.FilteredConnectPoint)7 DefaultForwardingObjective (org.onosproject.net.flowobjective.DefaultForwardingObjective)7 DefaultNextObjective (org.onosproject.net.flowobjective.DefaultNextObjective)7