nbd.h 3.5 KB
Newer Older
1
/*
B
bellard 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15
 *  Copyright (C) 2005  Anthony Liguori <anthony@codemonkey.ws>
 *
 *  Network Block Device
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; under version 2 of the License.
 *
 *  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
16
 *  along with this program; if not, see <http://www.gnu.org/licenses/>.
17
 */
B
bellard 已提交
18 19 20 21 22 23

#ifndef NBD_H
#define NBD_H

#include <sys/types.h>

24
#include "qemu-common.h"
25
#include "qemu/option.h"
26

27
struct nbd_request {
28
    uint32_t magic;
29 30 31 32
    uint32_t type;
    uint64_t handle;
    uint64_t from;
    uint32_t len;
33
} QEMU_PACKED;
34 35

struct nbd_reply {
36
    uint32_t magic;
37 38
    uint32_t error;
    uint64_t handle;
39
} QEMU_PACKED;
40

P
Paolo Bonzini 已提交
41 42
#define NBD_FLAG_HAS_FLAGS      (1 << 0)        /* Flags are there */
#define NBD_FLAG_READ_ONLY      (1 << 1)        /* Device is read-only */
43 44 45 46 47
#define NBD_FLAG_SEND_FLUSH     (1 << 2)        /* Send FLUSH */
#define NBD_FLAG_SEND_FUA       (1 << 3)        /* Send FUA (Force Unit Access) */
#define NBD_FLAG_ROTATIONAL     (1 << 4)        /* Use elevator algorithm - rotational media */
#define NBD_FLAG_SEND_TRIM      (1 << 5)        /* Send TRIM (discard) */

48 49 50 51 52 53 54
/* New-style global flags. */
#define NBD_FLAG_FIXED_NEWSTYLE     (1 << 0)    /* Fixed newstyle protocol. */

/* New-style client flags. */
#define NBD_FLAG_C_FIXED_NEWSTYLE   (1 << 0)    /* Fixed newstyle protocol. */

/* Reply types. */
55 56
#define NBD_REP_ACK             (1)             /* Data sending finished. */
#define NBD_REP_SERVER          (2)             /* Export description. */
57 58
#define NBD_REP_ERR_UNSUP       ((UINT32_C(1) << 31) | 1) /* Unknown option. */
#define NBD_REP_ERR_INVALID     ((UINT32_C(1) << 31) | 3) /* Invalid length. */
59

60 61
#define NBD_CMD_MASK_COMMAND	0x0000ffff
#define NBD_CMD_FLAG_FUA	(1 << 16)
P
Paolo Bonzini 已提交
62

63 64 65
enum {
    NBD_CMD_READ = 0,
    NBD_CMD_WRITE = 1,
66 67 68
    NBD_CMD_DISC = 2,
    NBD_CMD_FLUSH = 3,
    NBD_CMD_TRIM = 4
69 70
};

71 72
#define NBD_DEFAULT_PORT	10809

73 74
/* Maximum size of a single READ/WRITE data buffer */
#define NBD_MAX_BUFFER_SIZE (32 * 1024 * 1024)
75

76
ssize_t nbd_wr_sync(int fd, void *buffer, size_t size, bool do_read);
77
int nbd_receive_negotiate(int csock, const char *name, uint32_t *flags,
78 79
                          off_t *size, Error **errp);
int nbd_init(int fd, int csock, uint32_t flags, off_t size);
P
Paolo Bonzini 已提交
80 81
ssize_t nbd_send_request(int csock, struct nbd_request *request);
ssize_t nbd_receive_reply(int csock, struct nbd_reply *reply);
82
int nbd_client(int fd);
B
bellard 已提交
83 84
int nbd_disconnect(int fd);

P
Paolo Bonzini 已提交
85
typedef struct NBDExport NBDExport;
86
typedef struct NBDClient NBDClient;
P
Paolo Bonzini 已提交
87

88
NBDExport *nbd_export_new(BlockBackend *blk, off_t dev_offset, off_t size,
M
Max Reitz 已提交
89 90
                          uint32_t nbdflags, void (*close)(NBDExport *),
                          Error **errp);
P
Paolo Bonzini 已提交
91
void nbd_export_close(NBDExport *exp);
92 93
void nbd_export_get(NBDExport *exp);
void nbd_export_put(NBDExport *exp);
94

95
BlockBackend *nbd_export_get_blockdev(NBDExport *exp);
P
Paolo Bonzini 已提交
96

P
Paolo Bonzini 已提交
97 98 99 100
NBDExport *nbd_export_find(const char *name);
void nbd_export_set_name(NBDExport *exp, const char *name);
void nbd_export_close_all(void);

101 102
NBDClient *nbd_client_new(NBDExport *exp, int csock,
                          void (*close)(NBDClient *));
103 104
void nbd_client_get(NBDClient *client);
void nbd_client_put(NBDClient *client);
P
Paolo Bonzini 已提交
105

B
bellard 已提交
106
#endif