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

Possibility for datagrams to be dropped when not able to send #4320

Merged
merged 36 commits into from
Jan 9, 2025
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
8f40f35
Added possibility for datagrams to be dropped when not able to send
May 23, 2024
03dceb1
Switch from not insert into queue if not empty to cancel all outstand…
May 29, 2024
b010939
Ran dotnet script
iiztp May 30, 2024
efb718a
Removed copies from clipboard I made when comitting...
May 30, 2024
ba30093
Modified for comments
May 30, 2024
f658311
Test if alg works now
iiztp May 30, 2024
1528319
style
nibanks May 30, 2024
084c172
It works now, but sometimes segfault, didn't went further
May 31, 2024
bbb2bf4
Merge because I didn't pulled before modifying..
May 31, 2024
9aeaab5
Inspired from previous work
May 31, 2024
9386e84
Doc + Modif flag hex because I'm bad at hex
May 31, 2024
1b20bac
I didn't save the file for the doc ;-;
May 31, 2024
928501f
Update datagram.c
iiztp May 31, 2024
ad9457f
Update datagram.c
iiztp May 31, 2024
5706fd9
Update datagram.c
iiztp May 31, 2024
d6835df
Merge branch 'microsoft:main' into main
iiztp Jun 1, 2024
e5e67b9
Test that crashes because ?
Jun 19, 2024
0e9041f
Merge branch 'main' of https://github.com/iiztp/msquic
Jun 19, 2024
2d7355e
Found out why core dumped
Jun 19, 2024
ce0d31e
Update src/test/lib/DatagramTest.cpp
iiztp Jun 19, 2024
86e903a
Revert changes of submodule
Jun 19, 2024
fbc659d
Merge branch 'main' into main
iiztp Jun 20, 2024
ffc798a
Merge branch 'microsoft:main' into main
iiztp Jul 17, 2024
4afc187
Merge branch 'microsoft:main' into main
iiztp Aug 14, 2024
62458da
Merge branch 'microsoft:main' into main
iiztp Sep 17, 2024
d8d4627
Merge branch 'microsoft:main' into main
iiztp Oct 26, 2024
90f03e0
Update DocFx after documentation changes.
Oct 26, 2024
6f716c2
Removed msquicdocs
iiztp Oct 28, 2024
cf0c4c2
Merge branch 'microsoft:main' into main
iiztp Jan 5, 2025
ea47e31
Update DocFx after documentation changes.
Jan 5, 2025
b52bf36
Added test for dropping datagrams
iiztp Jan 5, 2025
a3a08a4
Resolving comments
iiztp Jan 5, 2025
0090326
Resolve comments
iiztp Jan 8, 2025
91475bb
Merge branch 'microsoft:main' into main
iiztp Jan 8, 2025
4aee0c0
Modified rust bindings
iiztp Jan 8, 2025
6d97223
Modified Windows rust bindings
iiztp Jan 8, 2025
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
36 changes: 34 additions & 2 deletions src/core/datagram.c
Original file line number Diff line number Diff line change
Expand Up @@ -426,7 +426,6 @@ QuicDatagramSendFlush(
continue;
}
TotalBytesSent += SendRequest->TotalLength;

