- if((lenin = read(device_fd, packet->data + 14, MTU - 14)) <= 0) {
- logger(LOG_ERR, _("Error while reading from %s %s: %s"), device_info,
- device, strerror(errno));
- return false;
+ switch(device_type) {
+ case DEVICE_TYPE_TUN:
+ if((lenin = read(device_fd, packet->data + 14, MTU - 14)) <= 0) {
+ logger(LOG_ERR, _("Error while reading from %s %s: %s"), device_info,
+ device, strerror(errno));
+ return false;
+ }
+
+ switch(packet->data[14] >> 4) {
+ case 4:
+ packet->data[12] = 0x08;
+ packet->data[13] = 0x00;
+ break;
+ case 6:
+ packet->data[12] = 0x86;
+ packet->data[13] = 0xDD;
+ break;
+ default:
+ ifdebug(TRAFFIC) logger(LOG_ERR,
+ _ ("Unknown IP type %d while reading packet from %s %s"),
+ packet->data[14] >> 4, device_info, device);
+ return false;
+ }
+
+ packet->len = lenin + 14;
+ break;
+ case DEVICE_TYPE_TAP:
+ if((lenin = read(device_fd, packet->data, MTU)) <= 0) {
+ logger(LOG_ERR, _("Error while reading from %s %s: %s"), device_info,
+ device, strerror(errno));
+ return false;
+ }
+
+ packet->len = lenin;
+ break;
+ default:
+ return false;