rsesek | 5c7c3e9 | 2016-01-05 03:37:11 | [diff] [blame] | 1 | // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #ifndef UI_GFX_MAC_IO_SURFACE_H_ |
| 6 | #define UI_GFX_MAC_IO_SURFACE_H_ |
| 7 | |
| 8 | #include <IOSurface/IOSurface.h> |
| 9 | #include <mach/mach.h> |
| 10 | |
| 11 | #include "base/mac/scoped_cftyperef.h" |
| 12 | #include "ui/gfx/buffer_types.h" |
Sunny Sachanandani | 88353d2 | 2017-10-26 01:52:24 | [diff] [blame] | 13 | #include "ui/gfx/color_space.h" |
rsesek | 5c7c3e9 | 2016-01-05 03:37:11 | [diff] [blame] | 14 | #include "ui/gfx/generic_shared_memory_id.h" |
| 15 | #include "ui/gfx/geometry/size.h" |
| 16 | #include "ui/gfx/gfx_export.h" |
| 17 | |
| 18 | namespace gfx { |
| 19 | |
| 20 | namespace internal { |
| 21 | |
| 22 | struct IOSurfaceMachPortTraits { |
| 23 | GFX_EXPORT static mach_port_t InvalidValue() { return MACH_PORT_NULL; } |
| 24 | GFX_EXPORT static mach_port_t Retain(mach_port_t); |
| 25 | GFX_EXPORT static void Release(mach_port_t); |
| 26 | }; |
| 27 | |
ccameron | 69a2dae | 2016-03-28 03:23:45 | [diff] [blame] | 28 | struct ScopedInUseIOSurfaceTraits { |
| 29 | static IOSurfaceRef InvalidValue() { return nullptr; } |
| 30 | static IOSurfaceRef Retain(IOSurfaceRef io_surface) { |
| 31 | CFRetain(io_surface); |
| 32 | IOSurfaceIncrementUseCount(io_surface); |
| 33 | return io_surface; |
| 34 | } |
| 35 | static void Release(IOSurfaceRef io_surface) { |
| 36 | IOSurfaceDecrementUseCount(io_surface); |
| 37 | CFRelease(io_surface); |
| 38 | } |
| 39 | }; |
| 40 | |
rsesek | 5c7c3e9 | 2016-01-05 03:37:11 | [diff] [blame] | 41 | } // namespace internal |
| 42 | |
| 43 | using IOSurfaceId = GenericSharedMemoryId; |
| 44 | |
| 45 | // Helper function to create an IOSurface with a specified size and format. |
Sunny Sachanandani | ea6e12b | 2017-12-07 03:04:36 | [diff] [blame] | 46 | // The surface is zero-initialized if |should_clear| is true. This is not |
| 47 | // necessary for anonymous surfaces that are not exported to renderers and used |
| 48 | // as render targets only. |
| 49 | GFX_EXPORT IOSurfaceRef CreateIOSurface(const Size& size, |
| 50 | BufferFormat format, |
| 51 | bool should_clear = true); |
rsesek | 5c7c3e9 | 2016-01-05 03:37:11 | [diff] [blame] | 52 | |
| 53 | // A scoper for handling Mach port names that are send rights for IOSurfaces. |
| 54 | // This scoper is both copyable and assignable, which will increase the kernel |
| 55 | // reference count of the right. On destruction, the reference count is |
| 56 | // decremented. |
| 57 | using ScopedRefCountedIOSurfaceMachPort = |
| 58 | base::ScopedTypeRef<mach_port_t, internal::IOSurfaceMachPortTraits>; |
| 59 | |
ccameron | 69a2dae | 2016-03-28 03:23:45 | [diff] [blame] | 60 | // A scoper for holding a reference to an IOSurface and also incrementing its |
| 61 | // in-use counter while the scoper exists. |
| 62 | using ScopedInUseIOSurface = |
| 63 | base::ScopedTypeRef<IOSurfaceRef, internal::ScopedInUseIOSurfaceTraits>; |
| 64 | |
Christopher Cameron | 111548d | 2019-10-17 22:09:57 | [diff] [blame] | 65 | // Return true if there exists a value for IOSurfaceColorSpace or |
| 66 | // IOSurfaceICCProfile that will make CoreAnimation render using |color_space|. |
| 67 | GFX_EXPORT bool IOSurfaceCanSetColorSpace(const gfx::ColorSpace& color_space); |
| 68 | |
| 69 | // Set color space for given IOSurface. IOSurfaceCanSetColorSpace must return |
| 70 | // true for |color_space| otherwise this does nothing. |
Sunny Sachanandani | 88353d2 | 2017-10-26 01:52:24 | [diff] [blame] | 71 | GFX_EXPORT void IOSurfaceSetColorSpace(IOSurfaceRef io_surface, |
| 72 | const gfx::ColorSpace& color_space); |
| 73 | |
Christopher Cameron | 85e4544c | 2020-09-08 23:01:27 | [diff] [blame] | 74 | // Return the expected four character code pixel format for an IOSurface with |
| 75 | // the specified gfx::BufferFormat. |
| 76 | GFX_EXPORT uint32_t |
| 77 | BufferFormatToIOSurfacePixelFormat(gfx::BufferFormat format); |
| 78 | |
Markus Handell | 1f3c85d | 2020-09-22 19:17:55 | [diff] [blame] | 79 | // Return an IOSurface consuming |io_surface_mach_port|. |
| 80 | GFX_EXPORT base::ScopedCFTypeRef<IOSurfaceRef> IOSurfaceMachPortToIOSurface( |
| 81 | ScopedRefCountedIOSurfaceMachPort io_surface_mach_port); |
| 82 | |
rsesek | 5c7c3e9 | 2016-01-05 03:37:11 | [diff] [blame] | 83 | } // namespace gfx |
| 84 | |
| 85 | #endif // UI_GFX_MAC_IO_SURFACE_H_ |