3 * ===================================
4 * HARP | Host ATM Research Platform
5 * ===================================
8 * This Host ATM Research Platform ("HARP") file (the "Software") is
9 * made available by Network Computing Services, Inc. ("NetworkCS")
10 * "AS IS". NetworkCS does not provide maintenance, improvements or
11 * support of any kind.
13 * NETWORKCS MAKES NO WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED,
14 * INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
15 * AND FITNESS FOR A PARTICULAR PURPOSE, AS TO ANY ELEMENT OF THE
16 * SOFTWARE OR ANY SUPPORT PROVIDED IN CONNECTION WITH THIS SOFTWARE.
17 * In no event shall NetworkCS be responsible for any damages, including
18 * but not limited to consequential damages, arising from or relating to
19 * any use of the Software or related support.
21 * Copyright 1994-1998 Network Computing Services, Inc.
23 * Copies of this Software may be made, however, the above copyright
24 * notice must be reproduced on all copies.
26 * $FreeBSD: src/lib/libatm/atm_addr.c,v 1.4.2.1 2001/09/28 16:52:10 dillon Exp $
27 * $DragonFly: src/lib/libatm/atm_addr.c,v 1.3 2004/09/23 21:39:08 geekgod Exp $
31 * User Space Library Functions
32 * ----------------------------
34 * ATM address utility functions
38 #include <sys/types.h>
39 #include <sys/param.h>
40 #include <sys/socket.h>
42 #include <netinet/in.h>
43 #include <netatm/port.h>
44 #include <netatm/atm.h>
45 #include <netatm/atm_if.h>
46 #include <netatm/atm_sap.h>
47 #include <netatm/atm_sys.h>
48 #include <netatm/atm_ioctl.h>
59 * Get NSAP, NSAP prefix or MAC address
62 * in pointer to an address in ASCII
63 * out pointer to a buffer for the converted address
64 * len the length of the output buffer
68 * len the length of the data in the output buffer
72 get_hex_atm_addr(in
, out
, len
)
77 int c_type
, c_value
, i
, out_len
, state
, val
= 0;
87 {'.', 0, 0}, /* Type 0 -- period */
88 {':', 0, 0}, /* Type 0 -- colon */
89 {'0', 1, 0}, /* Type 1 -- hex digit */
111 {'\0', 2, 0}, /* Type 2 -- end of input */
120 } state_table
[3][3] = {
122 { { 0, 0 }, { 1, 1 }, { 2, 0} }, /* Init */
123 { { 4, 0 }, { 3, 2 }, { 4, 0} }, /* C1 */
124 { { 0, 2 }, { 1, 1 }, { 2, 0} }, /* C2 */
132 if (!strncasecmp(in
, "0x", 2)) {
137 * Loop through input until state table says to return
141 * Get the character type and value
143 for (i
=0; char_table
[i
].c
; i
++)
144 if (char_table
[i
].c
== *in
)
146 if (char_table
[i
].c
!= *in
)
148 c_type
= char_table
[i
].type
;
149 c_value
= char_table
[i
].value
;
152 * Process next character based on state and type
154 switch(state_table
[state
][c_type
].action
) {
157 * Ignore the character
163 * Save the character's value
170 * Return the assembled NSAP
176 * Assemble and save the output byte
180 out
[out_len
] = (u_char
) val
;
186 * Invalid input sequence
195 * Set the next state and go on to the next character
197 state
= state_table
[state
][c_type
].state
;
204 * Format an ATM address into a string
207 * addr pointer to an atm address
214 format_atm_addr(addr
)
219 Atm_addr_nsap
*atm_nsap
;
220 Atm_addr_e164
*atm_e164
;
221 Atm_addr_spans
*atm_spans
;
222 Atm_addr_pvc
*atm_pvc
;
223 static char str
[256];
229 static char nsap_format_DCC
[] = "0x%02x.%02x%02x.%02x.%02x%02x%02x.%02x%02x.%02x%02x.%02x%02x.%02x%02x%02x%02x%02x%02x.%02x";
230 static char nsap_format_ICD
[] = "0x%02x.%02x%02x.%02x.%02x%02x%02x.%02x%02x.%02x%02x.%02x%02x.%02x%02x%02x%02x%02x%02x.%02x";
231 static char nsap_format_E164
[] = "0x%02x.%02x%02x%02x%02x%02x%02x%02x%02x.%02x%02x.%02x%02x.%02x%02x%02x%02x%02x%02x.%02x";
234 * Clear the returned string
236 UM_ZERO(str
, sizeof(str
));
237 strlcpy(str
, "-", sizeof(str
));
240 * Print format is determined by address type
242 switch (addr
->address_format
) {
243 case T_ATM_ENDSYS_ADDR
:
244 atm_nsap
= (Atm_addr_nsap
*)addr
->address
;
245 switch(atm_nsap
->aan_afi
) {
248 nsap_format
= nsap_format_DCC
;
251 nsap_format
= nsap_format_ICD
;
254 nsap_format
= nsap_format_E164
;
257 sprintf(str
, nsap_format
,
259 atm_nsap
->aan_afspec
[0],
260 atm_nsap
->aan_afspec
[1],
261 atm_nsap
->aan_afspec
[2],
262 atm_nsap
->aan_afspec
[3],
263 atm_nsap
->aan_afspec
[4],
264 atm_nsap
->aan_afspec
[5],
265 atm_nsap
->aan_afspec
[6],
266 atm_nsap
->aan_afspec
[7],
267 atm_nsap
->aan_afspec
[8],
268 atm_nsap
->aan_afspec
[9],
269 atm_nsap
->aan_afspec
[10],
270 atm_nsap
->aan_afspec
[11],
271 atm_nsap
->aan_esi
[0],
272 atm_nsap
->aan_esi
[1],
273 atm_nsap
->aan_esi
[2],
274 atm_nsap
->aan_esi
[3],
275 atm_nsap
->aan_esi
[4],
276 atm_nsap
->aan_esi
[5],
280 case T_ATM_E164_ADDR
:
281 atm_e164
= (Atm_addr_e164
*)addr
->address
;
282 for(i
=0; i
<addr
->address_length
; i
++) {
283 sprintf(&str
[strlen(str
)], "%c",
284 atm_e164
->aae_addr
[i
]);
288 case T_ATM_SPANS_ADDR
:
290 * Print SPANS address as two words, xxxx.yyyy
292 atm_spans
= (Atm_addr_spans
*)addr
->address
;
293 u1
.c
[0] = atm_spans
->aas_addr
[0];
294 u1
.c
[1] = atm_spans
->aas_addr
[1];
295 u1
.c
[2] = atm_spans
->aas_addr
[2];
296 u1
.c
[3] = atm_spans
->aas_addr
[3];
298 u2
.c
[0] = atm_spans
->aas_addr
[4];
299 u2
.c
[1] = atm_spans
->aas_addr
[5];
300 u2
.c
[2] = atm_spans
->aas_addr
[6];
301 u2
.c
[3] = atm_spans
->aas_addr
[7];
303 if (!(u1
.w
== 0 && u2
.w
== 0))
304 sprintf(str
, "0x%08lx.%08lx", ntohl(u1
.w
), ntohl(u2
.w
));
309 * Print PVC as VPI, VCI
311 atm_pvc
= (Atm_addr_pvc
*)addr
->address
;
312 sprintf(str
, "%d, %d",
313 ATM_PVC_GET_VPI(atm_pvc
),
314 ATM_PVC_GET_VCI(atm_pvc
));