dix: preparation change: make runtime exchange of filter chain safe
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
		
							parent
							
								
									1a9f9ac50f
								
							
						
					
					
						commit
						a17cb29f5a
					
				|  | @ -30,6 +30,7 @@ | ||||||
| #include <ptrveloc.h> | #include <ptrveloc.h> | ||||||
| #include <inputstr.h> | #include <inputstr.h> | ||||||
| #include <assert.h> | #include <assert.h> | ||||||
|  | #include <os.h> | ||||||
| 
 | 
 | ||||||
| /*****************************************************************************
 | /*****************************************************************************
 | ||||||
|  * Predictable pointer ballistics |  * Predictable pointer ballistics | ||||||
|  | @ -151,6 +152,8 @@ InitFilterChain(DeviceVelocityPtr s, float rdecay, float progression, int stages | ||||||
| 	ErrorF("(dix ptracc) invalid filter chain progression specified\n"); | 	ErrorF("(dix ptracc) invalid filter chain progression specified\n"); | ||||||
| 	return; | 	return; | ||||||
|     } |     } | ||||||
|  |     /* Block here to support runtime filter adjustment */ | ||||||
|  |     OsBlockSignals(); | ||||||
|     for(fn = 0; fn < MAX_VELOCITY_FILTERS; fn++){ |     for(fn = 0; fn < MAX_VELOCITY_FILTERS; fn++){ | ||||||
| 	if(fn < stages){ | 	if(fn < stages){ | ||||||
| 	    InitFilterStage(&s->filters[fn], rdecay, lutsize); | 	    InitFilterStage(&s->filters[fn], rdecay, lutsize); | ||||||
|  | @ -159,6 +162,10 @@ InitFilterChain(DeviceVelocityPtr s, float rdecay, float progression, int stages | ||||||
| 	} | 	} | ||||||
| 	rdecay /= progression; | 	rdecay /= progression; | ||||||
|     } |     } | ||||||
|  |     /* release again. Should the input loop be threaded, we also need
 | ||||||
|  |      * memory release here (in princliple). | ||||||
|  |      */ | ||||||
|  |     OsReleaseSignals(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -199,7 +206,6 @@ InitFilterStage(FilterStagePtr s, float rdecay, int lutsize) | ||||||
|     float *oldlut; |     float *oldlut; | ||||||
| 
 | 
 | ||||||
|     s->fading_lut_size  = 0; /* prevent access */ |     s->fading_lut_size  = 0; /* prevent access */ | ||||||
|     /* mb(); concurrency issues may arise */ |  | ||||||
| 
 | 
 | ||||||
|     if(lutsize > 0){ |     if(lutsize > 0){ | ||||||
|         newlut = xalloc (sizeof(float)* lutsize); |         newlut = xalloc (sizeof(float)* lutsize); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue