iostat - add read/write details to output
[dragonfly.git] / contrib / bind / lib / dns / rdata / ch_3 / a_1.c
1 /*
2  * Copyright (C) 2005, 2007  Internet Systems Consortium, Inc. ("ISC")
3  *
4  * Permission to use, copy, modify, and/or distribute this software for any
5  * purpose with or without fee is hereby granted, provided that the above
6  * copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
9  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
10  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
11  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
12  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
13  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
14  * PERFORMANCE OF THIS SOFTWARE.
15  */
16
17 /* $Id: a_1.c,v 1.6 2007/06/19 23:47:17 tbox Exp $ */
18
19 /* by Bjorn.Victor@it.uu.se, 2005-05-07 */
20 /* Based on generic/soa_6.c and generic/mx_15.c */
21
22 #ifndef RDATA_CH_3_A_1_C
23 #define RDATA_CH_3_A_1_C
24
25 #include <isc/net.h>
26
27 #define RRTYPE_A_ATTRIBUTES (0)
28
29 static inline isc_result_t
30 fromtext_ch_a(ARGS_FROMTEXT) {
31         isc_token_t token;
32         dns_name_t name;
33         isc_buffer_t buffer;
34
35         REQUIRE(type == 1);
36         REQUIRE(rdclass == dns_rdataclass_ch); /* 3 */
37
38         UNUSED(type);
39         UNUSED(callbacks);
40
41         RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
42                                       ISC_FALSE));
43
44         /* get domain name */
45         dns_name_init(&name, NULL);
46         buffer_fromregion(&buffer, &token.value.as_region);
47         origin = (origin != NULL) ? origin : dns_rootname;
48         RETTOK(dns_name_fromtext(&name, &buffer, origin, options, target));
49         if ((options & DNS_RDATA_CHECKNAMES) != 0 &&
50             (options & DNS_RDATA_CHECKREVERSE) != 0) {
51                 isc_boolean_t ok;
52                 ok = dns_name_ishostname(&name, ISC_FALSE);
53                 if (!ok && (options & DNS_RDATA_CHECKNAMESFAIL) != 0)
54                         RETTOK(DNS_R_BADNAME);
55                 if (!ok && callbacks != NULL)
56                         warn_badname(&name, lexer, callbacks);
57         }
58
59         /* 16-bit octal address */
60         RETERR(isc_lex_getoctaltoken(lexer, &token, ISC_FALSE));
61         if (token.value.as_ulong > 0xffffU)
62                 RETTOK(ISC_R_RANGE);
63         return (uint16_tobuffer(token.value.as_ulong, target));
64 }
65
66 static inline isc_result_t
67 totext_ch_a(ARGS_TOTEXT) {
68         isc_region_t region;
69         dns_name_t name;
70         dns_name_t prefix;
71         isc_boolean_t sub;
72         char buf[sizeof("0177777")];
73         isc_uint16_t addr;
74
75         REQUIRE(rdata->type == 1);
76         REQUIRE(rdata->rdclass == dns_rdataclass_ch); /* 3 */
77         REQUIRE(rdata->length != 0);
78
79         dns_name_init(&name, NULL);
80         dns_name_init(&prefix, NULL);
81
82         dns_rdata_toregion(rdata, &region);
83         dns_name_fromregion(&name, &region);
84         isc_region_consume(&region, name_length(&name));
85         addr = uint16_fromregion(&region);
86
87         sub = name_prefix(&name, tctx->origin, &prefix);
88         RETERR(dns_name_totext(&prefix, sub, target));
89
90         sprintf(buf, "%o", addr); /* note octal */
91         RETERR(str_totext(" ", target));
92         return (str_totext(buf, target));
93 }
94
95 static inline isc_result_t
96 fromwire_ch_a(ARGS_FROMWIRE) {
97         isc_region_t sregion;
98         isc_region_t tregion;
99         dns_name_t name;
100
101         REQUIRE(type == 1);
102         REQUIRE(rdclass == dns_rdataclass_ch);
103
104         UNUSED(type);
105         UNUSED(rdclass);
106
107         dns_decompress_setmethods(dctx, DNS_COMPRESS_GLOBAL14);
108
109         dns_name_init(&name, NULL);
110         
111         RETERR(dns_name_fromwire(&name, source, dctx, options, target));
112
113         isc_buffer_activeregion(source, &sregion);
114         isc_buffer_availableregion(target, &tregion);
115         if (sregion.length < 2)
116                 return (ISC_R_UNEXPECTEDEND);
117         if (tregion.length < 2)
118                 return (ISC_R_NOSPACE);
119
120         memcpy(tregion.base, sregion.base, 2);
121         isc_buffer_forward(source, 2);
122         isc_buffer_add(target, 2);
123
124         return (ISC_R_SUCCESS);
125 }
126
127 static inline isc_result_t
128 towire_ch_a(ARGS_TOWIRE) {
129         dns_name_t name;
130         dns_offsets_t offsets;
131         isc_region_t sregion;
132         isc_region_t tregion;
133
134         REQUIRE(rdata->type == 1);
135         REQUIRE(rdata->rdclass == dns_rdataclass_ch);
136         REQUIRE(rdata->length != 0);
137
138         dns_compress_setmethods(cctx, DNS_COMPRESS_GLOBAL14);
139
140         dns_name_init(&name, offsets);
141
142         dns_rdata_toregion(rdata, &sregion);
143
144         dns_name_fromregion(&name, &sregion);
145         isc_region_consume(&sregion, name_length(&name));
146         RETERR(dns_name_towire(&name, cctx, target));
147
148         isc_buffer_availableregion(target, &tregion);
149         if (tregion.length < 2)
150                 return (ISC_R_NOSPACE);
151
152         memcpy(tregion.base, sregion.base, 2);
153         isc_buffer_add(target, 2);
154         return (ISC_R_SUCCESS);
155 }
156
157 static inline int
158 compare_ch_a(ARGS_COMPARE) {
159         dns_name_t name1;
160         dns_name_t name2;
161         isc_region_t region1;
162         isc_region_t region2;
163         int order;
164
165         REQUIRE(rdata1->type == rdata2->type);
166         REQUIRE(rdata1->rdclass == rdata2->rdclass);
167         REQUIRE(rdata1->type == 1);
168         REQUIRE(rdata1->rdclass == dns_rdataclass_ch);
169         REQUIRE(rdata1->length != 0);
170         REQUIRE(rdata2->length != 0);
171
172         dns_name_init(&name1, NULL);
173         dns_name_init(&name2, NULL);
174
175         dns_rdata_toregion(rdata1, &region1);
176         dns_rdata_toregion(rdata2, &region2);
177
178         dns_name_fromregion(&name1, &region1);
179         dns_name_fromregion(&name2, &region2);
180         isc_region_consume(&region1, name_length(&name1));
181         isc_region_consume(&region2, name_length(&name2));
182
183         order = dns_name_rdatacompare(&name1, &name2);
184         if (order != 0)
185                 return (order);
186
187         order = memcmp(rdata1->data, rdata2->data, 2);
188         if (order != 0)
189                 order = (order < 0) ? -1 : 1;
190         return (order);
191 }
192
193 static inline isc_result_t
194 fromstruct_ch_a(ARGS_FROMSTRUCT) {
195         dns_rdata_ch_a_t *a = source;
196         isc_region_t region;
197
198         REQUIRE(type == 1);
199         REQUIRE(source != NULL);
200         REQUIRE(a->common.rdtype == type);
201         REQUIRE(a->common.rdclass == rdclass);
202
203         UNUSED(type);
204         UNUSED(rdclass);
205
206         dns_name_toregion(&a->ch_addr_dom, &region);
207         RETERR(isc_buffer_copyregion(target, &region));
208         
209         return (uint16_tobuffer(ntohs(a->ch_addr), target));
210 }
211
212 static inline isc_result_t
213 tostruct_ch_a(ARGS_TOSTRUCT) {
214         dns_rdata_ch_a_t *a = target;
215         isc_region_t region;
216         dns_name_t name;
217
218         REQUIRE(rdata->type == 1);
219         REQUIRE(rdata->rdclass == dns_rdataclass_ch);
220         REQUIRE(rdata->length != 0);
221
222         a->common.rdclass = rdata->rdclass;
223         a->common.rdtype = rdata->type;
224         ISC_LINK_INIT(&a->common, link);
225
226         dns_rdata_toregion(rdata, &region);
227
228         dns_name_init(&name, NULL);
229         dns_name_fromregion(&name, &region);
230         isc_region_consume(&region, name_length(&name));
231
232         dns_name_init(&a->ch_addr_dom, NULL);
233         RETERR(name_duporclone(&name, mctx, &a->ch_addr_dom));
234         a->ch_addr = htons(uint16_fromregion(&region));
235         a->mctx = mctx;
236         return (ISC_R_SUCCESS);
237 }
238
239 static inline void
240 freestruct_ch_a(ARGS_FREESTRUCT) {
241         dns_rdata_ch_a_t *a = source;
242
243         REQUIRE(source != NULL);
244         REQUIRE(a->common.rdtype == 1);
245
246         if (a->mctx == NULL)
247                 return;
248
249         dns_name_free(&a->ch_addr_dom, a->mctx);
250         a->mctx = NULL;
251 }
252
253 static inline isc_result_t
254 additionaldata_ch_a(ARGS_ADDLDATA) {
255
256         REQUIRE(rdata->type == 1);
257         REQUIRE(rdata->rdclass == dns_rdataclass_ch);
258
259         UNUSED(rdata);
260         UNUSED(add);
261         UNUSED(arg);
262
263         return (ISC_R_SUCCESS);
264 }
265
266 static inline isc_result_t
267 digest_ch_a(ARGS_DIGEST) {
268         isc_region_t r;
269
270         dns_name_t name;
271
272         REQUIRE(rdata->type == 1);
273         REQUIRE(rdata->rdclass == dns_rdataclass_ch);
274
275         dns_rdata_toregion(rdata, &r);
276         dns_name_init(&name, NULL);
277         dns_name_fromregion(&name, &r);
278         isc_region_consume(&r, name_length(&name));
279         RETERR(dns_name_digest(&name, digest, arg));
280         return ((digest)(arg, &r));
281 }
282
283 static inline isc_boolean_t
284 checkowner_ch_a(ARGS_CHECKOWNER) {
285
286         REQUIRE(type == 1);
287         REQUIRE(rdclass == dns_rdataclass_ch);
288
289         UNUSED(type);
290
291         return (dns_name_ishostname(name, wildcard));
292 }
293
294 static inline isc_boolean_t
295 checknames_ch_a(ARGS_CHECKNAMES) {
296         isc_region_t region;
297         dns_name_t name;
298
299         REQUIRE(rdata->type == 1);
300         REQUIRE(rdata->rdclass == dns_rdataclass_ch);
301
302         UNUSED(owner);
303
304         dns_rdata_toregion(rdata, &region);
305         dns_name_init(&name, NULL);
306         dns_name_fromregion(&name, &region);
307         if (!dns_name_ishostname(&name, ISC_FALSE)) {
308                 if (bad != NULL)
309                         dns_name_clone(&name, bad);
310                 return (ISC_FALSE);
311         }
312
313         return (ISC_TRUE);
314 }
315
316 #endif  /* RDATA_CH_3_A_1_C */