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

Updated ACK_FREQUENCY according to draft-ietf-quic-ack-frequency-10 #4670

Merged
merged 32 commits into from
Jan 3, 2025
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
d6cde24
added reordering threshold in ack frequency
gaurav2699 Nov 28, 2024
bf614d9
modified log filesd
gaurav2699 Dec 2, 2024
542c781
few refactoring
gaurav2699 Dec 2, 2024
54a90da
minor refactoring
gaurav2699 Dec 2, 2024
8097350
fixed clog
gaurav2699 Dec 2, 2024
e7b4add
fixed clog
gaurav2699 Dec 3, 2024
5fdcc8d
removed IgnoreOrder
gaurav2699 Dec 3, 2024
3f17438
removed IgnoreCE
gaurav2699 Dec 3, 2024
d4ed890
updated names
gaurav2699 Dec 3, 2024
d7d69b8
updated the values
gaurav2699 Dec 3, 2024
93dd676
added logic for reordering
gaurav2699 Dec 4, 2024
4a2c327
removed ignorereordering parameter in connection
gaurav2699 Dec 4, 2024
77474a6
added assert
gaurav2699 Dec 4, 2024
d607245
updated logic for the reordering threshold function
gaurav2699 Dec 4, 2024
7a8cbad
minor change
gaurav2699 Dec 4, 2024
4c0e62a
added unit test
gaurav2699 Dec 5, 2024
6191f1f
added more unit test cases
gaurav2699 Dec 5, 2024
1d1e130
changed the reordering logic
gaurav2699 Dec 11, 2024
4a9aae6
minor refactoring
gaurav2699 Dec 11, 2024
f354d43
minor refactoring
gaurav2699 Dec 12, 2024
2cb10ef
changed variable names
gaurav2699 Dec 15, 2024
5e48229
modified way of implementing to be more optimised
gaurav2699 Dec 16, 2024
d2baaa0
addressed comments
gaurav2699 Dec 17, 2024
95a3533
resolved comments
gaurav2699 Dec 18, 2024
a928db6
modified variable name
gaurav2699 Dec 19, 2024
70b564e
changed the alogrithm logic
gaurav2699 Dec 23, 2024
f53a7fb
resolved comments
gaurav2699 Dec 24, 2024
56f3f00
addressed comments
gaurav2699 Dec 24, 2024
a8f2386
minor change
gaurav2699 Dec 24, 2024
7a37125
minor change to fix the pipeline
gaurav2699 Jan 3, 2025
d94d218
minor change
gaurav2699 Jan 3, 2025
140e052
New Largest Packet Number check shifted
gaurav2699 Jan 3, 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
2 changes: 1 addition & 1 deletion src/core/connection.c
Original file line number Diff line number Diff line change
Expand Up @@ -5247,7 +5247,7 @@ QuicConnRecvFrames(
} else {
Connection->PacketTolerance = UINT8_MAX; // Cap to 0xFF for space savings.
}
if(Frame.ReorderingThreshold < UINT8_MAX) {
if (Frame.ReorderingThreshold < UINT8_MAX) {
Connection->ReorderingThreshold = (uint8_t)Frame.ReorderingThreshold;
} else {
Connection->ReorderingThreshold = UINT8_MAX; // Cap to 0xFF for space savings.
Expand Down
22 changes: 11 additions & 11 deletions src/core/connection.h
Original file line number Diff line number Diff line change
Expand Up @@ -452,17 +452,7 @@ typedef struct QUIC_CONNECTION {
// be able to send to the peer.
//
uint8_t PeerPacketTolerance;

//
// The ACK frequency sequence number we are currently using to send.
//
uint64_t SendAckFreqSeqNum;

//
// The next ACK frequency sequence number we expect to receive.
//
uint64_t NextRecvAckFreqSeqNum;


//
// The maximum number of packets that can be out of order before an immediate
// acknowledgment (ACK) is triggered. If no specific instructions (ACK_FREQUENCY
Expand All @@ -478,6 +468,16 @@ typedef struct QUIC_CONNECTION {
//
uint8_t PeerReorderingThreshold;
nibanks marked this conversation as resolved.
Show resolved Hide resolved

//
// The ACK frequency sequence number we are currently using to send.
//
uint64_t SendAckFreqSeqNum;

//
// The next ACK frequency sequence number we expect to receive.
//
uint64_t NextRecvAckFreqSeqNum;

//
// The sequence number to use for the next source CID.
//
Expand Down
2 changes: 1 addition & 1 deletion src/core/unittest/FrameTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ struct ResetStreamFrameParams {
uint8_t TestValue = (j & 1) ? 64 : 255;

if (i & 1) {
Temp.Buffer[1] = TestValue;
Temp.Buffer[1] = TestValue;
gaurav2699 marked this conversation as resolved.
Show resolved Hide resolved
} else {
Temp.Buffer[1] = 0;
}
Expand Down
10 changes: 7 additions & 3 deletions src/manifest/clog.sidecar
Original file line number Diff line number Diff line change
Expand Up @@ -4306,7 +4306,7 @@
},
"FrameLogAckFrequency": {
"ModuleProperites": {},
"TraceString": "[%c][%cX][%llu] ACK_FREQUENCY SeqNum:%llu PktTolerance:%llu MaxAckDelay:%llu IgnoreOrder:%hhu IgnoreCE:%hhu",
"TraceString": "[%c][%cX][%llu] ACK_FREQUENCY SeqNum:%llu PktTolerance:%llu MaxAckDelay:%llu ReorderThreshold:%llu IgnoreOrder:%hhu IgnoreCE:%hhu,
"UniqueId": "FrameLogAckFrequency",
"splitArgs": [
{
Expand Down Expand Up @@ -4334,12 +4334,16 @@
"MacroVariableName": "arg7"
},
{
"DefinationEncoding": "hhu",
"DefinationEncoding": "llu",
"MacroVariableName": "arg8"
},
{
"DefinationEncoding": "hhu",
"MacroVariableName": "arg9"
},
{
"DefinationEncoding": "hhu",
"MacroVariableName": "arg10"
}
],
"macroName": "QuicTraceLogVerbose"
Expand Down Expand Up @@ -14711,7 +14715,7 @@
{
"UniquenessHash": "7470e68a-8ad6-563a-4957-76dc22e5deeb",
"TraceID": "FrameLogAckFrequency",
"EncodingString": "[%c][%cX][%llu] ACK_FREQUENCY SeqNum:%llu PktTolerance:%llu MaxAckDelay:%llu IgnoreOrder:%hhu IgnoreCE:%hhu"
"EncodingString": "[%c][%cX][%llu] ACK_FREQUENCY SeqNum:%llu PktTolerance:%llu MaxAckDelay:%llu ReorderThreshold:%llu IgnoreOrder:%hhu IgnoreCE:%hhu"
},
{
"UniquenessHash": "262b3f95-1062-851d-c2d8-c46867da793b",
Expand Down
Loading