dma-fence: Store the timestamp in the same union as the cb_list
The timestamp and the cb_list are mutually exclusive, the cb_list can only be added to prior to being signaled (and once signaled we drain), while the timestamp is only valid upon being signaled. Both the timestamp and the cb_list are only valid while the fence is alive, and as soon as no references are held can be replaced by the rcu_head. By reusing the union for the timestamp, we squeeze the base dma_fence struct to 64 bytes on x86-64. v2: Sort the union chronologically Suggested-by:Christian König <christian.koenig@amd.com> Signed-off-by:
Chris Wilson <chris@chris-wilson.co.uk> Cc: Christian König <christian.koenig@amd.com> Acked-by:
Christian König <christian.koenig@amd.com>.> Link: https://patchwork.freedesktop.org/patch/msgid/20190817153022.5749-1-chris@chris-wilson.co.uk
Showing
- drivers/dma-buf/dma-fence.c 9 additions, 7 deletionsdrivers/dma-buf/dma-fence.c
- drivers/gpu/drm/i915/gt/intel_breadcrumbs.c 7 additions, 6 deletionsdrivers/gpu/drm/i915/gt/intel_breadcrumbs.c
- drivers/gpu/drm/vmwgfx/vmwgfx_fence.c 3 additions, 0 deletionsdrivers/gpu/drm/vmwgfx/vmwgfx_fence.c
- include/linux/dma-fence.h 19 additions, 5 deletionsinclude/linux/dma-fence.h
Please register or sign in to comment