forked from mirrors/gecko-dev
		
	Bug 1881076 - Ref snapshot shmem. r=aosmond
Differential Revision: https://phabricator.services.mozilla.com/D205404
This commit is contained in:
		
							parent
							
								
									4b0b6bbd2c
								
							
						
					
					
						commit
						36b74f7869
					
				
					 1 changed files with 12 additions and 8 deletions
				
			
		|  | @ -511,6 +511,10 @@ already_AddRefed<gfx::DataSourceSurface> CanvasChild::GetDataSurface( | |||
|     return nullptr; | ||||
|   } | ||||
| 
 | ||||
|   gfx::IntSize ssSize = aSurface->GetSize(); | ||||
|   gfx::SurfaceFormat ssFormat = aSurface->GetFormat(); | ||||
|   auto stride = ImageDataSerializer::ComputeRGBStride(ssFormat, ssSize.width); | ||||
| 
 | ||||
|   // Shmem is only valid if the surface is the latest snapshot (not detached).
 | ||||
|   if (!aDetached) { | ||||
|     // If there is a shmem associated with this snapshot id, then we want to try
 | ||||
|  | @ -525,12 +529,15 @@ already_AddRefed<gfx::DataSourceSurface> CanvasChild::GetDataSurface( | |||
|       if (NS_WARN_IF(!mRecorder->WaitForCheckpoint(checkpoint))) { | ||||
|         return nullptr; | ||||
|       } | ||||
|       gfx::IntSize size = aSurface->GetSize(); | ||||
|       gfx::SurfaceFormat format = aSurface->GetFormat(); | ||||
|       auto stride = ImageDataSerializer::ComputeRGBStride(format, size.width); | ||||
|       auto* closure = new CanvasDataShmemHolder(mDataSurfaceShmem, this); | ||||
|       if (NS_WARN_IF(!closure->Init(mWorkerRef))) { | ||||
|         delete closure; | ||||
|         return nullptr; | ||||
|       } | ||||
|       RefPtr<gfx::DataSourceSurface> dataSurface = | ||||
|           gfx::Factory::CreateWrappingDataSourceSurface(shmemPtr, stride, size, | ||||
|                                                         format); | ||||
|           gfx::Factory::CreateWrappingDataSourceSurface( | ||||
|               shmemPtr, stride, ssSize, ssFormat, ReleaseDataShmemHolder, | ||||
|               closure); | ||||
|       aMayInvalidate = true; | ||||
|       return dataSurface.forget(); | ||||
|     } | ||||
|  | @ -538,8 +545,6 @@ already_AddRefed<gfx::DataSourceSurface> CanvasChild::GetDataSurface( | |||
| 
 | ||||
|   RecordEvent(RecordedPrepareDataForSurface(aSurface)); | ||||
| 
 | ||||
|   gfx::IntSize ssSize = aSurface->GetSize(); | ||||
|   gfx::SurfaceFormat ssFormat = aSurface->GetFormat(); | ||||
|   if (!EnsureDataSurfaceShmem(ssSize, ssFormat)) { | ||||
|     return nullptr; | ||||
|   } | ||||
|  | @ -559,7 +564,6 @@ already_AddRefed<gfx::DataSourceSurface> CanvasChild::GetDataSurface( | |||
|   mDataSurfaceShmemAvailable = false; | ||||
| 
 | ||||
|   auto* data = static_cast<uint8_t*>(mDataSurfaceShmem->memory()); | ||||
|   auto stride = ImageDataSerializer::ComputeRGBStride(ssFormat, ssSize.width); | ||||
| 
 | ||||
|   RefPtr<gfx::DataSourceSurface> dataSurface = | ||||
|       gfx::Factory::CreateWrappingDataSourceSurface( | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Lee Salzman
						Lee Salzman