components/openvswitch/files/lib/dpif-solaris.c
author akshay.kale@oracle.com <akshay.kale@oracle.com>
Fri, 14 Oct 2016 13:13:27 -0700
changeset 7112 dab9beb5bc49
parent 6924 e8aaad6b5075
child 7237 c378a893371d
permissions -rw-r--r--
24843178 Method of choosing ofports need to be improved in OVS
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     1
/*
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
     2
 * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     3
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     4
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     5
/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     6
 * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2014 Nicira, Inc.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     7
 *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     8
 * Licensed under the Apache License, Version 2.0 (the "License");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
     9
 * you may not use this file except in compliance with the License.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    10
 * You may obtain a copy of the License at:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    11
 *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    12
 *     http://www.apache.org/licenses/LICENSE-2.0
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    13
 *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    14
 * Unless required by applicable law or agreed to in writing, software
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    15
 * distributed under the License is distributed on an "AS IS" BASIS,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    17
 * See the License for the specific language governing permissions and
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    18
 * limitations under the License.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    19
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    20
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    21
#include <config.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    22
#include "dpif-solaris.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    23
#include <fcntl.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    24
#include <strings.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    25
#include <unistd.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    26
#include "classifier.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    27
#include "dpif-provider.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    28
#include "dynamic-string.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    29
#include "netdev-solaris.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    30
#include "netdev-vport.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    31
#include "netlink.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    32
#include "odp-execute.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    33
#include "poll-loop.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    34
#include "shash.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    35
#include "socket-util.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    36
#include "sset.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    37
#include "vlog.h"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    38
#include <netpacket/packet.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    39
#include <zone.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    40
#include <libdllink.h>
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    41
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    42
#ifndef	MAC_OFPORT_ARRAY
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    43
/*
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    44
 * Keeping a bitbucket of each containing 64-bits (uint64_t)
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    45
 * for kernel ofports to effectively lookup a free ofport.
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    46
 */
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    47
#define	MAC_OFPORT_ARRAY		(MAC_OF_MAXPORT/64)
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    48
#define	MAC_OFPORT_ARRAY_MASK		0x3F
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    49
#define	MAC_OFPORT_ARRAY_SHIFT		6
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    50
#endif
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    51
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    52
VLOG_DEFINE_THIS_MODULE(dpif_solaris);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    53
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    54
static kstat2_handle_t	dpif_khandle;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    55
static boolean_t	kstat2_handle_initialized = B_FALSE;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    56
static struct ovs_mutex	kstat_mutex = OVS_MUTEX_INITIALIZER;
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    57
static struct ovs_mutex dp_ports_bitvector_mutex = OVS_MUTEX_INITIALIZER;
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
    58
