Blame view

net/openvswitch/vport.h 6.2 KB
ccb1352e7   Jesse Gross   net: Add Open vSw...
1
  /*
caf2ee14b   Raju Subramanian   openvswitch: Repl...
2
   * Copyright (c) 2007-2012 Nicira, Inc.
ccb1352e7   Jesse Gross   net: Add Open vSw...
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
   *
   * This program is free software; you can redistribute it and/or
   * modify it under the terms of version 2 of the GNU General Public
   * License as published by the Free Software Foundation.
   *
   * This program is distributed in the hope that it will be useful, but
   * WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
   * General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
   * 02110-1301, USA
   */
  
  #ifndef VPORT_H
  #define VPORT_H 1
e0f0ecf33   Pravin B Shelar   openvswitch: Use ...
21
  #include <linux/if_tunnel.h>
ccb1352e7   Jesse Gross   net: Add Open vSw...
22
  #include <linux/list.h>
46df7b814   Pravin B Shelar   openvswitch: Add ...
23
  #include <linux/netlink.h>
ccb1352e7   Jesse Gross   net: Add Open vSw...
24
  #include <linux/openvswitch.h>
5cd667b0a   Alex Wang   openvswitch: Allo...
25
  #include <linux/reciprocal_div.h>
ccb1352e7   Jesse Gross   net: Add Open vSw...
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  #include <linux/skbuff.h>
  #include <linux/spinlock.h>
  #include <linux/u64_stats_sync.h>
  
  #include "datapath.h"
  
  struct vport;
  struct vport_parms;
  
  /* The following definitions are for users of the vport subsytem: */
  
  int ovs_vport_init(void);
  void ovs_vport_exit(void);
  
  struct vport *ovs_vport_add(const struct vport_parms *);
  void ovs_vport_del(struct vport *);
12eb18f71   Thomas Graf   openvswitch: Cons...
42
  struct vport *ovs_vport_locate(const struct net *net, const char *name);
ccb1352e7   Jesse Gross   net: Add Open vSw...
43
44
45
46
47
  
  void ovs_vport_get_stats(struct vport *, struct ovs_vport_stats *);
  
  int ovs_vport_set_options(struct vport *, struct nlattr *options);
  int ovs_vport_get_options(const struct vport *, struct sk_buff *);
12eb18f71   Thomas Graf   openvswitch: Cons...
48
  int ovs_vport_set_upcall_portids(struct vport *, const struct nlattr *pids);
5cd667b0a   Alex Wang   openvswitch: Allo...
49
50
  int ovs_vport_get_upcall_portids(const struct vport *, struct sk_buff *);
  u32 ovs_vport_find_upcall_portid(const struct vport *, struct sk_buff *);
5cd667b0a   Alex Wang   openvswitch: Allo...
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
  /**
   * struct vport_portids - array of netlink portids of a vport.
   *                        must be protected by rcu.
   * @rn_ids: The reciprocal value of @n_ids.
   * @rcu: RCU callback head for deferred destruction.
   * @n_ids: Size of @ids array.
   * @ids: Array storing the Netlink socket pids to be used for packets received
   * on this port that miss the flow table.
   */
  struct vport_portids {
  	struct reciprocal_value rn_ids;
  	struct rcu_head rcu;
  	u32 n_ids;
  	u32 ids[];
  };
