r294: Delay daemon() call as long as possible, and modify error handling slightly to
[nbd.git] / cliserv.h
index 569d1ce..49dffca 100644 (file)
--- a/cliserv.h
+++ b/cliserv.h
@@ -36,9 +36,13 @@ typedef unsigned long long u64;
 #endif
 
 #ifdef NBD_H_LOCAL
+/* 2.6.18 and above use __be* rather than u* */
+#define __be32 u32
+#define __be64 u64
 #include "nbd.h"
 #endif
 #ifdef NBD_H_LINUX
+#include <linux/types.h>
 #include <linux/nbd.h>
 #endif
 
@@ -52,8 +56,7 @@ u64 cliserv_magic = 0x00420281861253LL;
 
 #define INFO(a) do { } while(0)
 
-void setmysockopt(int sock)
-{
+void setmysockopt(int sock) {
        int size = 1;
 #if 0
        if (setsockopt(sock, SOL_SOCKET, SO_SNDBUF, &size, sizeof(int)) < 0)
@@ -71,8 +74,7 @@ void setmysockopt(int sock)
 #endif
 }
 
-void err(const char *s)
-{
+void err(const char *s) {
        const int maxlen = 150;
        char s1[maxlen], *s2;
 
@@ -94,14 +96,12 @@ void err(const char *s)
        s1[maxlen-1] = '\0';
 #ifdef ISSERVER
        syslog(LOG_ERR, "%s", s1);
-#else
-       fprintf(stderr, "Error: %s\n", s1);
 #endif
+       fprintf(stderr, "Error: %s\n", s1);
        exit(1);
 }
 
-void logging(void)
-{
+void logging(void) {
 #ifdef ISSERVER
        openlog(MY_NAME, LOG_PID, LOG_DAEMON);
 #endif
@@ -110,13 +110,11 @@ void logging(void)
 }
 
 #ifdef WORDS_BIGENDIAN
-u64 ntohll(u64 a)
-{
+u64 ntohll(u64 a) {
        return a;
 }
 #else
-u64 ntohll(u64 a)
-{
+u64 ntohll(u64 a) {
        u32 lo = a & 0xffffffff;
        u32 hi = a >> 32U;
        lo = ntohl(lo);
@@ -125,3 +123,7 @@ u64 ntohll(u64 a)
 }
 #endif
 #define htonll ntohll
+
+/* Flags used between the client and server */
+#define NBD_FLAG_HAS_FLAGS     (1 << 0)        /* Flags are there */
+#define NBD_FLAG_READ_ONLY     (1 << 1)        /* Device is read-only */