Initial commit of OpenSPARC T2 design and verification files.
[OpenSPARC-T2-DV] / verif / env / common / vera / niu_ippktgen / C / libnet / src / libnet_init.c
CommitLineData
86530b38
AT
1/*
2 * $Id: libnet_init.c,v 1.20 2005/11/29 22:09:23 carlosc Exp $
3 *
4 * libnet
5 * libnet_init.c - Initilization routines.
6 *
7 * Copyright (c) 1998 - 2004 Mike D. Schiffman <mike@infonexus.com>
8 * All rights reserved.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 *
31 */
32
33#if (HAVE_CONFIG_H)
34#include "../include/config.h"
35#endif
36#if (!(_WIN32) || (__CYGWIN__))
37#include "../include/libnet.h"
38#else
39#include "../include/win32/libnet.h"
40#endif
41
42libnet_t *
43libnet_init(int injection_type, char *device, char *err_buf)
44{
45 libnet_t *l = NULL;
46
47#if !defined(__WIN32__)
48 if (getuid() && geteuid())
49 {
50 snprintf(err_buf, LIBNET_ERRBUF_SIZE,
51 "%s(): UID or EUID of 0 required\n", __func__);
52 goto bad;
53 }
54#else
55 WSADATA wsaData;
56
57 if ((WSAStartup(0x0202, &wsaData)) != 0)
58 {
59 snprintf(err_buf, LIBNET_ERRBUF_SIZE,
60 "%s(): unable to initialize winsock 2\n", __func__);
61 goto bad;
62 }
63#endif
64
65 l = (libnet_t *)malloc(sizeof (libnet_t));
66 if (l == NULL)
67 {
68 snprintf(err_buf, LIBNET_ERRBUF_SIZE, "%s(): malloc(): %s\n", __func__,
69 strerror(errno));
70 goto bad;
71 }
72
73 memset(l, 0, sizeof (*l));
74
75 l->injection_type = injection_type;
76 l->ptag_state = LIBNET_PTAG_INITIALIZER;
77 l->device = (device ? strdup(device) : NULL);
78
79 strncpy(l->label, LIBNET_LABEL_DEFAULT, LIBNET_LABEL_SIZE);
80 l->label[sizeof(l->label)] = '\0';
81
82 switch (l->injection_type)
83 {
84 case LIBNET_LINK:
85 case LIBNET_LINK_ADV:
86 if (libnet_select_device(l) == -1)
87 {
88 snprintf(err_buf, LIBNET_ERRBUF_SIZE, l->err_buf);
89 goto bad;
90 }
91 if (libnet_open_link(l) == -1)
92 {
93 snprintf(err_buf, LIBNET_ERRBUF_SIZE, l->err_buf);
94 goto bad;
95 }
96 break;
97 case LIBNET_RAW4:
98 case LIBNET_RAW4_ADV:
99 if (libnet_open_raw4(l) == -1)
100 {
101 snprintf(err_buf, LIBNET_ERRBUF_SIZE, l->err_buf);
102 goto bad;
103 }
104 break;
105 case LIBNET_RAW6:
106 case LIBNET_RAW6_ADV:
107 if (libnet_open_raw6(l) == -1)
108 {
109 snprintf(err_buf, LIBNET_ERRBUF_SIZE, l->err_buf);
110 goto bad;
111 }
112 break;
113 default:
114 snprintf(err_buf, LIBNET_ERRBUF_SIZE,
115 "%s(): unsupported injection type\n", __func__);
116 goto bad;
117 break;
118 }
119
120 return (l);
121
122bad:
123 if (l)
124 {
125 libnet_destroy(l);
126 }
127 return (NULL);
128}
129
130void
131libnet_destroy(libnet_t *l)
132{
133 if (l)
134 {
135 close(l->fd);
136 if (l->device)
137 {
138 free(l->device);
139 }
140 libnet_clear_packet(l);
141 free(l);
142 }
143}
144
145void
146libnet_clear_packet(libnet_t *l)
147{
148 libnet_pblock_t *p;
149 libnet_pblock_t *next;
150
151 if (l)
152 {
153 p = l->protocol_blocks;
154 if (p)
155 {
156 for (; p; p = next)
157 {
158 next = p->next;
159 if (p->buf)
160 {
161 free(p->buf);
162 }
163 free(p);
164 }
165 }
166 l->protocol_blocks = NULL;
167 l->total_size = 0;
168 }
169}
170
171void
172libnet_stats(libnet_t *l, struct libnet_stats *ls)
173{
174 if (l == NULL)
175 {
176 return;
177 }
178
179 ls->packets_sent = l->stats.packets_sent;
180 ls->packet_errors = l->stats.packet_errors;
181 ls->bytes_written = l->stats.bytes_written;
182}
183
184int
185libnet_getfd(libnet_t *l)
186{
187 if (l == NULL)
188 {
189 return (-1);
190 }
191
192 return (l->fd);
193}
194
195int8_t *
196libnet_getdevice(libnet_t *l)
197{
198 if (l == NULL)
199 {
200 return (NULL);
201 }
202
203 return (l->device);
204}
205
206u_int8_t *
207libnet_getpbuf(libnet_t *l, libnet_ptag_t ptag)
208{
209 libnet_pblock_t *p;
210
211 if (l == NULL)
212 {
213 return (NULL);
214 }
215
216 p = libnet_pblock_find(l, ptag);
217 if (p == NULL)
218 {
219 /* err msg set in libnet_pblock_find() */
220 return (NULL);
221 }
222 else
223 {
224 return (p->buf);
225 }
226}
227
228u_int32_t
229libnet_getpbuf_size(libnet_t *l, libnet_ptag_t ptag)
230{
231 libnet_pblock_t *p;
232
233 if (l == NULL)
234 {
235 return (0);
236 }
237
238 p = libnet_pblock_find(l, ptag);
239 if (p == NULL)
240 {
241 /* err msg set in libnet_pblock_find() */
242 return (0);
243 }
244 else
245 {
246 return (p->b_len);
247 }
248}
249
250u_int32_t
251libnet_getpacket_size(libnet_t *l)
252{
253 libnet_pblock_t *p;
254 u_int32_t n;
255
256 if (l == NULL)
257 {
258 return (0);
259 }
260
261 n = 0;
262 p = l->protocol_blocks;
263 if (p)
264 {
265 for (; p; p = p->next)
266 {
267 n += p->b_len;
268 }
269 }
270 return (n);
271}
272
273/* EOF */