G-SYNC 101: In-game vs. External FPS Limiters


Closer to the Source*

*As of NVIDIA driver version 441.87, NVIDIA has made an official framerate limiting method available in the NVCP/App; labeled “Max Frame Rate,” which is a CPU-level FPS limiter, and as such, is comparable to the RTSS framerate limiter in both frametime performance and added delay. The NVIDIA framerate limiting solutions tested below are legacy, and their results do not apply to the “Max Frame Rate” limiter.

Up until this point, an in-game framerate limiter has been used exclusively to test FPS-limited scenarios. However, in-game framerate limiters aren’t available in every game, and while they aren’t required for games where the framerate can’t meet or exceed the maximum refresh rate, if the system can sustain the framerate above the refresh rate, and a said option isn’t present, an external framerate limiter must be used to prevent V-SYNC-level input lag instead.

In-game framerate limiters, being at the game’s engine-level, are almost always free of additional latency, as they can regulate frames at the source. External framerate limiters, on the other hand, must intercept frames further down the rendering chain, which can result in delayed frame delivery and additional input latency; how much depends on the limiter and its implementation.

RTSS is a CPU-level FPS limiter, which is the closest an external method can get to the engine-level of an in-game limiter. In my initial input lag tests on my original thread, RTSS appeared to introduce no additional delay when used with G-SYNC. However, it was later discovered disabling CS:GO’s “Multicore Rendering” setting, which runs the game on a single CPU-core, caused the discrepancy, and once enabled, RTSS introduced the expected 1 frame of delay.

Seeing as the CS:GO still uses DX9, and is a native single-core performer, I opted to test the more modern “Overwatch” this time around, which uses DX11, and features native multi-threaded/multi-core support. Will RTSS behave the same way in a native multi-core game?

Blur Buster's G-SYNC 101: Input Latency & Optimal Settings
Blur Buster's G-SYNC 101: Input Latency & Optimal Settings
Blur Buster's G-SYNC 101: Input Latency & Optimal Settings

Yes, RTSS still introduces up to 1 frame of delay, regardless of the syncing method, or lack thereof, used. To prove that a -2 FPS limit was enough to avoid the G-SYNC ceiling, a -10 FPS limit was tested with no improvement. The V-SYNC scenario also shows RTSS delay stacks with other types of delay, retaining the FPS-limited V-SYNC’s 1/2 to 1 frame of accumulative delay.

Next up is NVIDIA’s FPS limiter, which can be accessed via the third-party “NVIDIA Profile Inspector.” Unlike RTSS, it is a driver-level limiter, one further step removed from engine-level. My original tests showed the NVIDIA limiter introduced 2 frames of delay across V-SYNC OFF, V-SYNC, and G-SYNC scenarios.

Blur Buster's G-SYNC 101: Input Latency & Optimal Settings
Blur Buster's G-SYNC 101: Input Latency & Optimal Settings
Blur Buster's G-SYNC 101: Input Latency & Optimal Settings

Yet again, the results for V-SYNC and V-SYNC OFF (“Use the 3D application setting” + in-game V-SYNC disabled) show standard, out-of-the-box usage of both NVIDIA’s v1 and v2 FPS limiter introduce the expected 2 frames of delay. The limiter’s impact on G-SYNC appears to be particularly unforgiving, with a 2 to 3 1/2 frame delay due to an increase in maximums at -2 FPS compared to -10 FPS, meaning -2 FPS with this limiter may not be enough to keep it below the G-SYNC ceiling at all times, and it might be worsened by the NVIDIA limiter’s own frame pacing behavior’s effect on G-SYNC functionality.

Needless to say, even if an in-game framerate limiter isn’t available, RTSS only introduces up to 1 frame of delay, which is still preferable to the 2+ frame delay added by NVIDIA’s limiter with G-SYNC enabled, and a far superior alternative to the 2-6 frame delay added by uncapped G-SYNC.



3838 Comments For “G-SYNC 101”

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Sort by:   newest | oldest | most liked
ksydew
Member
ksydew

With the newest drivers nvidia has now gotten rid of the nvidia control panel. Does this change anything for how to implement g sync? Has it changed any behavior to your knowledge? I keep g sync on, v sync on and use a frame rate limiter of RTSS. I also use v sync globally. I just had to use DDU due to sudden instability after installing the newest drivers and that’s when I found out nvcp was missing.

Flop
Member
Flop

What’s the best way to go about using both technologies? My main game is CS2, where i use Fixed Refresh. I want to use G-SYNC in pretty much every other game though. It seems that in order to do this, i have to enable G-SYNC in the global settings, then set CS2 to Fixed Refresh in Program settings. I would rather do this the other way around though (though it doesn’t work) since I play CS2 most of the time, and the long alt-tab times are annoying (unless there is a way to fix them) due to the game not using G-SYNC, while the rest of the operating system operates with G-SYNC.

tearxinnuan
Member
tearxinnuan

I have a new question. I have two monitors, both of which support G-SYNC. However, I only use one screen for full-screen gaming, while the other is used for watching videos and browsing the web in extended screen mode. I’d like to ask if both monitors need to have G-SYNC enabled simultaneously? Their refresh rates are also different. I only want the primary gaming screen to perform at its best, so will the setup for both monitors be relevant? Looking forward to your answer.

jPqQhMkV1b2fwm27ri07e0cZs64e42aLXE4w0cUiOlUl7kIwid
Member
jPqQhMkV1b2fwm27ri07e0cZs64e42aLXE4w0cUiOlUl7kIwid

Can I run Maxwell-era (GTX 970) GPUs in SLI mode with native GSYNC? I have read conflicting/contradicting reports. Some of them mention performance drop in SLI + GSYNC mode. I have even found an opinion that GSYNC does not work properly with SLI due to the fact that GSYNC wasn’t designed with SLI in mind. Do you have any knowledge in this regard?

2ndHouse
Member
2ndHouse

Just making sure I got this right…

Setting “Preferred refresh rate” to “Highest available” globally is not needed as it will automatically kick in while G-SYNC is on?

I recently performed a driver reset and can’t remember if I had that setting on globally or not before, and not 100% sure what to set it to. I don’t see it mentioned on the Optimal G-SYNC settings page, so I’m thinking it might be best to just leave it at driver default?

wpDiscuz