From: "Sven Köhler" <skoehler@upb.de>
To: Paul.Clements@steeleye.com
Cc: pavel@suse.cz, linux-kernel@vger.kernel.org
Subject: [NBD] patch and documentation
Date: Mon, 08 Sep 2003 18:59:00 +0200 [thread overview]
Message-ID: <3F5CB554.5040507@upb.de> (raw)
[-- Attachment #1: Type: text/plain, Size: 739 bytes --]
Hi,
The patch i attached defines max_sectors for each NBD device to be 256
which is 128KB as described in the protocol description i attached.
The value 255 which is default in 2.4 kernels is not optimal. See my
other posting in the lkml to read why.
The patch seems to work fine. My server-implementation receives one
128KB request as expected instead of two 127KB and 1Kb requests.
Even if 256 is the new max_sectors-default of kernel 2.6, the patch
should be applied since the value should be part of the protocol
specification and therefor part of nbd.c
The documentation i attached should be published somewhere. For example
on nbd.sf.net since we didn't find one source where all the information
is collected.
Thx
Sven
[-- Attachment #2: nbd-patch.gz --]
[-- Type: application/gzip, Size: 487 bytes --]
[-- Attachment #3: protocol.txt --]
[-- Type: text/plain, Size: 3128 bytes --]
The NBD-protocol
How it works:
To use the NBD features of the kernel you must compile the kernel module
called "Network block device support" (CONFIG_BLK_DEV_NBD). After you've
loaded the module the devices will appear in /dev/nbd/ if you're using
devfs. If you're not using devfs you will possibly need to create your
device-nodes with "mknod". All NBD devices have major ID 43. /dev/nbd/0
has minor ID 0, /dev/nbd/1 has minor ID 1 and so on.
To connect a NBD device to a remote server you need install the NBD tools
downloadable at http://nbd.sf.net or http://sf.net/projects/nbd. Run
"nbd-client <host> <tcp-port> /dev/nbd/0" to connect the device /dev/nbd/0
to the remote server. nbd-client will open a TCP-connection to the server
and waits for some initial data which contains the size of the device.
Than the handle of the TCP-connection is transferred to the kernel for
further use. nbd-client will fork into background because the handle of the
TCP-connection would be closed by the kernel if nbd-client exits.
The tools also contain a very basic NBD server which will enable you to use
any file or device as a NBD.
The protocol:
The protocol is based on top of TCP/IP. Both client and server send packets
to each other. The server must send an init-packet to the client if a
client connects. After that the server just receives request-packets from
the client and sends back reply-packets until the connection is closed or a
disconnect-request is received.
The amount of data that can be read or written with one request
is limited to 128KB.
The current implementation of the NBD-protocol in the Linux-Kernel does
send multiple requests without waiting for replies. So it does make sense
for the server to handle requests in parallel.
Constants:
INIT_PASSWD = "NBDMAGIC"
INIT_MAGIC = 0x0000420281861253
REQUEST_MAGIC = 0x25609513
REPLY_MAGIC = 0x67446698
REQUEST_READ = 0
REQUEST_WRITE = 1
REQUEST_DISCONNECT = 2
Packets:
init-packet:
passwd : 8 bytes (string) = INIT_PASSWD
magic : 8 bytes (integer) = INIT_MAGIC
size : 8 bytes (integer) = size of the device in bytes
reserved : 128 bytes (filled with zeros)
request-packet:
magic : 4 bytes (integer) = REQUEST_MAGIC
type : 4 bytes (integer) = REQUEST_READ, REQUEST_WRITE or REQUEST_DISCONNECT
handle : 8 bytes (integer) = request-handle
from : 8 bytes (integer) = start offset for read/write-operation in bytes
length : 4 bytes (integer) = length of the read/write-operationion bytes
data : x bytes (only for write request, x = length field of this packet)
reply-packet:
magic : 4 bytes (integer) = REPLY_MAGIC
error : 4 bytes (integer) = errorcode (0 = no error)
handle : 8 bytes (integer) = copy of request-handle
data : x bytes (only for reply to read request and if no error occured,
x = length field of the request packet)
all integer values are stored unsigned and in network-byte-order (big-endian)
next reply other threads:[~2003-09-08 16:58 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-09-08 16:59 Sven Köhler [this message]
2003-09-08 19:38 ` [NBD] patch and documentation Pavel Machek
2003-09-08 19:42 ` Sven Köhler
2003-09-08 20:04 ` Paul Clements
2003-09-08 20:17 ` Sven Köhler
2003-09-08 21:10 ` Paul Clements
2003-09-08 22:04 ` Sven Köhler
2003-09-08 22:17 ` Pavel Machek
2003-09-08 22:13 ` Sven Köhler
2003-09-08 22:21 ` Pavel Machek
2003-09-08 22:24 ` Sven Köhler
2003-09-08 23:28 ` Pavel Machek
2003-09-09 0:12 ` Sven Köhler
2003-09-09 0:47 ` Paul Clements
2003-09-09 0:52 ` Sven Köhler
2003-09-09 6:10 ` Sven Köhler
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3F5CB554.5040507@upb.de \
--to=skoehler@upb.de \
--cc=Paul.Clements@steeleye.com \
--cc=linux-kernel@vger.kernel.org \
--cc=pavel@suse.cz \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox