-
Notifications
You must be signed in to change notification settings - Fork 271
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
TCPSocket_PollStatus crash on Linux #154
Comments
FWIW, I've had some success using static SocketStatus TCPSocket_PollStatus(TCPSocket* tcp_socket)
{
SocketStatus status;
struct pollfd fds[1];
status.can_read = RMT_FALSE;
status.can_write = RMT_FALSE;
status.error_state = RMT_ERROR_NONE;
assert(tcp_socket != NULL);
if (tcp_socket->socket == INVALID_SOCKET)
{
status.error_state = RMT_ERROR_SOCKET_INVALID_POLL;
return status;
}
// Set read/write/error markers for the socket
fds[0].fd = tcp_socket->socket;
fds[0].events = POLLIN | POLLPRI | POLLOUT | POLLERR;
// Poll socket status without blocking
if (poll(fds, 1, 0) == SOCKET_ERROR)
{
status.error_state = RMT_ERROR_SOCKET_SELECT_FAIL;
return status;
}
status.can_read = (fds[0].revents & (POLLIN | POLLPRI)) != 0 ? RMT_TRUE : RMT_FALSE;
status.can_write = (fds[0].revents & POLLOUT) != 0 ? RMT_TRUE : RMT_FALSE;
status.error_state = (fds[0].revents & POLLERR) != 0 ? RMT_ERROR_SOCKET_POLL_ERRORS : RMT_ERROR_NONE;
return status;
} |
Thanks, reading up on all this now. |
This certainly is a cross-platform minefield. https://daniel.haxx.se/docs/poll-vs-select.html |
Sure is ! Do toujours think trying to bail out and error using FD_SETSIZE
would be possible/a thing to try ?
Le ven. 8 févr. 2019 à 19:29, Don Williamson <notifications@github.com> a
écrit :
… This certainly is a cross-platform minefield.
https://daniel.haxx.se/docs/poll-vs-select.html
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#154 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA4hksLblwWxjqAQyGDp3kVE7P2cBP-nks5vLcIIgaJpZM4awF4K>
.
|
I mean, this is a pretty crazy old API limitation, almost funny. I'm not sure I want to introduce How's about trying to trick it? Could you try negatively offsetting the address of int byte_index = socket / 8;
int bit_index = socket & 7;
FD_ZERO(&fd_read);
FD_SET(bit_index, &fd_read);
select(socket + 1, (char*)&fd_read - byte_index, ...
can_read = FD_ISSET(bit_index, &fd_read); |
Just looked at the implementation of |
Would the only sensible thing to do be to check on FD_SETSIZE ? At least to prevent crashing. This would need to change if (FD_SETSIZE <= tcp_socket->socket) {
status.error_state = RMT_ERROR_SOCKET_SELECT_FAIL;
return status;
} |
I think that would help and needs adding, with obvious error reporting to the user. But it's not the solution. The irony in all this is that it's fine on Windows as So... we may need an |
I'm traditionnally a Windows developper, I'm a newcomer in *NIX land, so I'm not versed enough to help on the |
It's in wide use as a replacement and was introduced in 1986 vs 1983 but POSIX-like systems sometimes muck it up (e.g. see https://daniel.haxx.se/blog/2016/10/11/poll-on-mac-10-12-is-broken/). Remotery is used on so many varying platforms now that something this core is quite nerve-wracking to change. |
Yep, I saw on the same blog (your earlier link) that `poll` is broken on
OSX <= 10.4 ;
If this issue was never brought to you, I understand that all this looks
like opening a can of worms :) `poll` could be strictly an opt-in solution
for people who get in trouble because of `select` errors related to `fd`
values.
…On Mon, Feb 11, 2019 at 9:26 PM Don Williamson ***@***.***> wrote:
It's in wide use as a replacement and was introduced in 1986 vs 1983 but
POSIX-like systems sometimes muck it up (e.g. see
https://daniel.haxx.se/blog/2016/10/11/poll-on-mac-10-12-is-broken/).
Remotery is used on so many varying platforms now that something this core
is quite nerve-wracking to change.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#154 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA4hkpNrJ2HwQP3KxVq0Df-s3GO_mUSiks5vMdHpgaJpZM4awF4K>
.
|
Good idea. Maybe worth doing it the other way round: use Motivation being |
While trying to use Remotery (@ 589ded3) on my Linux app, I get a crash every time the browser connects on the app.
I managed to trace the issue to
TCPSocket_PollStatus
which corrupts the stack.It seems that the crash is provoked by the
select
call, which is known to cause memory corruptions when the givenfd
is larger than 1024... see https://sigquit.wordpress.com/2009/12/24/stack-corruption-improper-use-of-fd_set/I've put an
assert(tcp_socket->socket+1<FD_SETSIZE);
before theselect
call, which fires right before the crash occurs.The text was updated successfully, but these errors were encountered: