<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 12pt;
font-family:Calibri
}
--></style></head>
<body class='hmmessage'><div dir='ltr'>The other server has just crashed. So the problem is not restricted to a single machine.<BR>We are thinking about updating HP NIC drivers and firmware (dated January 2011), hoping that an outdated driver/firmware could make WinPcap more prone to participate in these crashes.<BR> <BR>There is another strange behaviour: we have applied a safety mechanism to detect malformed packets; it compares the len property of the pktHeader returned by WinPcap to the datagramSize derived from the IP datagram header. If they don't match, a log message is written, and the packet is discarded.<BR> <BR> Public Const EthernetHeaderSize = 14<br> Public Const BasicIPHeaderSize = 20<BR> Private _MaxDatagramSize As Integer = 65535<br> Private _MaxEthernetPacketSize As Integer = EthernetHeaderSize + Me._MaxDatagramSize<BR> ...<BR> Dim errBuf As New StringBuilder(WinPcap.Constants.PCAP_ERRBUF_SIZE)<br> Dim session = WinPcap.Driver.pcap_open(Me._DeviceName, Me._MaxEthernetPacketSize, WinPcap.Constants.PCAP_OPENFLAG_MAX_RESPONSIVENESS + WinPcap.Constants.PCAP_OPENFLAG_NOCAPTURE_LOCAL, 1, IntPtr.Zero, errBuf)<BR> ...<BR> While Not cancellationTokenSource.IsCancellationRequested<br> Dim pktHeader As IntPtr = IntPtr.Zero<br> Dim pktData As IntPtr = IntPtr.Zero<BR> Select Case WinPcap.Driver.pcap_next_ex(session, pktHeader, pktData)<br> Case 0<br> Continue While<br> Case Is < 0<br> Throw New Exception(WinPcap.Driver.pcap_geterr(session))<br> End Select<BR> Dim header = DirectCast(Marshal.PtrToStructure(pktHeader, GetType(WinPcap.pcap_pkthdr)), WinPcap.pcap_pkthdr)<br> If header.len > EthernetHeaderSize + BasicIPHeaderSize Then 'Ethernet header + IPv4 header (without options)<br> Dim datagramSize As UShort = Marshal.ReadByte(pktData, EthernetHeaderSize + 2)<br> datagramSize <<= 8<br> datagramSize = datagramSize Or Marshal.ReadByte(pktData, EthernetHeaderSize + 3)<br> If header.len >= EthernetHeaderSize + datagramSize AndAlso datagramSize <= Me._MaxDatagramSize Then<br> 'Process the packet<br> ...<br><strong> Else<br> Logging.Write(TraceEventType.Verbose, "Discarded packet with datagramSize {0} and header.len {1}", datagramSize, header.len)<br> End If<br></strong> End If<br> End While<BR> <BR>Well, it is happening, very significantly I would say.<BR> <BR>My questions are:<BR>-- Is it common that packets are this malformed?<BR>-- Is my understanding right that in PCAP_OPENFLAG_MAX_RESPONSIVENESS mode WinPcap delivers complete datagrams to the application (if the internal buffer is big enough)? I'm not precluding IP fragmentation, rather I wonder whether individual datagrams (be they fragments or not) are delivered as indisivible units to the application. Otherwise, the behaviour we are experiencing could be the result of WinPcap delivering a portion of a datagram, not the whole datagram; but it would be a burden for the application to aggregate the portions.<BR> <BR>Thank you very much.<BR> <BR>J.M.<br> <BR><div><hr id="stopSpelling">From: carpe7@hotmail.com<br>To: winpcap-users@winpcap.org<br>Subject: Service crash after update to WinPcap networking<br>Date: Fri, 28 Mar 2014 10:07:37 +0000<br><br>
<style><!--
.ExternalClass .ecxhmmessage P {
padding:0px;
}
.ExternalClass body.ecxhmmessage {
font-size:12pt;
font-family:Calibri;
}
--></style>
<div dir="ltr">Hi,<br> <br>We have updated the raw socket networking subsystem of a Windows service to WinPcap, with the following architecture:<br>-- One thread continuously captures on its own pcap_t calling pcap_next_ex.<br>-- Several threads send packets concurrently over the same interface, but each one with it own private pcap_t obtained from pcap_open. These threads call pcap_sendpacket.<br> <br>Since the update, the service crashes intermittently, although only one of the two servers in a redundant cluster exhibit the problem.<br>We are logging the errors produced by WinPcap. For that, after pcap_sendpacket returning a negative result we call pcap_geterr.<br> <br>Just before the crash, the service logs (pcap_geterr result):<br> <br><em>send error: PacketSendPacket failed</em><br><em></em> <br>In EventViewer, this is the detail of the crash:<br> <br><em>Faulting application name: ...<br>Faulting module name: ntdll.dll, version: 6.1.7601.17725, time stamp: 0x4ec4aa8e<br>Exception code: 0xc0000374<br>Fault offset: 0x00000000000c40f2<br>Faulting process id: 0x1d64<br>Faulting application start time: 0x01cf4a53bf7cfe86<br>Faulting application path: ...<br>Faulting module path: C:\Windows\SYSTEM32\ntdll.dll<br>Report Id: 0e886882-b656-11e3-b6bb-e4115be757a8</em><br><em></em> <br>The OS is Windows Server 2008 R2 64 bits.<br>The WinPcap version is 4.1.3.<br><em></em> <br>The question is: has someone observed this problem?<br> <br>Thank you very much.<br> <br>Regards,<br>J.M.<br> </div></div> </div></body>
</html>