--- gvpe/src/device.h 2003/04/06 20:01:52 1.4 +++ gvpe/src/device.h 2003/10/16 02:28:36 1.10 @@ -19,7 +19,7 @@ #ifndef VPE_DEVICE_H__ #define VPE_DEVICE_H__ -#include +#define IFNAMESIZE 256 // be conservative #include "gettext.h" @@ -30,9 +30,16 @@ u8 &operator[] (u16 offset) const; + void unshift_hdr (u16 hdrsize) + { + memmove ((void *)&(*this)[hdrsize], (void *)&(*this)[0], len); + len += hdrsize; + } + void skip_hdr (u16 hdrsize) { - memmove ((void *)&(*this)[0], (void *)&(*this)[hdrsize], len -= hdrsize); + len -= hdrsize; + memmove ((void *)&(*this)[0], (void *)&(*this)[hdrsize], len); } void set (const net_packet &pkt) @@ -41,7 +48,23 @@ memcpy (&((*this)[0]), &(pkt[0]), len); } - bool is_arp () + bool is_ipv4 () const + { + return (*this)[12] == 0x08 && (*this)[13] == 0x00 // IP + && ((*this)[14] & 0xf0) == 0x40; // IPv4 + } + + u32 &ipv4_src () const + { + return *(u32 *)&(*this)[26]; + } + + u32 &ipv4_dst () const + { + return *(u32 *)&(*this)[30]; + } + + bool is_arp () const { return (*this)[12] == 0x08 && (*this)[13] == 0x06 // 0806 protocol && (*this)[14] == 0x00 && (*this)[15] == 0x01 // 0001 hw_format @@ -74,20 +97,25 @@ struct tap_device { int fd; - // linux tuntap - char ifrname[IFNAMSIZ + 1]; + // network interface name or identifier + char ifrname[IFNAMESIZE + 1]; char *device; tap_device (); ~tap_device (); + //bool open (); + //void close (); + const char *interface () { return ifrname; } - const char *info () { return _("Linux tun/tap device"); } + const char *info (); tap_packet *recv (); void send (tap_packet *pkt); }; +//extern tap_device *tap_device (); + #endif