00001 /* -*- Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */ 00002 /* 00003 * Copyright (c) 1996 Regents of the University of California. 00004 * All rights reserved. 00005 * 00006 * Redistribution and use in source and binary forms, with or without 00007 * modification, are permitted provided that the following conditions 00008 * are met: 00009 * 1. Redistributions of source code must retain the above copyright 00010 * notice, this list of conditions and the following disclaimer. 00011 * 2. Redistributions in binary form must reproduce the above copyright 00012 * notice, this list of conditions and the following disclaimer in the 00013 * documentation and/or other materials provided with the distribution. 00014 * 3. All advertising materials mentioning features or use of this software 00015 * must display the following acknowledgement: 00016 * This product includes software developed by the Computer Systems 00017 * Engineering Group at Lawrence Berkeley Laboratory and the Daedalus 00018 * research group at UC Berkeley. 00019 * 4. Neither the name of the University nor of the Laboratory may be used 00020 * to endorse or promote products derived from this software without 00021 * specific prior written permission. 00022 * 00023 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 00024 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00025 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00026 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 00027 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00028 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 00029 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 00030 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00031 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 00032 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00033 * SUCH DAMAGE. 00034 */ 00035 00036 #include "varp.h" 00037 #include "mac.h" 00038 #include "packet.h" 00039 00040 00041 static class VARPTableClass : public TclClass { 00042 public: 00043 VARPTableClass() : TclClass("VARPTable") {} 00044 TclObject* create(int, const char*const*) { 00045 return (new VARPTable); 00046 } 00047 } class_VARPTable; 00048 00049 00050 VARPTable::VARPTable(void) : TclObject(), maddr_(0), size_(0) 00051 {} 00052 00053 00054 VARPTable::~VARPTable(void) 00055 { 00056 delete [] maddr_; 00057 } 00058 00059 void VARPTable::sizeinit(int n) 00060 { 00061 int *temp = maddr_; 00062 int osize = size_; 00063 int i; 00064 00065 if (size_ == 0) 00066 size_ = 10; 00067 while(!(n < size_)) 00068 size_ = 2*size_; 00069 maddr_ = new int[size_]; 00070 for (i=0;i<osize;i++) 00071 maddr_[i] = temp[i]; 00072 for (i=osize;i<size_;i++) 00073 maddr_[i] = -1; 00074 delete [] temp; 00075 } 00076 00077 int VARPTable::command(int argc, const char*const* argv) { 00078 if (argc == 4) { 00079 if (strcmp(argv[1], "mac-addr") == 0) { 00080 int n = atoi(argv[2]); 00081 if(!(n < size_)) 00082 sizeinit(n); 00083 00084 maddr_[n] = atoi(argv[3]); 00085 return (TCL_OK); 00086 } 00087 } 00088 return TclObject::command(argc, argv); 00089 } 00090 00091 int VARPTable::arpresolve(int IPaddr, Packet* p) { 00092 if (IPaddr > size_) 00093 return 1; 00094 int ma = maddr_[IPaddr]; 00095 if (ma >= 0) { 00096 HDR_MAC(p)->macDA_ = ma; 00097 return 0; 00098 } 00099 return 1; 00100 }
1.4.6