15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Multiply-included message file, hence no include guard here, but see below
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// for a much smaller-than-usual include guard section.
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <string>
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <vector>
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
117dbb3d5cf0c15f500944d211057644d6a2f37371Ben Murdoch#include "base/memory/shared_memory.h"
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/common/content_export.h"
132a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "content/common/gpu/gpu_memory_uma_stats.h"
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/common/gpu/gpu_process_launch_causes.h"
15116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include "content/common/gpu/gpu_result_codes.h"
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/common/common_param_traits.h"
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/common/gpu_memory_stats.h"
18a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)#include "gpu/command_buffer/common/capabilities.h"
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "gpu/command_buffer/common/command_buffer.h"
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "gpu/command_buffer/common/constants.h"
211e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)#include "gpu/command_buffer/common/gpu_memory_allocation.h"
22868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "gpu/command_buffer/common/mailbox.h"
2390dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)#include "gpu/config/gpu_info.h"
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "gpu/ipc/gpu_command_buffer_traits.h"
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ipc/ipc_channel_handle.h"
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ipc/ipc_message_macros.h"
273551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)#include "media/base/video_frame.h"
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "media/video/video_decode_accelerator.h"
293551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)#include "media/video/video_encode_accelerator.h"
3068043e1e95eeb07d5cae7aca370b26518b0867d6Torne (Richard Coles)#include "ui/events/latency_info.h"
311e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)#include "ui/gfx/gpu_memory_buffer.h"
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/gfx/native_widget_types.h"
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/gfx/size.h"
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/gl/gpu_preference.h"
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(OS_ANDROID)
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/common/android/surface_texture_peer.h"
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
405d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)#undef IPC_MESSAGE_EXPORT
415d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)#define IPC_MESSAGE_EXPORT CONTENT_EXPORT
425d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#define IPC_MESSAGE_START GpuMsgStart
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
455d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(content::CauseForGpuLaunch,
465d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          content::CAUSE_FOR_GPU_LAUNCH_MAX_ENUM - 1)
47116680a4aac90f2aa7413d9095a592090648e557Ben MurdochIPC_ENUM_TRAITS_MAX_VALUE(content::CreateCommandBufferResult,
48116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                          content::CREATE_COMMAND_BUFFER_RESULT_LAST)
495d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(gfx::GpuPreference,
505d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          gfx::GpuPreferenceLast)
515d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(gfx::SurfaceType,
525d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          gfx::SURFACE_TYPE_LAST)
535d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(gpu::MemoryAllocation::PriorityCutoff,
545d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          gpu::MemoryAllocation::CUTOFF_LAST)
555d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(gpu::error::ContextLostReason,
565d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          gpu::error::kContextLostReasonLast)
575d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(media::VideoEncodeAccelerator::Error,
585d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                          media::VideoEncodeAccelerator::kErrorMax)
595d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MAX_VALUE(media::VideoFrame::Format,
60a1401311d1ab56c4ed0a474bd38c108f75cb0cd9Torne (Richard Coles)                          media::VideoFrame::FORMAT_MAX)
615d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::VideoCodecProfile,
625d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                              media::VIDEO_CODEC_PROFILE_MIN,
635d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                              media::VIDEO_CODEC_PROFILE_MAX)
641320f92c476a1ad9d19dba2a48c72b75566198e9Primiano TucciIPC_ENUM_TRAITS_MIN_MAX_VALUE(gpu::CollectInfoResult,
651320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci                              gpu::kCollectInfoNone,
661320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci                              gpu::kCollectInfoFatalFailure)
675d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GPUCreateCommandBufferConfig)
695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, share_group_id)
705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(std::vector<int>, attribs)
715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(GURL, active_url)
725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(gfx::GpuPreference, gpu_preference)
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params)
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, surface_id)
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(uint64, surface_handle)
785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, route_id)
795d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)  IPC_STRUCT_MEMBER(gpu::Mailbox, mailbox)
805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(gfx::Size, size)
8190dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  IPC_STRUCT_MEMBER(float, scale_factor)
825d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)  IPC_STRUCT_MEMBER(std::vector<ui::LatencyInfo>, latency_info)
835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GpuHostMsg_AcceleratedSurfacePostSubBuffer_Params)
865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, surface_id)
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(uint64, surface_handle)
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, route_id)
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int, x)
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int, y)
915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int, width)
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int, height)
935d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)  IPC_STRUCT_MEMBER(gpu::Mailbox, mailbox)
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(gfx::Size, surface_size)
9590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  IPC_STRUCT_MEMBER(float, surface_scale_factor)
965d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)  IPC_STRUCT_MEMBER(std::vector<ui::LatencyInfo>, latency_info)
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GpuHostMsg_AcceleratedSurfaceRelease_Params)
1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, surface_id)
1012a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_STRUCT_END()
1022a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
1032a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_STRUCT_BEGIN(AcceleratedSurfaceMsg_BufferPresented_Params)
1045d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)  IPC_STRUCT_MEMBER(gpu::Mailbox, mailbox)
1052a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_MEMBER(uint32, sync_point)
1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(OS_MACOSX)
1072a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_MEMBER(int32, renderer_id)
1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif
109d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles)#if defined(OS_WIN)
110d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles)  IPC_STRUCT_MEMBER(base::TimeTicks, vsync_timebase)
111d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles)  IPC_STRUCT_MEMBER(base::TimeDelta, vsync_interval)
112d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles)#endif
1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GPUCommandBufferConsoleMessage)
1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(int32, id)
1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(std::string, message)
1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(OS_ANDROID)
1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_BEGIN(GpuStreamTextureMsg_MatrixChanged_Params)
1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m00)
1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m01)
1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m02)
1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m03)
1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m10)
1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m11)
1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m12)
1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m13)
1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m20)
1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m21)
1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m22)
1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m23)
1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m30)
1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m31)
1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m32)
1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_MEMBER(float, m33)
1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_END()
1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif
1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
14190dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  IPC_STRUCT_TRAITS_BEGIN(gpu::DxDiagNode)
1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(values)
1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(children)
1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
14690dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gpu::GpuPerformanceStats)
1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(graphics)
1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gaming)
1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(overall)
1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
15290dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gpu::GPUInfo::GPUDevice)
1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(vendor_id)
1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(device_id)
155e5d81f57cb97b3b6b7fccc9c5610d21eb81db09dBen Murdoch  IPC_STRUCT_TRAITS_MEMBER(active)
1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(vendor_string)
1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(device_string)
1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1601320f92c476a1ad9d19dba2a48c72b75566198e9Primiano TucciIPC_STRUCT_TRAITS_BEGIN(media::VideoEncodeAccelerator::SupportedProfile)
1611320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(profile)
1621320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(max_resolution)
1631320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(max_framerate_numerator)
1641320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(max_framerate_denominator)
1651320f92c476a1ad9d19dba2a48c72b75566198e9Primiano TucciIPC_STRUCT_TRAITS_END()
1661320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
16790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gpu::GPUInfo)
1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(initialization_time)
1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(optimus)
1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(amd_switchable)
1712a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(lenovo_dcute)
1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gpu)
1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(secondary_gpus)
17490dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(adapter_luid)
1755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(driver_vendor)
1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(driver_version)
1775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(driver_date)
1785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(pixel_shader_version)
1795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(vertex_shader_version)
1800529e5d033099cbfc42635f6f6183833b09dff6eBen Murdoch  IPC_STRUCT_TRAITS_MEMBER(machine_model_name)
1810529e5d033099cbfc42635f6f6183833b09dff6eBen Murdoch  IPC_STRUCT_TRAITS_MEMBER(machine_model_version)
1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_version)
1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_vendor)
1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_renderer)
1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_extensions)
186868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_ws_vendor)
187868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_ws_version)
188868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_ws_extensions)
189a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(gl_reset_notification_strategy)
1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(can_lose_context)
1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(performance_stats)
1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(software_rendering)
193effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch  IPC_STRUCT_TRAITS_MEMBER(direct_rendering)
1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(sandboxed)
1955f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(process_crash_count)
1961320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(basic_info_state)
1971320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(context_info_state)
1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(OS_WIN)
1991320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(dx_diagnostics_info_state)
2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(dx_diagnostics)
2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif
2021320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(video_encode_accelerator_supported_profiles)
2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
205a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gpu::Capabilities)
206a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(post_sub_buffer)
207a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(egl_image_external)
208a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(texture_format_bgra8888)
209a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(texture_format_etc1)
2101320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci  IPC_STRUCT_TRAITS_MEMBER(texture_format_etc1_npot)
211a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(texture_rectangle)
212a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(iosurface)
213a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(texture_usage)
214a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(texture_storage)
215a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(discard_framebuffer)
216010d83a9304c5a91596085d917d248abff47903aTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(sync_query)
217a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(map_image)
218a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
219a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)
2205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(content::GPUVideoMemoryUsageStats::ProcessStats)
2215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(video_memory)
2225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(has_duplicates)
2235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
2245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(content::GPUVideoMemoryUsageStats)
2265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(process_map)
2272a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_allocated)
2282a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_allocated_historical_max)
2292a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_STRUCT_TRAITS_END()
2302a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
2312a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(content::GPUMemoryUmaStats)
2322a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_allocated_current)
2332a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_allocated_max)
2342a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_limit)
2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2371e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gpu::MemoryAllocation)
2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(bytes_limit_when_visible)
2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(priority_cutoff_when_visible)
2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_BEGIN(gfx::GLSurfaceHandle)
2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(handle)
2442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(transport_type)
2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  IPC_STRUCT_TRAITS_MEMBER(parent_client_id)
2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_STRUCT_TRAITS_END()
2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// GPU Messages
2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These are messages from the browser to the GPU process.
2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to initialize itself. The browser explicitly
2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// requests this be done so that we are guaranteed that the channel is set
2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// up between the browser and GPU process before doing any work that might
2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// potentially crash the GPU process. Detection of the child process
2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// exiting abruptly is predicated on having the IPC channel set up.
2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_Initialize)
2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to create a new channel for communication with a
2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// given client.  The channel name is returned in a
2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// GpuHostMsg_ChannelEstablished message.  The client ID is passed so that
2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// the GPU process reuses an existing channel to that process if it exists.
2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// This ID is a unique opaque identifier generated by the browser process.
264116680a4aac90f2aa7413d9095a592090648e557Ben MurdochIPC_MESSAGE_CONTROL3(GpuMsg_EstablishChannel,
2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int /* client_id */,
266116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                     bool /* share_context */,
267116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                     bool /* allow_future_sync_points */)
2685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to close the channel identified by IPC channel
2705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// handle.  If no channel can be identified, do nothing.
2715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuMsg_CloseChannel,
2725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     IPC::ChannelHandle /* channel_handle */)
2735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to create a new command buffer that renders directly
2755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// to a native view. A corresponding GpuCommandBufferStub is created.
276c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_MESSAGE_CONTROL5(GpuMsg_CreateViewCommandBuffer,
2775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     gfx::GLSurfaceHandle, /* compositing_surface */
2785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int32, /* surface_id */
2795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int32, /* client_id */
280c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                     GPUCreateCommandBufferConfig, /* init_params */
281c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                     int32 /* route_id */)
2825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
283f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// Tells the GPU process to create a new gpu memory buffer for |handle|.
284f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)IPC_MESSAGE_CONTROL4(GpuMsg_CreateGpuMemoryBuffer,
285f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     gfx::GpuMemoryBufferHandle, /* handle */
286f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     gfx::Size, /* size */
287f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     unsigned, /* internalformat */
288f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     unsigned /* usage */)
289f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
290f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// Tells the GPU process to destroy buffer.
291f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)IPC_MESSAGE_CONTROL2(GpuMsg_DestroyGpuMemoryBuffer,
292f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     gfx::GpuMemoryBufferHandle, /* handle */
293f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     int32 /* sync_point */)
294f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
2955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to create a context for collecting graphics card
2965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// information.
2975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_CollectGraphicsInfo)
2985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to report video_memory information for the task manager
3005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_GetVideoMemoryUsageStats)
3015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process that the browser process has handled the swap
3035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// buffers or post sub-buffer request. A non-zero sync point means
3042a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// that we should wait for the sync point. The surface_handle identifies
3052a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// that buffer that has finished presented, i.e. the buffer being returned.
3062a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedSurfaceMsg_BufferPresented,
3072a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    AcceleratedSurfaceMsg_BufferPresented_Params)
3085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
309f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// Tells the GPU process to wake up the GPU because we're about to draw.
310f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedSurfaceMsg_WakeUpGpu)
311f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)
3125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to remove all contexts.
3135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_Clean)
3145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to crash.
3165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_Crash)
3175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to hang.
3195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_Hang)
3205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3212a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Tells the GPU process to disable the watchdog thread.
3222a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuMsg_DisableWatchdog)
3232a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
3245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
3255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// GPU Host Messages
3265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These are messages to the browser.
3275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// A renderer sends this when it wants to create a connection to the GPU
3295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// process. The browser will create the GPU process if necessary, and will
3305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// return a handle to the channel via a GpuChannelEstablished message.
3315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_SYNC_MESSAGE_CONTROL1_3(GpuHostMsg_EstablishGpuChannel,
3325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            content::CauseForGpuLaunch,
3335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            int /* client id */,
3345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            IPC::ChannelHandle /* handle to channel */,
33590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)                            gpu::GPUInfo /* stats about GPU process*/)
3365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// A renderer sends this to the browser process when it wants to
3385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// create a GL context associated with the given view_id.
339c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_CONTROL3_1(GpuHostMsg_CreateViewCommandBuffer,
3405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            int32, /* surface_id */
3415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            GPUCreateCommandBufferConfig, /* init_params */
342c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                            int32, /* route_id */
343116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                            content::CreateCommandBufferResult /* result */)
3445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response from GPU to a GputMsg_Initialize message.
34690dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)IPC_MESSAGE_CONTROL2(GpuHostMsg_Initialized,
34790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)                     bool /* result */,
34890dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)                     ::gpu::GPUInfo /* gpu_info */)
3495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response from GPU to a GpuHostMsg_EstablishChannel message.
3515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_ChannelEstablished,
3525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     IPC::ChannelHandle /* channel_handle */)
3535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3542a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Message from GPU to notify to destroy the channel.
3552a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_DestroyChannel,
3562a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     int32 /* client_id */)
3572a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
3582a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Message to cache the given shader information.
3592a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL3(GpuHostMsg_CacheShader,
3602a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     int32 /* client_id */,
3612a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     std::string /* key */,
3622a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     std::string /* shader */)
3632a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
3642a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Message to the GPU that a shader was loaded from disk.
3652a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuMsg_LoadedShader,
3662a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     std::string /* encoded shader */)
3672a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
3685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Respond from GPU to a GpuMsg_CreateViewCommandBuffer message.
3695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_CommandBufferCreated,
370116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                     content::CreateCommandBufferResult /* result */)
3715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Request from GPU to free the browser resources associated with the
3735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// command buffer.
3745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_DestroyCommandBuffer,
3755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int32 /* surface_id */)
3765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
377f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// Response from GPU to a GpuMsg_CreateGpuMemoryBuffer message.
378f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_GpuMemoryBufferCreated,
379f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)                     gfx::GpuMemoryBufferHandle /* handle */)
380f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
3815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response from GPU to a GpuMsg_CollectGraphicsInfo.
3825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_GraphicsInfoCollected,
38390dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)                     gpu::GPUInfo /* GPU logging stats */)
3845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response from GPU to a GpuMsg_GetVideoMemory.
3865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_VideoMemoryUsageStats,
3875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     content::GPUVideoMemoryUsageStats /* GPU memory stats */)
3885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Message from GPU to add a GPU log message to the about:gpu page.
3905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL3(GpuHostMsg_OnLogMessage,
3915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int /*severity*/,
3925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     std::string /* header */,
3935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     std::string /* message */)
3945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
395f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// Tells the browser that a new accelerated surface was initialized.
396f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)IPC_MESSAGE_CONTROL2(GpuHostMsg_AcceleratedSurfaceInitialized,
397f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)                     int32 /* surface_id */,
398f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)                     int32 /* route_id */)
399f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)
400c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)// Tells the browser that a frame with the specific latency info was drawn to
401c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)// the screen
402c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_FrameDrawn,
4035d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                     std::vector<ui::LatencyInfo> /* latency_info */)
404c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)
4055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Same as above with a rect of the part of the surface that changed.
4065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_AcceleratedSurfaceBuffersSwapped,
4075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params)
4085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// This message notifies the browser process that the renderer
4105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// swapped a portion of the buffers associated with the given "window", which
4115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// should cause the browser to redraw the compositor's contents.
4125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_AcceleratedSurfacePostSubBuffer,
4135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     GpuHostMsg_AcceleratedSurfacePostSubBuffer_Params)
4145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the browser to release whatever resources are associated with
4165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// the given surface. The browser must send an ACK once this operation
4175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// is complete.
4185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_AcceleratedSurfaceRelease,
4195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     GpuHostMsg_AcceleratedSurfaceRelease_Params)
4205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the browser to release resources for the given surface until the next
4225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// time swap buffers or post sub buffer is sent.
4235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_AcceleratedSurfaceSuspend,
4245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int32 /* surface_id */)
4255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the browser about updated parameters for vsync alignment.
4275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_CONTROL3(GpuHostMsg_UpdateVSyncParameters,
4285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     int32 /* surface_id */,
4295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     base::TimeTicks /* timebase */,
4305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                     base::TimeDelta /* interval */)
4315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4322a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_DidCreateOffscreenContext,
4332a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     GURL /* url */)
4342a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
4352a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL3(GpuHostMsg_DidLoseContext,
4362a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     bool /* offscreen */,
4372a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     gpu::error::ContextLostReason /* reason */,
4382a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     GURL /* url */)
4392a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
4402a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_DidDestroyOffscreenContext,
4412a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     GURL /* url */)
4422a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
4432a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Tells the browser about GPU memory usage statistics for UMA logging.
4442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_CONTROL1(GpuHostMsg_GpuMemoryUmaStats,
4452a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                     content::GPUMemoryUmaStats /* GPU memory UMA stats */)
4462a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
4475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
4485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// GPU Channel Messages
4495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These are messages from a renderer process to the GPU process.
4505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the GPU process to create a new command buffer that renders to an
4525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// offscreen frame buffer.
453c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_CONTROL3_1(GpuChannelMsg_CreateOffscreenCommandBuffer,
4545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            gfx::Size, /* size */
4555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            GPUCreateCommandBufferConfig, /* init_params */
456c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                            int32, /* route_id */
457c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                            bool /* succeeded */)
4585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// The CommandBufferProxy sends this to the GpuCommandBufferStub in its
4605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// destructor, so that the stub deletes the actual CommandBufferService
4615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// object that it's hosting.
4625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_SYNC_MESSAGE_CONTROL1_0(GpuChannelMsg_DestroyCommandBuffer,
4635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            int32 /* instance_id */)
4645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
465f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// Sent by DevTools agent in the inspected renderer process to initiate GPU
466f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// instrumentation events recording.
467c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_CONTROL1_1(GpuChannelMsg_DevToolsStartEventsRecording,
468c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                            int32, /* route_id */
469c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                            bool /* succeeded */)
470f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)
471f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// The message is sent when DevTools want to stop events recording.
472f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)IPC_MESSAGE_CONTROL0(GpuChannelMsg_DevToolsStopEventsRecording)
473f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)
4745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(OS_ANDROID)
4755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
4765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Stream Texture Messages
4775d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// Tells the GPU process create and send the java surface texture object to
4785d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// the renderer process through the binder thread.
4795d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_MESSAGE_ROUTED2(GpuStreamTextureMsg_EstablishPeer,
4805d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                    int32, /* primary_id */
4815d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                    int32  /* secondary_id */)
4825d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
4835d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// Tells the GPU process to set the size of StreamTexture from the given
4845d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// stream Id.
4855d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuStreamTextureMsg_SetSize,
4865d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                    gfx::Size /* size */)
4875d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
4885d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// Tells the service-side instance to start sending frame available
4895d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// notifications.
4905d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)IPC_MESSAGE_ROUTED0(GpuStreamTextureMsg_StartListening)
4915d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
4925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Inform the renderer that a new frame is available.
4935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(GpuStreamTextureMsg_FrameAvailable)
4945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Inform the renderer process that the transform matrix has changed.
4965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuStreamTextureMsg_MatrixChanged,
4975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    GpuStreamTextureMsg_MatrixChanged_Params /* params */)
4985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif
4995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
5015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// GPU Command Buffer Messages
5025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These are messages between a renderer process to the GPU process relating to
5035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// a single OpenGL context.
5045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Initialize a command buffer with the given number of command entries.
5055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Returns the shared memory handle for the command buffer mapped to the
5065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// calling process.
507a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)IPC_SYNC_MESSAGE_ROUTED1_2(GpuCommandBufferMsg_Initialize,
5082a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                           base::SharedMemoryHandle /* shared_state */,
509a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)                           bool /* result */,
510a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)                           gpu::Capabilities /* capabilities */)
5115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Sets the shared memory buffer used for commands.
5135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_SYNC_MESSAGE_ROUTED1_0(GpuCommandBufferMsg_SetGetBuffer,
5145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           int32 /* shm_id */)
5155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
516868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)// Produces the front buffer into a mailbox. This allows another context to draw
517868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)// the output of this context.
518868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_ProduceFrontBuffer,
519868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)                    gpu::Mailbox /* mailbox */)
5205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
521c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Wait until the token is in a specific range, inclusive.
522c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_ROUTED2_1(GpuCommandBufferMsg_WaitForTokenInRange,
523c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32 /* start */,
524c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32 /* end */,
525c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           gpu::CommandBuffer::State /* state */)
526c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch
527c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Wait until the get offset is in a specific range, inclusive.
528c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_ROUTED2_1(GpuCommandBufferMsg_WaitForGetOffsetInRange,
529c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32 /* start */,
530c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32 /* end */,
5315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           gpu::CommandBuffer::State /* state */)
5325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Asynchronously synchronize the put and get offsets of both processes.
5345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Caller passes its current put offset. Current state (including get offset)
5351320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci// is returned in shared memory. The input latency info for the current
5361320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci// frame is also sent to the GPU process.
5371320f92c476a1ad9d19dba2a48c72b75566198e9Primiano TucciIPC_MESSAGE_ROUTED3(GpuCommandBufferMsg_AsyncFlush,
5385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    int32 /* put_offset */,
5391320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci                    uint32 /* flush_count */,
5405d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                    std::vector<ui::LatencyInfo> /* latency_info */)
541c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)
5425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Asynchronously process any commands known to the GPU process. This is only
5435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// used in the event that a channel is unscheduled and needs to be flushed
5445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// again to process any commands issued subsequent to unscheduling. The GPU
5455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// process actually sends it (deferred) to itself.
5465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(GpuCommandBufferMsg_Rescheduled)
5475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Sent by the GPU process to display messages in the console.
5495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_ConsoleMsg,
5505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    GPUCommandBufferConsoleMessage /* msg */)
5515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5521e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)// Register an existing shared memory transfer buffer. The id that can be
5535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// used to identify the transfer buffer from a command buffer.
5542a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_ROUTED3(GpuCommandBufferMsg_RegisterTransferBuffer,
5552a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    int32 /* id */,
5562a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    base::SharedMemoryHandle /* transfer_buffer */,
5572a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    uint32 /* size */)
5585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Destroy a previously created transfer buffer.
5602a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_DestroyTransferBuffer,
5612a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    int32 /* id */)
5625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
563c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Create and initialize a hardware video decoder using the specified route_id.
564c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)// Created decoders should be freed with AcceleratedVideoDecoderMsg_Destroy when
565c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)// no longer needed.
566c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_ROUTED2_1(GpuCommandBufferMsg_CreateVideoDecoder,
5675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           media::VideoCodecProfile /* profile */,
568c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32, /* route_id */
569c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           bool /* succeeded */)
570c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch
571c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Create and initialize a hardware video encoder using the specified route_id.
572c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Created encoders should be freed with AcceleratedVideoEncoderMsg_Destroy when
573c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// no longer needed.
574c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_ROUTED5_1(GpuCommandBufferMsg_CreateVideoEncoder,
575c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           media::VideoFrame::Format /* input_format */,
576c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           gfx::Size /* input_visible_size */,
577c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           media::VideoCodecProfile /* output_profile */,
578c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           uint32 /* initial_bitrate */,
579c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32, /* route_id */
580c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           bool /* succeeded */)
5815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Tells the proxy that there was an error and the command buffer had to be
5835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// destroyed for some reason.
5845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_Destroyed,
5855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    gpu::error::ContextLostReason /* reason */)
5865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Request that the GPU process reply with the given message. Reply may be
5885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// delayed.
5895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_Echo,
5905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    IPC::Message /* reply */)
5915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response to a GpuChannelMsg_Echo message.
5935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(GpuCommandBufferMsg_EchoAck)
5945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send to stub on surface visibility change.
5965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_SetSurfaceVisible, bool /* visible */)
5975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Sent to proxy when the gpu memory manager changes its memory allocation.
5995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_SetMemoryAllocation,
6001e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    gpu::MemoryAllocation /* allocation */)
6015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Sent to stub when proxy is assigned a memory allocation changed callback.
6035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(
6045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    GpuCommandBufferMsg_SetClientHasMemoryAllocationChangedCallback,
6055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    bool /* has_callback */)
6065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Inserts a sync point into the channel. This is handled on the IO thread, so
6085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// can be expected to be reasonably fast, but the sync point is actually
6095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// retired in order with respect to the other calls. The sync point is shared
6105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// across channels.
611116680a4aac90f2aa7413d9095a592090648e557Ben MurdochIPC_SYNC_MESSAGE_ROUTED1_1(GpuCommandBufferMsg_InsertSyncPoint,
612116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                           bool /* retire */,
6135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           uint32 /* sync_point */)
6145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Retires the sync point. Note: this message is not sent explicitly by the
6165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// renderer, but is synthesized by the GPU process.
6175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_RetireSyncPoint,
6185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    uint32 /* sync_point */)
6195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Makes this command buffer signal when a sync point is reached, by sending
6215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// back a GpuCommandBufferMsg_SignalSyncPointAck message with the same
6225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// signal_id.
6235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED2(GpuCommandBufferMsg_SignalSyncPoint,
6245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    uint32 /* sync_point */,
6255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    uint32 /* signal_id */)
6265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Response to GpuCommandBufferMsg_SignalSyncPoint.
6285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_SignalSyncPointAck,
6295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    uint32 /* signal_id */)
6305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
631eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch// Makes this command buffer signal when a query is reached, by sending
632eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch// back a GpuCommandBufferMsg_SignalSyncPointAck message with the same
633eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch// signal_id.
634eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen MurdochIPC_MESSAGE_ROUTED2(GpuCommandBufferMsg_SignalQuery,
635eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch                    uint32 /* query */,
636eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch                    uint32 /* signal_id */)
637eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch
6381e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)// Register an existing gpu memory buffer. The id that can be
6391e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)// used to identify the gpu memory buffer from a command buffer.
6401e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)IPC_MESSAGE_ROUTED5(GpuCommandBufferMsg_RegisterGpuMemoryBuffer,
6411e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    int32 /* id */,
6421e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    gfx::GpuMemoryBufferHandle /* gpu_memory_buffer */,
6431e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    uint32 /* width */,
6441e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    uint32 /* height */,
6451e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    uint32 /* internalformat */)
6461e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)
6475f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)// Unregister a previously registered gpu memory buffer.
6485f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)IPC_MESSAGE_ROUTED1(GpuCommandBufferMsg_UnregisterGpuMemoryBuffer,
6491e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)                    int32 /* id */)
6501e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)
6515d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// Attaches an external image stream to the client texture.
652c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_SYNC_MESSAGE_ROUTED2_1(GpuCommandBufferMsg_CreateStreamTexture,
6535d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)                           uint32, /* client_texture_id */
654c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           int32, /* stream_id */
655c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch                           bool /* succeeded */)
6565d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)
6575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
6585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Accelerated Video Decoder Messages
6595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These messages are sent from Renderer process to GPU process.
6605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send input buffer for decoding.
6625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED3(AcceleratedVideoDecoderMsg_Decode,
6635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    base::SharedMemoryHandle, /* input_buffer_handle */
6645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    int32, /* bitstream_buffer_id */
6652a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)                    uint32) /* size */
6665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Sent from Renderer process to the GPU process to give the texture IDs for
6685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// the textures the decoder will use for output.
66968043e1e95eeb07d5cae7aca370b26518b0867d6Torne (Richard Coles)IPC_MESSAGE_ROUTED2(AcceleratedVideoDecoderMsg_AssignPictureBuffers,
67068043e1e95eeb07d5cae7aca370b26518b0867d6Torne (Richard Coles)                    std::vector<int32>,  /* Picture buffer ID */
67168043e1e95eeb07d5cae7aca370b26518b0867d6Torne (Richard Coles)                    std::vector<uint32>) /* Texture ID */
6725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send from Renderer process to the GPU process to recycle the given picture
6745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// buffer for further decoding.
6755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoDecoderMsg_ReusePictureBuffer,
6765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    int32) /* Picture buffer ID */
6775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send flush request to the decoder.
6795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedVideoDecoderMsg_Flush)
6805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send reset request to the decoder.
6825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedVideoDecoderMsg_Reset)
6835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Send destroy request to the decoder.
685c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedVideoDecoderMsg_Destroy)
6865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)//------------------------------------------------------------------------------
6885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Accelerated Video Decoder Host Messages
6895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// These messages are sent from GPU process to Renderer process.
6905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Inform AcceleratedVideoDecoderHost that AcceleratedVideoDecoder has been
6915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// created.
6925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Accelerated video decoder has consumed input buffer from transfer buffer.
6945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoDecoderHostMsg_BitstreamBufferProcessed,
6955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    int32) /* Processed buffer ID */
6965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
6975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Allocate video frames for output of the hardware video decoder.
6985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED3(
6995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    AcceleratedVideoDecoderHostMsg_ProvidePictureBuffers,
7005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    int32, /* Number of video frames to generate */
7015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    gfx::Size, /* Requested size of buffer */
7025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    uint32 ) /* Texture target */
7035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
7045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Decoder reports that a picture is ready and buffer does not need to be passed
7055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// back to the decoder.
7065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoDecoderHostMsg_DismissPictureBuffer,
7075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    int32) /* Picture buffer ID */
7085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
7095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Decoder reports that a picture is ready.
71003b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)IPC_MESSAGE_ROUTED3(AcceleratedVideoDecoderHostMsg_PictureReady,
71103b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)                    int32,     /* Picture buffer ID */
71203b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)                    int32,     /* Bitstream buffer ID */
71303b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)                    gfx::Rect) /* Visible rectangle */
7145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
7155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Confirm decoder has been flushed.
7165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedVideoDecoderHostMsg_FlushDone)
7175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
7185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Confirm decoder has been reset.
7195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED0(AcceleratedVideoDecoderHostMsg_ResetDone)
7205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
7215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Video decoder has encountered an error.
7225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoDecoderHostMsg_ErrorNotification,
7235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                    uint32) /* Error ID */
7243551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7253551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)//------------------------------------------------------------------------------
7263551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Accelerated Video Encoder Messages
7273551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// These messages are sent from the Renderer process to GPU process.
7283551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7293551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Queue a input buffer to the encoder to encode. |frame_id| will be returned by
7303551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// AcceleratedVideoEncoderHostMsg_NotifyEncodeDone.
7313551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED4(AcceleratedVideoEncoderMsg_Encode,
7323551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    int32 /* frame_id */,
7333551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    base::SharedMemoryHandle /* buffer_handle */,
7343551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* buffer_size */,
7353551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    bool /* force_keyframe */)
7363551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7373551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Queue a buffer to the encoder for use in returning output.  |buffer_id| will
7383551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// be returned by AcceleratedVideoEncoderHostMsg_BitstreamBufferReady.
7393551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED3(AcceleratedVideoEncoderMsg_UseOutputBitstreamBuffer,
7403551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    int32 /* buffer_id */,
7413551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    base::SharedMemoryHandle /* buffer_handle */,
7423551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* buffer_size */)
7433551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7443551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Request a runtime encoding parameter change.
7453551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED2(AcceleratedVideoEncoderMsg_RequestEncodingParametersChange,
7463551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* bitrate */,
7473551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* framerate */)
7483551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7493551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)//------------------------------------------------------------------------------
7503551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Accelerated Video Encoder Host Messages
7513551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// These messages are sent from GPU process to Renderer process.
7523551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7533551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Notify renderer of the input/output buffer requirements of the encoder.
7543551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED3(AcceleratedVideoEncoderHostMsg_RequireBitstreamBuffers,
7553551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* input_count */,
7563551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    gfx::Size /* input_coded_size */,
7573551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* output_buffer_size */)
7583551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7593551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Notify the renderer that the encoder has finished using an input buffer.
7603551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// There is no congruent entry point in the media::VideoEncodeAccelerator
7613551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// interface, in VEA this same done condition is indicated by dropping the
7623551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// reference to the media::VideoFrame passed to VEA::Encode().
7633551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoEncoderHostMsg_NotifyInputDone,
7643551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    int32 /* frame_id */)
7653551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7663551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Notify the renderer that an output buffer has been filled with encoded data.
7673551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED3(AcceleratedVideoEncoderHostMsg_BitstreamBufferReady,
7683551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    int32 /* bitstream_buffer_id */,
7693551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    uint32 /* payload_size */,
7703551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    bool /* key_frame */)
7713551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)
7723551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)// Report error condition.
7733551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)IPC_MESSAGE_ROUTED1(AcceleratedVideoEncoderHostMsg_NotifyError,
7743551c9c881056c480085172ff9840cab31610854Torne (Richard Coles)                    media::VideoEncodeAccelerator::Error /* error */)
775c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch
776c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen Murdoch// Send destroy request to the encoder.
777c5cede9ae108bb15f6b7a8aea21c7e1fefa2834cBen MurdochIPC_MESSAGE_ROUTED0(AcceleratedVideoEncoderMsg_Destroy)
778