Skip to content
This repository has been archived by the owner on May 4, 2018. It is now read-only.

windows: remember writes before connect and issue writes after connect #1439

Closed
wants to merge 30 commits into from
Closed

windows: remember writes before connect and issue writes after connect #1439

wants to merge 30 commits into from

Conversation

txdv
Copy link
Contributor

@txdv txdv commented Aug 26, 2014

This makes it behave it like the linux code.

Currently this is not working, I get an segmentation error on windows when I try to remove something from the queue.

@saghul can you take a look on this, maybe i'm missing something obvious?

For some reason this gives me a segmentation error: https://github.com/txdv/libuv/compare/write_queue?expand=1#diff-dc490d8a5a8a41100ae824b52c0e496fR240

Also the returned pointer from QUEUE_DATA is absolute bullshit.

@saghul
Copy link
Contributor

saghul commented Aug 26, 2014

Thanks for working on this Andrius! I'll take a deeper look, but at a first glance I don't see the queue in the request being initialized, you sould also QUEUE_INIT(&req->queue).

@@ -821,6 +823,11 @@ int uv_tcp_write(uv_loop_t* loop,
int result;
DWORD bytes;

if (!(handle->flags & UV_HANDLE_WRITABLE)) {
QUEUE_INSERT_TAIL(&handle->write_queue, &req->queue);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You'll also need to initialize req first.

@saghul
Copy link
Contributor

saghul commented Aug 26, 2014

Also, once the stream is connected successfully we need to do the actual writes, not just call the callbacks with UV_ECANCELED, is this something you plan to implement?

@txdv
Copy link
Contributor Author

txdv commented Aug 26, 2014

Yes.

I'm getting a Segmentation fault right now, so I want to get it out of the way before going on.

@txdv
Copy link
Contributor Author

txdv commented Aug 26, 2014

It still immediately gets a segmentation fault on the QUEUE_REMOVE.

@saghul
Copy link
Contributor

saghul commented Aug 26, 2014

You haven't initialized req->queue.

@txdv
Copy link
Contributor Author

txdv commented Aug 26, 2014

Like with QUEUE_INIT? I haven't seen it initialized anywhere in the unix code.... but now I see.

@saghul
Copy link
Contributor

saghul commented Aug 26, 2014

@txdv
Copy link
Contributor Author

txdv commented Aug 26, 2014

Looks reasonable, but still segfaults, I'll check the pointers now, maybe something changed.

@@ -1117,6 +1125,8 @@ void uv_process_tcp_connect_req(uv_loop_t* loop, uv_tcp_t* handle,
}
req->cb(req, uv_translate_sys_error(err));

uv__stream_flush_write_queue(&handle->write_queue, UV_ECANCELED);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You need to pass handle here, not handle->write_queue.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Damn, I'm stupid.
Why doesn't it issue a warning :/

@saghul saghul added this to the v0.12 milestone Aug 28, 2014
@saghul
Copy link
Contributor

saghul commented Sep 4, 2014

Andrius, if nothing unexpected happens I plan to make the 1.0.0 release by the end of next week, and since this modifies the ABI it would be nice to have it before that. Can you work on it by then? If not maybe I can find some time o help. Thanks!

@txdv
Copy link
Contributor Author

txdv commented Sep 5, 2014

Changing the struct is an ABI change?

@saghul
Copy link
Contributor

saghul commented Sep 5, 2014

Fantastic, thanks a lot!

@saghul
Copy link
Contributor

saghul commented Sep 5, 2014

Changing the struct is an ABI change?

Yep.

saghul and others added 4 commits September 5, 2014 16:59
Remove duplicated code by directly calling uv_timer_stop
`fd_set`s are way too small for `select()` hack when stream's fd is
bigger than 1023. Make `fd_set`s a part of `uv__stream_select_t`
structure.

fix #1461
saghul and others added 4 commits September 10, 2014 09:52
- Remove the UV_HANDLE_ACTIVE flag. It's a duplicate from
  UV__HANDLE_ACTIVE, which was used solely on timers and loop watchers.

- Avoid duplicated code when running timers by stopping the handle and
  rearming it with the repeat time, thus having a single place where the
  timers are added and removed to and from the RB tree, respectively.
The echo server shouldn't close the connection when there's an error on
write. Instead simply echo the error message and allow the other side to
close the connection.

Also do a partial revert of 4d905fb where after_shutdown was removed.

Fixes: 4d905fb "test: close stream immediately on error"
Signed-off-by: Trevor Norris <trev.norris@gmail.com>
Signed-off-by: Saúl Ibarra Corretgé <saghul@gmail.com>
Remove comments describing the API which are now part of the
documentation, thus avoiding future comment rot (and removing the
existing part).
@saghul
Copy link
Contributor

saghul commented Sep 12, 2014

Ping.

@saghul
Copy link
Contributor

saghul commented Sep 19, 2014

@txdv any plans to resume this work? @trevnorris volunteered to take it over if you don't have the time.

@trevnorris
Copy link
Contributor

Here's a quick diff to get rid of all build warnings:

diff --git a/src/win/internal.h b/src/win/internal.h
index d87402b..af6754c 100644
--- a/src/win/internal.h
+++ b/src/win/internal.h
@@ -120,6 +120,7 @@ extern UV_THREAD_LOCAL int uv__crt_assert_enabled;
  * Streams: see stream-inl.h
  */

+void uv__stream_flush_write_queue(uv_stream_t* stream, int error);

 /*
  * TCP
diff --git a/src/win/tcp.c b/src/win/tcp.c
index dbebc06..38602eb 100644
--- a/src/win/tcp.c
+++ b/src/win/tcp.c
@@ -1126,7 +1126,7 @@ void uv_process_tcp_connect_req(uv_loop_t* loop, uv_tcp_t* handle,
   }
   req->cb(req, uv_translate_sys_error(err));

-  uv__stream_flush_write_queue(handle, UV_ECANCELED);
+  uv__stream_flush_write_queue((uv_stream_t*)handle, UV_ECANCELED);

   DECREASE_PENDING_REQ_COUNT(handle);
 }
diff --git a/test/test-tcp-write-after-connect.c b/test/test-tcp-write-after-connect.c
index 02ff9c4..7d1d04a 100644
--- a/test/test-tcp-write-after-connect.c
+++ b/test/test-tcp-write-after-connect.c
@@ -42,7 +42,6 @@ static void connect_cb(uv_connect_t *req, int status) {


 TEST_IMPL(tcp_write_after_connect) {
-  int r;
   struct sockaddr_in sa;
   uv_buf_t buf;
   buf = uv_buf_init("HELLO", 4);

@txdv
Copy link
Contributor Author

txdv commented Sep 22, 2014

I'm working on it now.

@txdv
Copy link
Contributor Author

txdv commented Sep 22, 2014

TTY works by default (it always immediately opens the stdin/stdout).

Now only the pipe is in question. The pipe functionality is strange on windows...

@saghul
Copy link
Contributor

saghul commented Sep 22, 2014

Andrius, can you open the PR against the v1.x branch? Now GH picks up all commits which are not yet in master.

@txdv txdv closed this Sep 22, 2014
@trevnorris
Copy link
Contributor

@txdv Can you link the new PR here?

@saghul
Copy link
Contributor

saghul commented Sep 23, 2014

#1487

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants