I am experiencing an issue that my process does not wake out of a select() call when a single character is received in an input file descriptor when running as a VMware guest. Anyone ever experienced this ? I can run tshark and see the character arrive, but my process does not wake up and see that character. Most times it works - but once in a while it does not. So I made a change on my code - and did not just wait on select() - but just try to read the buffer all the time and print the results. once in a while that character is "delayed" getting to my input buffer. Top reports the machine is 99% idle. Any thoughts? Jerry
On 12/3/19 8:46 AM, Jerry Geis wrote:> I am experiencing an issue that my process does not wake out of a select() > call when a single character is received in an input file descriptor when > running as a VMware guest. > > Anyone ever experienced this ? > > I can run tshark and see the character arrive, but my process does not wake > up and see that character. Most times it works - but once in a while it > does not. > > So I made a change on my code - and did not just wait on select() - but > just try to read the buffer all the time and print the results. once in a > while that character is "delayed" getting to my input buffer. Top reports > the machine is 99% idle. > > Any thoughts? > > Jerry > _______________________________________________ > CentOS mailing list > CentOS at centos.org > lists.centos.org/mailman/listinfo/centosYou don't say what the app is written in but I ran into this with perl.? perl apps can either be line buffered or character buffered ($| if I remember right is the switch).? Line buffered means the buffer is not delivered until a newline character is received.? If nothing else, try "<char>\n" and see if that gets consistently delivered. Cheers, Dave -- "They that can give up essential liberty to obtain a little temporary safety deserve neither safety nor liberty." -- Benjamin Franklin
>You don't say what the app is written in but I ran into this with perl. >perl apps can either be line buffered or character buffered ($| if I >remember right is the switch). Line buffered means the buffer is not >delivered until a newline character is received. If nothing else, try >"<char>\n" and see if that gets consistently delivered.That is the funny thing also - that character I'm waiting on is a CR. My program is written in C. vmtoolsd is running. Jerry
On Dec 3, 2019, at 9:18 AM, David G. Miller <dave at davenjudy.org> wrote:> > On 12/3/19 8:46 AM, Jerry Geis wrote: >> I am experiencing an issue that my process does not wake out of a select() >> call when a single character is received in an input file descriptor when >> running as a VMware guest.You imply but don?t say that this doesn?t happen when the app is running on bare metal. Is that the case?>> Anyone ever experienced this ?No, and I?ve been writing sockets-type code since the days when it wasn?t clear whether BSD sockets would win out over AT&T TLI/XTI/STREAMS.>> once in a while that character is "delayed" getting to my input buffer.That?s probably the Nagle algorithm: en.wikipedia.org/wiki/Nagle's_algorithm It?s intentional. You almost never want to disable it.> Perl apps can either be line buffered or character bufferedI think that?s controlled by the kernel?s terminal driver code, not by Perl. Perl is just giving you an alternate configuration to the underlying termios() or whatever call controls this. Anyway, you have to go out of your way to get line-buffered sockets on Linux. One way is to bind a socket to a pty, as ssh does, bringing the terminal I/O code into it again, but I doubt Jerry?s doing that. I?d bet Jerry's app is just making assumptions about the way TCP works that just aren?t true. Jerry, please show your sockets setup code and the skeletonized read loop. I?m talking socket(), bind(), setsockopt(), etc. I want to see every sockets call. Your app logic you?re free to keep hidden away.
Seems like its the single byte thing... I tried adding: int flag = 1; if(setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, &flag, sizeof(flag)) < 0) but did not have any effect. I also did the echo 1 > /proc/sys/net/ipv4/tcp_low_latency seems to have no effect also. Jerry
Warren,>Now that we?ve dispensed with Nagle, let?s get down to the actual issue.Correct. I was trying to find something... Agreed that is on the sending side - I am on the receiving side. Are there other options that this single byte CR over socket is not getting seen by my application. tshark shows its been received, I have tried to skip my select() call and just call recv() with nonblocking direct - the byte is not seen. Very odd. Jerry