| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 module mus.mojom; | 5 module mus.mojom; |
| 6 | 6 |
| 7 import "cc/ipc/returned_resource.mojom"; | 7 import "cc/ipc/returned_resource.mojom"; |
| 8 import "cc/ipc/transferable_resource.mojom"; |
| 8 import "components/mus/public/interfaces/quads.mojom"; | 9 import "components/mus/public/interfaces/quads.mojom"; |
| 9 import "ui/gfx/geometry/mojo/geometry.mojom"; | 10 import "ui/gfx/geometry/mojo/geometry.mojom"; |
| 10 import "gpu/ipc/common/mailbox_holder.mojom"; | 11 import "gpu/ipc/common/mailbox_holder.mojom"; |
| 11 import "gpu/ipc/common/sync_token.mojom"; | 12 import "gpu/ipc/common/sync_token.mojom"; |
| 12 | 13 |
| 13 enum ResourceFormat { | |
| 14 RGBA_8888, | |
| 15 RGBA_4444, | |
| 16 BGRA_8888, | |
| 17 ALPHA_8, | |
| 18 LUMINANCE_8, | |
| 19 RGB_565, | |
| 20 ETC1, | |
| 21 }; | |
| 22 | |
| 23 // A TransferableResource is a graphics resource such as a texture or a bitmap | |
| 24 // in shared memory (software mode) that is shared between the window server and | |
| 25 // a client. This data structure is used to manage reuse of | |
| 26 // the memory once it is no longer needed by the window server and GPU service. | |
| 27 struct TransferableResource { | |
| 28 // |id| is an integer that uniquely identifies this resource in the client so | |
| 29 // that the window server can return this resource back to the client. | |
| 30 uint32 id; | |
| 31 ResourceFormat format; | |
| 32 uint32 filter; | |
| 33 mojo.Size size; | |
| 34 gpu.mojom.MailboxHolder mailbox_holder; | |
| 35 bool read_lock_fences_enabled; | |
| 36 bool is_software; | |
| 37 bool is_overlay_candidate; | |
| 38 }; | |
| 39 | |
| 40 // See cc/output/compositor_frame_metadata.h. | 14 // See cc/output/compositor_frame_metadata.h. |
| 41 struct CompositorFrameMetadata { | 15 struct CompositorFrameMetadata { |
| 42 float device_scale_factor; | 16 float device_scale_factor; |
| 43 }; | 17 }; |
| 44 | 18 |
| 45 // See src/cc/output/compositor_frame.h. | 19 // See src/cc/output/compositor_frame.h. |
| 46 struct CompositorFrame { | 20 struct CompositorFrame { |
| 47 CompositorFrameMetadata metadata; | 21 CompositorFrameMetadata metadata; |
| 48 array<TransferableResource> resources; | 22 array<cc.mojom.TransferableResource> resources; |
| 49 array<Pass> passes; | 23 array<Pass> passes; |
| 50 }; | 24 }; |
| 51 | 25 |
| 52 // A Surface is an interface for receiving CompositorFrame structs. This is a | 26 // A Surface is an interface for receiving CompositorFrame structs. This is a |
| 53 // separate interface to allow CompositorFrames to be delivered from | 27 // separate interface to allow CompositorFrames to be delivered from |
| 54 // supplementary (not main) threads of a mojo app. | 28 // supplementary (not main) threads of a mojo app. |
| 55 interface Surface { | 29 interface Surface { |
| 56 // After the submitted frame is drawn for the first time, the receiver will | 30 // After the submitted frame is drawn for the first time, the receiver will |
| 57 // respond to the SubmitFrame message. Clients should use this acknowledgement | 31 // respond to the SubmitFrame message. Clients should use this acknowledgement |
| 58 // to ratelimit frame submissions. | 32 // to ratelimit frame submissions. |
| 59 SubmitCompositorFrame(CompositorFrame frame) => (); | 33 SubmitCompositorFrame(CompositorFrame frame) => (); |
| 60 }; | 34 }; |
| 61 | 35 |
| 62 interface SurfaceClient { | 36 interface SurfaceClient { |
| 63 ReturnResources(array<cc.mojom.ReturnedResource> resources); | 37 ReturnResources(array<cc.mojom.ReturnedResource> resources); |
| 64 }; | 38 }; |
| OLD | NEW |