/* * \brief Generic network address definitions * \author Stefan Kalkowski * \date 2010-08-20 */ /* * Copyright (C) 2010-2013 Genode Labs GmbH * * This file is part of the Genode OS framework, which is distributed * under the terms of the GNU General Public License version 2. */ #ifndef _NET__NETADDRESS_H_ #define _NET__NETADDRESS_H_ /* Genode */ #include #include #include namespace Net { template class Network_address; } /** * Generic form of a network address. */ template struct Net::Network_address { Genode::uint8_t addr[LEN]; /****************** ** Constructors ** ******************/ Network_address(Genode::uint8_t value = 0) { Genode::memset(&addr, value, LEN); } Network_address(void *src) { Genode::memcpy(&addr, src, LEN); } /********************* ** Helper methods ** *********************/ void copy(void *dst) { Genode::memcpy(dst, addr, LEN); } void print(Genode::Output &output) const { using namespace Genode; for (unsigned i = 0; i < LEN; i++) { if (!HEX) { Genode::print(output, (unsigned) addr[i]); } else { Genode::print(output, Hex(addr[i], Hex::OMIT_PREFIX, Hex::PAD)); } if (i < LEN - 1) output.out_char(DELIM); } } /*************** ** Operators ** ***************/ bool operator==(const Network_address &other) const { /* * We compare from lowest address segment to highest * one, because in a local context, the higher segments * of two addresses normally don't distinguish. * (e.g. in an IPv4 local subnet) */ for (int i = LEN-1; i >= 0; --i) { if (addr[i] != other.addr[i]) return false; } return true; } }; #endif /* _NET__NETADDRESS_H_ */