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

TOMOYO Linux Cross Reference
Linux/include/uapi/linux/nbd.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ 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.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/uapi/linux/nbd.h (Version linux-6.12-rc7) and /include/uapi/linux/nbd.h (Version linux-6.7.12)


  1 /* SPDX-License-Identifier: GPL-1.0+ WITH Linu      1 /* SPDX-License-Identifier: GPL-1.0+ WITH Linux-syscall-note */
  2 /*                                                  2 /*
  3  * 1999 Copyright (C) Pavel Machek, pavel@ucw.      3  * 1999 Copyright (C) Pavel Machek, pavel@ucw.cz. This code is GPL.
  4  * 1999/11/04 Copyright (C) 1999 VMware, Inc.       4  * 1999/11/04 Copyright (C) 1999 VMware, Inc. (Regis "HPReg" Duchesne)
  5  *            Made nbd_end_request() use the i      5  *            Made nbd_end_request() use the io_request_lock
  6  * 2001 Copyright (C) Steven Whitehouse             6  * 2001 Copyright (C) Steven Whitehouse
  7  *            New nbd_end_request() for compat      7  *            New nbd_end_request() for compatibility with new linux block
  8  *            layer code.                           8  *            layer code.
  9  * 2003/06/24 Louis D. Langholtz <ldl@aros.net      9  * 2003/06/24 Louis D. Langholtz <ldl@aros.net>
 10  *            Removed unneeded blksize_bits fi     10  *            Removed unneeded blksize_bits field from nbd_device struct.
 11  *            Cleanup PARANOIA usage & code.       11  *            Cleanup PARANOIA usage & code.
 12  * 2004/02/19 Paul Clements                        12  * 2004/02/19 Paul Clements
 13  *            Removed PARANOIA, plus various c     13  *            Removed PARANOIA, plus various cleanup and comments
 14  * 2023 Copyright Red Hat                          14  * 2023 Copyright Red Hat
 15  *            Link to userspace extensions, fa     15  *            Link to userspace extensions, favor cookie over handle.
 16  */                                                16  */
 17                                                    17 
 18 #ifndef _UAPILINUX_NBD_H                           18 #ifndef _UAPILINUX_NBD_H
 19 #define _UAPILINUX_NBD_H                           19 #define _UAPILINUX_NBD_H
 20                                                    20 
 21 #include <linux/types.h>                           21 #include <linux/types.h>
 22                                                    22 
 23 #define NBD_SET_SOCK    _IO( 0xab, 0 )             23 #define NBD_SET_SOCK    _IO( 0xab, 0 )
 24 #define NBD_SET_BLKSIZE _IO( 0xab, 1 )             24 #define NBD_SET_BLKSIZE _IO( 0xab, 1 )
 25 #define NBD_SET_SIZE    _IO( 0xab, 2 )             25 #define NBD_SET_SIZE    _IO( 0xab, 2 )
 26 #define NBD_DO_IT       _IO( 0xab, 3 )             26 #define NBD_DO_IT       _IO( 0xab, 3 )
 27 #define NBD_CLEAR_SOCK  _IO( 0xab, 4 )             27 #define NBD_CLEAR_SOCK  _IO( 0xab, 4 )
 28 #define NBD_CLEAR_QUE   _IO( 0xab, 5 )             28 #define NBD_CLEAR_QUE   _IO( 0xab, 5 )
 29 #define NBD_PRINT_DEBUG _IO( 0xab, 6 )             29 #define NBD_PRINT_DEBUG _IO( 0xab, 6 )
 30 #define NBD_SET_SIZE_BLOCKS     _IO( 0xab, 7 )     30 #define NBD_SET_SIZE_BLOCKS     _IO( 0xab, 7 )
 31 #define NBD_DISCONNECT  _IO( 0xab, 8 )             31 #define NBD_DISCONNECT  _IO( 0xab, 8 )
 32 #define NBD_SET_TIMEOUT _IO( 0xab, 9 )             32 #define NBD_SET_TIMEOUT _IO( 0xab, 9 )
 33 #define NBD_SET_FLAGS   _IO( 0xab, 10)             33 #define NBD_SET_FLAGS   _IO( 0xab, 10)
 34                                                    34 
 35 /*                                                 35 /*
 36  * See also https://github.com/NetworkBlockDev     36  * See also https://github.com/NetworkBlockDevice/nbd/blob/master/doc/proto.md
 37  * for additional userspace extensions not yet     37  * for additional userspace extensions not yet utilized in the kernel module.
 38  */                                                38  */
 39                                                    39 
 40 enum {                                             40 enum {
 41         NBD_CMD_READ = 0,                          41         NBD_CMD_READ = 0,
 42         NBD_CMD_WRITE = 1,                         42         NBD_CMD_WRITE = 1,
 43         NBD_CMD_DISC = 2,                          43         NBD_CMD_DISC = 2,
 44         NBD_CMD_FLUSH = 3,                         44         NBD_CMD_FLUSH = 3,
 45         NBD_CMD_TRIM = 4,                      !!  45         NBD_CMD_TRIM = 4
 46         /* userspace defines additional extens     46         /* userspace defines additional extension commands */
 47         NBD_CMD_WRITE_ZEROES = 6,              << 
 48 };                                                 47 };
 49                                                    48 
 50 /* values for flags field, these are server in     49 /* values for flags field, these are server interaction specific. */
 51 #define NBD_FLAG_HAS_FLAGS      (1 << 0) /* nb     50 #define NBD_FLAG_HAS_FLAGS      (1 << 0) /* nbd-server supports flags */
 52 #define NBD_FLAG_READ_ONLY      (1 << 1) /* de     51 #define NBD_FLAG_READ_ONLY      (1 << 1) /* device is read-only */
 53 #define NBD_FLAG_SEND_FLUSH     (1 << 2) /* ca     52 #define NBD_FLAG_SEND_FLUSH     (1 << 2) /* can flush writeback cache */
 54 #define NBD_FLAG_SEND_FUA       (1 << 3) /* se     53 #define NBD_FLAG_SEND_FUA       (1 << 3) /* send FUA (forced unit access) */
 55 #define NBD_FLAG_ROTATIONAL     (1 << 4) /* de << 
 56 #define NBD_FLAG_SEND_TRIM      (1 << 5) /* se << 
 57 #define NBD_FLAG_SEND_WRITE_ZEROES (1 << 6) /* << 
 58 /* there is a gap here to match userspace */       54 /* there is a gap here to match userspace */
                                                   >>  55 #define NBD_FLAG_SEND_TRIM      (1 << 5) /* send trim/discard */
 59 #define NBD_FLAG_CAN_MULTI_CONN (1 << 8)           56 #define NBD_FLAG_CAN_MULTI_CONN (1 << 8)        /* Server supports multiple connections per export. */
 60                                                    57 
 61 /* values for cmd flags in the upper 16 bits o     58 /* values for cmd flags in the upper 16 bits of request type */
 62 #define NBD_CMD_FLAG_FUA        (1 << 16) /* F     59 #define NBD_CMD_FLAG_FUA        (1 << 16) /* FUA (forced unit access) op */
 63 #define NBD_CMD_FLAG_NO_HOLE    (1 << 17) /* D << 
 64                                                    60 
 65 /* These are client behavior specific flags. *     61 /* These are client behavior specific flags. */
 66 #define NBD_CFLAG_DESTROY_ON_DISCONNECT (1 <<      62 #define NBD_CFLAG_DESTROY_ON_DISCONNECT (1 << 0) /* delete the nbd device on
 67                                                    63                                                     disconnect. */
 68 #define NBD_CFLAG_DISCONNECT_ON_CLOSE (1 << 1)     64 #define NBD_CFLAG_DISCONNECT_ON_CLOSE (1 << 1) /* disconnect the nbd device on
 69                                                    65                                                 *  close by last opener.
 70                                                    66                                                 */
 71                                                    67 
 72 /* userspace doesn't need the nbd_device struc     68 /* userspace doesn't need the nbd_device structure */
 73                                                    69 
 74 /* These are sent over the network in the requ     70 /* These are sent over the network in the request/reply magic fields */
 75                                                    71 
 76 #define NBD_REQUEST_MAGIC 0x25609513               72 #define NBD_REQUEST_MAGIC 0x25609513
 77 #define NBD_REPLY_MAGIC 0x67446698                 73 #define NBD_REPLY_MAGIC 0x67446698
 78 /* Do *not* use magics: 0x12560953 0x96744668.     74 /* Do *not* use magics: 0x12560953 0x96744668. */
 79 /* magic 0x668e33ef for structured reply not s     75 /* magic 0x668e33ef for structured reply not supported by kernel yet */
 80                                                    76 
 81 /*                                                 77 /*
 82  * This is the packet used for communication b     78  * This is the packet used for communication between client and
 83  * server. All data are in network byte order.     79  * server. All data are in network byte order.
 84  */                                                80  */
 85 struct nbd_request {                               81 struct nbd_request {
 86         __be32 magic;   /* NBD_REQUEST_MAGIC       82         __be32 magic;   /* NBD_REQUEST_MAGIC    */
 87         __be32 type;    /* See NBD_CMD_*           83         __be32 type;    /* See NBD_CMD_*        */
 88         union {                                    84         union {
 89                 __be64 cookie;  /* Opaque iden     85                 __be64 cookie;  /* Opaque identifier for request        */
 90                 char handle[8]; /* older spell     86                 char handle[8]; /* older spelling of cookie             */
 91         };                                         87         };
 92         __be64 from;                               88         __be64 from;
 93         __be32 len;                                89         __be32 len;
 94 } __attribute__((packed));                         90 } __attribute__((packed));
 95                                                    91 
 96 /*                                                 92 /*
 97  * This is the reply packet that nbd-server se     93  * This is the reply packet that nbd-server sends back to the client after
 98  * it has completed an I/O request (or an erro     94  * it has completed an I/O request (or an error occurs).
 99  */                                                95  */
100 struct nbd_reply {                                 96 struct nbd_reply {
101         __be32 magic;           /* NBD_REPLY_M     97         __be32 magic;           /* NBD_REPLY_MAGIC      */
102         __be32 error;           /* 0 = ok, els     98         __be32 error;           /* 0 = ok, else error   */
103         union {                                    99         union {
104                 __be64 cookie;  /* Opaque iden    100                 __be64 cookie;  /* Opaque identifier from request       */
105                 char handle[8]; /* older spell    101                 char handle[8]; /* older spelling of cookie             */
106         };                                        102         };
107 };                                                103 };
108 #endif /* _UAPILINUX_NBD_H */                     104 #endif /* _UAPILINUX_NBD_H */
109                                                   105 

~ [ 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