Skip to content
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

improve fake network write() efficiency #1178

Closed
wants to merge 28 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
5af221d
improve write() efficiency
chschnell Nov 4, 2024
3c28d30
fixed eslint errors
chschnell Nov 4, 2024
c46e34b
fixed FIN flag in generated TCP packets
chschnell Nov 4, 2024
ed7bf7a
minor fixes
chschnell Nov 4, 2024
dd3e314
several improvements to GrowableRingbuffer (former class Uint8Stream)
chschnell Nov 5, 2024
c1c52b8
fixed finding unused dynamic TCP port
chschnell Nov 5, 2024
bf877f8
removed class EthernetPacketEncoder
chschnell Nov 5, 2024
d8136c1
minor cleanups and alignments
chschnell Nov 5, 2024
bd91c53
Merge branch 'copy:master' into fake-network-refactor
chschnell Nov 8, 2024
f8af3c6
remove unused functions
chschnell Nov 8, 2024
7ddf24b
improve TCP state mechanics support
chschnell Nov 10, 2024
72e8aec
suggested improvements and a bugfix
chschnell Nov 11, 2024
51204e2
bugfix: late FIN support in case of passive TCP close was incomplete
chschnell Nov 11, 2024
4004a4a
added more TCP state mechanics
chschnell Nov 17, 2024
7cbd89c
added now required call to close() once fetch() is complete
chschnell Nov 17, 2024
c5557a6
Merge branch 'copy:master' into fake-network-refactor
chschnell Nov 18, 2024
00ad28d
added method TCPConnection.writev([ Uint8Array, ... ])
chschnell Nov 18, 2024
b3721ef
use ReadableStream in fetch() response body handling
chschnell Nov 18, 2024
65ceac6
removed/solved a few leftover TODOs
chschnell Nov 19, 2024
6ad738a
fixed eslint errors
chschnell Nov 19, 2024
68b9b2c
reactivated FetchNetworkAdapter.fetch()
chschnell Nov 21, 2024
b06c291
removed method TCPConnection.on_passive_close()
chschnell Nov 21, 2024
5ec28a2
added TCPConnection.on_shutdown() and TCPConnection.on_close()
chschnell Nov 22, 2024
38e01d8
simplified control flow in handle_fake_networking() and WispNetworkAd…
chschnell Nov 24, 2024
a73e383
reduced code duplication in WispNetworkAdapter
chschnell Nov 24, 2024
2a95ec6
fixed eslint error
chschnell Nov 24, 2024
cf3b38d
moved DoH-code to fake_network.js
chschnell Nov 25, 2024
6203ebb
fixed eslint error
chschnell Nov 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
bugfix: late FIN support in case of passive TCP close was incomplete
  • Loading branch information
chschnell committed Nov 11, 2024
commit 51204e27432bfb91f70220052c2f8e20a6b41ce0
9 changes: 5 additions & 4 deletions src/browser/fake_network.js
Original file line number Diff line number Diff line change
Expand Up @@ -966,7 +966,7 @@ function TCPConnection()
this.state = TCP_STATE_CLOSED;
this.send_buffer = new GrowableRingbuffer(2048, 0);
this.send_chunk_buf = new Uint8Array(TCP_PAYLOAD_SIZE);
this.delayed_active_close = false;
this.delayed_send_fin = false;
}

TCPConnection.prototype.ipv4_reply = function() {
Expand Down Expand Up @@ -1119,7 +1119,7 @@ TCPConnection.prototype.process = function(packet) {
this.pending = false;

let send_fin;
if(this.delayed_active_close && !this.send_buffer.length) {
if(this.delayed_send_fin && !this.send_buffer.length) {
if(this.state === TCP_STATE_ESTABLISHED) {
dbg_log(`TCP[${this.tuple}]: sending delayed FIN from active close in state "${this.state}", next "${TCP_STATE_FIN_WAIT_1}"`, LOG_FETCH);
this.state = TCP_STATE_FIN_WAIT_1;
Expand Down Expand Up @@ -1158,6 +1158,7 @@ TCPConnection.prototype.process = function(packet) {
reply.tcp.ack = true;
if(this.send_buffer.length || this.pending) {
this.state = TCP_STATE_CLOSE_WAIT;
this.delayed_send_fin = true;
}
else {
dbg_log(`TCP[${this.tuple}]: sending FIN in state "${this.state}", next "${TCP_STATE_LAST_ACK}"`, LOG_FETCH);
Expand Down Expand Up @@ -1210,10 +1211,10 @@ TCPConnection.prototype.write = function(data) {
};

TCPConnection.prototype.close = function() {
if(this.state === TCP_STATE_ESTABLISHED && !this.delayed_active_close) {
if(this.state === TCP_STATE_ESTABLISHED && !this.delayed_send_fin) {
if(this.send_buffer.length || this.pending) {
dbg_log(`TCP[${this.tuple}]: active close, delaying FIN in state "${this.state}"`, LOG_FETCH);
this.delayed_active_close = true;
this.delayed_send_fin = true;
}
else {
dbg_log(`TCP[${this.tuple}]: active close, sending FIN in state "${this.state}", next "${TCP_STATE_FIN_WAIT_1}"`, LOG_FETCH);
Expand Down
Loading