ccb1352e7   Jesse Gross   net: Add Open vSw...
66
67
68
  
  /**
   * struct vport - one port within a datapath
c5420eb12   Jean Sacren   openvswitch: upda...
69
   * @dev: Pointer to net_device.
ccb1352e7   Jesse Gross   net: Add Open vSw...
70
   * @dp: Datapath to which this port belongs.
5cd667b0a   Alex Wang   openvswitch: Allo...
71
   * @upcall_portids: RCU protected 'struct vport_portids'.
03599c941   Thomas Graf   openvswitch: Avoi...
72
   * @port_no: Index into @dp's @ports array.
ccb1352e7   Jesse Gross   net: Add Open vSw...
73
   * @hash_node: Element in @dev_table hash table in vport.c.
15eac2a74   Pravin B Shelar   openvswitch: Incr...
74
   * @dp_hash_node: Element in @datapath->ports hash table in datapath.c.
ccb1352e7   Jesse Gross   net: Add Open vSw...
75
   * @ops: Class structure.
7b4577a9d   Pravin B Shelar   openvswitch: Fix ...
76
   * @detach_list: list used for detaching vport in net-exit call.
c5420eb12   Jean Sacren   openvswitch: upda...
77
   * @rcu: RCU callback head for deferred destruction.
ccb1352e7   Jesse Gross   net: Add Open vSw...
78
79
   */
  struct vport {
be4ace6e6   Thomas Graf   openvswitch: Move...
80
  	struct net_device *dev;
ccb1352e7   Jesse Gross   net: Add Open vSw...
81
  	struct datapath	*dp;
5cd667b0a   Alex Wang   openvswitch: Allo...
82
  	struct vport_portids __rcu *upcall_portids;
03599c941   Thomas Graf   openvswitch: Avoi...
83
  	u16 port_no;
ccb1352e7   Jesse Gross   net: Add Open vSw...
84
85
  
  	struct hlist_node hash_node;
15eac2a74   Pravin B Shelar   openvswitch: Incr...
86
  	struct hlist_node dp_hash_node;
ccb1352e7   Jesse Gross   net: Add Open vSw...
87
  	const struct vport_ops *ops;
7b4577a9d   Pravin B Shelar   openvswitch: Fix ...
88
  	struct list_head detach_list;
be4ace6e6   Thomas Graf   openvswitch: Move...
89
  	struct rcu_head rcu;
ccb1352e7   Jesse Gross   net: Add Open vSw...
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
  };
  
  /**
   * struct vport_parms - parameters for creating a new vport
   *
   * @name: New vport's name.
   * @type: New vport's type.
   * @options: %OVS_VPORT_ATTR_OPTIONS attribute from Netlink message, %NULL if
   * none was supplied.
   * @dp: New vport's datapath.
   * @port_no: New vport's port number.
   */
  struct vport_parms {
  	const char *name;
  	enum ovs_vport_type type;
  	struct nlattr *options;
  
  	/* For ovs_vport_alloc(). */
  	struct datapath *dp;
  	u16 port_no;
5cd667b0a   Alex Wang   openvswitch: Allo...
110
  	struct nlattr *upcall_portids;
ccb1352e7   Jesse Gross   net: Add Open vSw...
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
  };
  
  /**
   * struct vport_ops - definition of a type of virtual port
   *
   * @type: %OVS_VPORT_TYPE_* value for this type of virtual port.
   * @create: Create a new vport configured as specified.  On success returns
   * a new vport allocated with ovs_vport_alloc(), otherwise an ERR_PTR() value.
   * @destroy: Destroys a vport.  Must call vport_free() on the vport but not
   * before an RCU grace period has elapsed.
   * @set_options: Modify the configuration of an existing vport.  May be %NULL
   * if modification is not supported.
   * @get_options: Appends vport-specific attributes for the configuration of an
   * existing vport to a &struct sk_buff.  May be %NULL for a vport that does not
   * have any configuration.
8c876639c   Pravin B Shelar   openvswitch: Remo...
126
   * @send: Send a packet on the device.
91b7514cd   Pravin B Shelar   openvswitch: Unif...
127
   * zero for dropped packets or negative for error.
ccb1352e7   Jesse Gross   net: Add Open vSw...
128
129
130
   */
  struct vport_ops {
  	enum ovs_vport_type type;
8e4e1713e   Pravin B Shelar   openvswitch: Simp...
131
  	/* Called with ovs_mutex. */
ccb1352e7   Jesse Gross   net: Add Open vSw...
132
133
134
135
136
  	struct vport *(*create)(const struct vport_parms *);
  	void (*destroy)(struct vport *);
  
  	int (*set_options)(struct vport *, struct nlattr *);
  	int (*get_options)(const struct vport *, struct sk_buff *);
aec159247   Pravin B Shelar   openvswitch: Use ...
137
  	netdev_tx_t (*send) (struct sk_buff *skb);
62b9c8d03   Thomas Graf   ovs: Turn vports ...
138
139
  	struct module *owner;
  	struct list_head list;
ccb1352e7   Jesse Gross   net: Add Open vSw...
140
  };
