perf_pkt4.cc 2.1 KB
Newer Older
1
// Copyright (C) 2012 Internet Systems Consortium, Inc. ("ISC")
2 3 4 5 6 7 8 9 10 11 12 13 14 15
//
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice appear in all copies.
//
// THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
// AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
// INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
// LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
// OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
// PERFORMANCE OF THIS SOFTWARE.

#include <dhcp/libdhcp++.h>
16
#include <dhcp/dhcp4.h>
17 18 19 20 21 22 23 24 25 26

#include "perf_pkt4.h"

using namespace std;
using namespace isc;
using namespace dhcp;

namespace isc {
namespace perfdhcp {

27 28 29 30
PerfPkt4::PerfPkt4(const uint8_t* buf,
                   size_t len,
                   size_t transid_offset,
                   uint32_t transid) :
31 32
    Pkt4(buf, len),
    transid_offset_(transid_offset) {
33
    setTransid(transid);
34 35 36 37
}

bool
PerfPkt4::rawPack() {
38 39 40
    return (PktTransform::pack(dhcp::Option::V4,
                               data_,
                               options_,
41 42
                               getTransidOffset(),
                               getTransid(),
Tomek Mrugalski's avatar
Tomek Mrugalski committed
43
                               buffer_out_));
44 45 46 47
}

bool
PerfPkt4::rawUnpack() {
48 49 50 51 52 53 54 55 56 57
    uint32_t transid = getTransid();
    bool res = PktTransform::unpack(dhcp::Option::V4,
                                    data_,
                                    options_,
                                    getTransidOffset(),
                                    transid);
    if (res) {
        setTransid(transid);
    }
    return (res);
58 59
}

60 61 62 63 64 65 66 67 68
void
PerfPkt4::writeAt(size_t dest_pos,
                  std::vector<uint8_t>::iterator first,
                  std::vector<uint8_t>::iterator last) {
    return (PktTransform::writeAt(data_, dest_pos, first, last));
}



69 70
} // namespace perfdhcp
} // namespace isc