1

I created a socket using: socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP).

According to this, if I send simple packet several times (multiply send() and/or sendto()), I can get ECONNREFUSED. ICMP should tell that previous packet didn't arrive and ECONNREFUSED should appear. But it fails, errno doesn't report about any errors, and send() always returns number of bytes sent.

UDP protocol actually shouldn't tell that packet was sent. But ICMP can give advice as I understand.

So, the question is - why does it fail to receive ECONNREFUSED?

Everything is done using Winsock.

pb2q
  • 58,613
  • 19
  • 146
  • 147
naixx
  • 1,176
  • 11
  • 17

2 Answers2

1

INFO: Winsock Ignores ICMP Port Unreachable Control Messages

You have to enable the SIO_UDP_CONNRESET control via WSAIoctl() in order for UDP sockets to react to ICMP failures:

WinSock Recvfrom() now returns WSAECONNRESET instead of blocking or timing out

Remy Lebeau
  • 555,201
  • 31
  • 458
  • 770
1

There could be two reasons for this.

  • The target machine does not (for some reason) send the ICMP back
  • The target machines does send the ICMP back but winsock doesn't correctly interpret it (I know that certain older Unixes did this)

In short, your best bet to find out would be using a sniffer. Try wireshark and see if you get an ICMP back.

cnicutar
  • 178,505
  • 25
  • 365
  • 392
  • Thank you for the answer. System is winxp, local machine. ICMP is just assumption, probably something else – naixx Apr 23 '11 at 07:09