perf_pkt4.cc 2.13 KB
Newer Older
1
// Copyright (C) 2012, 2015 Internet Systems Consortium, Inc. ("ISC")
2 3 4 5 6 7 8 9 10 11 12 13 14
//
// 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.

15 16
#include <config.h>

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

#include "perf_pkt4.h"

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

namespace isc {
namespace perfdhcp {

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

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

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

62 63 64 65 66 67 68 69 70
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));
}



71 72
} // namespace perfdhcp
} // namespace isc