/*
* Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 Yokogawa Electric Corporation,
* YDC Corporation, IPA (Information-technology Promotion Agency, Japan).
* All rights reserved.
*
* Redistribution and use of this software in source and binary forms, with
* or without modification, are permitted provided that the following
* conditions and disclaimer are agreed and accepted by the user:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* 3. Neither the names of the copyrighters, the name of the project which
* is related to this software (hereinafter referred to as "project") nor
* the names of the contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* 4. No merchantable use may be permitted without prior written
* notification to the copyrighters. However, using this software for the
* purpose of testing or evaluating any products including merchantable
* products may be permitted without any notification to the copyrighters.
*
*
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHTERS, THE PROJECT AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING
* BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHTERS, THE PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT,STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*
* $TAHI: v6eval/lib/Pz/McUDP.cc,v 1.5 2002/12/02 12:31:30 akisada Exp $
*/
#include "McUDP.h"
#include "MmHeader.h"
#include "MmChecksum.h"
#include "ItPosition.h"
#include "WObject.h"
#include "RObject.h"
#include "PControl.h"
#include "PvObject.h"
#include "PvOctets.h"
//////////////////////////////////////////////////////////////////////////////
#define SUPER McUpper
McUpp_UDP* McUpp_UDP::instance_=0;
McTopHdr_UDP* McUpp_UDP::tophdr_=0;
McUpp_UDP::McUpp_UDP(CSTR key):SUPER(key) {instance_=this;}
McUpp_UDP::~McUpp_UDP(){if(instance_==this)instance_=0;}
// COMPOSE/REVERSE
uint32_t McUpp_UDP::length_for_reverse(
RControl& c,ItPosition& at,OCTBUF& buf) const{
uint32_t length = tophdr_->Layerlength_for_reverse(c,at,buf);
return length;}
RObject* McUpp_UDP::reverse(RControl& c,
RObject* r_parent,ItPosition& at,OCTBUF& buf)const{
RObject* r_self = SUPER::reverse(c,r_parent,at,buf);
if(!c.error()){
Con_IPinfo* info = c.IPinfo();
if(info)info->reverse_postUppChecksum(c,r_self);}
return r_self;}
bool McUpp_UDP::generate(WControl& c,WObject* w_self,OCTBUF& buf) const {
bool rtn = SUPER::generate(c,w_self,buf);
if(!c.error()){
Con_IPinfo* info = c.IPinfo();
if(info)info->generate_postUppChecksum(c,buf,w_self);}
return rtn;}
#undef SUPER
//----------------------------------------------------------------------------
#define SUPER McHeader
McTopHdr_UDP::McTopHdr_UDP(CSTR key):SUPER(key), SrcPort_meta_(0), DstPort_meta_(0), Layerlength_meta_(0) {
PrtObjs_ = new PrtObjs();
}
McTopHdr_UDP::~McTopHdr_UDP(){}
// COMPOSE/REVERSE
uint32_t McTopHdr_UDP::Layerlength_for_reverse(
RControl& c,ItPosition& at,OCTBUF& buf) const{
if(!Layerlength_meta_)return SUPER::Layerlength_for_reverse(c,at,buf);
uint32_t valulen = Layerlength_meta_->value(at,buf);
uint32_t Layerlength = valulen;
return Layerlength;}
bool McTopHdr_UDP::HCGENE(Length)(
WControl& cntr,WObject* wmem,OCTBUF& buf) const{
WObject* wc = wmem->parent(); //TopHdr_UDP
WObject* upper = wc->parent(); //Upper_UDP
uint32_t reallen = upper->size().bytes();
uint32_t valulen = reallen;
PvNumber def(valulen);
return def.generate(cntr,wmem,buf);}
RObject *McTopHdr_UDP::reverse(RControl &c, RObject *r_parent, ItPosition &at, OCTBUF &buf) const {
RObject *r_self = SUPER::reverse(c, r_parent, at, buf);
if(r_self) {
upperProto_set_Object(r_self);
}
return(r_self);
}
void McTopHdr_UDP::upperProto_set_Object(RObject *r_self) const {
if((!r_self) || (!SrcPort_meta_) || (!DstPort_meta_) || (!PrtObjs_)) {
return;
}
RObject *src = (RObject *)r_self->corresponding(SrcPort_meta_);
RObject *dst = (RObject *)r_self->corresponding(DstPort_meta_);
if(src){
set_srcobj(src);
}
if(dst) {
set_dstobj(dst);
}
return;
}
bool McTopHdr_UDP::HCGENE(SourcePort)(WControl &cntr, WObject *wmem, OCTBUF &buf) const {
int32_t val = get_next_protocolPort(wmem);
if(val == -1) {
return(false);
}
PvNumber def(val);
return(def.generate(cntr, wmem, buf));
}
PObject *McTopHdr_UDP::HCEVAL(SourcePort)(WObject *wmem) const {
int32_t val = get_next_protocolPort(wmem);
return(new PvNumber(val));
}
bool McTopHdr_UDP::HCGENE(DestinationPort)(WControl &cntr, WObject *wmem, OCTBUF &buf) const {
int32_t val = get_next_protocolPort(wmem);
if(val == -1) {
return(false);
}
PvNumber def(val);
return(def.generate(cntr, wmem, buf));
}
PObject *McTopHdr_UDP::HCEVAL(DestinationPort)(WObject *wmem) const {
int32_t val = get_next_protocolPort(wmem);
return(new PvNumber(val));
}
#undef SUPER
syntax highlighted by Code2HTML, v. 0.9.1