uint64_t dp_ports_bitvector[MAC_OFPORT_ARRAY];
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    59
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    60
/* Datapath interface for the openvswitch Solaris kernel module. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    61
struct dpif_solaris {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    62
	struct dpif dpif;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    63
	dladm_handle_t dh;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    64
	int dp_ifindex;	/* datapath id */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    65
	const struct dpif_class *class;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    66
	char *name;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    67
	atomic_flag destroyed;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    68
	struct ovs_refcount ref_cnt;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    69
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    70
	/* BRIDGES */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    71
	struct ovs_rwlock bridge_rwlock;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    72
	struct hmap bridges;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    73
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    74
	/* PORT */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    75
	struct ovs_rwlock port_rwlock;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    76
	struct hmap ports;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    77
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    78
	/* FLOW */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    79
	struct ovs_rwlock flow_rwlock;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    80
	struct hmap flows OVS_GUARDED;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    81
	struct classifier cls;		/* rule, flow & mask */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    82
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    83
	/* Upcall messages. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    84
	struct ovs_rwlock upcall_lock;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    85
	bool recv_set;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    86
	int event_rfd;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
    87
	int event_wfd;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    88
	uint32_t n_handlers;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    89
	/*
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    90
	 * List of lower links of the OVS ports, over which the upcall_fd(s)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    91
	 * are created
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    92
	 */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    93
	struct hmap lowerlinks;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    94
};
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    95
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    96
struct dpif_solaris_lowerlink {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    97
	struct hmap_node node;	/* Node in dpif_solaris's 'lowerlinks'. */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    98
	char physname[MAXLINKNAMELEN];
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
    99
	struct dpif_solaris_handler *handlers;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   100
	uint32_t n_handlers;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   101
	uint32_t next_idx;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   102
	uint32_t nports;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   103
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   104
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   105
static struct ovs_mutex dp_solaris_mutex = OVS_MUTEX_INITIALIZER;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   106
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   107
/* Contains all 'struct dpif_solaris's. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   108
static struct shash dp_all_solaris OVS_GUARDED_BY(dp_solaris_mutex) =
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   109
    SHASH_INITIALIZER(&dp_all_solaris);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   110
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   111
static struct vlog_rate_limit error_rl = VLOG_RATE_LIMIT_INIT(9999, 5);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   112
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   113
struct dpif_solaris_handler {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   114
	int upcall_fd;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   115
	odp_port_t pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   116
};
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   117
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   118
struct dpif_solaris_bridge {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   119
	char *name;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   120
	struct hmap_node node;	/* Node in dpif_solaris's 'bridges'. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   121
	struct hmap ports;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   122
	struct list uplink_port_list;	/* List of all uplinks to the bridge */
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   123
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   124
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   125
struct dpif_solaris_port {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   126
	struct hmap_node node;		/* Node in dpif_solaris's 'ports'. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   127
	struct hmap_node brnode;	/* Node in dpif_bridge's 'ports'. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   128
	odp_port_t port_no;		/* OF port no of this port */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   129
	odp_port_t pf_port_no;		/* OF port no of the PF_PACKET socket */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   130
	char *type;			/* Port type as requested by user. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   131
	char *name;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   132
	char *linkname;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   133
	char *physname;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   134
	enum ovs_vport_type vtype;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   135
	struct netdev *netdev;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   136
	struct dpif_solaris_bridge *bridge;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   137
	boolean_t is_uplink;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   138
	struct list uplink_node;	/* Node in dpif_solaris_bridge's */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   139
					/* uplink_port_list */
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   140
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   141
	/* Receive the upcalls */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   142
	int upcall_fd;			/* PF_PACKET fd for MISS event */
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   143
	struct dpif_solaris_lowerlink *lowerlink;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   144
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   145
	/* Send the packet */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   146
	int xfd;			/* PF_PACKET to execute output action */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   147
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   148
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   149
struct dpif_solaris_flow {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   150
	/* Packet classification. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   151
	struct cls_rule cr;	/* Node in dpif_solaris's 'cls'. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   152
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   153
	/* Hash table index by unmasked flow. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   154
	struct hmap_node node;	/* Node in dpif_solaris's 'flows'. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   155
	struct flow flow;	/* The flow that created this entry. */
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
   156
	struct flow mask;	/* The flow that created this entry. */
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   157
	char *physname;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   158
	char flowname[MAXUSERFLOWNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   159
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   160
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   161
static void dpif_solaris_port_del__(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   162
    struct dpif_solaris_port *port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   163
    OVS_REQ_WRLOCK(dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   164
static void dpif_solaris_destroy_channels(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   165
    OVS_REQ_WRLOCK(dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   166
static int dpif_solaris_refresh_port_channel(struct dpif_solaris *dpif,
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   167
    struct dpif_solaris_port *port, boolean_t notify)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   168
    OVS_REQ_WRLOCK(dpif->port_rwlock);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   169
static void dpif_solaris_destroy_port_channel(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   170
    struct dpif_solaris_port *port);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   171
static int dpif_solaris_get_port_by_number(struct dpif_solaris *dpif,
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   172
    odp_port_t port_no, struct dpif_solaris_port **portp);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   173
    OVS_REQ_RDLOCK(dpif->port_rwlock);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   174
static int dpif_solaris_get_uplink_port_info(struct dpif_solaris *dpif,
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   175
    odp_port_t port_no, odp_port_t *uport_nop, int *xfdp,
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   176
    enum ovs_vport_type *vtypep);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   177
static void dpif_solaris_flow_remove(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   178
    struct dpif_solaris_flow *flow)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   179
    OVS_REQ_WRLOCK(dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   180
static int dpif_solaris_flow_flush__(struct dpif_solaris *dpif);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   181
static void dpif_solaris_destroy_lowerlink(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   182
    struct dpif_solaris_lowerlink *lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   183
static int dpif_solaris_create_lowerlink(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   184
    char *physname, struct dpif_solaris_lowerlink **lowerlinkp);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   185
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   186
static struct dpif_solaris *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   187
dpif_solaris_cast(const struct dpif *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   188
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   189
	dpif_assert_class(dpif, &dpif_solaris_class);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   190
	return (CONTAINER_OF(dpif, struct dpif_solaris, dpif));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   191
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   192
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   193
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   194
dpif_solaris_enumerate(struct sset *all_dps)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   195
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   196
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   197
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   198
	VLOG_DBG("dpif_solaris_enumerate");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   199
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   200
	error = solaris_init_rad();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   201
	if (error != 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   202
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   203
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   204
	if (netdev_impl_etherstub_exists()) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   205
		VLOG_DBG("dpif_solaris_enumerate ovs-system");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   206
		sset_add(all_dps, "ovs-system");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   207
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   208
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   209
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   210
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   211
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   212
dpif_solaris_open(const struct dpif_class *class, const char *name,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   213
    bool create, struct dpif **dpifp)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   214
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   215
	struct dpif_solaris *dpif;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   216
	int error = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   217
	boolean_t dp_exists;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   218
	dladm_status_t status;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   219
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   220
	VLOG_DBG("dpif_solaris_open class type %s name %s do %screate",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   221
	    class->type, name, create ? "" : "not ");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   222
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   223
	if (strcmp(name, "ovs-system") != 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   224
		return (ENODEV);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   225
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   226
	error = solaris_init_rad();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   227
	if (error != 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   228
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   229
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   230
	ovs_mutex_lock(&dp_solaris_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   231
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   232
	dp_exists = netdev_impl_etherstub_exists();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   233
	dpif = shash_find_data(&dp_all_solaris, name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   234
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   235
	/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   236
	 * The same function is shared by ovs-vswitchd and other utilities as
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   237
	 * they call into the same library. Note that for other utilities,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   238
	 * dpif does not exists at first, create it here if dp_exists indicate
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   239
	 * the datapath already exists.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   240
	 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   241
again:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   242
	if ((dp_exists && dpif == NULL) || (!dp_exists && create)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   243
		dladm_handle_t dh = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   244
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   245
		status = dladm_open(&dh);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   246
		error = solaris_dladm_status2error(status);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   247
		if (error != 0) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   248
			ovs_mutex_unlock(&dp_solaris_mutex);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   249
			return (error);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   250
		}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   251
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   252
		if (!dp_exists) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   253
			error = netdev_create_impl_etherstub();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   254
			if (error != 0) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   255
				ovs_mutex_unlock(&dp_solaris_mutex);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   256
				dladm_close(dh);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   257
				return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   258
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   259
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   260
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   261
		dpif = xzalloc(sizeof (*dpif));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   262
		dpif->dh = dh;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   263
		dpif->dp_ifindex = getzoneid();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   264
		dpif->class = class;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   265
		dpif->name = xstrdup(name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   266
		atomic_flag_clear(&dpif->destroyed);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   267
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   268
		/* UPCALL related */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   269
		ovs_rwlock_init(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   270
		dpif->recv_set = false;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   271
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   272
		/* uplink related */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   273
		ovs_rwlock_init(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   274
		hmap_init(&dpif->bridges);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   275
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   276
		/* port related */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   277
		ovs_rwlock_init(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   278
		hmap_init(&dpif->ports);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   279
		hmap_init(&dpif->lowerlinks);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   280
		dpif->event_rfd = dpif->event_wfd = -1;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   281
		dpif->n_handlers = 0;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   282
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   283
		/* flow related */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   284
		ovs_rwlock_init(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   285
		classifier_init(&dpif->cls, NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   286
		hmap_init(&dpif->flows);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   287
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   288
		ovs_refcount_init(&dpif->ref_cnt);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   289
		shash_add(&dp_all_solaris, name, dpif);
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
   290
		if (!create) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   291
			ovs_refcount_ref(&dpif->ref_cnt);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   292
			goto again;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   293
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   294
	} else if (!dp_exists) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   295
		error = ENODEV;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   296
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   297
		error = (dpif->class != class ? EOPNOTSUPP :
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   298
		    create ? EEXIST : 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   299
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   300
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   301
	if (!error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   302
		ovs_refcount_ref(&dpif->ref_cnt);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   303
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   304
		/* Choose dp_ifindex to be used as netflow engine type and id */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   305
		dpif_init(&dpif->dpif, class, name, dpif->dp_ifindex,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   306
		    dpif->dp_ifindex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   307
		*dpifp = &dpif->dpif;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   308
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   309
	ovs_mutex_unlock(&dp_solaris_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   310
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   311
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   312
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   313
/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   314
 * Requires dp_netdev_mutex so that we can't get a new reference to 'dp'
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   315
 * through the 'dp_netdevs' shash while freeing 'dp'.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   316
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   317
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   318
dp_solaris_free(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   319
    OVS_REQUIRES(dp_solaris_mutex)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   320
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   321
	struct dpif_solaris_port *port, *next;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   322
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   323
	VLOG_DBG("dp_solaris_free %s", dpif->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   324
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   325
	shash_find_and_delete(&dp_all_solaris, dpif->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   326
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   327
	HMAP_FOR_EACH_SAFE(port, next, node, &dpif->ports) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   328
		dpif_solaris_port_del__(dpif, port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   329
	}
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   330
	ovs_assert(hmap_count(&dpif->lowerlinks) == 0);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   331
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   332
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   333
	dpif_solaris_flow_flush__(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   334
	classifier_destroy(&dpif->cls);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   335
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   336
	hmap_destroy(&dpif->bridges);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   337
	ovs_rwlock_destroy(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   338
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   339
	hmap_destroy(&dpif->ports);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   340
	hmap_destroy(&dpif->lowerlinks);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   341
	ovs_rwlock_destroy(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   342
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   343
	hmap_destroy(&dpif->flows);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   344
	ovs_rwlock_destroy(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   345
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   346
	(void) close(dpif->event_rfd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   347
	(void) close(dpif->event_wfd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   348
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   349
	free(dpif->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   350
	dladm_close(dpif->dh);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   351
	netdev_delete_impl_etherstub();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   352
	ovs_rwlock_destroy(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   353
	free(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   354
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   355
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   356
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   357
dp_solaris_unref(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   358
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   359
	if (dpif != NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   360
		/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   361
		 * Take dp_solaris_mutex so that, if dpif->ref_cnt falls to
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   362
		 * zero, we can't get a hold of 'dpif'.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   363
		 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   364
		ovs_mutex_lock(&dp_solaris_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   365
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   366
		if (ovs_refcount_unref(&dpif->ref_cnt) == 2) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   367
			dp_solaris_free(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   368
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   369
		ovs_mutex_unlock(&dp_solaris_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   370
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   371
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   372
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   373
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   374
dpif_solaris_close(struct dpif *dpif_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   375
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   376
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   377
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   378
	VLOG_DBG("dpif_solaris_close %s", dpif->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   379
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   380
	ovs_rwlock_wrlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   381
	dpif_solaris_destroy_channels(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   382
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   383
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   384
	dp_solaris_unref(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   385
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   386
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   387
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   388
dpif_solaris_destroy(struct dpif *dpif_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   389
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   390
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   391
	int cnt;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   392
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   393
	VLOG_DBG("dpif_solaris_destroy %s", dpif->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   394
	if (!atomic_flag_test_and_set(&dpif->destroyed)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   395
		cnt = ovs_refcount_unref(&dpif->ref_cnt);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   396
		if (cnt <= 2) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   397
			OVS_NOT_REACHED();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   398
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   399
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   400
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   401
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   402
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   403
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   404
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   405
dpif_solaris_get_stats(const struct dpif *dpif_, struct dpif_dp_stats *stats)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   406
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   407
	struct dpif_solaris		*dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   408
	struct dpif_solaris_bridge	*bridge;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   409
	struct dpif_solaris_port	*port;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   410
	kstat2_status_t			stat;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   411
	kstat2_map_t			map;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   412
	char				kuri[1024];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   413
	char				kstat_name[MAXLINKNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   414
	char				*name;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   415
	zoneid_t			zid;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   416
	uint_t				instance;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   417
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   418
	bzero(stats, sizeof (struct dpif_dp_stats));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   419
	ovs_mutex_lock(&kstat_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   420
	if (!kstat2_handle_initialized) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   421
		VLOG_DBG("dpif_solaris_get_stats initializing handle");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   422
		if (!kstat_handle_init(&dpif_khandle)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   423
			ovs_mutex_unlock(&kstat_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   424
			VLOG_DBG("dpif_solaris_get_stats: error initializing"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   425
			    " kstat handle");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   426
			return (-1);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   427
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   428
		kstat2_handle_initialized = B_TRUE;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   429
	} else if (!kstat_handle_update(dpif_khandle)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   430
		kstat_handle_close(&dpif_khandle);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   431
		kstat2_handle_initialized = B_FALSE;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   432
		ovs_mutex_unlock(&kstat_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   433
		VLOG_DBG("dpif_solaris_get_stats: error updating kstats");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   434
		return (-1);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   435
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   436
	ovs_rwlock_rdlock(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   437
	HMAP_FOR_EACH(bridge, node, &dpif->bridges) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   438
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   439
		LIST_FOR_EACH(port, uplink_node, &bridge->uplink_port_list) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   440
			name = (char *)port->physname;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   441
			instance = 0;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   442
			if (strchr(port->physname, '/') != NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   443
				(void) solaris_dlparse_zonelinkname(
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   444
				    port->physname, kstat_name, &zid);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   445
				name = kstat_name;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   446
				instance = zid;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   447
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   448
			(void) snprintf(kuri, sizeof (kuri),
6538
a53c8be7d7b3 24356657 OVS adds VLAN flows with CFI set, but packets don't have that set
Cathy Zhou <Cathy.Zhou@Oracle.COM>
parents: 6128
diff changeset
   449
			    "kstat:/net/%s/link/%d", name, instance);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   450
			stat = kstat2_lookup_map(dpif_khandle, kuri, &map);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   451
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   452
			if (stat != KSTAT2_S_OK) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   453
				ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   454
				ovs_mutex_unlock(&kstat_mutex);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   455
				VLOG_WARN("dpif_solaris_get_stats kstat_lookup "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   456
				    "of %s failed: %s", kuri,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   457
				    kstat2_status_string(stat));
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   458
				return (-1);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   459
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   460
			stats->n_hit += (get_nvvt_int(map, "ipkthit") +
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   461
			    get_nvvt_int(map, "opkthit"));
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   462
			stats->n_missed += (get_nvvt_int(map, "ipktmiss") +
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   463
			    get_nvvt_int(map, "opktmiss"));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   464
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   465
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   466
	ovs_rwlock_unlock(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   467
	ovs_mutex_unlock(&kstat_mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   468
	stats->n_lost   = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   469
	stats->n_flows  = solaris_flow_walk(NULL, NULL, B_TRUE, NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   470
	stats->n_masks  = UINT32_MAX;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   471
	stats->n_mask_hit  = UINT64_MAX;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   472
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   473
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   474
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   475
static enum ovs_vport_type
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   476
netdev_to_ovs_vport_type(const struct netdev *netdev)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   477
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   478
	const char *type = netdev_get_type(netdev);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   479
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   480
	if (strcmp(type, "system") == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   481
		return (OVS_VPORT_TYPE_NETDEV);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   482
	} else if (strcmp(type, "internal") == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   483
		return (OVS_VPORT_TYPE_INTERNAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   484
	} else if (strcmp(type, "vxlan") == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   485
		return (OVS_VPORT_TYPE_VXLAN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   486
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   487
		return (OVS_VPORT_TYPE_UNSPEC);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   488
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   489
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   490
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   491
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   492
dpif_solaris_create_xsocket(struct dpif_solaris *dpif OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   493
    struct dpif_solaris_port *port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   494
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   495
	int fd;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   496
	struct sockaddr_ll sll;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   497
	datalink_id_t linkid;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   498
	dladm_status_t status;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   499
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   500
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   501
	if (port->vtype != OVS_VPORT_TYPE_NETDEV &&
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   502
	    port->vtype != OVS_VPORT_TYPE_VXLAN &&
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   503
	    port->vtype != OVS_VPORT_TYPE_INTERNAL)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   504
		return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   505
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   506
	if ((fd = socket(PF_PACKET, SOCK_RAW, ETH_P_ALL)) == -1) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   507
		return (errno);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   508
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   509
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   510
	status = dladm_name2info(dpif->dh, port->linkname, &linkid,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   511
	    NULL, NULL, NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   512
	error = solaris_dladm_status2error(status);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   513
	if (error != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   514
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   515
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   516
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   517
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   518
	(void) memset(&sll, 0, sizeof (sll));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   519
	sll.sll_family = AF_PACKET;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   520
	sll.sll_ifindex = linkid;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   521
	sll.sll_protocol = ETH_P_ALL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   522
	if (bind(fd, (struct sockaddr *)&sll, sizeof (sll)) == -1) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   523
		error = errno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   524
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   525
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   526
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   527
	port->xfd = fd;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   528
	VLOG_DBG("dpif_solaris_create_xsocket %d on %s port_no: %d", fd,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   529
	    port->name, port->port_no);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   530
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   531
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   532
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   533
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   534
/*
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   535
 * Choose an unused, non-zero port number and return it on success.
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   536
 * Return ODPP_NONE on failure.
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   537
 * The current approach to choose unused port number is quite inefficient,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   538
 * need improvement. TBD
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   539
 */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   540
static odp_port_t
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   541
choose_port(void)
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   542
{
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   543
	uint32_t port_no;
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   544
	uint64_t chk_bit;
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   545
	ovs_mutex_lock(&dp_ports_bitvector_mutex);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   546
	for (port_no = PORT_PF_PACKET_UPLINK + 1;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   547
	    port_no < MAC_OF_MAXPORT; port_no++) {
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   548
		chk_bit = dp_ports_bitvector[port_no >> MAC_OFPORT_ARRAY_SHIFT];
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   549
		if ((chk_bit & (1LL << (port_no & MAC_OFPORT_ARRAY_MASK))) > 0)
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   550
			continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   551
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   552
		dp_ports_bitvector[port_no >> MAC_OFPORT_ARRAY_SHIFT] |=
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   553
		    (1LL << (port_no & MAC_OFPORT_ARRAY_MASK));
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   554
		ovs_mutex_unlock(&dp_ports_bitvector_mutex);
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   555
		VLOG_DBG("dpif_solaris_choose_port: port no: %d", port_no);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   556
		return (u32_to_odp(port_no));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   557
	}
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   558
	ovs_mutex_unlock(&dp_ports_bitvector_mutex);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   559
	return (ODPP_NONE);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   560
}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   561
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   562
static void
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   563
reset_port(uint32_t port_no)
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   564
{
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   565
	ovs_mutex_lock(&dp_ports_bitvector_mutex);
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   566
	dp_ports_bitvector[port_no >> MAC_OFPORT_ARRAY_SHIFT] &=
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   567
	    ~(1LL << (port_no & MAC_OFPORT_ARRAY_MASK));
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   568
	ovs_mutex_unlock(&dp_ports_bitvector_mutex);
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   569
}
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   570
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   571
static boolean_t
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   572
pf_port_no_used(struct dpif_solaris *dpif, uint32_t pf_port_no)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   573
{
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   574
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   575
	int i;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   576
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   577
	HMAP_FOR_EACH(lowerlink, node, &dpif->lowerlinks) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   578
		for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   579
			ovs_assert(lowerlink->handlers != NULL);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   580
			ovs_assert(lowerlink->handlers[i].upcall_fd != -1);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   581
			if (lowerlink->handlers[i].pf_port_no == pf_port_no)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   582
				return (true);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   583
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   584
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   585
	return (false);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   586
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   587
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   588
/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   589
 * Choose an unused, non-zero port number and return it on success.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   590
 * Return ODPP_NONE on failure.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   591
 * The current approach to choose unused port number is quite inefficient,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   592
 * need improvement. TBD
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   593
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   594
static odp_port_t
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   595
choose_pf_port(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   596
    struct dpif_solaris_lowerlink *lowerlink, int n)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   597
    OVS_REQ_WRLOCK(dp->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   598
{
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   599
	uint32_t pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   600
	int i;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   601
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   602
	for (pf_port_no = MAC_OF_MAXPORT + 1; pf_port_no < UINT32_MAX;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   603
	    pf_port_no++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   604
		if (pf_port_no_used(dpif, pf_port_no))
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   605
			continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   606
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   607
		for (i = 0; i < n; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   608
			ovs_assert(lowerlink->handlers != NULL);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   609
			ovs_assert(lowerlink->handlers[i].upcall_fd != -1);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   610
			if (lowerlink->handlers[i].pf_port_no == pf_port_no)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   611
				break;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   612
		}
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   613
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   614
		if (i < n)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   615
			continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   616
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   617
		return (u32_to_odp(pf_port_no));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   618
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   619
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   620
	return (ODPP_NONE);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   621
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   622
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   623
static struct dpif_solaris_bridge *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   624
dpif_solaris_lookup_bridge(const struct dpif_solaris *dpif,
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   625
    const char *brname)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   626
    OVS_REQ_RDLOCK(dpif->bridge_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   627
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   628
	struct dpif_solaris_bridge *bridge;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   629
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   630
	HMAP_FOR_EACH(bridge, node, &dpif->bridges) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   631
		if (strcmp(bridge->name, brname) == 0) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   632
			return (bridge);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   633
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   634
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   635
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   636
	return (NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   637
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   638
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   639
static struct dpif_solaris_bridge *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   640
dpif_solaris_bridge_add_port(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   641
    const char *physname, struct dpif_solaris_port *port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   642
    OVS_REQ_WRLOCK(dpif->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   643
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   644
	struct dpif_solaris_bridge *bridge;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   645
	const char *brname = NULL;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   646
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   647
	ovs_rwlock_wrlock(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   648
	VLOG_DBG("dpif_solaris_bridge_add_port adding port %d to uplink %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   649
	    port->port_no, physname);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   650
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   651
	if (strcmp(physname, NETDEV_IMPL_ETHERSTUB) == 0)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   652
		brname = port->name;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   653
	else
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   654
		brname = shash_find_data(&port_to_bridge_map, port->name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   655
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   656
	if (brname == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   657
		/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   658
		 * For vxlan or for such cases where we couldn't obtain
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   659
		 * brname
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   660
		 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   661
		brname = physname;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   662
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   663
	bridge = dpif_solaris_lookup_bridge(dpif, brname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   664
	if (bridge == NULL) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   665
		VLOG_DBG("dpif_solaris_bridge_add_port creating bridge %s",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   666
		    brname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   667
		bridge = xzalloc(sizeof (*bridge));
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   668
		bridge->name = xstrdup(brname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   669
		hmap_insert(&dpif->bridges, &bridge->node,
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   670
		    hash_string(bridge->name, 0));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   671
		hmap_init(&bridge->ports);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   672
		list_init(&bridge->uplink_port_list);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   673
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   674
	port->bridge = bridge;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   675
	hmap_insert(&bridge->ports, &port->brnode,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   676
	    hash_odp_port(port->port_no));
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   677
	VLOG_DBG("dpif_solaris_bridge_add_port add port %s portno %d to "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   678
	    "bridge %s", port->name, port->port_no, brname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   679
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   680
	if ((port->is_uplink) && (port->vtype != OVS_VPORT_TYPE_VXLAN)) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   681
		VLOG_DBG("Insert port %s into bridge %s uplink_port_list",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   682
		    port->name, bridge->name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   683
		list_push_back(&bridge->uplink_port_list, &port->uplink_node);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   684
	}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   685
	ovs_rwlock_unlock(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   686
	return (bridge);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   687
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   688
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   689
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   690
dpif_solaris_bridge_del_port(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   691
    struct dpif_solaris_port *port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   692
    OVS_REQ_WRLOCK(dpif->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   693
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   694
	struct dpif_solaris_bridge *bridge = port->bridge;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   695
	struct dpif_solaris_port *i_port;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   696
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   697
	if (bridge == NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   698
		VLOG_DBG("dpif_solaris_bridge_del_port port %d not assigned "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   699
		    "to a bridge", port->port_no);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   700
		return;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   701
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   702
	VLOG_DBG("dpif_solaris_bridge_del_port deleting port %d from %s",
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   703
	    port->port_no, bridge->name);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   704
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   705
	ovs_rwlock_wrlock(&dpif->bridge_rwlock);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   706
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   707
	if ((port->is_uplink) && (port->vtype != OVS_VPORT_TYPE_VXLAN)) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   708
		/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   709
		 * The extra thing we do if it's uplink (other than vxlan)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   710
		 * is to remove the uplink port from bridge's uplink_port_list.
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   711
		 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   712
		LIST_FOR_EACH(i_port, uplink_node, &bridge->uplink_port_list) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   713
			if (strcmp(i_port->name, port->name) == 0) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   714
				list_remove(&port->uplink_node);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   715
				VLOG_DBG("dpif_solaris_port_del__: Removed the "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   716
				    "uplink %s from bridge's(%s) "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   717
				    "uplink_port_list\n", i_port->name,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   718
				    bridge->name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   719
				break;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   720
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   721
		}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   722
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   723
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   724
	hmap_remove(&bridge->ports, &port->brnode);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   725
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   726
	if (hmap_is_empty(&bridge->ports)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   727
		VLOG_DBG("dpif_solaris_bridge_del_port destroying bridge");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   728
		hmap_destroy(&bridge->ports);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   729
		hmap_remove(&dpif->bridges, &bridge->node);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   730
		free(bridge->name);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   731
		free(bridge);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   732
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   733
	ovs_rwlock_unlock(&dpif->bridge_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   734
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   735
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   736
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   737
dpif_solaris_port_add__(struct dpif_solaris *dpif, struct netdev *netdev,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   738
			odp_port_t *port_nop)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   739
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   740
	char namebuf[NETDEV_VPORT_NAME_BUFSIZE];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   741
	const char *name = netdev_vport_get_dpif_port(netdev,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   742
	    namebuf, sizeof (namebuf));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   743
	const char *linkname = netdev_get_name(netdev);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   744
	const char *type = netdev_get_type(netdev);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   745
	enum ovs_vport_type vtype;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   746
	struct dpif_solaris_port *port = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   747
	char physname[MAXLINKNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   748
	char dlbuffer[DLADM_PROP_VAL_MAX];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   749
	int error = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   750
	boolean_t is_uplink = false;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   751
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   752
	vtype = netdev_to_ovs_vport_type(netdev);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   753
	if (vtype == OVS_VPORT_TYPE_UNSPEC) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   754
		VLOG_WARN_RL(&error_rl, "%s: cannot create port `%s' because "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   755
		    "it has unsupported type `%s'", dpif_name(&dpif->dpif),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   756
		    name, type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   757
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   758
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   759
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   760
	VLOG_DBG("dpif_solaris_port_add %s (%s) type %s port_no %d vtype %d",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   761
	    name, linkname, type, *port_nop, vtype);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   762
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   763
	physname[0] = '\0';
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   764
	if (vtype == OVS_VPORT_TYPE_NETDEV || vtype == OVS_VPORT_TYPE_VXLAN ||
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   765
	    vtype == OVS_VPORT_TYPE_INTERNAL) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   766
		error = solaris_get_dlclass(linkname, dlbuffer,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   767
		    sizeof (dlbuffer));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   768
		if (error != 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   769
			return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   770
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   771
		if (solaris_is_uplink_class(dlbuffer)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   772
			if (strlcpy(physname, linkname, sizeof (physname)) >=
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   773
			    sizeof (physname))
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   774
				return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   775
			VLOG_DBG("dpif_solaris_port_add primary port %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   776
			    name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   777
			is_uplink = true;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   778
		} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   779
			error = solaris_get_dllower(linkname, dlbuffer,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   780
			    sizeof (dlbuffer));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   781
			if (error != 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   782
				return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   783
			if (strlcpy(physname, dlbuffer, sizeof (physname)) >=
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   784
			    sizeof (physname))
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   785
				return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   786
			VLOG_DBG("dpif_solaris_port_add non-primary port "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   787
			    "%s to %s", name, dlbuffer);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   788
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   789
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   790
		VLOG_DBG("dpif_solaris_port_add adding unknown type");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   791
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   792
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   793
	ovs_rwlock_wrlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   794
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   795
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   796
	if (*port_nop == ODPP_NONE) {
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   797
		*port_nop = choose_port();
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   798
		if (*port_nop == ODPP_NONE) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   799
			error = EFBIG;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   800
			goto fail;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   801
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   802
	}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   803
	if (vtype == OVS_VPORT_TYPE_NETDEV || vtype == OVS_VPORT_TYPE_VXLAN ||
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   804
	    vtype == OVS_VPORT_TYPE_INTERNAL) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   805
		uint64_t u64 = (uint32_t)(*port_nop);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   806
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   807
		VLOG_DBG("set portno %d on %s", (uint32_t)(*port_nop),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   808
		    linkname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   809
		if ((error = solaris_set_dlprop_ulong(linkname, "ofport",
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
   810
		    &u64, B_TRUE)) != 0) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   811
			VLOG_ERR("set portno %d on %s failed: %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   812
			    (uint32_t)(*port_nop), linkname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   813
			    ovs_strerror(error));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   814
			goto fail;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   815
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   816
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   817
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   818
	port = xzalloc(sizeof (*port));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   819
	port->port_no = *port_nop;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   820
	port->pf_port_no = ODPP_NONE;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   821
	port->name = xstrdup(name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   822
	port->linkname = xstrdup(linkname);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   823
	port->physname = xstrdup(physname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   824
	port->type = xstrdup(type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   825
	port->vtype = vtype;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   826
	port->netdev = netdev;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   827
	port->upcall_fd = -1;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   828
	port->xfd = -1;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   829
	port->is_uplink = is_uplink;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   830
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   831
	/* Only create the TX PF_SOCKET on the physical link */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   832
	if (is_uplink) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   833
		error = dpif_solaris_create_xsocket(dpif, port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   834
		if (error != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   835
			VLOG_ERR("dpif_solaris_create_xsocket on %s failed: %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   836
			    port->linkname, ovs_strerror(error));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   837
			goto fail;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   838
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   839
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   840
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   841
	error = dpif_solaris_refresh_port_channel(dpif, port, true);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   842
	if (error != 0) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   843
		VLOG_ERR("dpif_solaris_refresh_port_channel on %s failed %s",
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   844
		    linkname, ovs_strerror(error));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   845
		goto fail;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   846
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   847
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   848
	if (vtype == OVS_VPORT_TYPE_NETDEV || vtype == OVS_VPORT_TYPE_VXLAN ||
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   849
	    vtype == OVS_VPORT_TYPE_INTERNAL)
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   850
		(void) dpif_solaris_bridge_add_port(dpif, physname, port);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   851
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   852
	hmap_insert(&dpif->ports, &port->node, hash_odp_port(port->port_no));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   853
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   854
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   855
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   856
fail:
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   857
	if (*port_nop != ODPP_NONE)
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   858
		reset_port(odp_to_u32(*port_nop));
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   859
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   860
	if (port != NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   861
		if (port->xfd != -1)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   862
			(void) close(port->xfd);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   863
		dpif_solaris_destroy_port_channel(dpif, port);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   864
		free(port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   865
		free(port->linkname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   866
		free(port->type);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   867
		free(port->physname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   868
		free(port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   869
	}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   870
	if (vtype == OVS_VPORT_TYPE_NETDEV || vtype == OVS_VPORT_TYPE_VXLAN ||
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   871
	    vtype == OVS_VPORT_TYPE_INTERNAL) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   872
		VLOG_DBG("reset portno on %s", linkname);
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
   873
		(void) solaris_set_dlprop_ulong(linkname, "ofport", NULL,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
   874
		    B_TRUE);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   875
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   876
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   877
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   878
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   879
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   880
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   881
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   882
dpif_solaris_port_add(struct dpif *dpif_, struct netdev *netdev,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   883
    odp_port_t *port_nop)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   884
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   885
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   886
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   887
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   888
	error = dpif_solaris_port_add__(dpif, netdev, port_nop);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   889
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   890
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   891
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   892
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   893
dpif_solaris_get_port_by_number(struct dpif_solaris *dpif, odp_port_t port_no,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   894
    struct dpif_solaris_port **portp)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   895
    OVS_REQ_RDLOCK(dpif->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   896
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   897
	struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   898
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   899
	if (port_no == ODPP_NONE) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   900
		*portp = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   901
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   902
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   903
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   904
	HMAP_FOR_EACH_WITH_HASH(port, node,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   905
	    hash_odp_port(port_no), &dpif->ports) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   906
		if (port->port_no == port_no) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   907
			*portp = port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   908
			return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   909
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   910
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   911
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   912
	*portp = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   913
	return (ENOENT);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   914
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   915
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   916
static int
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   917
dpif_solaris_get_uplink_port_info(struct dpif_solaris *dpif,
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   918
    odp_port_t port_no, odp_port_t *uport_nop, int *xfdp,
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   919
    enum ovs_vport_type *vtypep)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   920
{
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   921
	struct dpif_solaris_port *port, *uport;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   922
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   923
	ovs_rwlock_rdlock(&dpif->port_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   924
	HMAP_FOR_EACH(port, node, &dpif->ports)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   925
		if (port->port_no == port_no)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   926
			break;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   927
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   928
	if (port == NULL)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   929
		goto done;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   930
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   931
	if (vtypep != NULL)
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   932
		*vtypep = port->vtype;
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
   933
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   934
	HMAP_FOR_EACH(uport, node, &dpif->ports) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   935
		if (uport->is_uplink &&
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   936
		    strcmp(port->physname, uport->linkname) == 0) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   937
			if (uport_nop != NULL)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   938
				*uport_nop = uport->port_no;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   939
			if (xfdp != NULL)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   940
				*xfdp = uport->xfd;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   941
			ovs_rwlock_unlock(&dpif->port_rwlock);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   942
			return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   943
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   944
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   945
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   946
done:
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   947
	ovs_rwlock_unlock(&dpif->port_rwlock);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   948
	return (ENOENT);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   949
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   950
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   951
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   952
dpif_solaris_port_del__(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   953
    struct dpif_solaris_port *port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   954
    OVS_REQ_WRLOCK(dpif->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   955
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   956
	VLOG_DBG("dpif_solaris_port_del__ port %s # %d", port->name,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   957
	    port->port_no);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   958
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   959
	hmap_remove(&dpif->ports, &port->node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   960
	dpif_solaris_bridge_del_port(dpif, port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   961
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   962
	if (port->xfd != -1)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   963
		(void) close(port->xfd);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   964
	dpif_solaris_destroy_port_channel(dpif, port);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   965
	if (port->vtype == OVS_VPORT_TYPE_NETDEV || port->vtype ==
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   966
	    OVS_VPORT_TYPE_VXLAN || port->vtype == OVS_VPORT_TYPE_INTERNAL) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   967
		VLOG_DBG("1.reset portno on %s", port->linkname);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   968
		(void) solaris_set_dlprop_ulong(port->linkname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   969
		    "ofport", NULL, B_TRUE);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   970
		if (port->is_uplink) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   971
			VLOG_DBG("dpif_solaris_port_del__ primary port "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   972
			    "%s", port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   973
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   974
	}
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   975
	VLOG_DBG("dpif_solaris_port_del %s close xfd %d", port->name,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
   976
	    port->xfd);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   977
7112
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   978
	reset_port(port->port_no);
dab9beb5bc49 24843178 Method of choosing ofports need to be improved in OVS
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6924
diff changeset
   979
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   980
	free(port->type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   981
	free(port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   982
	free(port->linkname);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
   983
	free(port->physname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   984
	free(port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   985
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   986
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   987
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   988
dpif_solaris_port_del(struct dpif *dpif_, odp_port_t port_no)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   989
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   990
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   991
	struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   992
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   993
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   994
	VLOG_DBG("dpif_solaris_port_del port # %d", port_no);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   995
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   996
	if (port_no == ODPP_LOCAL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   997
		VLOG_ERR("dpif_solaris_port_del invalid port # %d", port_no);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   998
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
   999
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1000
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1001
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1002
	error = dpif_solaris_get_port_by_number(dpif, port_no, &port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1003
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1004
		ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1005
		VLOG_ERR("dpif_solaris_port_del port # %d failed %d", port_no,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1006
		    error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1007
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1008
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1009
	dpif_solaris_port_del__(dpif, port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1010
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1011
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1012
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1013
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1014
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1015
dpif_solaris_port_query_by_number(const struct dpif *dpif_, odp_port_t port_no,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1016
    struct dpif_port *dpif_port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1017
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1018
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1019
	struct dpif_solaris_port *port = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1020
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1021
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1022
	ovs_rwlock_rdlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1023
	error = dpif_solaris_get_port_by_number(dpif, port_no, &port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1024
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1025
	if (!error && dpif_port) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1026
		dpif_port->name = xstrdup(port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1027
		dpif_port->type = xstrdup(port->type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1028
		dpif_port->port_no = port->port_no;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1029
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1030
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1031
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1032
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1033
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1034
dpif_solaris_port_query_by_name(const struct dpif *dpif_, const char *devname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1035
				struct dpif_port *dpif_port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1036
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1037
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1038
	struct dpif_solaris_port *port = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1039
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1040
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1041
	HMAP_FOR_EACH(port, node, &dpif->ports) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1042
		if (strcmp(port->name, devname) == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1043
			if (dpif_port) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1044
				dpif_port->name = xstrdup(devname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1045
				dpif_port->type = xstrdup(port->type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1046
				dpif_port->port_no = port->port_no;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1047
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1048
			ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1049
			return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1050
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1051
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1052
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1053
	return (ENOENT);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1054
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1055
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1056
struct dpif_solaris_port_state {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1057
	struct hmap ports;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1058
	struct ovs_rwlock port_rwlock;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1059
	uint32_t bucket;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1060
	uint32_t offset;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1061
	char *name;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1062
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1063
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1064
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1065
port_dump_start(void *arg, const char *name, char *type, odp_port_t portno)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1066
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1067
	struct dpif_solaris_port_state *state = arg;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1068
	struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1069
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1070
	port = xzalloc(sizeof (struct dpif_solaris_port));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1071
	port->name = xstrdup(name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1072
	port->type = type;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1073
	port->port_no = portno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1074
	ovs_rwlock_wrlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1075
	hmap_insert(&state->ports, &port->node, hash_odp_port(port->port_no));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1076
	ovs_rwlock_unlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1077
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1078
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1079
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1080
dpif_solaris_port_dump_start(const struct dpif *dpif_ OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1081
    void **statep)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1082
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1083
	struct dpif_solaris_port_state *state;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1084
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1085
	*statep = state = xzalloc(sizeof (struct dpif_solaris_port_state));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1086
	hmap_init(&state->ports);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1087
	ovs_rwlock_init(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1088
	solaris_port_walk(state, port_dump_start);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1089
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1090
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1091
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1092
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1093
dpif_solaris_port_dump_next(const struct dpif *dpif_ OVS_UNUSED, void *state_,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1094
    struct dpif_port *dpif_port)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1095
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1096
	struct dpif_solaris_port_state *state = state_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1097
	struct hmap_node *node;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1098
	int retval;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1099
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1100
	ovs_rwlock_wrlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1101
	node = hmap_at_position(&state->ports, &state->bucket, &state->offset);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1102
	if (node) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1103
		struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1104
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1105
		port = CONTAINER_OF(node, struct dpif_solaris_port, node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1106
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1107
		free(state->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1108
		state->name = xstrdup(port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1109
		dpif_port->name = state->name;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1110
		dpif_port->type = port->type;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1111
		dpif_port->port_no = port->port_no;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1112
		retval = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1113
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1114
		retval = EOF;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1115
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1116
	ovs_rwlock_unlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1117
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1118
	return (retval);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1119
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1120
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1121
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1122
dpif_solaris_port_dump_done(const struct dpif *dpif_ OVS_UNUSED, void *state_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1123
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1124
	struct dpif_solaris_port_state *state = state_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1125
	struct dpif_solaris_port *port, *next;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1126
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1127
	ovs_rwlock_wrlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1128
	HMAP_FOR_EACH_SAFE(port, next, node, &state->ports) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1129
		free(port->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1130
		hmap_remove(&state->ports, &port->node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1131
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1132
	ovs_rwlock_unlock(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1133
	hmap_destroy(&state->ports);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1134
	ovs_rwlock_destroy(&state->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1135
	free(state->name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1136
	free(state);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1137
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1138
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1139
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1140
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1141
dpif_solaris_port_poll(const struct dpif *dpif_ OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1142
    char **devnamep OVS_UNUSED)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1143
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1144
	return (EAGAIN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1145
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1146
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1147
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1148
dpif_solaris_port_poll_wait(const struct dpif *dpif_ OVS_UNUSED)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1149
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1150
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1151
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1152
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1153
dpif_solaris_key_to_flow(const struct nlattr *key, size_t key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1154
    struct flow *f)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1155
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1156
	if (odp_flow_key_to_flow(key, key_len, f)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1157
		/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1158
		 * This should not happen: it indicates that
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1159
		 * odp_flow_key_from_flow() and odp_flow_key_to_flow()
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1160
		 * disagree on the acceptable form of a flow.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1161
		 * Log the problem as an error, with enough details to enable
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1162
		 * debugging.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1163
		 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1164
		static struct vlog_rate_limit rl = VLOG_RATE_LIMIT_INIT(1, 5);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1165
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1166
		if (!VLOG_DROP_ERR(&rl)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1167
			struct ds s;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1168
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1169
			ds_init(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1170
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1171
			odp_flow_format(key, key_len, NULL, 0, NULL, &s, true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1172
			VLOG_ERR("internal error parsing flow key %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1173
			    ds_cstr(&s));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1174
			ds_destroy(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1175
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1176
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1177
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1178
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1179
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1180
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1181
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1182
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1183
dpif_solaris_key_to_mask(const struct nlattr *key, uint32_t key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1184
    const struct nlattr *mask_key, uint32_t mask_key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1185
    const struct flow *f, struct flow *m)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1186
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1187
	enum mf_field_id id;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1188
	enum odp_key_fitness fitness;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1189
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1190
	/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1191
	 * Force unwildcard the in_port.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1192
	 * We need to do this even in the case where we unwildcard "everything"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1193
	 * above because "everything" only includes the 16-bit OpenFlow port
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1194
	 * number mask->in_port.ofp_port, which only covers half of the 32-bit
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1195
	 * datapath port number mask->in_port.odp_port.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1196
	 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1197
	m->in_port.odp_port = ODPP_NONE;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1198
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1199
	if (!mask_key_len) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1200
		/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1201
		 * No mask key, unwildcard everything except fields whose
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1202
		 * prerequisities are not met.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1203
		 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1204
		memset(m, 0x0, sizeof (*m));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1205
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1206
		for (id = 0; id < MFF_N_IDS; ++id) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1207
			/* Skip registers and metadata. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1208
			if (!(id >= MFF_REG0 && id < MFF_REG0 + FLOW_N_REGS) &&
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1209
			    id != MFF_METADATA) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1210
				const struct mf_field *mf = mf_from_id(id);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1211
				if (mf_are_prereqs_ok(mf, f)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1212
					mf_mask_field(mf, m);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1213
				}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1214
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1215
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1216
		return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1217
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1218
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1219
	fitness = odp_flow_key_to_mask(mask_key, mask_key_len, m, f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1220
	if (fitness) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1221
		/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1222
		 * This should not happen: it indicates that
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1223
		 * odp_flow_key_from_mask() and odp_flow_key_to_mask()
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1224
		 * disagree on the acceptable form of a mask.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1225
		 * Log the problem as an error, with enough details to
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1226
		 * enable debugging.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1227
		 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1228
		static struct vlog_rate_limit rl = VLOG_RATE_LIMIT_INIT(1, 5);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1229
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1230
		if (!VLOG_DROP_ERR(&rl)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1231
			struct ds s;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1232
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1233
			ds_init(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1234
			odp_flow_format(key, key_len, mask_key, mask_key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1235
			    NULL, &s, true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1236
			VLOG_ERR("internal error parsing flow mask %s (%s)",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1237
			    ds_cstr(&s), odp_key_fitness_to_string(fitness));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1238
			ds_destroy(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1239
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1240
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1241
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1242
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1243
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1244
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1245
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1246
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1247
static struct dpif_solaris_flow *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1248
dpif_solaris_flow_cast(const struct cls_rule *cr)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1249
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1250
	return (cr ? CONTAINER_OF(cr, struct dpif_solaris_flow, cr) : NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1251
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1252
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1253
static struct dpif_solaris_flow *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1254
dpif_solaris_lookup_flow(const struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1255
    const struct miniflow *key)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1256
    OVS_EXCLUDED(dpif->cls.rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1257
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1258
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1259
	struct cls_rule *rule;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1260
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1261
	fat_rwlock_rdlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1262
	rule = classifier_lookup_miniflow_first(&dpif->cls, key);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1263
	solaris_flow = dpif_solaris_flow_cast(rule);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1264
	fat_rwlock_unlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1265
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1266
	return (solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1267
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1268
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1269
static struct dpif_solaris_flow *
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1270
dpif_solaris_find_flow(const struct dpif_solaris *dpif, const struct flow *flow)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1271
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1272
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1273
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1274
	HMAP_FOR_EACH_WITH_HASH(solaris_flow, node, flow_hash(flow, 0),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1275
	    &dpif->flows) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1276
		if (flow_equal(&solaris_flow->flow, flow)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1277
			return (solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1278
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1279
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1280
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1281
	return (NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1282
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1283
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1284
static struct dpif_solaris_flow *
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1285
dpif_solaris_find_flow_by_name(const struct dpif_solaris *dpif,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1286
    const char *flowname)
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1287
{
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1288
	struct dpif_solaris_flow *solaris_flow;
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1289
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1290
	HMAP_FOR_EACH(solaris_flow, node, &dpif->flows) {
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1291
		if (strcmp(solaris_flow->flowname, flowname) == 0) {
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1292
			return (solaris_flow);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1293
		}
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1294
	}
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1295
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1296
	return (NULL);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1297
}
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1298
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1299
static struct dpif_solaris_flow *
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1300
dpif_solaris_flow_add(struct dpif_solaris *dpif, const char *physname,
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1301
    struct flow *flow, struct flow *mask, const struct flow_wildcards *wc)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1302
    OVS_REQ_WRLOCK(dpif->flow_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1303
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1304
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1305
	struct match match;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1306
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1307
	solaris_flow = xzalloc(sizeof (*solaris_flow));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1308
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1309
	solaris_flow->physname = xstrdup(physname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1310
	(void) snprintf(solaris_flow->flowname, MAXUSERFLOWNAMELEN,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1311
	    "%p.sys.of", (void *)solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1312
	solaris_flow->flow = *flow;
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1313
	solaris_flow->mask = *mask;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1314
	match_init(&match, flow, wc);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1315
	fat_rwlock_wrlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1316
	cls_rule_init(&solaris_flow->cr, &match, 0x8001);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1317
	hmap_insert(&dpif->flows, &solaris_flow->node, flow_hash(flow, 0));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1318
	classifier_insert(&dpif->cls, &solaris_flow->cr);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1319
	fat_rwlock_unlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1320
	return (solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1321
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1322
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1323
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1324
dpif_solaris_flow_remove(struct dpif_solaris *dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1325
    struct dpif_solaris_flow *solaris_flow) OVS_REQ_WRLOCK(dpif->flow_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1326
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1327
	struct cls_rule *cr;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1328
	struct hmap_node *node;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1329
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1330
	fat_rwlock_wrlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1331
	cr = &solaris_flow->cr;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1332
	node = CONST_CAST(struct hmap_node *, &solaris_flow->node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1333
	classifier_remove(&dpif->cls, cr);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1334
	hmap_remove(&dpif->flows, node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1335
	cls_rule_destroy(CONST_CAST(struct cls_rule *, cr));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1336
	fat_rwlock_unlock(&dpif->cls.rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1337
	free(solaris_flow->physname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1338
	free(solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1339
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1340
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1341
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1342
dpif_solaris_get_flowstats(char *flowname, struct dpif_flow_stats *stats)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1343
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1344
	uint64_t npackets, nbytes, lastused;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1345
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1346
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1347
	bzero(stats, sizeof (*stats));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1348
	error = solaris_get_flowstats(flowname, &npackets, &nbytes, &lastused);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1349
	if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1350
		stats->n_packets = npackets;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1351
		stats->n_bytes = nbytes;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1352
		stats->used = lastused / 1000000;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1353
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1354
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1355
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1356
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1357
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1358
dpif_solaris_flow_get(const struct dpif *dpif_,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1359
    const struct nlattr *key, size_t key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1360
    struct ofpbuf **bufp,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1361
    struct nlattr **maskp, size_t *mask_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1362
    struct nlattr **actionsp, size_t *actions_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1363
    struct dpif_flow_stats *stats)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1364
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1365
	const struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1366
	struct flow f, m;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1367
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1368
	char flowname[MAXUSERFLOWNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1369
	struct ofpbuf actions;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1370
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1371
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1372
	VLOG_DBG("dpif_solaris_flow_get");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1373
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1374
	error = dpif_solaris_key_to_flow(key, key_len, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1375
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1376
		VLOG_ERR("dpif_solaris_key_to_flow failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1377
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1378
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1379
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1380
	ovs_rwlock_rdlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1381
	solaris_flow = dpif_solaris_find_flow(dpif, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1382
	if (solaris_flow == NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1383
		ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1384
		error = ENOENT;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1385
		VLOG_ERR("dpif_solaris_flow_get failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1386
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1387
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1388
	(void) strlcpy(flowname, solaris_flow->flowname, MAXUSERFLOWNAMELEN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1389
	error = solaris_get_flowattr(flowname, &f, &m);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1390
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1391
		VLOG_ERR("solaris_get_flowattr failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1392
		ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1393
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1394
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1395
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1396
	ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1397
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1398
	/* Allocate buffer big enough for everything. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1399
	*bufp = ofpbuf_new(4096);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1400
	ofpbuf_init(*bufp, 4096);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1401
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1402
	/* Mask. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1403
	odp_flow_key_from_mask(*bufp, &m, &f, m.in_port.odp_port,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1404
	    SIZE_MAX);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1405
	*maskp = ofpbuf_data(*bufp);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1406
	*mask_len = ofpbuf_size(*bufp);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1407
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1408
	/* Actions. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1409
	ofpbuf_init(&actions, 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1410
	(void) solaris_get_flowaction(flowname, &actions);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1411
	if (ofpbuf_size(&actions) == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1412
		*actionsp = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1413
		*actions_len = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1414
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1415
		*actionsp = ofpbuf_put(*bufp, ofpbuf_data(&actions),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1416
		    ofpbuf_size(&actions));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1417
		*actions_len = ofpbuf_size(&actions);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1418
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1419
	ofpbuf_uninit(&actions);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1420
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1421
	/* Stats. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1422
	error = dpif_solaris_get_flowstats(flowname, stats);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1423
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1424
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1425
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1426
int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1427
dpif_solaris_get_priority_details(void *cookie, odp_port_t outport,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1428
    uint_t queueid, struct smap *details)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1429
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1430
	struct dpif_solaris		*dpif = (struct dpif_solaris *)cookie;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1431
	struct dpif_solaris_port	*port = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1432
	int				error = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1433
	struct netdev			*netdev;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1434
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1435
	VLOG_DBG("dpif_solaris_get_priority_details: "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1436
	" Port : %d, Queue: %d\n", outport, queueid);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1437
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1438
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1439
	error = dpif_solaris_get_port_by_number(dpif, outport, &port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1440
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1441
	if (error != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1442
		VLOG_DBG("dpif_solaris_get_priority_details: "
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  1443
		"failed to get port %d\n", outport);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1444
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1445
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1446
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1447
	netdev = port->netdev;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1448
	error = netdev_get_queue(netdev, queueid, details);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1449
	if (error != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1450
		VLOG_DBG("dpif_solaris_get_priority_details: "
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  1451
		"failed to get queue %d\n", queueid);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1452
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1453
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1454
	VLOG_DBG("dpif_solaris_get_priority_details: done");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1455
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1456
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1457
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1458
void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1459
dpif_log(int err, const char *fmt, ...)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1460
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1461
	va_list ap;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1462
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1463
	va_start(ap, fmt);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1464
	if (err == 0)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1465
		vlog_valist(THIS_MODULE, VLL_DBG, fmt, ap);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1466
	else
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1467
		vlog_valist(THIS_MODULE, VLL_ERR, fmt, ap);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1468
	va_end(ap);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1469
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1470
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1471
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1472
dpif_solaris_flow_put(struct dpif *dpif_, const struct dpif_flow_put *put)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1473
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1474
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1475
	struct flow f;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1476
	struct flow_wildcards wc;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1477
	struct miniflow miniflow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1478
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1479
	char flowname[MAXUSERFLOWNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1480
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1481
	struct ds fs, as;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1482
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1483
	VLOG_DBG("dpif_solaris_flow_put");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1484
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1485
	ds_init(&fs);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1486
	ds_init(&as);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1487
	odp_flow_format(put->key, put->key_len, put->mask,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1488
	    put->mask_len, NULL, &fs, true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1489
	ds_put_cstr(&as, ", actions:");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1490
	format_odp_actions(&as, put->actions, put->actions_len);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1491
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1492
	error = dpif_solaris_key_to_flow(put->key, put->key_len, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1493
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1494
		VLOG_ERR("dpif_solaris_key_to_flow failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1495
		goto done;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1496
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1497
	error = dpif_solaris_key_to_mask(put->key, put->key_len, put->mask,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1498
	    put->mask_len, &f, &wc.masks);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1499
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1500
		VLOG_ERR("dpif_solaris_key_to_mask failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1501
		goto done;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1502
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1503
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1504
	miniflow_init(&miniflow, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1505
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1506
	ovs_rwlock_wrlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1507
	solaris_flow = dpif_solaris_lookup_flow(dpif, &miniflow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1508
	miniflow_destroy(&miniflow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1509
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1510
	if (solaris_flow == NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1511
		if (put->flags & DPIF_FP_CREATE) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1512
			struct dpif_solaris_port *port = NULL;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1513
			odp_port_t		inport;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1514
			char			physname[MAXLINKNAMESPECIFIER];
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1515
			char			portname[MAXLINKNAMESPECIFIER];
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1516
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1517
			inport = f.in_port.odp_port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1518
			ovs_rwlock_rdlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1519
			error = dpif_solaris_get_port_by_number(dpif, inport,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1520
			    &port);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1521
			if (error == 0) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1522
				(void) strlcpy(physname, port->physname,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1523
				    sizeof (physname));
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1524
				(void) strlcpy(portname, port->name,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1525
				    sizeof (portname));
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1526
			}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1527
			ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1528
			if (error == 0) {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1529
				VLOG_DBG("dpif_solaris_flow_put on %s",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1530
				    physname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1531
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1532
				solaris_flow = dpif_solaris_flow_add(dpif,
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1533
				    physname, &f, &wc.masks, &wc);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1534
				(void) strlcpy(flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1535
				    solaris_flow->flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1536
				    MAXUSERFLOWNAMELEN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1537
				VLOG_DBG("dpif_solaris_flow_put %s mask %s "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1538
				    "actions %s", flowname, ds_cstr(&fs),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1539
				    ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1540
				/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1541
				 * workaround to passing a struct dpif to
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1542
				 * solaris_add_flow adding dpif_provider.h to
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1543
				 * util-solaris brings up a conflict in
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1544
				 * Solaris's list and the OVS list
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1545
				 * implementations.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1546
				 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1547
				error = solaris_add_flow((void *)dpif,
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1548
				    physname, flowname, &f,
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1549
				    &wc.masks, put->actions, put->actions_len);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1550
				if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1551
					VLOG_DBG("dpif_solaris_flow_put "
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1552
					    "solaris_add_flow %s on %s succeed"
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1553
					    "(port:%s)",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1554
					    flowname, physname, portname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1555
				} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1556
					VLOG_ERR("dpif_solaris_flow_put "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1557
					    "solaris_add_flow %s on %s failed "
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1558
					    "(port:%s)"
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1559
					    "%d", flowname,
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1560
					    physname,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1561
					    portname,
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1562
					    error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1563
					dpif_solaris_flow_remove(dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1564
					    solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1565
				}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1566
			} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1567
				VLOG_DBG("dpif_solaris_flow_put(): "
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  1568
				    "failed to get inport %d\n", inport);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1569
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1570
		} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1571
			VLOG_ERR("dpif_solaris_flow_put mask %s "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1572
			    "actions %s not found", ds_cstr(&fs),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1573
			    ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1574
			error = ENOENT;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1575
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1576
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1577
		VLOG_DBG("dpif_solaris_flow_put exsting flow %s found for"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1578
		    " mask %s actions %s", solaris_flow->flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1579
		    ds_cstr(&fs), ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1580
		if ((put->flags & DPIF_FP_MODIFY) &&
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1581
		    flow_equal(&f, &solaris_flow->flow)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1582
			(void) strlcpy(flowname, solaris_flow->flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1583
			    MAXUSERFLOWNAMELEN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1584
			error = solaris_modify_flow((void *)dpif,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1585
			    flowname, put->actions, put->actions_len);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1586
			if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1587
				VLOG_DBG("dpif_solaris_flow_put "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1588
				    "exsting flow %s found and updated,"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1589
				    "for mask %s actions %s", flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1590
				    ds_cstr(&fs), ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1591
			} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1592
				VLOG_ERR("dpif_solaris_flow_put "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1593
				    "exsting flow %s found but update "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1594
				    "failed %d, for mask %s actions %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1595
				    flowname, error, ds_cstr(&fs),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1596
				    ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1597
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1598
		} else if (put->flags & DPIF_FP_CREATE) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1599
			VLOG_DBG("dpif_solaris_flow_put existing flow "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1600
			    "%s already exists for mask %s actions %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1601
			    solaris_flow->flowname, ds_cstr(&fs),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1602
			    ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1603
			error = EEXIST;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1604
		} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1605
			/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1606
			 * Overlapping flow. (Flow & Mask) matches but flow
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1607
			 * itself does not match
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1608
			 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1609
			VLOG_ERR("dpif_solaris_flow_put overlapped "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1610
			    "with existing flow %s, for mask %s actions %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1611
			    solaris_flow->flowname, ds_cstr(&fs),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1612
			    ds_cstr(&as));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1613
			error = EINVAL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1614
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1615
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1616
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1617
	if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1618
		if (put->stats) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1619
			if (dpif_solaris_get_flowstats(flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1620
			    put->stats) == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1621
				VLOG_DBG("dpif_solaris_flow_put "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1622
				    "get_flowstats %s succeed", flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1623
			} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1624
				VLOG_ERR("dpif_solaris_flow_put "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1625
				    "get_flowstats %s failed", flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1626
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1627
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1628
		/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1629
		 * If DPIF_FP_MODIFY and DPIF_FP_ZERO_STATS is set in
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1630
		 * put->flags, we should zero out the statistics of the
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1631
		 * given flow. This is currently not supported, and so far,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1632
		 * we don't see any problem yet.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1633
		 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1634
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1635
	ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1636
done:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1637
	ds_destroy(&fs);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1638
	ds_destroy(&as);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1639
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1640
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1641
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1642
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1643
dpif_solaris_flow_del(struct dpif *dpif_, const struct dpif_flow_del *del)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1644
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1645
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1646
	struct dpif_solaris_flow *solaris_flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1647
	char flowname[MAXUSERFLOWNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1648
	char *physname;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1649
	struct flow f;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1650
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1651
	struct ds fs;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1652
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1653
	ds_init(&fs);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1654
	odp_flow_format(del->key, del->key_len, NULL, 0, NULL, &fs, true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1655
	VLOG_DBG("dpif_solaris_flow_del %s", ds_cstr(&fs));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1656
	ds_destroy(&fs);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1657
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1658
	error = dpif_solaris_key_to_flow(del->key, del->key_len, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1659
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1660
		VLOG_ERR("dpif_solaris_key_to_flow failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1661
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1662
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1663
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1664
	ovs_rwlock_wrlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1665
	solaris_flow = dpif_solaris_find_flow(dpif, &f);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1666
	if (solaris_flow == NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1667
		ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1668
		error = ENOENT;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1669
		VLOG_ERR("dpif_solaris_flow_del failed %d", error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1670
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1671
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1672
	(void) strlcpy(flowname, solaris_flow->flowname, MAXUSERFLOWNAMELEN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1673
	physname = xstrdup(solaris_flow->physname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1674
	dpif_solaris_flow_remove(dpif, solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1675
	if (del->stats) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1676
		error = dpif_solaris_get_flowstats(flowname, del->stats);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1677
		if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1678
			VLOG_DBG("dpif_solaris_flow_del "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1679
			    "get_flowstats %s succeed", flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1680
		} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1681
			VLOG_ERR("dpif_solaris_flow_del "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1682
			    "get_flowstats %s failed %d", flowname, error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1683
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1684
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1685
	error = solaris_remove_flow(physname, flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1686
	if (error == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1687
		VLOG_DBG("dpif_solaris_flow_del solaris_remove_flow %s "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1688
		    "succeed", flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1689
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1690
		VLOG_ERR("dpif_solaris_flow_del solaris_remove_flow %s "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1691
		    "failed %d", flowname, error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1692
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1693
	ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1694
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1695
	free(physname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1696
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1697
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1698
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1699
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1700
dpif_solaris_flow_flush__(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1701
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1702
	struct dpif_solaris_flow *solaris_flow, *next;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1703
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1704
	ovs_rwlock_wrlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1705
	HMAP_FOR_EACH_SAFE(solaris_flow, next, node, &dpif->flows) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1706
		(void) solaris_remove_flow(solaris_flow->physname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1707
		    solaris_flow->flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1708
		dpif_solaris_flow_remove(dpif, solaris_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1709
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1710
	ovs_rwlock_unlock(&dpif->flow_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1711
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1712
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1713
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1714
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1715
dpif_solaris_flow_flush(struct dpif *dpif_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1716
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1717
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1718
	return (dpif_solaris_flow_flush__(dpif));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1719
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1720
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1721
struct dpif_solaris_flow_state {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1722
	struct odputil_keybuf keybuf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1723
	struct odputil_keybuf maskbuf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1724
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1725
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1726
struct dpif_solaris_flow_ent {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1727
	struct hmap_node node;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1728
	char flowname[MAXUSERFLOWNAMELEN];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1729
	struct flow f;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1730
	struct flow m;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1731
	struct ofpbuf action;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1732
	struct dpif_flow_stats stats;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1733
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1734
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1735
struct dpif_solaris_flow_iter {
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1736
	struct dpif_solaris *dpif;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1737
	struct hmap flows;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1738
	uint32_t bucket;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1739
	uint32_t offset;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1740
	int status;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1741
	struct ovs_mutex mutex;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1742
};
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1743
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1744
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1745
dpif_solaris_flow_dump_state_init(void **statep)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1746
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1747
	struct dpif_solaris_flow_state *state;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1748
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1749
	*statep = state = xmalloc(sizeof (*state));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1750
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1751
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1752
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1753
dpif_solaris_flow_dump_state_uninit(void *state_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1754
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1755
	struct dpif_solaris_flow_state *state = state_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1756
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1757
	free(state);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1758
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1759
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1760
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1761
walk_flow(void *arg, const char *name, boolean_t is_default, struct flow *f,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1762
    struct flow *m, struct ofpbuf *action, uint64_t npackets, uint64_t nbytes,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1763
    uint64_t lastused)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1764
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1765
	struct dpif_solaris_flow_iter *iter = arg;
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1766
	struct dpif_solaris *dpif = iter->dpif;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1767
	struct dpif_solaris_flow_ent *flow;
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1768
	struct dpif_solaris_flow *dsflow;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1769
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1770
	VLOG_DBG("dpif_solaris_flow_dump_start walk flow %s", name);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1771
	ovs_assert(!is_default);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1772
	flow = xzalloc(sizeof (*flow));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1773
	strlcpy(flow->flowname, name, sizeof (flow->flowname));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1774
	bcopy(f, &flow->f, sizeof (*f));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1775
	bcopy(m, &flow->m, sizeof (*m));
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1776
	fat_rwlock_rdlock(&dpif->cls.rwlock);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1777
	if ((dsflow = dpif_solaris_find_flow_by_name(dpif, name)) != NULL) {
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1778
		bcopy(&dsflow->flow, &flow->f, sizeof (struct flow));
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1779
		bcopy(&dsflow->mask, &flow->m, sizeof (struct flow));
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1780
		VLOG_DBG("dpif_solaris_flow_dump_start walk flow %s found "
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1781
		    "tunnel 0x%lx src 0x%x dst 0x%x\n", name,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1782
		    flow->f.tunnel.tun_id, flow->f.tunnel.ip_src,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1783
		    flow->f.tunnel.ip_dst);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1784
	} else {
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1785
		VLOG_DBG("dpif_solaris_flow_dump_start walk flow %s not found"
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1786
		    "\n", name);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1787
	}
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1788
	fat_rwlock_unlock(&dpif->cls.rwlock);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1789
	flow->stats.n_packets = npackets;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1790
	flow->stats.n_bytes = nbytes;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1791
	flow->stats.used = lastused / 1000000;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1792
	ofpbuf_init(&flow->action, 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1793
	if (ofpbuf_size(action) != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1794
		ofpbuf_put(&flow->action, ofpbuf_data(action),
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1795
		    ofpbuf_size(action));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1796
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1797
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1798
	hmap_insert(&iter->flows, &flow->node,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1799
	    hash_words((const uint32_t *)flow, sizeof (*flow) / 4, 0));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1800
	ofpbuf_reinit(action, 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1801
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1802
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1803
static int
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1804
dpif_solaris_flow_dump_start(const struct dpif *dpif_, void **iterp)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1805
{
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1806
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1807
	struct dpif_solaris_flow_iter *iter;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1808
	struct ofpbuf action;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1809
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1810
	*iterp = iter = xmalloc(sizeof (*iter));
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1811
	iter->dpif = dpif;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1812
	iter->bucket = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1813
	iter->offset = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1814
	iter->status = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1815
	hmap_init(&iter->flows);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1816
	ovs_mutex_init(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1817
	ovs_mutex_lock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1818
	ofpbuf_init(&action, 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1819
	(void) solaris_flow_walk(iter, &action, B_TRUE, walk_flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1820
	ofpbuf_uninit(&action);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1821
	ovs_mutex_unlock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1822
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1823
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1824
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1825
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1826
dpif_solaris_flow_dump_next(const struct dpif *dpif_ OVS_UNUSED, void *iter_,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1827
    void *state_, const struct nlattr **key, size_t *key_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1828
    const struct nlattr **mask, size_t *mask_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1829
    const struct nlattr **actions, size_t *actions_len,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1830
    const struct dpif_flow_stats **stats)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1831
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1832
	struct dpif_solaris_flow_iter *iter = iter_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1833
	struct dpif_solaris_flow_state *state = state_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1834
	struct dpif_solaris_flow_ent *flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1835
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1836
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1837
	ovs_mutex_lock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1838
	error = iter->status;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1839
	if (!error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1840
		struct hmap_node *node;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1841
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1842
		node = hmap_at_position(&iter->flows, &iter->bucket,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1843
		    &iter->offset);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1844
		if (node) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1845
			flow = CONTAINER_OF(node,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1846
			    struct dpif_solaris_flow_ent, node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1847
			VLOG_DBG("dpif_solaris_flow_dump_next %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1848
			    flow->flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1849
		} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1850
			iter->status = error = EOF;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1851
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1852
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1853
	ovs_mutex_unlock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1854
	if (error) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1855
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1856
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1857
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1858
	if (key) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1859
		struct ofpbuf buf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1860
		struct ds s;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1861
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1862
		ofpbuf_use_stack(&buf, &state->keybuf, sizeof (state->keybuf));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1863
		odp_flow_key_from_flow(&buf, &flow->f, &flow->m,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1864
		    flow->f.in_port.odp_port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1865
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1866
		*key = ofpbuf_data(&buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1867
		*key_len = ofpbuf_size(&buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1868
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1869
		ds_init(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1870
		odp_flow_format(*key, *key_len, NULL, 0, NULL, &s, true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1871
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1872
		VLOG_DBG("dpif_solaris_flow_dump_next %s key %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1873
		    flow->flowname, ds_cstr(&s));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1874
		ds_destroy(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1875
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1876
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1877
	if (key && mask) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1878
		struct ofpbuf buf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1879
		struct ds s;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1880
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1881
		ofpbuf_use_stack(&buf, &state->maskbuf,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1882
		    sizeof (state->maskbuf));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1883
		odp_flow_key_from_mask(&buf, &flow->m, &flow->m,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1884
		    flow->f.in_port.odp_port, SIZE_MAX);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1885
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1886
		*mask = ofpbuf_data(&buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1887
		*mask_len = ofpbuf_size(&buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1888
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1889
		ds_init(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1890
		odp_flow_format(*key, *key_len, *mask, *mask_len, NULL, &s,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1891
		    true);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1892
		VLOG_DBG("dpif_solaris_flow_dump_next %s mask %s "
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1893
		    "mask_key_len %"PRIuSIZE, flow->flowname,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1894
		    ds_cstr(&s), *mask_len);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1895
		ds_destroy(&s);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1896
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1897
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1898
	if (actions || stats) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1899
		if (actions) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1900
			*actions = ofpbuf_data(&flow->action);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1901
			*actions_len = ofpbuf_size(&flow->action);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1902
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1903
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1904
		if (stats) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1905
			*stats = &flow->stats;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1906
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1907
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1908
	VLOG_DBG("dpif_solaris_flow_dump_next %s succeed",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1909
	    flow->flowname);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1910
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1911
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1912
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1913
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1914
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1915
dpif_solaris_flow_dump_done(const struct dpif *dpif OVS_UNUSED, void *iter_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1916
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1917
	struct dpif_solaris_flow_iter *iter = iter_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1918
	struct dpif_solaris_flow_ent *flow, *next;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1919
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1920
	ovs_mutex_lock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1921
	HMAP_FOR_EACH_SAFE(flow, next, node, &iter->flows) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1922
		ofpbuf_uninit(&flow->action);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1923
		hmap_remove(&iter->flows, &flow->node);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1924
		free(flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1925
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1926
	ovs_mutex_unlock(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1927
	hmap_destroy(&iter->flows);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1928
	ovs_mutex_destroy(&iter->mutex);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1929
	free(iter);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1930
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1931
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1932
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1933
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1934
dpif_solaris_port_output(struct dpif_solaris *dpif, odp_port_t port_no,
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1935
    struct ofpbuf *packet, struct flow_tnl *tnl, bool may_steal)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1936
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1937
	struct msghdr			msghdr;
6557
dc9edc6fb773 23531185 Conditional MAC_OVS_AUX_DATA_VERSION code should be removed from OVS
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 6556
diff changeset
  1938
	struct iovec			iov;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1939
	struct cmsghdr			*cmsg;
6557
dc9edc6fb773 23531185 Conditional MAC_OVS_AUX_DATA_VERSION code should be removed from OVS
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 6556
diff changeset
  1940
	struct tpacket_auxdata		auxdata;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1941
	char coutmsg[sizeof (auxdata) + sizeof (*cmsg) + _CMSG_HDR_ALIGNMENT];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1942
	size_t		nwritten;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1943
	ssize_t		nbytes = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1944
	const char	*buf = ofpbuf_data(packet);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1945
	size_t		buflen = ofpbuf_size(packet);
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1946
	int		error, fd = -1;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1947
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1948
	VLOG_DBG("dpif_solaris_port_output %d tunnel %ld", port_no,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1949
	    tnl == NULL ? 0 : tnl->tun_id);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1950
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  1951
	error = dpif_solaris_get_uplink_port_info(dpif, port_no, NULL,
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  1952
	    &fd, NULL);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  1953
	if (error != 0 || fd == -1) {
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1954
		if (may_steal) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1955
			ofpbuf_delete(packet);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1956
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1957
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1958
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1959
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1960
	bzero(&msghdr, sizeof (msghdr));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1961
	msghdr.msg_iov = &iov;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1962
	msghdr.msg_iovlen = 1;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1963
	msghdr.msg_control = (void *)_CMSG_HDR_ALIGN(coutmsg);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1964
	msghdr.msg_controllen = sizeof (*cmsg) + sizeof (auxdata);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1965
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1966
	iov.iov_len = buflen;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1967
	iov.iov_base = (char *)buf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1968
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1969
	cmsg = CMSG_FIRSTHDR(&msghdr);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1970
	cmsg->cmsg_level = SOL_PACKET;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1971
	cmsg->cmsg_type = PACKET_AUXDATA;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1972
	cmsg->cmsg_len = CMSG_DATA(cmsg) + sizeof (auxdata) - (uchar_t *)cmsg;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1973
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1974
	memcpy(&auxdata, CMSG_DATA(cmsg), sizeof (auxdata));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1975
	auxdata.tp_of_port = port_no;
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1976
	auxdata.tp_tun_id = 0;
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1977
	IN6_IPADDR_TO_V4MAPPED(0, &auxdata.tp_tun_dstip);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1978
	if (tnl != NULL) {
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1979
		auxdata.tp_tun_type = 0;
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1980
		auxdata.tp_tun_id = htonll(tnl->tun_id);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1981
		IN6_IPADDR_TO_V4MAPPED(tnl->ip_dst, &auxdata.tp_tun_dstip);
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  1982
	}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1983
	memcpy(CMSG_DATA(cmsg), &auxdata, sizeof (auxdata));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1984
	for (nwritten = 0; nwritten < buflen; nwritten += nbytes) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1985
		nbytes = sendmsg(fd, &msghdr, 0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1986
		if (nbytes == -1) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1987
			if (errno != EAGAIN) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1988
				error = errno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1989
				break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1990
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1991
			nbytes = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1992
		} else if (nbytes == 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1993
			error = EIO;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1994
			break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1995
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1996
		iov.iov_len = buflen - (nwritten + nbytes);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1997
		iov.iov_base = (char *)buf + (nwritten + nbytes);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1998
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  1999
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2000
	VLOG_DBG("dpif_solaris_port_output len %"PRIuSIZE" to %d %s",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2001
	    buflen, port_no, error == 0 ? "succeed" :
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2002
	    ovs_strerror(error));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2003
	ovs_assert(error != 0 || nwritten == buflen);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2004
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2005
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2006
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2007
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2008
static struct dpif_solaris *
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2009
get_dp_by_name(char *dp_name)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2010
{
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2011
	struct dpif_solaris *dpif = NULL;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2012
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2013
	ovs_mutex_lock(&dp_solaris_mutex);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2014
	dpif = shash_find_data(&dp_all_solaris, dp_name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2015
	if (!dpif) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2016
		VLOG_ERR("get_dp_by_name: couldn't get a hold on dpif for %s",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2017
		    dp_name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2018
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2019
	ovs_mutex_unlock(&dp_solaris_mutex);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2020
	return (dpif);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2021
}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2022
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2023
struct netdev *
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2024
dpif_solaris_obtain_netdev_to_migrate(char *brname, bool *error)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2025
{
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2026
	struct dpif_solaris		*dpif;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2027
	struct dpif_solaris_bridge	*bridge;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2028
	struct dpif_solaris_port	*i_port;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2029
	struct netdev			*i_netdev;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2030
	struct netdev			*netdev_to_migrate = NULL;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2031
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2032
	dpif = get_dp_by_name("ovs-system");
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2033
	if (dpif == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2034
		*error = true;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2035
		return (NULL);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2036
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2037
	ovs_rwlock_wrlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2038
	bridge = dpif_solaris_lookup_bridge(dpif, brname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2039
	if (bridge == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2040
		VLOG_ERR("dpif_solaris_obtain_netdev_to_migrate: Could not "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2041
		    "locate bridge for %s", brname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2042
		ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2043
		*error = true;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2044
		return (NULL);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2045
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2046
	/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2047
	 * If bridge has no uplinks migrate bridge vnic to implicit etherstub.
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2048
	 * If it has uplinks, look for an uplink which is not etherstub. If not
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2049
	 * get the first uplink from the uplink_port_list.
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2050
	 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2051
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2052
	if (list_is_empty(&bridge->uplink_port_list)) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2053
		ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2054
		return (NULL);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2055
	} else {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2056
		LIST_FOR_EACH(i_port, uplink_node, &bridge->uplink_port_list) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2057
			i_netdev = i_port->netdev;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2058
			if (i_netdev == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2059
				VLOG_ERR(
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2060
				    "dpif_solaris_obtain_netdev_to_migrate:"
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2061
				    " Could not obtain netdev for %s",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2062
				    i_port->name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2063
				ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2064
				*error = true;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2065
				return (NULL);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2066
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2067
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2068
			if (strcmp(netdev_solaris_get_class(i_netdev),
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2069
			    "etherstub") != 0) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2070
				netdev_to_migrate = i_netdev;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2071
				break;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2072
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2073
		}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2074
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2075
		if (netdev_to_migrate == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2076
			VLOG_DBG("Couldn't find a netdev other than etherstub. "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2077
			    "Thus migrating to first etherstub");
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2078
			ASSIGN_CONTAINER(i_port,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2079
			    (&(bridge->uplink_port_list))->next,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2080
			    uplink_node);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2081
			netdev_to_migrate = i_port->netdev;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2082
			if (netdev_to_migrate == NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2083
				VLOG_ERR(
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2084
				    "dpif_solaris_obtain_netdev_to_migrate:"
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2085
				    " Could not obtain netdev for %s",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2086
				    i_port->name);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2087
				ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2088
				*error = true;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2089
				return (NULL);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2090
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2091
		}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2092
	}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2093
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2094
	ovs_rwlock_unlock(&dpif->bridge_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2095
	return (netdev_to_migrate);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2096
}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2097
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2098
/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2099
 * Migrate the internal port to a different lower link, sets its physname, and
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2100
 * refresh its port channel.
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2101
 *
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2102
 * Note that the internal port's name is the same as bridge name
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2103
 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2104
void
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2105
dpif_solaris_migrate_internal_port(const char *bridge, const char *physname)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2106
{
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2107
	struct dpif_solaris		*dpif;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2108
	struct dpif_solaris_port	*port;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2109
	int				err;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2110
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2111
	VLOG_DBG("dpif_solaris_migrate_internal_port port %s on %s", bridge,
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2112
	    physname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2113
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2114
	if ((dpif = get_dp_by_name("ovs-system")) != NULL) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2115
		ovs_rwlock_wrlock(&dpif->port_rwlock);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2116
		HMAP_FOR_EACH(port, node, &dpif->ports) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2117
			if (strcmp(port->name, bridge) != 0)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2118
				continue;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2119
			dpif_solaris_destroy_port_channel(dpif, port);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2120
			free(port->physname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2121
			port->physname = xstrdup(physname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2122
			err = dpif_solaris_refresh_port_channel(dpif, port,
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2123
			    false);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2124
			if (err == 0)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2125
				VLOG_DBG("dpif_solaris_migrate_internal_port %s"
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2126
				    " on %s succeed", bridge, physname);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2127
			else
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2128
				VLOG_ERR("dpif_solaris_migrate_internal_port %s"
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2129
				    " on %s failed %d", bridge, physname, err);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2130
			break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2131
		}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2132
		ovs_rwlock_unlock(&dpif->port_rwlock);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2133
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2134
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2135
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2136
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2137
dp_solaris_execute_cb(void *aux_, struct ofpbuf *packet,
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2138
    struct pkt_metadata *md, const struct nlattr *a, bool may_steal)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2139
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2140
	struct dpif_solaris *dpif = aux_;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2141
	int type = nl_attr_type(a);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2142
	odp_port_t pin, pout;
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2143
	struct flow_tnl *tnl = NULL;
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2144
	enum ovs_vport_type vtype;
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2145
	int err;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2146
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2147
	VLOG_DBG("dp_solaris_execute_cb type %d", type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2148
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2149
	switch ((enum ovs_action_attr)type) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2150
	case OVS_ACTION_ATTR_OUTPUT: {
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2151
		odp_port_t			port_no;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2152
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2153
		port_no = u32_to_odp(nl_attr_get_u32(a));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2154
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2155
		VLOG_DBG("dp_solaris_execute_cb OVS_ACTION_ATTR_OUTPUT "
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2156
		    "%d: inport is %d", port_no, md->in_port.odp_port);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2157
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2158
		/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2159
		 * If in_port number is OFPP_NONE, this means this packet out
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2160
		 * request comes from the controller.
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2161
		 *
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2162
		 * if the in or outport is the internal port, and its uplink
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2163
		 * can not be found, it means there is no physical uplink
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2164
		 * added to the bridge yet, directly drop the packet.
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2165
		 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2166
		if (md->in_port.odp_port != ODPP_NONE) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2167
			err = dpif_solaris_get_uplink_port_info(dpif,
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2168
			    md->in_port.odp_port, &pin, NULL, &vtype);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2169
			if (err != 0) {
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2170
				if (vtype != OVS_VPORT_TYPE_INTERNAL) {
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2171
					VLOG_DBG("dp_solaris_execute_cb "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2172
					    "OVS_ACTION_ATTR_OUTPUT failed to"
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2173
					    "get uplink for inport %d ",
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2174
					    md->in_port.odp_port);
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2175
				}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2176
				if (may_steal)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2177
					ofpbuf_delete(packet);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2178
				break;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2179
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2180
			err = dpif_solaris_get_uplink_port_info(dpif, port_no,
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2181
			    &pout, NULL, &vtype);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2182
			if (err != 0) {
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2183
				if (vtype != OVS_VPORT_TYPE_INTERNAL) {
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2184
					VLOG_DBG("dp_solaris_execute_cb "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2185
					    "OVS_ACTION_ATTR_OUTPUT failed to "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2186
					    "get uplink for outport %d",
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2187
					    port_no);
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2188
				}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2189
				if (may_steal)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2190
					ofpbuf_delete(packet);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2191
				break;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2192
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2193
			/*
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2194
			 * Bridging across different uplinks is not supported
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2195
			 * in the kernel currently, so we disable that support
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2196
			 * here as well.
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2197
			 */
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2198
			if (pin != pout) {
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2199
				VLOG_DBG("dp_solaris_execute_cb "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2200
				    "OVS_ACTION_ATTR_OUTPUT inport %d and "
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2201
				    "outport %d on different uplinks",
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2202
				    md->in_port.odp_port, port_no);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2203
				if (may_steal)
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2204
					ofpbuf_delete(packet);
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2205
				break;
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2206
			}
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2207
		}
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2208
		if (md->tunnel.ip_dst && (port_no == pout))
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2209
			tnl = &md->tunnel;
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2210
		(void) dpif_solaris_port_output(dpif, port_no, packet, tnl,
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2211
		    may_steal);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2212
		break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2213
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2214
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2215
	/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2216
	 * We'll send the packet back to the kernel and it'll be classified
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2217
	 * and we should get it back. XXX Check if this could cause an
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2218
	 * infinite loop. This is not terribly effective, but if we use
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2219
	 * sockets, it will still get to the kernel before coming back.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2220
	 * Need a short-cut. Note we don't care about any userland data
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2221
	 * since we will get it when the packets comes back from the
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2222
	 * kernel. Also, currently we always send using the uplink associated
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2223
	 * with the in_port number.
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2224
	 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2225
	case OVS_ACTION_ATTR_USERSPACE:	{	/* controller */
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2226
		VLOG_DBG("dp_solaris_execute_cb OVS_ACTION_ATTR_USERSPACE");
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2227
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2228
		err = dpif_solaris_get_uplink_port_info(dpif,
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2229
		    md->in_port.odp_port, &pin, NULL, &vtype);
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2230
		if (err != 0) {
6556
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2231
			if (vtype != OVS_VPORT_TYPE_INTERNAL) {
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2232
				VLOG_DBG("dp_solaris_execute_cb "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2233
				    "OVS_ACTION_ATTR_USERSPACE failed to get "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2234
				    "uplink for inport %d",
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2235
				    md->in_port.odp_port);
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2236
			} else {
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2237
				VLOG_DBG("dp_solaris_execute_cb "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2238
				    "OVS_ACTION_ATTR_USERSPACE from an internal"
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2239
				    "port %d which is not associated with a "
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2240
				    "physical uplink",
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2241
				    md->in_port.odp_port);
692ea531a2fc 24340559 ping or ssh fails if 200 VNICs are added into VXLAN based OVS (userland changes)
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6538
diff changeset
  2242
			}
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2243
			if (may_steal)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2244
				ofpbuf_delete(packet);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2245
			break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2246
		}
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2247
		if (md->tunnel.ip_dst)
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2248
			tnl = &md->tunnel;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2249
		VLOG_DBG("dp_solaris_execute_cb OVS_ACTION_ATTR_USERSPACE "
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  2250
		    "%d", pin);
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2251
		(void) dpif_solaris_port_output(dpif, pin, packet, tnl,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2252
		    may_steal);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2253
		break;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2254
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2255
	case OVS_ACTION_ATTR_HASH:		/* for bonding */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2256
	case OVS_ACTION_ATTR_RECIRC:		/* for bonding */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2257
	case OVS_ACTION_ATTR_PUSH_VLAN:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2258
	case OVS_ACTION_ATTR_POP_VLAN:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2259
	case OVS_ACTION_ATTR_PUSH_MPLS:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2260
	case OVS_ACTION_ATTR_POP_MPLS:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2261
	case OVS_ACTION_ATTR_SET:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2262
	case OVS_ACTION_ATTR_SAMPLE:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2263
	case OVS_ACTION_ATTR_UNSPEC:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2264
	case __OVS_ACTION_ATTR_MAX:
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2265
		VLOG_DBG("dp_solaris_execute_cb type %d", type);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2266
		OVS_NOT_REACHED();
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2267
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2268
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2269
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2270
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2271
dpif_solaris_execute(struct dpif *dpif_, struct dpif_execute *execute)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2272
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2273
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2274
	struct pkt_metadata *md = &execute->md;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2275
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2276
	if (ofpbuf_size(execute->packet) < ETH_HEADER_LEN ||
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2277
	    ofpbuf_size(execute->packet) > UINT16_MAX) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2278
		VLOG_ERR("dpif_solaris_execute invalid size %d",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2279
		    ofpbuf_size(execute->packet));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2280
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2281
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2282
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2283
	odp_execute_actions(dpif, execute->packet, false, md, execute->actions,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2284
	    execute->actions_len, dp_solaris_execute_cb);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2285
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2286
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2287
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2288
static void
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2289
dpif_solaris_destroy_lowerlink(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2290
    struct dpif_solaris_lowerlink *lowerlink)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2291
    OVS_REQ_WRLOCK(dpif->port_rwlock)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2292
{
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2293
	int i;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2294
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2295
	VLOG_DBG("dpif_solaris_destroy_lowerlink %s", lowerlink->physname);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2296
	ovs_assert(lowerlink->nports == 0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2297
	hmap_remove(&dpif->lowerlinks, &lowerlink->node);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2298
	for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2299
		ovs_assert(lowerlink->handlers != NULL);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2300
		if (lowerlink->handlers[i].upcall_fd != -1)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2301
			(void) close(lowerlink->handlers[i].upcall_fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2302
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2303
	if (lowerlink->handlers != NULL)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2304
		free(lowerlink->handlers);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2305
	free(lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2306
}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2307
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2308
static void
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2309
dpif_solaris_destroy_port_channel(struct dpif_solaris *dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2310
    struct dpif_solaris_port *port)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2311
{
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2312
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2313
	ovs_assert(dpif->recv_set);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2314
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2315
	if (port->upcall_fd == -1)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2316
		return;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2317
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2318
	VLOG_DBG("dpif_solaris_destroy_port_channel port %s lower-link %s",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2319
	    port->linkname, port->physname);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2320
	(void) setsockopt(port->upcall_fd, SOL_PACKET,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2321
	    PACKET_REM_OF_DEFFLOW, &port->port_no, sizeof (uint32_t));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2322
	port->upcall_fd = -1;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2323
	port->pf_port_no = ODPP_NONE;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2324
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2325
	lowerlink = port->lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2326
	port->lowerlink = NULL;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2327
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2328
	if (--lowerlink->nports == 0)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2329
		dpif_solaris_destroy_lowerlink(dpif, lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2330
}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2331
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2332
static void
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2333
dpif_solaris_destroy_channels(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2334
    OVS_REQ_WRLOCK(dpif->upcall_lock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2335
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2336
	struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2337
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2338
	if (!dpif->recv_set)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2339
		return;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2340
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2341
	VLOG_DBG("dpif_solaris_destroy_channels");
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2342
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2343
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2344
	HMAP_FOR_EACH(port, node, &dpif->ports) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2345
		dpif_solaris_destroy_port_channel(dpif, port);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2346
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2347
	ovs_rwlock_unlock(&dpif->port_rwlock);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2348
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2349
	(void) close(dpif->event_rfd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2350
	(void) close(dpif->event_wfd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2351
	dpif->event_rfd = dpif->event_wfd = -1;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2352
	dpif->recv_set = false;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2353
	dpif->n_handlers = 0;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2354
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2355
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2356
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2357
dpif_solaris_refresh_port_channel(struct dpif_solaris *dpif,
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2358
    struct dpif_solaris_port *port, boolean_t notify)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2359
    OVS_REQ_WRLOCK(dpif->port_rwlock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2360
{
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2361
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2362
	mac_of_ports_t mofport;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2363
	odp_port_t pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2364
	int fd, idx, error;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2365
	boolean_t lowerlink_found = false;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2366
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2367
	if (!dpif->recv_set || (port->vtype != OVS_VPORT_TYPE_NETDEV &&
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2368
	    port->vtype != OVS_VPORT_TYPE_VXLAN && port->vtype !=
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2369
	    OVS_VPORT_TYPE_INTERNAL))
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2370
		return (0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2371
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2372
	VLOG_DBG("dpif_solaris_refresh_port_channel(%s) port_no %d on %s%s",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2373
	    port->linkname, port->port_no, port->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2374
	    notify ? " notify" : "");
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2375
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2376
	HMAP_FOR_EACH(lowerlink, node, &dpif->lowerlinks) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2377
		if (strcmp(lowerlink->physname, port->physname) == 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2378
			lowerlink_found = true;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2379
			break;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2380
		}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2381
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2382
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2383
	/* Create the lower link if it is not found */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2384
	if (!lowerlink_found) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2385
		error = dpif_solaris_create_lowerlink(dpif, port->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2386
		    &lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2387
		if (error != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2388
			VLOG_DBG("dpif_solaris_refresh_port_channel lowerlink "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2389
			    "%s creation failed %s", port->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2390
			    ovs_strerror(error));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2391
			return (error);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2392
		}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2393
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2394
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2395
	idx = port->is_uplink ? 0 :
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2396
	    (lowerlink->next_idx % lowerlink->n_handlers);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2397
	fd = lowerlink->handlers[idx].upcall_fd;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2398
	pf_port_no = lowerlink->handlers[idx].pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2399
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2400
	VLOG_DBG("dpif_solaris_refresh_port_channel(%s) port_no %d pf_port_no "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2401
	    "%d upcall_fd %d", port->linkname, port->port_no, pf_port_no, fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2402
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2403
	mofport.mop_port = pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2404
	mofport.mop_sport = port->port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2405
	if (setsockopt(fd, SOL_PACKET, PACKET_ADD_OF_DEFFLOW,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2406
	    &mofport, sizeof (mac_of_ports_t)) != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2407
		error = errno;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2408
		VLOG_ERR("dpif_solaris_refresh_port_channel %s failed to set "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2409
		    "PACKET_ADD_OF_DEFFLOW: %s", port->name,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2410
		    ovs_strerror(error));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2411
		if (!lowerlink_found)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2412
			dpif_solaris_destroy_lowerlink(dpif, lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2413
		return (error);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2414
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2415
	if (!port->is_uplink)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2416
		lowerlink->next_idx ++;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2417
	lowerlink->nports ++;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2418
	port->lowerlink = lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2419
	port->upcall_fd = fd;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2420
	port->pf_port_no = pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2421
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2422
	/* Inform the event_rfd that the port->upcall_fd has been changed */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2423
	if (notify && write(dpif->event_wfd, (char *)(&port->port_no),
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2424
	    sizeof (odp_port_t)) < 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2425
		VLOG_ERR("dpif_solaris_refresh_port_channel %s event "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2426
		    "notify failed: %s", port->linkname, ovs_strerror(errno));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2427
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2428
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2429
	return (0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2430
}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2431
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2432
static int
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2433
dpif_solaris_create_upfd(struct dpif_solaris *dpif, const char *physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2434
    int *upcall_fdp) OVS_REQ_WRLOCK(dpif->port_rwlock)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2435
{
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2436
	int fd, flags, onoff = 1;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2437
	struct sockaddr_ll sll;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2438
	datalink_id_t linkid;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2439
	mac_of_ports_t mofport;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2440
	dladm_status_t status;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2441
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2442
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2443
	if (!dpif->recv_set)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2444
		return (EINVAL);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2445
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2446
	VLOG_DBG("dpif_solaris_create_upfd() on %s", physname);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2447
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2448
	fd = socket(PF_PACKET, SOCK_RAW, ETH_P_ALL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2449
	if (fd == -1) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2450
		VLOG_ERR("dpif_solaris_create_upfd %s failed to "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2451
		    "create socket: %s", physname, ovs_strerror(errno));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2452
		return (errno);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2453
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2454
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2455
	status = dladm_name2info(dpif->dh, physname, &linkid,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2456
	    NULL, NULL, NULL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2457
	error = solaris_dladm_status2error(status);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2458
	if (error != 0) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2459
		VLOG_ERR("dpif_solaris_create_upfd %s failed to get "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2460
		    "linkid: %s", physname, ovs_strerror(error));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2461
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2462
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2463
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2464
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2465
	(void) memset(&sll, 0, sizeof (sll));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2466
	sll.sll_family = AF_PACKET;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2467
	sll.sll_ifindex = linkid;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2468
	sll.sll_protocol = ETH_P_ALL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2469
	if (bind(fd, (struct sockaddr *)&sll, sizeof (sll)) == -1) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2470
		error = errno;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2471
		VLOG_ERR("dpif_solaris_create_upfd %s failed to bind: "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2472
		    "%s", physname, ovs_strerror(error));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2473
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2474
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2475
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2476
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2477
	if (setsockopt(fd, SOL_PACKET,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2478
	    PACKET_AUXDATA, &onoff, sizeof (onoff)) != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2479
		error = errno;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2480
		VLOG_ERR("dpif_solaris_create_upfd %s failed to set "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2481
		    "PACKET_AUXDATAQ: %s", physname,
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2482
		    ovs_strerror(error));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2483
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2484
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2485
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2486
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2487
	/* Disable the promiscous mode on this socket */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2488
	mofport.mop_port = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2489
	mofport.mop_sport = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2490
	if (setsockopt(fd, SOL_PACKET, PACKET_ADD_OF_DEFFLOW,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2491
	    &mofport, sizeof (mac_of_ports_t)) != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2492
		error = errno;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2493
		VLOG_ERR("dpif_solaris_create_upfd %s failed to set "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2494
		    "PACKET_ADD_OF_DEFFLOW port 0: %s", physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2495
		    ovs_strerror(error));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2496
		(void) close(fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2497
		return (error);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2498
	}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2499
	/* must not block */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2500
	if (((flags = fcntl(fd, F_GETFL, 0)) == -1) ||
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2501
	    (fcntl(fd, F_SETFL, flags | O_NONBLOCK) == -1)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2502
		error = errno;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2503
		VLOG_ERR("dpif_solaris_create_upfd %s failed to set "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2504
		    "non-block: %s", physname, ovs_strerror(error));
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2505
		(void) close(fd);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2506
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2507
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2508
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2509
	VLOG_DBG("dpif_solaris_create_upfd %s fd=%d", physname, fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2510
	*upcall_fdp = fd;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2511
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2512
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2513
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2514
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2515
static int
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2516
dpif_solaris_create_lowerlink(struct dpif_solaris *dpif, char *physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2517
    struct dpif_solaris_lowerlink **lowerlinkp)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2518
    OVS_REQ_WRLOCK(dpif->port_rwlock)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2519
{
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2520
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2521
	odp_port_t pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2522
	int i, err;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2523
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2524
	if (!dpif->recv_set)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2525
		return (0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2526
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2527
	VLOG_DBG("dpif_solaris_create_lowerlink create %d upfds over lower "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2528
	    "link %s", dpif->n_handlers, physname);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2529
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2530
	lowerlink = xzalloc(sizeof (*lowerlink));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2531
	if (strlcpy(lowerlink->physname, physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2532
	    sizeof (lowerlink->physname)) >= sizeof (lowerlink->physname)) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2533
		free(lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2534
		return (ENOBUFS);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2535
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2536
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2537
	lowerlink->n_handlers = dpif->n_handlers;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2538
	lowerlink->handlers = xzalloc(lowerlink->n_handlers *
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2539
	    sizeof (struct dpif_solaris_handler));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2540
	lowerlink->nports = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2541
	lowerlink->next_idx = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2542
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2543
	for (i = 0; i < lowerlink->n_handlers; i++)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2544
		lowerlink->handlers[i].upcall_fd = -1;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2545
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2546
	for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2547
		err = dpif_solaris_create_upfd(dpif,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2548
		    lowerlink->physname, &(lowerlink->handlers[i].upcall_fd));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2549
		if (err != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2550
			VLOG_ERR("dpif_solaris_create_lowerlink create %dth "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2551
			    "upfd over %s failed %s", i, lowerlink->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2552
			    ovs_strerror(err));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2553
			goto fail;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2554
		} else {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2555
			VLOG_DBG("dpif_solaris_create_lowerlink create %dth "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2556
			    "upfd over %s: %d", i, lowerlink->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2557
			    lowerlink->handlers[i].upcall_fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2558
		}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2559
		pf_port_no = (i == 0) ? PORT_PF_PACKET_UPLINK :
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2560
		    choose_pf_port(dpif, lowerlink, i);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2561
		if (pf_port_no == ODPP_NONE) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2562
			VLOG_ERR("dpif_solaris_create_lowerlink no usable "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2563
			    "port_no avaiable for %dth upfd over %s", i,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2564
			    lowerlink->physname);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2565
			err = EFBIG;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2566
			goto fail;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2567
		} else {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2568
			VLOG_DBG("dpif_solaris_create_lowerlink "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2569
			    "avaiable pf_port_no for %dth upfd over %s: %d", i,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2570
			    lowerlink->physname, pf_port_no);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2571
		}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2572
		lowerlink->handlers[i].pf_port_no = pf_port_no;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2573
	}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2574
	hmap_insert(&dpif->lowerlinks, &lowerlink->node,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2575
	    hash_string(lowerlink->physname, 0));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2576
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2577
	*lowerlinkp = lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2578
	return (0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2579
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2580
fail:
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2581
	dpif_solaris_destroy_lowerlink(dpif, lowerlink);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2582
	return (err);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2583
}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2584
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2585
/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2586
 * Synchronizes 'channels' in 'dpif->handlers'  with the set of vports
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2587
 * currently in 'dpif' in the kernel, by adding a new set of channels for
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2588
 * any kernel vport that lacks one and deleting any channels that have no
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2589
 * backing kernel vports.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2590
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2591
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2592
dpif_solaris_refresh_channels(struct dpif_solaris *dpif, uint32_t n_handlers)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2593
    OVS_REQ_WRLOCK(dpif->upcall_lock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2594
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2595
	struct dpif_solaris_port *port;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2596
	int error, flags;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2597
	odp_port_t port_no = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2598
	int fds[2];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2599
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2600
	VLOG_DBG("dpif_solaris_refresh_channels %d", n_handlers);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2601
	dpif_solaris_destroy_channels(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2602
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2603
	/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2604
	 * Setup the event pipe to monitor the port changes, so that
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2605
	 * port_channel_fd is able to be refreshed into the pollfds set.
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2606
	 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2607
	if ((pipe(fds)) < 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2608
		error = errno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2609
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2610
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2611
	/* must not block */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2612
	if (((flags = fcntl(fds[0], F_GETFL, 0)) == -1) ||
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2613
	    (fcntl(fds[0], F_SETFL, flags | O_NONBLOCK) == -1)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2614
		error = errno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2615
		(void) close(fds[0]);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2616
		(void) close(fds[1]);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2617
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2618
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2619
	if (((flags = fcntl(fds[1], F_GETFL, 0)) == -1) ||
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2620
	    (fcntl(fds[1], F_SETFL, flags | O_NONBLOCK) == -1)) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2621
		error = errno;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2622
		(void) close(fds[0]);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2623
		(void) close(fds[1]);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2624
		return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2625
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2626
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2627
	dpif->n_handlers = n_handlers;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2628
	dpif->recv_set = true;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2629
	dpif->event_rfd = fds[0];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2630
	dpif->event_wfd = fds[1];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2631
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2632
	ovs_rwlock_wrlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2633
	HMAP_FOR_EACH(port, node, &dpif->ports) {
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2634
		error = dpif_solaris_refresh_port_channel(dpif, port, false);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2635
		if (error != 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2636
			ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2637
			dpif_solaris_destroy_channels(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2638
			return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2639
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2640
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2641
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2642
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2643
	/* Inform the event_rfd that all ports' upcall_fd has been changed */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2644
	if (write(dpif->event_wfd, (char *)&port_no, sizeof (odp_port_t)) < 0) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2645
		VLOG_ERR("dpif_solaris_refresh_channels event notify"
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2646
		    "failed: %s", ovs_strerror(errno));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2647
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2648
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2649
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2650
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2651
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2652
dpif_solaris_recv_set_(struct dpif_solaris *dpif, bool enable)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2653
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2654
	if (dpif->recv_set == enable)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2655
		return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2656
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2657
	if (!enable) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2658
		dpif_solaris_destroy_channels(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2659
		return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2660
	} else {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2661
		return (dpif_solaris_refresh_channels(dpif, 1));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2662
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2663
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2664
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2665
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2666
dpif_solaris_recv_set(struct dpif *dpif_, bool enable)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2667
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2668
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2669
	int error = 0;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2670
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2671
	VLOG_DBG("dpif_solaris_recv_set %s", enable ? "true" : "false");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2672
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2673
	ovs_rwlock_wrlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2674
	dpif_solaris_recv_set_(dpif, enable);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2675
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2676
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2677
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2678
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2679
/*
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2680
 * For Solaris we will use the queue_id as the priority. The queue id
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2681
 * will be used to get the QoS information and used to configure
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2682
 * the bandwidth and priority
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2683
 */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2684
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2685
dpif_solaris_queue_to_priority(const struct dpif *dpif OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2686
    uint32_t queue_id, uint32_t *priority)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2687
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2688
	*priority = queue_id;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2689
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2690
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2691
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2692
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2693
dpif_solaris_parse_pkt(struct dpif_solaris *dpif OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2694
    struct ofpbuf *packet, struct pkt_metadata *md, uint16_t action_type,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2695
    struct dpif_upcall *upcall, struct ofpbuf *buf)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2696
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2697
	struct flow flow;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2698
	void *data;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2699
	size_t buf_size;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2700
	const struct nlattr *userdata = NULL;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2701
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2702
	VLOG_DBG("dpif_solaris_parse_pkt");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2703
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2704
	if ((buf_size = ofpbuf_size(packet)) < ETH_HEADER_LEN) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2705
		VLOG_ERR("dpif_solaris_parse_pkt bufsize too small %"PRIuSIZE,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2706
		    buf_size);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2707
		return (EINVAL);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2708
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2709
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2710
	flow_extract(packet, md, &flow);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2711
	upcall->type = (action_type == FLOW_ACTION_MISSED_PKT) ? DPIF_UC_MISS :
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2712
	    DPIF_UC_ACTION;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2713
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2714
	/* Allocate buffer big enough for everything. */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2715
	buf_size = ODPUTIL_FLOW_KEY_BYTES;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2716
	if (action_type == FLOW_ACTION_OF_CONTROLLER) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2717
		struct ofpbuf abuf;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2718
		char slow_path_buf[128];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2719
		const struct nlattr *a;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2720
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2721
		VLOG_DBG("dpif_solaris_parse_p:: FLOW_ACTION_OF_CONTROLLER!!");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2722
		ofpbuf_use_stack(&abuf, slow_path_buf, sizeof (slow_path_buf));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2723
		slowpath_to_actions(SLOW_CONTROLLER, &abuf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2724
		a = nl_attr_find(&abuf, 0, OVS_ACTION_ATTR_USERSPACE);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2725
		if (a != NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2726
			userdata = nl_attr_find_nested(a,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2727
			    OVS_USERSPACE_ATTR_USERDATA);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2728
			if (userdata != NULL)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2729
				buf_size += NLA_ALIGN(userdata->nla_len);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2730
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2731
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2732
	buf_size += ofpbuf_size(packet);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2733
	ofpbuf_init(buf, buf_size);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2734
6018
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2735
	VLOG_DBG("PARSE flow in_port %d tunnel dst %u", flow.in_port.odp_port,
b5072b523988 23086193 implicitly created OVS bridge VNIC shows incorrect statistic
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5730
diff changeset
  2736
	    flow.tunnel.ip_dst);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2737
	odp_flow_key_from_flow(buf, &flow, NULL, flow.in_port.odp_port);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2738
	upcall->key = ofpbuf_data(buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2739
	upcall->key_len = ofpbuf_size(buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2740
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2741
	if (userdata != NULL) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2742
		upcall->userdata = ofpbuf_put(buf, userdata,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2743
		    NLA_ALIGN(userdata->nla_len));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2744
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2745
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2746
	data = ofpbuf_put(buf, ofpbuf_data(packet), ofpbuf_size(packet));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2747
	ofpbuf_use_stub(&upcall->packet, data, ofpbuf_size(packet));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2748
	ofpbuf_set_size(&upcall->packet, ofpbuf_size(packet));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2749
	return (0);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2750
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2751
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2752
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2753
dpif_solaris_recv__(struct dpif_solaris *dpif, uint32_t handler_id OVS_UNUSED,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2754
    struct dpif_upcall *upcall, struct ofpbuf *buf)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2755
    OVS_REQ_WRLOCK(dpif->upcall_lock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2756
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2757
	struct iovec iov;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2758
	struct msghdr msg;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2759
	struct cmsghdr *cmsg;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2760
	char cmsg_buf[sizeof (*cmsg) + sizeof (struct tpacket_auxdata) +
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2761
	    _CMSG_HDR_ALIGNMENT];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2762
	uint8_t pktbuf[65536];
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2763
	int pktlen;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2764
	struct dpif_solaris_lowerlink *lowerlink;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2765
	odp_port_t port_no;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2766
	uint16_t action_type;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2767
	int i, fd, error;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2768
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2769
	if (!dpif->recv_set) {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2770
		return (EAGAIN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2771
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2772
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2773
	(void) read(dpif->event_rfd, (char *)&port_no,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2774
	    sizeof (odp_port_t));
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2775
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2776
	ovs_rwlock_rdlock(&dpif->port_rwlock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2777
	HMAP_FOR_EACH(lowerlink, node, &dpif->lowerlinks) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2778
		for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2779
			if ((fd = lowerlink->handlers[i].upcall_fd) == -1)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2780
				continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2781
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2782
			msg.msg_name = NULL;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2783
			msg.msg_namelen = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2784
			msg.msg_iov = &iov;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2785
			msg.msg_iovlen = 1;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2786
			msg.msg_control = (void *)_CMSG_HDR_ALIGN(cmsg_buf);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2787
			msg.msg_controllen = sizeof (cmsg_buf) -
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2788
			    (_CMSG_HDR_ALIGN(cmsg_buf) - (uintptr_t)cmsg_buf);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2789
			msg.msg_flags = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2790
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2791
			iov.iov_len = sizeof (pktbuf);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2792
			iov.iov_base = pktbuf;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2793
			pktlen = recvmsg(fd, &msg, MSG_TRUNC);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2794
			if (pktlen > 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2795
				struct pkt_metadata	md;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2796
				mactun_info_t		*tuninfop = NULL;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2797
				struct flow_tnl		*tun;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2798
				struct ofpbuf		pkt;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2799
				struct tpacket_auxdata	aux;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2800
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2801
				action_type = FLOW_ACTION_OF_MAX;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2802
				for (cmsg = CMSG_FIRSTHDR(&msg); cmsg;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2803
				    cmsg = CMSG_NXTHDR(&msg, cmsg)) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2804
					if (cmsg->cmsg_len <
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2805
					    CMSG_LEN(
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2806
					    sizeof (struct tpacket_auxdata)) ||
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2807
					    cmsg->cmsg_level != SOL_PACKET ||
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2808
					    cmsg->cmsg_type != PACKET_AUXDATA)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2809
						continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2810
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2811
					memcpy(&aux, CMSG_DATA(cmsg),
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2812
					    sizeof (aux));
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2813
					action_type = aux.tp_of_action;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2814
					port_no = aux.tp_of_port;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2815
					tuninfop = &aux.tp_tun_info;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2816
					break;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2817
				}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2818
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2819
				if (action_type != FLOW_ACTION_MISSED_PKT &&
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2820
				    action_type != FLOW_ACTION_OF_CONTROLLER) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2821
					VLOG_ERR("dpif_solaris_recv__ on %s fd "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2822
					    "%d len %d but with unknown "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2823
					    "auxdata type %d",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2824
					    lowerlink->physname, fd, pktlen,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2825
					    action_type);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2826
					continue;
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2827
				}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2828
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2829
				if (port_no == 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2830
					VLOG_ERR("dpif_solaris_recv__ on %s fd "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2831
					    "%d len %d but with unknown "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2832
					    "port_no 0",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2833
					    lowerlink->physname, fd, pktlen);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2834
					continue;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2835
				}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2836
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2837
				VLOG_DBG("dpif_solaris_recv__ on %s fd %d len "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2838
				    "%d type %s (src_port = %u)",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2839
				    lowerlink->physname, fd, pktlen,
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2840
				    action_type == FLOW_ACTION_MISSED_PKT ?
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2841
				    "miss_pkt" : "fwd_controller", port_no);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2842
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2843
				ovs_assert(tuninfop != NULL);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2844
				md = PKT_METADATA_INITIALIZER(port_no);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2845
				if (tuninfop->mti_dst._S6_un._S6_u32[3] != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2846
					tun = &md.tunnel;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2847
					tun->tun_id = htonll(tuninfop->mti_id);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2848
					tun->flags |= FLOW_TNL_F_KEY;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2849
					tun->ip_src = tuninfop->
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2850
					    mti_src._S6_un._S6_u32[3];
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2851
					tun->ip_dst = tuninfop->
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2852
					    mti_dst._S6_un._S6_u32[3];
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2853
					tun->ip_tos = tuninfop->mti_tos;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2854
					tun->ip_ttl = tuninfop->mti_ttl;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2855
					/* TBD? */
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2856
					tun->flags |= FLOW_TNL_F_DONT_FRAGMENT;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2857
				}
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2858
				ofpbuf_use_const(&pkt, pktbuf, pktlen);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2859
				error = dpif_solaris_parse_pkt(dpif, &pkt, &md,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2860
				    action_type, upcall, buf);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2861
				if (error != 0) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2862
					VLOG_ERR("dpif_solaris_recv__ "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2863
					    "parse_pkt on %s fd %d action %s "
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2864
					    "failed %d", lowerlink->physname,
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2865
					    fd, action_type ==
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2866
					    FLOW_ACTION_MISSED_PKT ?
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2867
					    "miss_pkt" : "fwd_to_controller",
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2868
					    error);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2869
				} else {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2870
					ovs_rwlock_unlock(&dpif->port_rwlock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2871
					return (0);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2872
				}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2873
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2874
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2875
	}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2876
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2877
	ovs_rwlock_unlock(&dpif->port_rwlock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2878
	return (EAGAIN);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2879
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2880
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2881
static int
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2882
dpif_solaris_recv(struct dpif *dpif_, uint32_t handler_id,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2883
    struct dpif_upcall *upcall, struct ofpbuf *buf)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2884
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2885
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2886
	int error;
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2887
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2888
	ovs_rwlock_rdlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2889
	error = dpif_solaris_recv__(dpif, handler_id, upcall, buf);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2890
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2891
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2892
	return (error);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2893
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2894
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2895
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2896
dpif_solaris_recv_wait(struct dpif *dpif_, uint32_t handler_id OVS_UNUSED)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2897
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2898
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2899
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2900
	int i, fd;
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2901
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2902
	ovs_rwlock_rdlock(&dpif->upcall_lock);
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2903
	if (!dpif->recv_set)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2904
		goto done;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2905
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2906
	poll_fd_wait(dpif->event_rfd, POLLIN);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2907
	ovs_rwlock_rdlock(&dpif->port_rwlock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2908
	HMAP_FOR_EACH(lowerlink, node, &dpif->lowerlinks) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2909
		for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2910
			if ((fd = lowerlink->handlers[i].upcall_fd) != -1) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2911
				poll_fd_wait(fd, POLLIN);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2912
			}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2913
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2914
	}
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2915
	ovs_rwlock_unlock(&dpif->port_rwlock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2916
done:
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2917
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2918
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2919
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2920
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2921
dpif_solaris_recv_purge__(struct dpif_solaris *dpif)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2922
    OVS_REQ_WRLOCK(dpif->upcall_lock)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2923
{
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2924
	struct dpif_solaris_lowerlink *lowerlink;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2925
	int i, fd;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2926
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2927
	if (!dpif->recv_set)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2928
		return;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2929
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2930
	drain_rcvbuf(dpif->event_rfd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2931
	ovs_rwlock_rdlock(&dpif->port_rwlock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2932
	HMAP_FOR_EACH(lowerlink, node, &dpif->lowerlinks) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2933
		for (i = 0; i < lowerlink->n_handlers; i++) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2934
			if ((fd = lowerlink->handlers[i].upcall_fd) != -1) {
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2935
				drain_rcvbuf(fd);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2936
			}
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2937
		}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2938
	}
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2939
	ovs_rwlock_unlock(&dpif->port_rwlock);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2940
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2941
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2942
static void
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2943
dpif_solaris_recv_purge(struct dpif *dpif_)
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2944
{
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2945
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2946
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2947
	VLOG_DBG("dpif_solaris_recv_purge");
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2948
	ovs_rwlock_wrlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2949
	dpif_solaris_recv_purge__(dpif);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2950
	ovs_rwlock_unlock(&dpif->upcall_lock);
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2951
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2952
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2953
static int
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2954
dpif_solaris_handlers_set(struct dpif *dpif_, uint32_t n_handlers)
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2955
{
6924
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2956
	struct dpif_solaris *dpif = dpif_solaris_cast(dpif_);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2957
	int err = 0;
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2958
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2959
	VLOG_DBG("dpif_solaris_handlers_set %d", n_handlers);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2960
	ovs_rwlock_wrlock(&dpif->upcall_lock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2961
	if (dpif->recv_set)
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2962
		err = dpif_solaris_refresh_channels(dpif, n_handlers);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2963
	ovs_rwlock_unlock(&dpif->upcall_lock);
e8aaad6b5075 24681506 The OVS drop action does not work as designed - userland part
akshay.kale@oracle.com <akshay.kale@oracle.com>
parents: 6557
diff changeset
  2964
	return (err);
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2965
}
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2966
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2967
const struct dpif_class dpif_solaris_class = {
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2968
	"system",
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2969
	dpif_solaris_enumerate,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2970
	NULL,					/* port_open_type */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2971
	dpif_solaris_open,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2972
	dpif_solaris_close,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2973
	dpif_solaris_destroy,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2974
	NULL,					/* run */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2975
	NULL,					/* wait */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2976
	dpif_solaris_get_stats,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2977
	dpif_solaris_port_add,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2978
	dpif_solaris_port_del,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2979
	dpif_solaris_port_query_by_number,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2980
	dpif_solaris_port_query_by_name,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2981
	NULL, 					/* port_get_pid */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2982
	dpif_solaris_port_dump_start,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2983
	dpif_solaris_port_dump_next,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2984
	dpif_solaris_port_dump_done,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2985
	dpif_solaris_port_poll,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2986
	dpif_solaris_port_poll_wait,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2987
	dpif_solaris_flow_get,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2988
	dpif_solaris_flow_put,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2989
	dpif_solaris_flow_del,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2990
	dpif_solaris_flow_flush,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2991
	dpif_solaris_flow_dump_state_init,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2992
	dpif_solaris_flow_dump_start,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2993
	dpif_solaris_flow_dump_next,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2994
	NULL,				/* flow_dump_next_may_destroy_keys */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2995
	dpif_solaris_flow_dump_done,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2996
	dpif_solaris_flow_dump_state_uninit,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2997
	dpif_solaris_execute,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2998
	NULL,					/* operate */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  2999
	dpif_solaris_recv_set,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  3000
	dpif_solaris_handlers_set,		/* handlers_set */
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  3001
	dpif_solaris_queue_to_priority,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  3002
	dpif_solaris_recv,
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  3003
	dpif_solaris_recv_wait,
5730
cca4aa297e68 22590644 OpenvSwitch should be updated to version 2.3.2
Mark Haywood <Mark.Haywood@Oracle.COM>
parents: 5090
diff changeset
  3004
	dpif_solaris_recv_purge
5090
5f131162e136 PSARC/2015/311 Open vSwitch (OVS)
Mark Haywood <Mark.Haywood@Oracle.COM>
parents:
diff changeset
  3005
};