ccb1352e7   Jesse Gross   net: Add Open vSw...
141
142
143
  struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *,
  			      const struct vport_parms *);
  void ovs_vport_free(struct vport *);
aa310701e   Pravin B Shelar   openvswitch: Add ...
144
  void ovs_vport_deferred_free(struct vport *vport);
ccb1352e7   Jesse Gross   net: Add Open vSw...
145
146
147
148
149
150
151
152
153
154
155
156
157
158
  
  #define VPORT_ALIGN 8
  
  /**
   *	vport_priv - access private data area of vport
   *
   * @vport: vport to access
   *
   * If a nonzero size was passed in priv_size of vport_alloc() a private data
   * area was allocated on creation.  This allows that area to be accessed and
   * used for any purpose needed by the vport implementer.
   */
  static inline void *vport_priv(const struct vport *vport)
  {
07dc0602c   Daniele Di Proietto   openvswitch: avoi...
159
  	return (u8 *)(uintptr_t)vport + ALIGN(sizeof(struct vport), VPORT_ALIGN);
ccb1352e7   Jesse Gross   net: Add Open vSw...
160
161
162
163
164
165
166
167
168
169
170
171
  }
  
  /**
   *	vport_from_priv - lookup vport from private data pointer
   *
   * @priv: Start of private data area.
   *
   * It is sometimes useful to translate from a pointer to the private data
   * area to the vport, such as in the case where the private data pointer is
   * the result of a hash table lookup.  @priv must point to the start of the
   * private data area.
   */
d0b4da137   Daniele Di Proietto   openvswitch: avoi...
172
  static inline struct vport *vport_from_priv(void *priv)
ccb1352e7   Jesse Gross   net: Add Open vSw...
173
  {
d0b4da137   Daniele Di Proietto   openvswitch: avoi...
174
  	return (struct vport *)((u8 *)priv - ALIGN(sizeof(struct vport), VPORT_ALIGN));
ccb1352e7   Jesse Gross   net: Add Open vSw...
175
  }
8c876639c   Pravin B Shelar   openvswitch: Remo...
176
177
  int ovs_vport_receive(struct vport *, struct sk_buff *,
  		      const struct ip_tunnel_info *);
ccb1352e7   Jesse Gross   net: Add Open vSw...
178

c9db965c5   Thomas Graf   openvswitch: Abst...
179
180
  static inline const char *ovs_vport_name(struct vport *vport)
  {
24d43f32d   Pravin B Shelar   openvswitch: Remo...
181
  	return vport->dev->name;
c9db965c5   Thomas Graf   openvswitch: Abst...
182
  }
83e4bf7a7   Paolo Abeni   openvswitch: prop...
183
184
185
186
187
188
  int __ovs_vport_ops_register(struct vport_ops *ops);
  #define ovs_vport_ops_register(ops)		\
  	({					\
  		(ops)->owner = THIS_MODULE;	\
  		__ovs_vport_ops_register(ops);	\
  	})
62b9c8d03   Thomas Graf   ovs: Turn vports ...
189
  void ovs_vport_ops_unregister(struct vport_ops *ops);
aec159247   Pravin B Shelar   openvswitch: Use ...
190
  void ovs_vport_send(struct vport *vport, struct sk_buff *skb);
8c876639c   Pravin B Shelar   openvswitch: Remo...
191

ccb1352e7   Jesse Gross   net: Add Open vSw...
192
  #endif /* vport.h */