blob: ff16376937882b9e3e38fa63dcf49798c806b37c [file] [log] [blame]
Marc De Leenheerc662d322016-02-18 16:05:10 -08001/*
Marc De Leenheer40a544b2017-04-25 14:16:02 -07002 * Copyright 2017-present Open Networking Laboratory
Marc De Leenheerc662d322016-02-18 16:05:10 -08003 *
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 */
Marc De Leenheer40a544b2017-04-25 14:16:02 -070016package org.onosproject.driver.optical.flowrule;
Marc De Leenheerc662d322016-02-18 16:05:10 -080017
18import org.apache.commons.lang3.tuple.Pair;
19import org.onosproject.net.flow.FlowId;
20
21/**
22 * Simple interface to cache flow ID and priority of cross connect flows.
23 */
Marc De Leenheer40a544b2017-04-25 14:16:02 -070024public interface CrossConnectCache {
Marc De Leenheerc662d322016-02-18 16:05:10 -080025 /**
26 * Returns the flow ID and priority corresponding to the flow hash.
27 *
28 * @param hash flow hash
29 * @return flow ID and priority, null if not in cache
30 */
31 Pair<FlowId, Integer> get(int hash);
32
33 /**
34 * Stores the flow ID and priority corresponding to the flow hash.
35 *
36 * @param hash flow hash
37 * @param flowId flow ID
38 * @param priority flow priority
39 */
40 void set(int hash, FlowId flowId, int priority);
41
42 /**
43 * Removes the given hash from the cache.
44 *
45 * @param hash flow hash
46 */
47 void remove(int hash);
48}