mirror of
				https://github.com/gnif/LookingGlass.git
				synced 2025-10-25 00:38:09 +00:00 
			
		
		
		
	[client] put back the fps correction from drift/skew
This commit is contained in:
		| @@ -148,10 +148,36 @@ static int renderThread(void * unused) | |||||||
|   /* signal to other threads that the renderer is ready */ |   /* signal to other threads that the renderer is ready */ | ||||||
|   lgSignalEvent(e_startup); |   lgSignalEvent(e_startup); | ||||||
|  |  | ||||||
|  |   int resyncCheck = 0; | ||||||
|   struct timespec time; |   struct timespec time; | ||||||
|  |   clock_gettime(CLOCK_REALTIME, &time); | ||||||
|  |  | ||||||
|   while(state.running) |   while(state.running) | ||||||
|   { |   { | ||||||
|  |     // if our clock is too far out of sync, resync it | ||||||
|  |     // this can happen when switching to/from a TTY, or due to clock drift | ||||||
|  |     // we only check this once every 100 frames | ||||||
|  |     if (state.frameTime > 0 && ++resyncCheck == 100) | ||||||
|  |     { | ||||||
|  |       resyncCheck = 0; | ||||||
|  |  | ||||||
|  |       struct timespec tmp; | ||||||
|  |       clock_gettime(CLOCK_REALTIME, &tmp); | ||||||
|  |       if (tmp.tv_nsec - time.tv_nsec < 0) | ||||||
|  |       { | ||||||
|  |         tmp.tv_sec -= time.tv_sec - 1; | ||||||
|  |         tmp.tv_nsec = 1000000000 + tmp.tv_nsec - time.tv_nsec; | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         tmp.tv_sec  -= time.tv_sec; | ||||||
|  |         tmp.tv_nsec -= time.tv_nsec; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       if (tmp.tv_sec > 1) | ||||||
|  |         clock_gettime(CLOCK_REALTIME, &time); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (state.lgrResize) |     if (state.lgrResize) | ||||||
|     { |     { | ||||||
|       if (state.lgr) |       if (state.lgr) | ||||||
| @@ -193,7 +219,6 @@ static int renderThread(void * unused) | |||||||
|  |  | ||||||
|     if (state.frameTime > 0) |     if (state.frameTime > 0) | ||||||
|     { |     { | ||||||
|       clock_gettime(CLOCK_REALTIME, &time); |  | ||||||
|       uint64_t nsec = time.tv_nsec + state.frameTime; |       uint64_t nsec = time.tv_nsec + state.frameTime; | ||||||
|       if(nsec > 1e9) |       if(nsec > 1e9) | ||||||
|       { |       { | ||||||
| @@ -1300,20 +1325,9 @@ static int lg_run() | |||||||
|   // ensure renderer viewport is aware of the current window size |   // ensure renderer viewport is aware of the current window size | ||||||
|   updatePositionInfo(); |   updatePositionInfo(); | ||||||
|  |  | ||||||
|   //Auto detect active monitor refresh rate for FPS Limit if no FPS Limit was passed. |   // use a default of 60FPS now that frame updates are host update triggered | ||||||
|   if (params.fpsMin == -1) |   if (params.fpsMin == -1) | ||||||
|   { |     state.frameTime = 1e9 / 60; | ||||||
|       SDL_DisplayMode current; |  | ||||||
|       if (SDL_GetCurrentDisplayMode(SDL_GetWindowDisplayIndex(state.window), ¤t) == 0) |  | ||||||
|       { |  | ||||||
|           state.frameTime = 1e9 / current.refresh_rate; |  | ||||||
|       } |  | ||||||
|       else |  | ||||||
|       { |  | ||||||
|           DEBUG_WARN("Unable to capture monitor refresh rate using the default FPS minimum of 60"); |  | ||||||
|           state.frameTime = 1e9 / 60; |  | ||||||
|       } |  | ||||||
|   } |  | ||||||
|   else |   else | ||||||
|   { |   { | ||||||
|       DEBUG_INFO("Using the FPS minimum from args: %d", params.fpsMin); |       DEBUG_INFO("Using the FPS minimum from args: %d", params.fpsMin); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Geoffrey McRae
					Geoffrey McRae