~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/net/vmw_vsock/vsock_addr.c

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /net/vmw_vsock/vsock_addr.c (Architecture sparc) and /net/vmw_vsock/vsock_addr.c (Architecture m68k)


  1 // SPDX-License-Identifier: GPL-2.0-only            1 // SPDX-License-Identifier: GPL-2.0-only
  2 /*                                                  2 /*
  3  * VMware vSockets Driver                           3  * VMware vSockets Driver
  4  *                                                  4  *
  5  * Copyright (C) 2007-2012 VMware, Inc. All ri      5  * Copyright (C) 2007-2012 VMware, Inc. All rights reserved.
  6  */                                                 6  */
  7                                                     7 
  8 #include <linux/types.h>                            8 #include <linux/types.h>
  9 #include <linux/socket.h>                           9 #include <linux/socket.h>
 10 #include <linux/stddef.h>                          10 #include <linux/stddef.h>
 11 #include <net/sock.h>                              11 #include <net/sock.h>
 12 #include <net/vsock_addr.h>                        12 #include <net/vsock_addr.h>
 13                                                    13 
 14 void vsock_addr_init(struct sockaddr_vm *addr,     14 void vsock_addr_init(struct sockaddr_vm *addr, u32 cid, u32 port)
 15 {                                                  15 {
 16         memset(addr, 0, sizeof(*addr));            16         memset(addr, 0, sizeof(*addr));
 17         addr->svm_family = AF_VSOCK;               17         addr->svm_family = AF_VSOCK;
 18         addr->svm_cid = cid;                       18         addr->svm_cid = cid;
 19         addr->svm_port = port;                     19         addr->svm_port = port;
 20 }                                                  20 }
 21 EXPORT_SYMBOL_GPL(vsock_addr_init);                21 EXPORT_SYMBOL_GPL(vsock_addr_init);
 22                                                    22 
 23 int vsock_addr_validate(const struct sockaddr_     23 int vsock_addr_validate(const struct sockaddr_vm *addr)
 24 {                                                  24 {
 25         __u8 svm_valid_flags = VMADDR_FLAG_TO_     25         __u8 svm_valid_flags = VMADDR_FLAG_TO_HOST;
 26                                                    26 
 27         if (!addr)                                 27         if (!addr)
 28                 return -EFAULT;                    28                 return -EFAULT;
 29                                                    29 
 30         if (addr->svm_family != AF_VSOCK)          30         if (addr->svm_family != AF_VSOCK)
 31                 return -EAFNOSUPPORT;              31                 return -EAFNOSUPPORT;
 32                                                    32 
 33         if (addr->svm_flags & ~svm_valid_flags     33         if (addr->svm_flags & ~svm_valid_flags)
 34                 return -EINVAL;                    34                 return -EINVAL;
 35                                                    35 
 36         return 0;                                  36         return 0;
 37 }                                                  37 }
 38 EXPORT_SYMBOL_GPL(vsock_addr_validate);            38 EXPORT_SYMBOL_GPL(vsock_addr_validate);
 39                                                    39 
 40 bool vsock_addr_bound(const struct sockaddr_vm     40 bool vsock_addr_bound(const struct sockaddr_vm *addr)
 41 {                                                  41 {
 42         return addr->svm_port != VMADDR_PORT_A     42         return addr->svm_port != VMADDR_PORT_ANY;
 43 }                                                  43 }
 44 EXPORT_SYMBOL_GPL(vsock_addr_bound);               44 EXPORT_SYMBOL_GPL(vsock_addr_bound);
 45                                                    45 
 46 void vsock_addr_unbind(struct sockaddr_vm *add     46 void vsock_addr_unbind(struct sockaddr_vm *addr)
 47 {                                                  47 {
 48         vsock_addr_init(addr, VMADDR_CID_ANY,      48         vsock_addr_init(addr, VMADDR_CID_ANY, VMADDR_PORT_ANY);
 49 }                                                  49 }
 50 EXPORT_SYMBOL_GPL(vsock_addr_unbind);              50 EXPORT_SYMBOL_GPL(vsock_addr_unbind);
 51                                                    51 
 52 bool vsock_addr_equals_addr(const struct socka     52 bool vsock_addr_equals_addr(const struct sockaddr_vm *addr,
 53                             const struct socka     53                             const struct sockaddr_vm *other)
 54 {                                                  54 {
 55         return addr->svm_cid == other->svm_cid     55         return addr->svm_cid == other->svm_cid &&
 56                 addr->svm_port == other->svm_p     56                 addr->svm_port == other->svm_port;
 57 }                                                  57 }
 58 EXPORT_SYMBOL_GPL(vsock_addr_equals_addr);         58 EXPORT_SYMBOL_GPL(vsock_addr_equals_addr);
 59                                                    59 
 60 int vsock_addr_cast(const struct sockaddr *add     60 int vsock_addr_cast(const struct sockaddr *addr,
 61                     size_t len, struct sockadd     61                     size_t len, struct sockaddr_vm **out_addr)
 62 {                                                  62 {
 63         if (len < sizeof(**out_addr))              63         if (len < sizeof(**out_addr))
 64                 return -EFAULT;                    64                 return -EFAULT;
 65                                                    65 
 66         *out_addr = (struct sockaddr_vm *)addr     66         *out_addr = (struct sockaddr_vm *)addr;
 67         return vsock_addr_validate(*out_addr);     67         return vsock_addr_validate(*out_addr);
 68 }                                                  68 }
 69 EXPORT_SYMBOL_GPL(vsock_addr_cast);                69 EXPORT_SYMBOL_GPL(vsock_addr_cast);
 70                                                    70 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php