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

Subframe rollback #285

Draft
wants to merge 83 commits into
base: slippi
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
35a3ce2
Annotations in progress
JulienBernard3383279 Mar 4, 2021
baac7b1
first ver slippi netplay client repo
JulienBernard3383279 Mar 27, 2021
517cf75
Before destroying project by including SlippiNetplay.h in GCAdapter.cpp
JulienBernard3383279 Mar 27, 2021
f93ad16
First SNC->Adapter concept
JulienBernard3383279 Mar 28, 2021
de847b8
Merge remote-tracking branch 'slippi/release/2.3.0' into annotations
JulienBernard3383279 Mar 28, 2021
2aad196
Add offsetUs logging + fix new/no snc
JulienBernard3383279 Mar 28, 2021
fe672e3
add KristalInputJudge + extract bytearray->pad
JulienBernard3383279 Mar 28, 2021
785a7ce
Kristal input judge
JulienBernard3383279 Mar 28, 2021
22b49cc
Cleanup
JulienBernard3383279 Mar 28, 2021
6a37ff5
Pick used controller + log Kristal inputs perception
JulienBernard3383279 Mar 28, 2021
57c8fa0
Fix KIJ and used controller perception
JulienBernard3383279 Mar 29, 2021
bb24939
More annotations
JulienBernard3383279 Apr 1, 2021
7a1a45b
Merge remote-tracking branch 'slippi/release/2.3.0' into annotations
JulienBernard3383279 Apr 17, 2021
dd5dbba
Add trigger checks in KristalInputJudge
JulienBernard3383279 Apr 17, 2021
3b9b24b
Add unconnected enabler methods to InputStabilizer and expose InputSt…
JulienBernard3383279 Apr 17, 2021
eda0889
fix startFrameCount parameter use
JulienBernard3383279 Apr 17, 2021
b88c196
Add note about delay in InputStabilizer
JulienBernard3383279 Apr 17, 2021
02de473
Timing estimation + input versioning + callback architecture
JulienBernard3383279 Apr 18, 2021
7da5ab9
Kristal messages + kristal pad struct/set ordering
JulienBernard3383279 Apr 18, 2021
c835bed
Publish Kristal pad to ASM WIP
JulienBernard3383279 Apr 18, 2021
ec96a40
'''Done.''' there isn't the slightest chance this works first try
JulienBernard3383279 Apr 18, 2021
4ed4d68
Suppress update
JulienBernard3383279 Apr 19, 2021
64d95b8
And so it begins
JulienBernard3383279 Apr 19, 2021
12483bc
Send A + receive A + evaluateTiming logs
JulienBernard3383279 Apr 19, 2021
58f3cd2
Learning about static and translation units: a WIP
JulienBernard3383279 Apr 19, 2021
b96d886
Log any received Slippi message
JulienBernard3383279 Apr 20, 2021
b0fbeac
Fix little endian + switch to X + fix << u8
JulienBernard3383279 Apr 20, 2021
b9b599b
fix << u8 bis
JulienBernard3383279 Apr 20, 2021
ad03f8a
log whether Kristal input is used
JulienBernard3383279 Apr 21, 2021
92e6c51
Fix iterating over stabilizers copy
JulienBernard3383279 Apr 21, 2021
d261d0c
calibrate to delay+2
JulienBernard3383279 Apr 21, 2021
eda5454
comments
JulienBernard3383279 Apr 24, 2021
5f0d49e
Fix local X press logging
JulienBernard3383279 Apr 24, 2021
35a9592
Log kristal input arrival as subframe in our timeline
JulienBernard3383279 Apr 24, 2021
abcc038
More timing logs
JulienBernard3383279 Apr 24, 2021
0819821
temp fix to incrementsSinceOrigin increment when reading WTF was I th…
JulienBernard3383279 Apr 24, 2021
4eae1a6
Now we're getting somewhere
JulienBernard3383279 Apr 24, 2021
5ae13f0
Fix CStick kristal input recognition
JulienBernard3383279 Apr 24, 2021
68d3869
improve comment
JulienBernard3383279 Apr 24, 2021
4b6e9e5
Pass adapted estimated_timing to kristal callback
JulienBernard3383279 Apr 24, 2021
edc585f
note to self: compile before pushing
JulienBernard3383279 Apr 24, 2021
4216ed1
log with floating point precision 2
JulienBernard3383279 Apr 25, 2021
31aedf0
Compensate stabilizer delay in evaluateTiming estimation
JulienBernard3383279 Apr 25, 2021
1ff2992
previousPoll wtf.
JulienBernard3383279 Apr 25, 2021
1aa5773
Fix precision 2 for kristal input usage
JulienBernard3383279 Apr 25, 2021
8423b36
Switch to KRISTAL logs
JulienBernard3383279 Apr 25, 2021
a11e710
log message improvement
JulienBernard3383279 Apr 25, 2021
9ff1c00
INFO_LOG the X tests & fix one SLIPPI_ONLINE->KRISTAL log
JulienBernard3383279 Apr 25, 2021
9134e64
Improve logs for sending inputs
JulienBernard3383279 Apr 25, 2021
f9e542d
improve logging
JulienBernard3383279 Apr 25, 2021
68632f2
Exception handling disabled: guess I'll crash ?
JulienBernard3383279 Apr 25, 2021
a403f6a
add #include <mutex> to attempt to fix linux compilation
JulienBernard3383279 Apr 25, 2021
c0e55a9
add #include <set> to attempt to fix macOS compilation
JulienBernard3383279 Apr 25, 2021
64eabde
Fix pad comms cpp to asm side in progress
JulienBernard3383279 Apr 27, 2021
9926799
whoops.
JulienBernard3383279 Apr 27, 2021
cc2aabc
use a custom pad format conversion function (my sanity is shrinking)
JulienBernard3383279 Apr 27, 2021
de7f92e
fix triggers in kristal pad
JulienBernard3383279 Apr 29, 2021
c1193b7
persist last adapter chan used in kristal callback
JulienBernard3383279 Apr 29, 2021
728ebc9
don't trigger subframe input on light shield update (until we handle …
JulienBernard3383279 Apr 30, 2021
1acfde7
use analog trigger values from latest known slippi input in subframe …
JulienBernard3383279 Apr 30, 2021
8fb1af2
Don't log the useless last 4 bytes of slippi pads
JulienBernard3383279 May 1, 2021
75b2f9d
Clear on release + Input read/write logs
JulienBernard3383279 May 11, 2021
7327cf7
Fix pad_mutex desync ?
JulienBernard3383279 May 17, 2021
7714192
more efficient fix to this desync
JulienBernard3383279 May 18, 2021
21de937
Merge 2.3.1 + small cleaning
JulienBernard3383279 May 21, 2021
b49c60f
update codeset with kristal + slippi v2.3.1
JulienBernard3383279 May 21, 2021
51f7df5
update codeset to hide unranked
JulienBernard3383279 May 21, 2021
1b0fff3
update codeset to restore correct prediction optimization
JulienBernard3383279 May 21, 2021
daaa159
update codeset to uncomment INPUTS_MATCH
JulienBernard3383279 May 22, 2021
c2344da
Disable bReduceTimingDispersion checkbox and set to default true
JulienBernard3383279 May 22, 2021
be85130
Perceive pad origins and adjust kristal pad values
JulienBernard3383279 May 23, 2021
9baeb16
Stop using the last Slippi pad data for triggers instead of the Krist…
JulienBernard3383279 May 23, 2021
166143c
Restore slight trigger press -> Kristal input
JulienBernard3383279 May 23, 2021
0159a35
Test +31 ???
JulienBernard3383279 May 23, 2021
1777835
Test +31 bis
JulienBernard3383279 May 23, 2021
d39a09a
Fix origin initialization and trigger light press kristal perception
JulienBernard3383279 May 24, 2021
16b9acb
Big rollback RE annotations cleaning
JulienBernard3383279 May 24, 2021
85f1360
X input debug logs removed
JulienBernard3383279 May 24, 2021
5b07226
Kristal input judge comment cleaning
JulienBernard3383279 May 24, 2021
7d487bc
Add triggers for: shield release, tap jump from dash, shield drop
JulienBernard3383279 Jun 9, 2021
8395f69
Block crossplay
JulienBernard3383279 Jun 22, 2021
1da00cd
send localKristalVersion and minimumRequiredKristalVersion
JulienBernard3383279 Jun 22, 2021
d392dd5
fix crossplay blocking code
JulienBernard3383279 Jun 22, 2021
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
temp fix to incrementsSinceOrigin increment when reading WTF was I th…
…inking
  • Loading branch information
