-
Notifications
You must be signed in to change notification settings - Fork 92
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
Timing detection #12
Comments
I've actually noticed this as well in my own tests recently. I'm not sure what I've changed, but it's failing to pass pafish and my own detection suite most of the time. I'll look into it. |
BTW, was this test done with the latest commit? It would probably be a good idea to remove the logging since that adds some overhead. |
It was done with the latest commit since it fixed all of my bsod issues. I'm using overhead + constant right now. I will remove the logging as well and will share if I find anything related to the cause of the issue, thanks for the reply. |
This is super weird... I'm testing using the following code and getting strange results: int info[4];
while (true) {
auto const start = __rdtsc();
__cpuidex(info, 0, 0);
auto const end = __rdtsc();
printf("%i\n", end - start);
Sleep(500);
} For some reason, the first print is ALWAYS around ~300tsc (which is what it should be) but then everything AFTER that hovers around 4-5k. Not sure why this is happening... |
If you are curious, my semi-consistent pafish output is only: they occur roughly 50 50 |
@AIVDNL Thank you. I'm working on a new solution which I think should fix all the issues, but I'm having a bit of trouble with the actual implementation details... The big issue is that context switches are way more likely to occur when virtualized vs on bare-metal, simply because it takes more time to execute. I'm experimenting with a per-process timer structure, as mentioned by Daax in some unknowncheats post, which should hopefully fix all these issues. |
When I ran pafish while my physical computer was virtualized(manually mapped the hv), I realized there was a timing detection via rdtsc + cpuid + rdtsc. I ran my own tests and it seems like tsc offseting doesn't work as well as intended. I am on Windows 10 22h2, i7-6700k cpu. Screenshots below show the overhead measurement by the driver, and on the console window each line represents the average time between 10 rdtsc + cpuid + rdtsc measurements. Average times before the red line is my system not virtualized and after the red line the system is virtualized.
The text was updated successfully, but these errors were encountered: