NLM : add raw function for NLM4 CANCEL
[deb_libnfs.git] / nlm / nlm.x
1 /* based on rfc1813 and wireshark */
2
3
4 struct nlm_fh4 {
5 opaque data<>;
6 };
7
8 typedef string nlm4_oh<>;
9
10 struct nlm_cookie {
11 opaque data<>;
12 };
13
14 enum 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
27 struct nlm4_holder {
28 bool exclusive;
29 unsigned int svid;
30 nlm4_oh oh;
31 unsigned hyper l_offset;
32 unsigned hyper l_len;
33 };
34
35 const NLM_MAXNAME = 256;
36 struct nlm4_lock {
37 string caller_name<NLM_MAXNAME>;
38 struct nlm_fh4 fh;
39 nlm4_oh oh;
40 unsigned int svid;
41 unsigned hyper l_offset;
42 unsigned hyper l_len;
43 };
44
45 struct nlm4_share {
46 string caller_name<NLM_MAXNAME>;
47 struct nlm_fh4 fh;
48 nlm4_oh oh;
49 unsigned int mode;
50 unsigned int access;
51 };
52
53 struct nlm4_testres_denied {
54 nlm4_holder holder;
55 };
56
57 union nlm4_testreply switch (nlmstat4 status) {
58 case NLM4_DENIED:
59 nlm4_testres_denied lock;
60 default:
61 void;
62 };
63
64 struct NLM4_TESTres {
65 nlm_cookie cookie;
66 nlm4_testreply reply;
67 };
68
69 struct NLM4_TESTargs {
70 nlm_cookie cookie;
71 bool exclusive;
72 nlm4_lock lock;
73 };
74
75 struct NLM4_CANCres {
76 nlm_cookie cookie;
77 nlmstat4 status;
78 };
79
80 struct NLM4_CANCargs {
81 nlm_cookie cookie;
82 bool block;
83 bool exclusive;
84 nlm4_lock lock;
85 };
86
87 program NLM_PROGRAM {
88 version NLM_V4 {
89 void
90 NLM4_NULL(void) = 0;
91
92 NLM4_TESTres
93 NLM4_TEST(NLM4_TESTargs) = 1;
94
95 /* nlm4_res */
96 /* NLM4_LOCK(nlm4_lockargs) = 2; */
97
98 NLM4_CANCres
99 NLM4_CANCEL(NLM4_CANCargs) = 3;
100
101 /* nlm4_res */
102 /* NLM4_UNLOCK(nlm4_unlockargs) = 4; */
103
104 /* nlm4_res */
105 /* NLM4_GRANTED(nlm4_testargs) = 5; */
106
107 void
108 NLM4_TEST_MSG(NLM4_TESTargs) = 6;
109
110 /* void */
111 /* NLM4_LOCK_MSG(nlm4_lockargs) = 7; */
112
113 void
114 NLM4_CANCEL_MSG(NLM4_CANCargs) = 8;
115
116 /* void */
117 /* NLM4_UNLOCK_MSG(nlm4_unlockargs) = 9; */
118
119 /* void */
120 /* NLM4_GRANTED_MSG(nlm4_testargs) = 10; */
121
122 void
123 NLM4_TEST_RES(NLM4_TESTres) = 11;
124
125 /* void */
126 /* NLM4_LOCK_RES(nlm4_res) = 12; */
127
128 void
129 NLM4_CANCEL_RES(NLM4_CANCres) = 13;
130
131 /* void */
132 /* NLM4_UNLOCK_RES(nlm4_res) = 14; */
133
134 /* void */
135 /* NLM4_GRANTED_RES(nlm4_res) = 15; */
136
137 /* nlm4_shareres */
138 /* NLM4_SHARE(nlm4_shareargs) = 20; */
139
140 /* nlm4_shareres */
141 /* NLM4_UNSHARE(nlm4_shareargs) = 21; */
142
143 /* nlm4_res */
144 /* NLM4_NM_LOCK(nlm4_lockargs) = 22; */
145
146 /* void */
147 /* NLM4_FREE_ALL(nlm4_notify) = 23; */
148 } = 4;
149 } = 100021;