JulienBernard3383279 committed Apr 24, 2021
commit 0819821ae123e9c8b2628e58ad98c16afc0c551f
6 changes: 3 additions & 3 deletions Source/Core/InputCommon/InputStabilizer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ void InputStabilizer::feedPollTiming(std::chrono::high_resolution_clock::time_po
}
}

time_point InputStabilizer::computeNextPollTimingInternal(bool init)
time_point InputStabilizer::computeNextPollTimingInternal(bool init, bool alter) //TODO Why the fuck is there a state change in the read method what was I thinking
{
const SConfig& sconfig = SConfig::GetInstance();
double period = (int64_t)1'000'000'000 / (sconfig.bUse5994HzStabilization ? 59.94 : 60.);
Expand All @@ -149,7 +149,7 @@ time_point InputStabilizer::computeNextPollTimingInternal(bool init)
if ((!init) && (size == sizeLimit))
{
auto result = steadyStateOrigin + std::chrono::nanoseconds((int64_t)(incrementsSinceOrigin * period - delay));
incrementsSinceOrigin++;
if (alter) incrementsSinceOrigin++;
return result;
}
}
Expand All @@ -163,7 +163,7 @@ time_point InputStabilizer::computeNextPollTimingInternal(bool init)
time_point InputStabilizer::computeNextPollTiming()
{
std::lock_guard<std::mutex> lock(mutex);
return computeNextPollTimingInternal(false);
return computeNextPollTimingInternal(false, false);
}

void InputStabilizer::startFrameCount(int32_t initialValue)
Expand Down
2 changes: 1 addition & 1 deletion Source/Core/InputCommon/InputStabilizer.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ class InputStabilizer
time_point computeNextPollTiming();

// Kristal
time_point computeNextPollTimingInternal(bool init = false);
time_point computeNextPollTimingInternal(bool init = false, bool alter = true);
void startFrameCount(int32_t initialValue=0);
void endFrameCount();
void decrementFrameCount();
Expand Down