iiztp marked this conversation as resolved.
Show resolved Hide resolved
if (SendRequest->Flags & QUIC_SEND_FLAG_DGRAM_PRIORITY) {
SendRequest->Next = *Datagram->PrioritySendQueueTail;
*Datagram->PrioritySendQueueTail = SendRequest;
Expand All @@ -438,7 +437,6 @@ QuicDatagramSendFlush(
*Datagram->SendQueueTail = SendRequest;
Datagram->SendQueueTail = &SendRequest->Next;
}

QuicTraceLogConnVerbose(
DatagramSendQueued,
Connection,
Expand Down Expand Up @@ -583,3 +581,37 @@ QuicDatagramProcessFrame(

return TRUE;
}

_IRQL_requires_max_(PASSIVE_LEVEL)
void
QuicDatagramCancelBlocked(
_In_ QUIC_CONNECTION* Connection
)
{
QUIC_DATAGRAM* Datagram = &Connection->Datagram;
iiztp marked this conversation as resolved.
Show resolved Hide resolved
QUIC_SEND_REQUEST* SendQueue = Datagram->SendQueue;
QUIC_SEND_REQUEST** PrioritySendQueueTail = Datagram->PrioritySendQueueTail;
Datagram->SendQueue = NULL;
bool priority = true;
iiztp marked this conversation as resolved.
Show resolved Hide resolved

while (SendQueue != NULL) {
if(SendQueue->Flags & QUIC_SEND_FLAG_CANCEL_ON_BLOCKED) {
iiztp marked this conversation as resolved.
Show resolved Hide resolved
QuicDatagramCancelSend(Connection, SendQueue);
} else {
if(Datagram->SendQueue == NULL) {
iiztp marked this conversation as resolved.
Show resolved Hide resolved
Datagram->SendQueue = SendQueue;
Datagram->SendQueueTail = &SendQueue;
} else {
if(priority) {
(*(Datagram->PrioritySendQueueTail))->Next = SendQueue;
}
(*(Datagram->SendQueueTail))->Next = SendQueue;
Datagram->SendQueueTail = &SendQueue;
}
}
if(&SendQueue == PrioritySendQueueTail) {
iiztp marked this conversation as resolved.
Show resolved Hide resolved
priority = false;
}
SendQueue = SendQueue->Next;
}
}
6 changes: 6 additions & 0 deletions src/core/datagram.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,3 +103,9 @@ QuicDatagramProcessFrame(
const uint8_t * const Buffer,
_Inout_ uint16_t* Offset
);

_IRQL_requires_max_(PASSIVE_LEVEL)
void
QuicDatagramCancelBlocked(
_In_ QUIC_CONNECTION* Connection
);
5 changes: 5 additions & 0 deletions src/core/send.c
Original file line number Diff line number Diff line change
Expand Up @@ -1498,6 +1498,11 @@ QuicSendFlush(
//QuicConnUpdatePeerPacketTolerance(Connection, Builder.TotalCountDatagrams);
}

//
// Clears the SendQueue list of not sent packets if the flag is applied
//
QuicDatagramCancelBlocked(Connection);

return Result != QUIC_SEND_INCOMPLETE;
}
#pragma warning(pop)
Expand Down
1 change: 1 addition & 0 deletions src/cs/lib/msquic_generated.cs
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,7 @@ internal enum QUIC_SEND_FLAGS
DGRAM_PRIORITY = 0x0008,
DELAY_SEND = 0x0010,
CANCEL_ON_LOSS = 0x0020,
CANCEL_ON_BLOCKED = 0x0030,
}

internal enum QUIC_DATAGRAM_SEND_STATE
Expand Down
1 change: 1 addition & 0 deletions src/inc/msquic.h
Original file line number Diff line number Diff line change
Expand Up @@ -241,6 +241,7 @@ typedef enum QUIC_SEND_FLAGS {
QUIC_SEND_FLAG_DGRAM_PRIORITY = 0x0008, // Indicates the datagram is higher priority than others.
QUIC_SEND_FLAG_DELAY_SEND = 0x0010, // Indicates the send should be delayed because more will be queued soon.
QUIC_SEND_FLAG_CANCEL_ON_LOSS = 0x0020, // Indicates that a stream is to be cancelled when packet loss is detected.
QUIC_SEND_FLAG_CANCEL_ON_BLOCKED = 0x0030, // Indicates that a frame should be dropped when it can't be sent immediately.
} QUIC_SEND_FLAGS;

DEFINE_ENUM_FLAG_OPERATORS(QUIC_SEND_FLAGS)
Expand Down