Annotation of embedaddon/libnet/src/libnet_build_fddi.c, revision 1.1
1.1 ! misho 1: /*
! 2: * libnet
! 3: * libnet_build_fddi.c - Fiber Distributed Data Interface packet assembler
! 4: *
! 5: * Copyright (c) 1998 - 2004 Mike D. Schiffman <mike@infonexus.com>
! 6: * Jason Damron <jsdamron@hushmail.com>
! 7: * All rights reserved.
! 8: *
! 9: * Redistribution and use in source and binary forms, with or without
! 10: * modification, are permitted provided that the following conditions
! 11: * are met:
! 12: * 1. Redistributions of source code must retain the above copyright
! 13: * notice, this list of conditions and the following disclaimer.
! 14: * 2. Redistributions in binary form must reproduce the above copyright
! 15: * notice, this list of conditions and the following disclaimer in the
! 16: * documentation and/or other materials provided with the distribution.
! 17: *
! 18: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
! 19: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! 20: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! 21: * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
! 22: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! 23: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
! 24: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
! 25: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
! 26: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
! 27: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
! 28: * SUCH DAMAGE.
! 29: *
! 30: */
! 31:
! 32: #if (HAVE_CONFIG_H)
! 33: #include "../include/config.h"
! 34: #endif
! 35: #if (!(_WIN32) || (__CYGWIN__))
! 36: #include "../include/libnet.h"
! 37: #else
! 38: #include "../include/win32/libnet.h"
! 39: #endif
! 40:
! 41: libnet_ptag_t
! 42: libnet_build_fddi(u_int8_t fc, u_int8_t *dst, u_int8_t *src, u_int8_t dsap,
! 43: u_int8_t ssap, u_int8_t cf, u_int8_t *org, u_int16_t type, u_int8_t *payload,
! 44: u_int32_t payload_s, libnet_t *l, libnet_ptag_t ptag)
! 45: {
! 46: u_int32_t n, h;
! 47: u_int16_t protocol_type;
! 48: libnet_pblock_t *p;
! 49: struct libnet_fddi_hdr fddi_hdr;
! 50:
! 51: if (l == NULL)
! 52: {
! 53: return (-1);
! 54: }
! 55:
! 56: /* sanity check injection type if we're not in advanced mode */
! 57: if (l->injection_type != LIBNET_LINK &&
! 58: !(((l->injection_type) & LIBNET_ADV_MASK)))
! 59: {
! 60: snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,
! 61: "%s(): called with non-link layer wire injection primitive",
! 62: __func__);
! 63: p = NULL;
! 64: goto bad;
! 65: }
! 66:
! 67: n = LIBNET_FDDI_H + payload_s;
! 68: h = 0;
! 69:
! 70: /*
! 71: * Find the existing protocol block if a ptag is specified, or create
! 72: * a new one.
! 73: */
! 74: p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_FDDI_H);
! 75: if (p == NULL)
! 76: {
! 77: return (-1);
! 78: }
! 79:
! 80: memset(&fddi_hdr, 0, sizeof(fddi_hdr));
! 81: fddi_hdr.fddi_frame_control = fc; /* Class/Format/Priority */
! 82: memcpy(fddi_hdr.fddi_dhost, dst, FDDI_ADDR_LEN); /* dst fddi address */
! 83: memcpy(fddi_hdr.fddi_shost, src, FDDI_ADDR_LEN); /* source fddi address */
! 84: fddi_hdr.fddi_llc_dsap = dsap; /* */
! 85: fddi_hdr.fddi_llc_ssap = ssap; /* */
! 86: fddi_hdr.fddi_llc_control_field = cf; /* Class/Format/Priority */
! 87: memcpy(&fddi_hdr.fddi_llc_org_code, org, LIBNET_ORG_CODE_SIZE);
! 88:
! 89: /* Deal with unaligned int16_t for type */
! 90: protocol_type = htons(type);
! 91: memcpy(&fddi_hdr.fddi_type, &protocol_type, sizeof(int16_t)); /* Protocol Type */
! 92:
! 93: n = libnet_pblock_append(l, p, (u_int8_t *)&fddi_hdr, LIBNET_FDDI_H);
! 94: if (n == -1)
! 95: {
! 96: goto bad;
! 97: }
! 98:
! 99: if ((payload && !payload_s) || (!payload && payload_s))
! 100: {
! 101: snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,
! 102: "%s(): payload inconsistency\n", __func__);
! 103: goto bad;
! 104: }
! 105:
! 106: if (payload && payload_s)
! 107: {
! 108: n = libnet_pblock_append(l, p, payload, payload_s);
! 109: if (n == -1)
! 110: {
! 111: goto bad;
! 112: }
! 113: }
! 114:
! 115: return (ptag ? ptag : libnet_pblock_update(l, p, h, LIBNET_PBLOCK_FDDI_H));
! 116: bad:
! 117: libnet_pblock_delete(l, p);
! 118: return (-1);
! 119: }
! 120:
! 121:
! 122: libnet_ptag_t
! 123: libnet_autobuild_fddi(u_int8_t fc, u_int8_t *dst, u_int8_t dsap, u_int8_t ssap,
! 124: u_int8_t cf, u_int8_t *org, u_int16_t type, libnet_t *l)
! 125: {
! 126: u_int32_t n, h;
! 127: u_int16_t protocol_type;
! 128: struct libnet_fddi_addr *src;
! 129: libnet_pblock_t *p;
! 130: libnet_ptag_t ptag;
! 131: struct libnet_fddi_hdr fddi_hdr;
! 132:
! 133: if (l == NULL)
! 134: {
! 135: return (-1);
! 136: }
! 137:
! 138: /* sanity check injection type if we're not in advanced mode */
! 139: if (l->injection_type != LIBNET_LINK &&
! 140: !(((l->injection_type) & LIBNET_ADV_MASK)))
! 141: {
! 142: snprintf(l->err_buf, LIBNET_ERRBUF_SIZE,
! 143: "%s(): called with non-link layer wire injection primitive",
! 144: __func__);
! 145: p = NULL;
! 146: goto bad;
! 147: }
! 148:
! 149: n = LIBNET_FDDI_H;
! 150: h = 0;
! 151: ptag = LIBNET_PTAG_INITIALIZER;
! 152:
! 153: /* FDDI and Ethernet have the same address size - so just typecast */
! 154: src = (struct libnet_fddi_addr *) libnet_get_hwaddr(l);
! 155: if (src == NULL)
! 156: {
! 157: /* err msg set in libnet_get_hwaddr() */
! 158: return (-1);
! 159: }
! 160:
! 161: p = libnet_pblock_probe(l, ptag, n, LIBNET_PBLOCK_FDDI_H);
! 162: if (p == NULL)
! 163: {
! 164: return (-1);
! 165: }
! 166:
! 167: memset(&fddi_hdr, 0, sizeof(fddi_hdr));
! 168: fddi_hdr.fddi_frame_control = fc; /* Class/Format/Priority */
! 169: memcpy(fddi_hdr.fddi_dhost, dst, FDDI_ADDR_LEN); /* destination fddi address */
! 170: memcpy(fddi_hdr.fddi_shost, src, FDDI_ADDR_LEN); /* source fddi address */
! 171: fddi_hdr.fddi_llc_dsap = dsap; /* */
! 172: fddi_hdr.fddi_llc_ssap = ssap; /* */
! 173: fddi_hdr.fddi_llc_control_field = cf; /* Class/Format/Priority */
! 174: memcpy(&fddi_hdr.fddi_llc_org_code, org, LIBNET_ORG_CODE_SIZE);
! 175:
! 176: /* Deal with unaligned int16_t for type */
! 177: protocol_type = htons(type);
! 178: memcpy(&fddi_hdr.fddi_type, &protocol_type, sizeof(int16_t)); /* Protocol Type */
! 179:
! 180: n = libnet_pblock_append(l, p, (u_int8_t *)&fddi_hdr, LIBNET_FDDI_H);
! 181: if (n == -1)
! 182: {
! 183: goto bad;
! 184: }
! 185:
! 186: return (libnet_pblock_update(l, p, h, LIBNET_PBLOCK_FDDI_H));
! 187: bad:
! 188: libnet_pblock_delete(l, p);
! 189: return (-1);
! 190: }
! 191: /* EOF */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>