Update how the rpc files are generated so we dont get "unused variable" for *buf
[deb_libnfs.git] / nlm / nlm.x
CommitLineData
6916a665
RS
1/* based on rfc1813 and wireshark */
2
e01ed6a2
RS
3
4struct nlm_fh4 {
5 opaque data<>;
6};
7
8typedef string nlm4_oh<>;
9
10struct nlm_cookie {
11 opaque data<>;
12};
6916a665
RS
13
14enum nlmstat4 {
15 NLM4_GRANTED = 0,
16 NLM4_DENIED = 1,
17 NLM4_DENIED_NOLOCKS = 2,
18 NLM4_BLOCKED = 3,
19 NLM4_DENIED_GRACE_PERIOD = 4,
20 NLM4_DEADLCK = 5,
21 NLM4_ROFS = 6,
22 NLM4_STALE_FH = 7,
23 NLM4_FBIG = 8,
24 NLM4_FAILED = 9
25};
26
27struct nlm4_holder {
e01ed6a2
RS
28 bool exclusive;
29 unsigned int svid;
30 nlm4_oh oh;
6916a665
RS
31 unsigned hyper l_offset;
32 unsigned hyper l_len;
33};
34
35const NLM_MAXNAME = 256;
36struct nlm4_lock {
e01ed6a2
RS
37 string caller_name<NLM_MAXNAME>;
38 struct nlm_fh4 fh;
39 nlm4_oh oh;
40 unsigned int svid;
6916a665
RS
41 unsigned hyper l_offset;
42 unsigned hyper l_len;
43};
44
45struct nlm4_share {
e01ed6a2
RS
46 string caller_name<NLM_MAXNAME>;
47 struct nlm_fh4 fh;
48 nlm4_oh oh;
49 unsigned int mode;
50 unsigned int access;
6916a665
RS
51};
52
2faefcac 53struct nlm4_testres_denied {
6916a665
RS
54 nlm4_holder holder;
55};
56
2faefcac
RS
57union nlm4_testreply switch (nlmstat4 status) {
58 case NLM4_DENIED:
59 nlm4_testres_denied lock;
6916a665
RS
60 default:
61 void;
62};
63
2faefcac
RS
64struct NLM4_TESTres {
65 nlm_cookie cookie;
66 nlm4_testreply reply;
67};
68
e01ed6a2 69struct NLM4_TESTargs {
6916a665
RS
70 nlm_cookie cookie;
71 bool exclusive;
72 nlm4_lock lock;
73};
74
c880fdac
RS
75struct NLM4_CANCres {
76 nlm_cookie cookie;
77 nlmstat4 status;
78};
79
80struct NLM4_CANCargs {
81 nlm_cookie cookie;
82 bool block;
83 bool exclusive;
84 nlm4_lock lock;
85};
86
8d3c1af0
RS
87struct NLM4_UNLOCKres {
88 nlm_cookie cookie;
89 nlmstat4 status;
90};
91
92struct NLM4_UNLOCKargs {
93 nlm_cookie cookie;
94 nlm4_lock lock;
95};
96
04ba56c4
RS
97struct NLM4_LOCKres {
98 nlm_cookie cookie;
99 nlmstat4 status;
100};
101
102struct NLM4_LOCKargs {
103 nlm_cookie cookie;
104 bool block;
105 bool exclusive;
106 nlm4_lock lock;
107 bool reclaim;
108 int state;
109};
110
c33ce42c
RS
111struct NLM4_GRANTEDargs {
112 nlm_cookie cookie;
113 bool exclusive;
114 nlm4_lock lock;
115};
116
117struct NLM4_GRANTEDres {
118 nlm_cookie cookie;
119 nlmstat4 status;
120};
121
6916a665
RS
122program NLM_PROGRAM {
123 version NLM_V4 {
124 void
125 NLM4_NULL(void) = 0;
126
e01ed6a2
RS
127 NLM4_TESTres
128 NLM4_TEST(NLM4_TESTargs) = 1;
6916a665 129
04ba56c4
RS
130 NLM4_LOCKres
131 NLM4_LOCK(NLM4_LOCKargs) = 2;
6916a665 132
c880fdac
RS
133 NLM4_CANCres
134 NLM4_CANCEL(NLM4_CANCargs) = 3;
6916a665 135
8d3c1af0
RS
136 NLM4_UNLOCKres
137 NLM4_UNLOCK(NLM4_UNLOCKargs) = 4;
6916a665 138
c33ce42c
RS
139 NLM4_GRANTEDres
140 NLM4_GRANT(NLM4_GRANTEDargs) = 5;
6916a665 141
e01ed6a2
RS
142 void
143 NLM4_TEST_MSG(NLM4_TESTargs) = 6;
6916a665 144
04ba56c4
RS
145 void
146 NLM4_LOCK_MSG(NLM4_LOCKargs) = 7;
6916a665 147
c880fdac
RS
148 void
149 NLM4_CANCEL_MSG(NLM4_CANCargs) = 8;
6916a665 150
8d3c1af0
RS
151 void
152 NLM4_UNLOCK_MSG(NLM4_UNLOCKargs) = 9;
6916a665 153
c33ce42c
RS
154 void
155 NLM4_GRANT_MSG(NLM4_GRANTEDargs) = 10;
6916a665 156
e01ed6a2
RS
157 void
158 NLM4_TEST_RES(NLM4_TESTres) = 11;
6916a665 159
04ba56c4
RS
160 void
161 NLM4_LOCK_RES(NLM4_LOCKres) = 12;
6916a665 162
c880fdac
RS
163 void
164 NLM4_CANCEL_RES(NLM4_CANCres) = 13;
6916a665 165
8d3c1af0
RS
166 void
167 NLM4_UNLOCK_RES(NLM4_UNLOCKres) = 14;
6916a665 168
c33ce42c
RS
169 void
170 NLM4_GRANT_RES(NLM4_GRANTEDres) = 15;
6916a665
RS
171
172/* nlm4_shareres */
173/* NLM4_SHARE(nlm4_shareargs) = 20; */
174
175/* nlm4_shareres */
176/* NLM4_UNSHARE(nlm4_shareargs) = 21; */
177
178/* nlm4_res */
179/* NLM4_NM_LOCK(nlm4_lockargs) = 22; */
180
181/* void */
182/* NLM4_FREE_ALL(nlm4_notify) = 23; */
183 } = 4;
184} = 100021;