blob: fcd70ad8b132c2d3e899532862c5d65b2162f2b9 [file] [log] [blame]
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -08001/**
2* Copyright 2011, Big Switch Networks, Inc.
3* Originally created by David Erickson, Stanford University
4*
5* Licensed under the Apache License, Version 2.0 (the "License"); you may
6* not use this file except in compliance with the License. You may obtain
7* a copy of the License at
8*
9* http://www.apache.org/licenses/LICENSE-2.0
10*
11* Unless required by applicable law or agreed to in writing, software
12* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14* License for the specific language governing permissions and limitations
15* under the License.
16**/
17
18package net.floodlightcontroller.routing;
19
20import net.floodlightcontroller.core.module.IFloodlightService;
21import net.floodlightcontroller.routing.Route;
22
23public interface IRoutingService extends IFloodlightService {
24
25 /** Provides a route between src and dst that allows tunnels. */
26 public Route getRoute(long src, long dst);
27
28 /** Provides a route between src and dst, with option to allow or
29 * not allow tunnels in the path.*/
30 public Route getRoute(long src, long dst, boolean tunnelEnabled);
31
32
33 public Route getRoute(long srcId, short srcPort,
34 long dstId, short dstPort);
35
36 public Route getRoute(long srcId, short srcPort,
37 long dstId, short dstPort,
38 boolean tunnelEnabled);
39
40 /** Check if a route exists between src and dst, including tunnel links
41 * in the path.
42 */
43 public boolean routeExists(long src, long dst);
44
45 /** Check if a route exists between src and dst, with option to have
46 * or not have tunnels as part of the path.
47 */
48 public boolean routeExists(long src, long dst, boolean tunnelEnabled);
49}