18d59ecb2SHans Petter Selasky /*-
28d59ecb2SHans Petter Selasky * Copyright (c) 2010 Isilon Systems, Inc.
38d59ecb2SHans Petter Selasky * Copyright (c) 2010 iX Systems, Inc.
48d59ecb2SHans Petter Selasky * Copyright (c) 2010 Panasas, Inc.
58d59ecb2SHans Petter Selasky * Copyright (c) 2013, 2014 Mellanox Technologies, Ltd.
68d59ecb2SHans Petter Selasky * All rights reserved.
78d59ecb2SHans Petter Selasky *
88d59ecb2SHans Petter Selasky * Redistribution and use in source and binary forms, with or without
98d59ecb2SHans Petter Selasky * modification, are permitted provided that the following conditions
108d59ecb2SHans Petter Selasky * are met:
118d59ecb2SHans Petter Selasky * 1. Redistributions of source code must retain the above copyright
128d59ecb2SHans Petter Selasky * notice unmodified, this list of conditions, and the following
138d59ecb2SHans Petter Selasky * disclaimer.
148d59ecb2SHans Petter Selasky * 2. Redistributions in binary form must reproduce the above copyright
158d59ecb2SHans Petter Selasky * notice, this list of conditions and the following disclaimer in the
168d59ecb2SHans Petter Selasky * documentation and/or other materials provided with the distribution.
178d59ecb2SHans Petter Selasky *
188d59ecb2SHans Petter Selasky * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
198d59ecb2SHans Petter Selasky * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
208d59ecb2SHans Petter Selasky * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
218d59ecb2SHans Petter Selasky * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
228d59ecb2SHans Petter Selasky * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
238d59ecb2SHans Petter Selasky * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
248d59ecb2SHans Petter Selasky * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
258d59ecb2SHans Petter Selasky * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
268d59ecb2SHans Petter Selasky * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
278d59ecb2SHans Petter Selasky * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
288d59ecb2SHans Petter Selasky */
29307f78f3SVladimir Kondratyev #ifndef _LINUXKPI_LINUX_NET_H_
30307f78f3SVladimir Kondratyev #define _LINUXKPI_LINUX_NET_H_
318d59ecb2SHans Petter Selasky
328e7baabcSHans Petter Selasky #include <sys/types.h>
338e7baabcSHans Petter Selasky #include <sys/malloc.h>
348e7baabcSHans Petter Selasky #include <sys/proc.h>
358d59ecb2SHans Petter Selasky #include <sys/protosw.h>
368d59ecb2SHans Petter Selasky #include <sys/socket.h>
378d59ecb2SHans Petter Selasky #include <sys/socketvar.h>
388e7baabcSHans Petter Selasky #include <sys/errno.h>
398d59ecb2SHans Petter Selasky
408d59ecb2SHans Petter Selasky static inline int
sock_create_kern(int family,int type,int proto,struct socket ** res)418d59ecb2SHans Petter Selasky sock_create_kern(int family, int type, int proto, struct socket **res)
428d59ecb2SHans Petter Selasky {
438d59ecb2SHans Petter Selasky return -socreate(family, res, type, proto, curthread->td_ucred,
448d59ecb2SHans Petter Selasky curthread);
458d59ecb2SHans Petter Selasky }
468d59ecb2SHans Petter Selasky
478d59ecb2SHans Petter Selasky static inline int
sock_getname(struct socket * so,struct sockaddr * sa,int * sockaddr_len,int peer)480fac350cSGleb Smirnoff sock_getname(struct socket *so, struct sockaddr *sa, int *sockaddr_len,
498d59ecb2SHans Petter Selasky int peer)
508d59ecb2SHans Petter Selasky {
518d59ecb2SHans Petter Selasky int error;
528d59ecb2SHans Petter Selasky
530fac350cSGleb Smirnoff /*
540fac350cSGleb Smirnoff * XXXGL: we can't use sopeeraddr()/sosockaddr() here since with
550fac350cSGleb Smirnoff * INVARIANTS they would check if supplied sockaddr has enough
560fac350cSGleb Smirnoff * length. Such notion doesn't even exist in Linux KPI.
570fac350cSGleb Smirnoff */
588d59ecb2SHans Petter Selasky if (peer) {
59*f79a8585SGleb Smirnoff if ((so->so_state & SS_ISCONNECTED) == 0)
608d59ecb2SHans Petter Selasky return (-ENOTCONN);
618d59ecb2SHans Petter Selasky
620fac350cSGleb Smirnoff error = so->so_proto->pr_peeraddr(so, sa);
638d59ecb2SHans Petter Selasky } else
640fac350cSGleb Smirnoff error = so->so_proto->pr_sockaddr(so, sa);
658d59ecb2SHans Petter Selasky if (error)
668d59ecb2SHans Petter Selasky return (-error);
670fac350cSGleb Smirnoff *sockaddr_len = sa->sa_len;
688d59ecb2SHans Petter Selasky
698d59ecb2SHans Petter Selasky return (0);
708d59ecb2SHans Petter Selasky }
718d59ecb2SHans Petter Selasky
728d59ecb2SHans Petter Selasky static inline void
sock_release(struct socket * so)738d59ecb2SHans Petter Selasky sock_release(struct socket *so)
748d59ecb2SHans Petter Selasky {
758d59ecb2SHans Petter Selasky soclose(so);
768d59ecb2SHans Petter Selasky }
778d59ecb2SHans Petter Selasky
78bc042266SBjoern A. Zeeb
79bc042266SBjoern A. Zeeb int linuxkpi_net_ratelimit(void);
80bc042266SBjoern A. Zeeb
81bc042266SBjoern A. Zeeb static inline int
net_ratelimit(void)82bc042266SBjoern A. Zeeb net_ratelimit(void)
83bc042266SBjoern A. Zeeb {
84bc042266SBjoern A. Zeeb
85bc042266SBjoern A. Zeeb return (linuxkpi_net_ratelimit());
86bc042266SBjoern A. Zeeb }
87bc042266SBjoern A. Zeeb
88307f78f3SVladimir Kondratyev #endif /* _LINUXKPI_LINUX_NET_H_ */
89