xref: /minix3/external/bsd/dhcp/dist/common/ctrace.c (revision 83ee113ee0d94f3844d44065af2311604e9a30ad)
1*83ee113eSDavid van Moolenbroek /*	$NetBSD: ctrace.c,v 1.1.1.2 2014/07/12 11:57:40 spz Exp $	*/
2*83ee113eSDavid van Moolenbroek /* trace.c
3*83ee113eSDavid van Moolenbroek 
4*83ee113eSDavid van Moolenbroek    Subroutines that support dhcp tracing... */
5*83ee113eSDavid van Moolenbroek 
6*83ee113eSDavid van Moolenbroek /*
7*83ee113eSDavid van Moolenbroek  * Copyright (c) 2004,2007,2009,2014 by Internet Systems Consortium, Inc. ("ISC")
8*83ee113eSDavid van Moolenbroek  * Copyright (c) 2001-2003 by Internet Software Consortium
9*83ee113eSDavid van Moolenbroek  *
10*83ee113eSDavid van Moolenbroek  * Permission to use, copy, modify, and distribute this software for any
11*83ee113eSDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
12*83ee113eSDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
13*83ee113eSDavid van Moolenbroek  *
14*83ee113eSDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
15*83ee113eSDavid van Moolenbroek  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
16*83ee113eSDavid van Moolenbroek  * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR
17*83ee113eSDavid van Moolenbroek  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
18*83ee113eSDavid van Moolenbroek  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
19*83ee113eSDavid van Moolenbroek  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
20*83ee113eSDavid van Moolenbroek  * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
21*83ee113eSDavid van Moolenbroek  *
22*83ee113eSDavid van Moolenbroek  *   Internet Systems Consortium, Inc.
23*83ee113eSDavid van Moolenbroek  *   950 Charter Street
24*83ee113eSDavid van Moolenbroek  *   Redwood City, CA 94063
25*83ee113eSDavid van Moolenbroek  *   <info@isc.org>
26*83ee113eSDavid van Moolenbroek  *   https://www.isc.org/
27*83ee113eSDavid van Moolenbroek  *
28*83ee113eSDavid van Moolenbroek  */
29*83ee113eSDavid van Moolenbroek 
30*83ee113eSDavid van Moolenbroek #include <sys/cdefs.h>
31*83ee113eSDavid van Moolenbroek __RCSID("$NetBSD: ctrace.c,v 1.1.1.2 2014/07/12 11:57:40 spz Exp $");
32*83ee113eSDavid van Moolenbroek 
33*83ee113eSDavid van Moolenbroek #include "dhcpd.h"
34*83ee113eSDavid van Moolenbroek 
35*83ee113eSDavid van Moolenbroek #if defined (TRACING)
trace_interface_register(trace_type_t * ttype,struct interface_info * ip)36*83ee113eSDavid van Moolenbroek void trace_interface_register (trace_type_t *ttype, struct interface_info *ip)
37*83ee113eSDavid van Moolenbroek {
38*83ee113eSDavid van Moolenbroek 	trace_interface_packet_t tipkt;
39*83ee113eSDavid van Moolenbroek 
40*83ee113eSDavid van Moolenbroek 	if (trace_record ()) {
41*83ee113eSDavid van Moolenbroek 		memset (&tipkt, 0, sizeof tipkt);
42*83ee113eSDavid van Moolenbroek 		memcpy (&tipkt.hw_address,
43*83ee113eSDavid van Moolenbroek 			&ip -> hw_address, sizeof ip -> hw_address);
44*83ee113eSDavid van Moolenbroek 		if (ip->address_count)
45*83ee113eSDavid van Moolenbroek 			memcpy(&tipkt.primary_address,
46*83ee113eSDavid van Moolenbroek 			       ip->addresses, sizeof(*ip->addresses));
47*83ee113eSDavid van Moolenbroek 		memcpy (tipkt.name, ip -> name, sizeof ip -> name);
48*83ee113eSDavid van Moolenbroek 		tipkt.index = htonl (ip -> index);
49*83ee113eSDavid van Moolenbroek 
50*83ee113eSDavid van Moolenbroek 		trace_write_packet (ttype, sizeof tipkt, (char *)&tipkt, MDL);
51*83ee113eSDavid van Moolenbroek 	}
52*83ee113eSDavid van Moolenbroek }
53*83ee113eSDavid van Moolenbroek 
trace_interface_input(trace_type_t * ttype,unsigned len,char * buf)54*83ee113eSDavid van Moolenbroek void trace_interface_input (trace_type_t *ttype, unsigned len, char *buf)
55*83ee113eSDavid van Moolenbroek {
56*83ee113eSDavid van Moolenbroek 	trace_interface_packet_t *tipkt;
57*83ee113eSDavid van Moolenbroek 	struct interface_info *ip;
58*83ee113eSDavid van Moolenbroek 	struct sockaddr_in *sin;
59*83ee113eSDavid van Moolenbroek 	struct iaddr addr;
60*83ee113eSDavid van Moolenbroek 	isc_result_t status;
61*83ee113eSDavid van Moolenbroek 
62*83ee113eSDavid van Moolenbroek 	if (len != sizeof *tipkt) {
63*83ee113eSDavid van Moolenbroek 		log_error ("trace interface packet size mismatch: %ld != %d",
64*83ee113eSDavid van Moolenbroek 			   (long)(sizeof *tipkt), len);
65*83ee113eSDavid van Moolenbroek 		return;
66*83ee113eSDavid van Moolenbroek 	}
67*83ee113eSDavid van Moolenbroek 	tipkt = (trace_interface_packet_t *)buf;
68*83ee113eSDavid van Moolenbroek 
69*83ee113eSDavid van Moolenbroek 	ip = (struct interface_info *)0;
70*83ee113eSDavid van Moolenbroek 	status = interface_allocate (&ip, MDL);
71*83ee113eSDavid van Moolenbroek 	if (status != ISC_R_SUCCESS) {
72*83ee113eSDavid van Moolenbroek 	      foo:
73*83ee113eSDavid van Moolenbroek 		log_error ("trace_interface_input: %s.",
74*83ee113eSDavid van Moolenbroek 			   isc_result_totext (status));
75*83ee113eSDavid van Moolenbroek 		return;
76*83ee113eSDavid van Moolenbroek 	}
77*83ee113eSDavid van Moolenbroek 	ip -> ifp = dmalloc (sizeof *(ip -> ifp), MDL);
78*83ee113eSDavid van Moolenbroek 	if (!ip -> ifp) {
79*83ee113eSDavid van Moolenbroek 		interface_dereference (&ip, MDL);
80*83ee113eSDavid van Moolenbroek 		status = ISC_R_NOMEMORY;
81*83ee113eSDavid van Moolenbroek 		goto foo;
82*83ee113eSDavid van Moolenbroek 	}
83*83ee113eSDavid van Moolenbroek 
84*83ee113eSDavid van Moolenbroek 	memcpy (&ip -> hw_address, &tipkt -> hw_address,
85*83ee113eSDavid van Moolenbroek 		sizeof ip -> hw_address);
86*83ee113eSDavid van Moolenbroek 	/* XXX: Without the full addresses state it's not quite a full
87*83ee113eSDavid van Moolenbroek 	 * trace.
88*83ee113eSDavid van Moolenbroek 	 */
89*83ee113eSDavid van Moolenbroek 	ip->address_count = ip->address_max = 1;
90*83ee113eSDavid van Moolenbroek 	ip->addresses = dmalloc(sizeof(*ip->addresses), MDL);
91*83ee113eSDavid van Moolenbroek 	memcpy(ip->addresses, &tipkt->primary_address, sizeof(*ip->addresses));
92*83ee113eSDavid van Moolenbroek 	memcpy (ip -> name, tipkt -> name, sizeof ip -> name);
93*83ee113eSDavid van Moolenbroek 	ip -> index = ntohl (tipkt -> index);
94*83ee113eSDavid van Moolenbroek 
95*83ee113eSDavid van Moolenbroek 	interface_snorf (ip, 0);
96*83ee113eSDavid van Moolenbroek 	if (dhcp_interface_discovery_hook)
97*83ee113eSDavid van Moolenbroek 		(*dhcp_interface_discovery_hook) (ip);
98*83ee113eSDavid van Moolenbroek 
99*83ee113eSDavid van Moolenbroek 	/* Fake up an ifp. */
100*83ee113eSDavid van Moolenbroek 	memcpy (ip -> ifp -> ifr_name, ip -> name, sizeof ip -> name);
101*83ee113eSDavid van Moolenbroek #ifdef HAVE_SA_LEN
102*83ee113eSDavid van Moolenbroek 	ip -> ifp -> ifr_addr.sa_len = sizeof (struct sockaddr_in);
103*83ee113eSDavid van Moolenbroek #endif
104*83ee113eSDavid van Moolenbroek 	sin = (struct sockaddr_in *)&ip -> ifp -> ifr_addr;
105*83ee113eSDavid van Moolenbroek 	sin->sin_addr = ip->addresses[0];
106*83ee113eSDavid van Moolenbroek 
107*83ee113eSDavid van Moolenbroek 	addr.len = 4;
108*83ee113eSDavid van Moolenbroek 	memcpy (addr.iabuf, &sin -> sin_addr.s_addr, addr.len);
109*83ee113eSDavid van Moolenbroek 	if (dhcp_interface_setup_hook)
110*83ee113eSDavid van Moolenbroek 		(*dhcp_interface_setup_hook) (ip, &addr);
111*83ee113eSDavid van Moolenbroek 	interface_stash (ip);
112*83ee113eSDavid van Moolenbroek 
113*83ee113eSDavid van Moolenbroek 	if (!quiet_interface_discovery) {
114*83ee113eSDavid van Moolenbroek 		log_info ("Listening on Trace/%s/%s%s%s",
115*83ee113eSDavid van Moolenbroek 			  ip -> name,
116*83ee113eSDavid van Moolenbroek 			  print_hw_addr (ip -> hw_address.hbuf [0],
117*83ee113eSDavid van Moolenbroek 					 ip -> hw_address.hlen - 1,
118*83ee113eSDavid van Moolenbroek 					 &ip -> hw_address.hbuf [1]),
119*83ee113eSDavid van Moolenbroek 			  (ip -> shared_network ? "/" : ""),
120*83ee113eSDavid van Moolenbroek 			  (ip -> shared_network ?
121*83ee113eSDavid van Moolenbroek 			   ip -> shared_network -> name : ""));
122*83ee113eSDavid van Moolenbroek 		if (strcmp (ip -> name, "fallback")) {
123*83ee113eSDavid van Moolenbroek 			log_info ("Sending   on Trace/%s/%s%s%s",
124*83ee113eSDavid van Moolenbroek 				  ip -> name,
125*83ee113eSDavid van Moolenbroek 				  print_hw_addr (ip -> hw_address.hbuf [0],
126*83ee113eSDavid van Moolenbroek 						 ip -> hw_address.hlen - 1,
127*83ee113eSDavid van Moolenbroek 						 &ip -> hw_address.hbuf [1]),
128*83ee113eSDavid van Moolenbroek 				  (ip -> shared_network ? "/" : ""),
129*83ee113eSDavid van Moolenbroek 				  (ip -> shared_network ?
130*83ee113eSDavid van Moolenbroek 				   ip -> shared_network -> name : ""));
131*83ee113eSDavid van Moolenbroek 		}
132*83ee113eSDavid van Moolenbroek 	}
133*83ee113eSDavid van Moolenbroek 	interface_dereference (&ip, MDL);
134*83ee113eSDavid van Moolenbroek }
135*83ee113eSDavid van Moolenbroek 
trace_interface_stop(trace_type_t * ttype)136*83ee113eSDavid van Moolenbroek void trace_interface_stop (trace_type_t *ttype) {
137*83ee113eSDavid van Moolenbroek 	/* XXX */
138*83ee113eSDavid van Moolenbroek }
139*83ee113eSDavid van Moolenbroek 
trace_inpacket_stash(struct interface_info * interface,struct dhcp_packet * packet,unsigned len,unsigned int from_port,struct iaddr from,struct hardware * hfrom)140*83ee113eSDavid van Moolenbroek void trace_inpacket_stash (struct interface_info *interface,
141*83ee113eSDavid van Moolenbroek 			   struct dhcp_packet *packet,
142*83ee113eSDavid van Moolenbroek 			   unsigned len,
143*83ee113eSDavid van Moolenbroek 			   unsigned int from_port,
144*83ee113eSDavid van Moolenbroek 			   struct iaddr from,
145*83ee113eSDavid van Moolenbroek 			   struct hardware *hfrom)
146*83ee113eSDavid van Moolenbroek {
147*83ee113eSDavid van Moolenbroek 	trace_inpacket_t tip;
148*83ee113eSDavid van Moolenbroek 	trace_iov_t iov [2];
149*83ee113eSDavid van Moolenbroek 
150*83ee113eSDavid van Moolenbroek 	if (!trace_record ())
151*83ee113eSDavid van Moolenbroek 		return;
152*83ee113eSDavid van Moolenbroek 	tip.from_port = from_port;
153*83ee113eSDavid van Moolenbroek 	tip.from = from;
154*83ee113eSDavid van Moolenbroek 	tip.from.len = htonl (tip.from.len);
155*83ee113eSDavid van Moolenbroek 	if (hfrom) {
156*83ee113eSDavid van Moolenbroek 		tip.hfrom = *hfrom;
157*83ee113eSDavid van Moolenbroek 		tip.havehfrom = 1;
158*83ee113eSDavid van Moolenbroek 	} else {
159*83ee113eSDavid van Moolenbroek 		memset (&tip.hfrom, 0, sizeof tip.hfrom);
160*83ee113eSDavid van Moolenbroek 		tip.havehfrom = 0;
161*83ee113eSDavid van Moolenbroek 	}
162*83ee113eSDavid van Moolenbroek 	tip.index = htonl (interface -> index);
163*83ee113eSDavid van Moolenbroek 
164*83ee113eSDavid van Moolenbroek 	iov [0].buf = (char *)&tip;
165*83ee113eSDavid van Moolenbroek 	iov [0].len = sizeof tip;
166*83ee113eSDavid van Moolenbroek 	iov [1].buf = (char *)packet;
167*83ee113eSDavid van Moolenbroek 	iov [1].len = len;
168*83ee113eSDavid van Moolenbroek 	trace_write_packet_iov (inpacket_trace, 2, iov, MDL);
169*83ee113eSDavid van Moolenbroek }
170*83ee113eSDavid van Moolenbroek 
trace_inpacket_input(trace_type_t * ttype,unsigned len,char * buf)171*83ee113eSDavid van Moolenbroek void trace_inpacket_input (trace_type_t *ttype, unsigned len, char *buf)
172*83ee113eSDavid van Moolenbroek {
173*83ee113eSDavid van Moolenbroek 	trace_inpacket_t *tip;
174*83ee113eSDavid van Moolenbroek 	int index;
175*83ee113eSDavid van Moolenbroek 
176*83ee113eSDavid van Moolenbroek 	if (len < sizeof *tip) {
177*83ee113eSDavid van Moolenbroek 		log_error ("trace_input_packet: too short - %d", len);
178*83ee113eSDavid van Moolenbroek 		return;
179*83ee113eSDavid van Moolenbroek 	}
180*83ee113eSDavid van Moolenbroek 	tip = (trace_inpacket_t *)buf;
181*83ee113eSDavid van Moolenbroek 	index = ntohl (tip -> index);
182*83ee113eSDavid van Moolenbroek 	tip -> from.len = ntohl (tip -> from.len);
183*83ee113eSDavid van Moolenbroek 
184*83ee113eSDavid van Moolenbroek 	if (index > interface_count ||
185*83ee113eSDavid van Moolenbroek 	    index < 0 ||
186*83ee113eSDavid van Moolenbroek 	    !interface_vector [index]) {
187*83ee113eSDavid van Moolenbroek 		log_error ("trace_input_packet: unknown interface index %d",
188*83ee113eSDavid van Moolenbroek 			   index);
189*83ee113eSDavid van Moolenbroek 		return;
190*83ee113eSDavid van Moolenbroek 	}
191*83ee113eSDavid van Moolenbroek 
192*83ee113eSDavid van Moolenbroek 	if (!bootp_packet_handler) {
193*83ee113eSDavid van Moolenbroek 		log_error ("trace_input_packet: no bootp packet handler.");
194*83ee113eSDavid van Moolenbroek 		return;
195*83ee113eSDavid van Moolenbroek 	}
196*83ee113eSDavid van Moolenbroek 
197*83ee113eSDavid van Moolenbroek 	(*bootp_packet_handler) (interface_vector [index],
198*83ee113eSDavid van Moolenbroek 				 (struct dhcp_packet *)(tip + 1),
199*83ee113eSDavid van Moolenbroek 				 len - sizeof *tip,
200*83ee113eSDavid van Moolenbroek 				 tip -> from_port,
201*83ee113eSDavid van Moolenbroek 				 tip -> from,
202*83ee113eSDavid van Moolenbroek 				 (tip -> havehfrom ?
203*83ee113eSDavid van Moolenbroek 				  &tip -> hfrom
204*83ee113eSDavid van Moolenbroek 				  : (struct hardware *)0));
205*83ee113eSDavid van Moolenbroek }
206*83ee113eSDavid van Moolenbroek 
trace_inpacket_stop(trace_type_t * ttype)207*83ee113eSDavid van Moolenbroek void trace_inpacket_stop (trace_type_t *ttype) { }
208*83ee113eSDavid van Moolenbroek 
trace_packet_send(struct interface_info * interface,struct packet * packet,struct dhcp_packet * raw,size_t len,struct in_addr from,struct sockaddr_in * to,struct hardware * hto)209*83ee113eSDavid van Moolenbroek ssize_t trace_packet_send (struct interface_info *interface,
210*83ee113eSDavid van Moolenbroek 			   struct packet *packet,
211*83ee113eSDavid van Moolenbroek 			   struct dhcp_packet *raw,
212*83ee113eSDavid van Moolenbroek 			   size_t len,
213*83ee113eSDavid van Moolenbroek 			   struct in_addr from,
214*83ee113eSDavid van Moolenbroek 			   struct sockaddr_in *to,
215*83ee113eSDavid van Moolenbroek 			   struct hardware *hto)
216*83ee113eSDavid van Moolenbroek {
217*83ee113eSDavid van Moolenbroek 	trace_outpacket_t tip;
218*83ee113eSDavid van Moolenbroek 	trace_iov_t iov [2];
219*83ee113eSDavid van Moolenbroek 
220*83ee113eSDavid van Moolenbroek 	if (trace_record ()) {
221*83ee113eSDavid van Moolenbroek 		if (hto) {
222*83ee113eSDavid van Moolenbroek 			tip.hto = *hto;
223*83ee113eSDavid van Moolenbroek 			tip.havehto = 1;
224*83ee113eSDavid van Moolenbroek 		} else {
225*83ee113eSDavid van Moolenbroek 			memset (&tip.hto, 0, sizeof tip.hto);
226*83ee113eSDavid van Moolenbroek 			tip.havehto = 0;
227*83ee113eSDavid van Moolenbroek 		}
228*83ee113eSDavid van Moolenbroek 		tip.from.len = 4;
229*83ee113eSDavid van Moolenbroek 		memcpy (tip.from.iabuf, &from, 4);
230*83ee113eSDavid van Moolenbroek 		tip.to.len = 4;
231*83ee113eSDavid van Moolenbroek 		memcpy (tip.to.iabuf, &to -> sin_addr, 4);
232*83ee113eSDavid van Moolenbroek 		tip.to_port = to -> sin_port;
233*83ee113eSDavid van Moolenbroek 		tip.index = htonl (interface -> index);
234*83ee113eSDavid van Moolenbroek 
235*83ee113eSDavid van Moolenbroek 		iov [0].buf = (char *)&tip;
236*83ee113eSDavid van Moolenbroek 		iov [0].len = sizeof tip;
237*83ee113eSDavid van Moolenbroek 		iov [1].buf = (char *)raw;
238*83ee113eSDavid van Moolenbroek 		iov [1].len = len;
239*83ee113eSDavid van Moolenbroek 		trace_write_packet_iov (outpacket_trace, 2, iov, MDL);
240*83ee113eSDavid van Moolenbroek 	}
241*83ee113eSDavid van Moolenbroek 	if (!trace_playback ()) {
242*83ee113eSDavid van Moolenbroek 		return send_packet (interface, packet, raw, len,
243*83ee113eSDavid van Moolenbroek 				    from, to, hto);
244*83ee113eSDavid van Moolenbroek 	}
245*83ee113eSDavid van Moolenbroek 	return len;
246*83ee113eSDavid van Moolenbroek }
247*83ee113eSDavid van Moolenbroek 
trace_outpacket_input(trace_type_t * ttype,unsigned len,char * buf)248*83ee113eSDavid van Moolenbroek void trace_outpacket_input (trace_type_t *ttype, unsigned len, char *buf)
249*83ee113eSDavid van Moolenbroek {
250*83ee113eSDavid van Moolenbroek 	trace_outpacket_t *tip;
251*83ee113eSDavid van Moolenbroek 	int index;
252*83ee113eSDavid van Moolenbroek 
253*83ee113eSDavid van Moolenbroek 	if (len < sizeof *tip) {
254*83ee113eSDavid van Moolenbroek 		log_error ("trace_input_packet: too short - %d", len);
255*83ee113eSDavid van Moolenbroek 		return;
256*83ee113eSDavid van Moolenbroek 	}
257*83ee113eSDavid van Moolenbroek 	tip = (trace_outpacket_t *)buf;
258*83ee113eSDavid van Moolenbroek 	index = ntohl (tip -> index);
259*83ee113eSDavid van Moolenbroek 
260*83ee113eSDavid van Moolenbroek 	if (index > interface_count ||
261*83ee113eSDavid van Moolenbroek 	    index < 0 ||
262*83ee113eSDavid van Moolenbroek 	    !interface_vector [index]) {
263*83ee113eSDavid van Moolenbroek 		log_error ("trace_input_packet: unknown interface index %d",
264*83ee113eSDavid van Moolenbroek 			   index);
265*83ee113eSDavid van Moolenbroek 		return;
266*83ee113eSDavid van Moolenbroek 	}
267*83ee113eSDavid van Moolenbroek 
268*83ee113eSDavid van Moolenbroek 	/* XXX would be nice to somehow take notice of these. */
269*83ee113eSDavid van Moolenbroek }
270*83ee113eSDavid van Moolenbroek 
trace_outpacket_stop(trace_type_t * ttype)271*83ee113eSDavid van Moolenbroek void trace_outpacket_stop (trace_type_t *ttype) { }
272*83ee113eSDavid van Moolenbroek 
trace_seed_stash(trace_type_t * ttype,unsigned seed)273*83ee113eSDavid van Moolenbroek void trace_seed_stash (trace_type_t *ttype, unsigned seed)
274*83ee113eSDavid van Moolenbroek {
275*83ee113eSDavid van Moolenbroek 	u_int32_t outseed;
276*83ee113eSDavid van Moolenbroek 	if (!trace_record ())
277*83ee113eSDavid van Moolenbroek 		return;
278*83ee113eSDavid van Moolenbroek 	outseed = htonl (seed);
279*83ee113eSDavid van Moolenbroek 	trace_write_packet (ttype, sizeof outseed, (char *)&outseed, MDL);
280*83ee113eSDavid van Moolenbroek 	return;
281*83ee113eSDavid van Moolenbroek }
282*83ee113eSDavid van Moolenbroek 
trace_seed_input(trace_type_t * ttype,unsigned length,char * buf)283*83ee113eSDavid van Moolenbroek void trace_seed_input (trace_type_t *ttype, unsigned length, char *buf)
284*83ee113eSDavid van Moolenbroek {
285*83ee113eSDavid van Moolenbroek 	u_int32_t *seed;
286*83ee113eSDavid van Moolenbroek 
287*83ee113eSDavid van Moolenbroek 	if (length != sizeof seed) {
288*83ee113eSDavid van Moolenbroek 		log_error ("trace_seed_input: wrong size (%d)", length);
289*83ee113eSDavid van Moolenbroek 	}
290*83ee113eSDavid van Moolenbroek 	seed = (u_int32_t *)buf;
291*83ee113eSDavid van Moolenbroek 	srandom (ntohl (*seed));
292*83ee113eSDavid van Moolenbroek }
293*83ee113eSDavid van Moolenbroek 
trace_seed_stop(trace_type_t * ttype)294*83ee113eSDavid van Moolenbroek void trace_seed_stop (trace_type_t *ttype) { }
295*83ee113eSDavid van Moolenbroek #endif /* TRACING */
296