iPXE
xs_wire.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Details of the "wire" protocol between Xen Store Daemon and client
4  * library or guest kernel.
5  *
6  * Copyright (C) 2005 Rusty Russell IBM Corporation
7  */
8 
9 #ifndef _XS_WIRE_H
10 #define _XS_WIRE_H
11 
12 FILE_LICENCE ( MIT );
13 
15 {
17 #define XS_DEBUG XS_CONTROL
37  /* XS_RESTRICT has been removed */
40 
41  XS_TYPE_COUNT, /* Number of valid types. */
42 
43  XS_INVALID = 0xffff /* Guaranteed to remain an invalid type */
44 };
45 
46 #define XS_WRITE_NONE "NONE"
47 #define XS_WRITE_CREATE "CREATE"
48 #define XS_WRITE_CREATE_EXCL "CREATE|EXCL"
49 
50 /* We hand errors as strings, for portability. */
51 struct xsd_errors
52 {
53  int errnum;
54  const char *errstring;
55 };
56 #ifdef EINVAL
57 #define XSD_ERROR(x) { x, #x }
58 /* LINTED: static unused */
59 static const struct xsd_errors xsd_errors[]
60 #if defined(__GNUC__)
62 #endif
63  = {
64  /* /!\ New errors should be added at the end of the array. */
65  XSD_ERROR(EINVAL),
66  XSD_ERROR(EACCES),
67  XSD_ERROR(EEXIST),
68  XSD_ERROR(EISDIR),
69  XSD_ERROR(ENOENT),
70  XSD_ERROR(ENOMEM),
71  XSD_ERROR(ENOSPC),
72  XSD_ERROR(EIO),
73  XSD_ERROR(ENOTEMPTY),
74  XSD_ERROR(ENOSYS),
75  XSD_ERROR(EROFS),
76  XSD_ERROR(EBUSY),
77  XSD_ERROR(EAGAIN),
78  XSD_ERROR(EISCONN),
79  XSD_ERROR(E2BIG),
80  XSD_ERROR(EPERM),
81 };
82 #endif
83 
85 {
86  uint32_t type; /* XS_??? */
87  uint32_t req_id;/* Request identifier, echoed in daemon's response. */
88  uint32_t tx_id; /* Transaction id (0 if not related to a transaction). */
89  uint32_t len; /* Length of data following this. */
90 
91  /* Generally followed by nul-terminated string(s). */
92 };
93 
95 {
98 };
99 
100 /*
101  * `incontents 150 xenstore_struct XenStore wire protocol.
102  *
103  * Inter-domain shared memory communications. */
104 #define XENSTORE_RING_SIZE 1024
106 #define MASK_XENSTORE_IDX(idx) ((idx) & (XENSTORE_RING_SIZE-1))
108  char req[XENSTORE_RING_SIZE]; /* Requests to xenstore daemon. */
109  char rsp[XENSTORE_RING_SIZE]; /* Replies and async watch events. */
112  uint32_t server_features; /* Bitmap of features supported by the server */
115 };
116 
117 /* Violating this is very bad. See docs/misc/xenstore.txt. */
118 #define XENSTORE_PAYLOAD_MAX 4096
119 
120 /* Violating these just gets you an error back */
121 #define XENSTORE_ABS_PATH_MAX 3072
122 #define XENSTORE_REL_PATH_MAX 2048
123 
124 /* The ability to reconnect a ring */
125 #define XENSTORE_SERVER_FEATURE_RECONNECTION 1
126 /* The presence of the "error" field in the ring page */
127 #define XENSTORE_SERVER_FEATURE_ERROR 2
128 
129 /* Valid values for the connection field */
130 #define XENSTORE_CONNECTED 0 /* the steady-state */
131 #define XENSTORE_RECONNECT 1 /* reconnect in progress */
132 
133 /* Valid values for the error field */
134 #define XENSTORE_ERROR_NONE 0 /* No error */
135 #define XENSTORE_ERROR_COMM 1 /* Communication problem */
136 #define XENSTORE_ERROR_RINGIDX 2 /* Invalid ring index */
137 #define XENSTORE_ERROR_PROTO 3 /* Protocol violation (payload too long) */
138 
139 #endif /* _XS_WIRE_H */
140 
141 /*
142  * Local variables:
143  * mode: C
144  * c-file-style: "BSD"
145  * c-basic-offset: 4
146  * tab-width: 4
147  * indent-tabs-mode: nil
148  * End:
149  */
#define EINVAL
Invalid argument.
Definition: errno.h:428
Definition: xs_wire.h:30
#define EBUSY
Device or resource busy.
Definition: errno.h:338
#define EISCONN
Socket is connected.
Definition: errno.h:438
uint32_t XENSTORE_RING_IDX
Definition: xs_wire.h:105
char req[XENSTORE_RING_SIZE]
Definition: xs_wire.h:108
int errnum
Definition: xs_wire.h:53
#define EEXIST
File exists.
Definition: errno.h:388
#define EISDIR
Is a directory.
Definition: errno.h:443
XENSTORE_RING_IDX rsp_cons
Definition: xs_wire.h:111
#define ENOENT
No such file or directory.
Definition: errno.h:514
uint32_t req_id
Definition: xs_wire.h:87
#define EACCES
Permission denied.
Definition: errno.h:298
xs_watch_type
Definition: xs_wire.h:94
#define ENOTEMPTY
Directory not empty.
Definition: errno.h:579
#define ENOMEM
Not enough space.
Definition: errno.h:534
A 16-bit general register.
Definition: registers.h:24
#define E2BIG
Argument list too long.
Definition: errno.h:293
XENSTORE_RING_IDX rsp_prod
Definition: xs_wire.h:111
unsigned int uint32_t
Definition: stdint.h:12
uint32_t type
Definition: xs_wire.h:86
#define EAGAIN
Resource temporarily unavailable.
Definition: errno.h:318
uint8_t unused
Unused.
Definition: librm.h:254
XENSTORE_RING_IDX req_prod
Definition: xs_wire.h:110
FILE_LICENCE(MIT)
uint32_t tx_id
Definition: xs_wire.h:88
#define EPERM
Operation not permitted.
Definition: errno.h:614
#define ENOSPC
No space left on device.
Definition: errno.h:549
#define EIO
Input/output error.
Definition: errno.h:433
XENSTORE_RING_IDX req_cons
Definition: xs_wire.h:110
xsd_sockmsg_type
Definition: xs_wire.h:14
#define ENOSYS
Function not implemented.
Definition: errno.h:564
#define EROFS
Read-only file system.
Definition: errno.h:644
char rsp[XENSTORE_RING_SIZE]
Definition: xs_wire.h:109
const char * errstring
Definition: xs_wire.h:54
uint32_t len
Definition: xs_wire.h:89
#define XENSTORE_RING_SIZE
Definition: xs_wire.h:104
if(natsemi->flags &NATSEMI_64BIT) return 1