Annotation of embedaddon/dhcp/omapip/convert.c, revision 1.1
1.1 ! misho 1: /* convert.c
! 2:
! 3: Safe copying of option values into and out of the option buffer, which
! 4: can't be assumed to be aligned. */
! 5:
! 6: /*
! 7: * Copyright (c) 2004,2007,2009 by Internet Systems Consortium, Inc. ("ISC")
! 8: * Copyright (c) 1996-2003 by Internet Software Consortium
! 9: *
! 10: * Permission to use, copy, modify, and distribute this software for any
! 11: * purpose with or without fee is hereby granted, provided that the above
! 12: * copyright notice and this permission notice appear in all copies.
! 13: *
! 14: * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
! 15: * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
! 16: * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR
! 17: * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
! 18: * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
! 19: * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
! 20: * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
! 21: *
! 22: * Internet Systems Consortium, Inc.
! 23: * 950 Charter Street
! 24: * Redwood City, CA 94063
! 25: * <info@isc.org>
! 26: * https://www.isc.org/
! 27: *
! 28: * This software has been written for Internet Systems Consortium
! 29: * by Ted Lemon in cooperation with Vixie Enterprises and Nominum, Inc.
! 30: * To learn more about Internet Systems Consortium, see
! 31: * ``https://www.isc.org/''. To learn more about Vixie Enterprises,
! 32: * see ``http://www.vix.com''. To learn more about Nominum, Inc., see
! 33: * ``http://www.nominum.com''.
! 34: */
! 35:
! 36: #include "dhcpd.h"
! 37:
! 38: #include <omapip/omapip_p.h>
! 39:
! 40: u_int32_t getULong (buf)
! 41: const unsigned char *buf;
! 42: {
! 43: u_int32_t ibuf;
! 44:
! 45: memcpy (&ibuf, buf, sizeof (u_int32_t));
! 46: return ntohl (ibuf);
! 47: }
! 48:
! 49: int32_t getLong (buf)
! 50: const unsigned char *buf;
! 51: {
! 52: int32_t ibuf;
! 53:
! 54: memcpy (&ibuf, buf, sizeof (int32_t));
! 55: return ntohl (ibuf);
! 56: }
! 57:
! 58: u_int32_t getUShort (buf)
! 59: const unsigned char *buf;
! 60: {
! 61: unsigned short ibuf;
! 62:
! 63: memcpy (&ibuf, buf, sizeof (u_int16_t));
! 64: return ntohs (ibuf);
! 65: }
! 66:
! 67: int32_t getShort (buf)
! 68: const unsigned char *buf;
! 69: {
! 70: short ibuf;
! 71:
! 72: memcpy (&ibuf, buf, sizeof (int16_t));
! 73: return ntohs (ibuf);
! 74: }
! 75:
! 76: void putULong (obuf, val)
! 77: unsigned char *obuf;
! 78: u_int32_t val;
! 79: {
! 80: u_int32_t tmp = htonl (val);
! 81: memcpy (obuf, &tmp, sizeof tmp);
! 82: }
! 83:
! 84: void putLong (obuf, val)
! 85: unsigned char *obuf;
! 86: int32_t val;
! 87: {
! 88: int32_t tmp = htonl (val);
! 89: memcpy (obuf, &tmp, sizeof tmp);
! 90: }
! 91:
! 92: void putUShort (obuf, val)
! 93: unsigned char *obuf;
! 94: u_int32_t val;
! 95: {
! 96: u_int16_t tmp = htons (val);
! 97: memcpy (obuf, &tmp, sizeof tmp);
! 98: }
! 99:
! 100: void putShort (obuf, val)
! 101: unsigned char *obuf;
! 102: int32_t val;
! 103: {
! 104: int16_t tmp = htons (val);
! 105: memcpy (obuf, &tmp, sizeof tmp);
! 106: }
! 107:
! 108: void putUChar (obuf, val)
! 109: unsigned char *obuf;
! 110: u_int32_t val;
! 111: {
! 112: *obuf = val;
! 113: }
! 114:
! 115: u_int32_t getUChar (obuf)
! 116: const unsigned char *obuf;
! 117: {
! 118: return obuf [0];
! 119: }
! 120:
! 121: int converted_length (buf, base, width)
! 122: const unsigned char *buf;
! 123: unsigned int base;
! 124: unsigned int width;
! 125: {
! 126: u_int32_t number;
! 127: u_int32_t column;
! 128: int power = 1;
! 129: u_int32_t newcolumn = base;
! 130:
! 131: if (base > 16)
! 132: return 0;
! 133:
! 134: if (width == 1)
! 135: number = getUChar (buf);
! 136: else if (width == 2)
! 137: number = getUShort (buf);
! 138: else if (width == 4)
! 139: number = getULong (buf);
! 140: else
! 141: return 0;
! 142:
! 143: do {
! 144: column = newcolumn;
! 145:
! 146: if (number < column)
! 147: return power;
! 148: power++;
! 149: newcolumn = column * base;
! 150: /* If we wrap around, it must be the next power of two up. */
! 151: } while (newcolumn > column);
! 152:
! 153: return power;
! 154: }
! 155:
! 156: int binary_to_ascii (outbuf, inbuf, base, width)
! 157: unsigned char *outbuf;
! 158: const unsigned char *inbuf;
! 159: unsigned int base;
! 160: unsigned int width;
! 161: {
! 162: u_int32_t number;
! 163: static char h2a [] = "0123456789abcdef";
! 164: int power = converted_length (inbuf, base, width);
! 165: int i;
! 166:
! 167: if (base > 16)
! 168: return 0;
! 169:
! 170: if (width == 1)
! 171: number = getUChar (inbuf);
! 172: else if (width == 2)
! 173: number = getUShort (inbuf);
! 174: else if (width == 4)
! 175: number = getULong (inbuf);
! 176: else
! 177: return 0;
! 178:
! 179: for (i = power - 1 ; i >= 0; i--) {
! 180: outbuf [i] = h2a [number % base];
! 181: number /= base;
! 182: }
! 183:
! 184: return power;
! 185: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>