chromium/ash/components/arc/mojom/protected_buffer_manager.mojom

// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// The original version of this file lives in the Chromium repository at:
// src/components/arc/mojom/protected_buffer_manager.mojom
// Next Version: 3

module arc.mojom;
import "media/mojo/mojom/stable/native_pixmap_handle.mojom";
import "sandbox/policy/mojom/sandbox.mojom";

// This interface is exposed by the GPU process for translating dummy handles
// for secure buffers into usable shared memory buffer or native pixmap handles.
// Next Method ID: 4
[Stable, Uuid="560fada2-b6b8-4b06-a337-188381028495",
 ServiceSandbox=sandbox.mojom.Sandbox.kGpu]
interface ProtectedBufferManager {
  // This is deprecated! Please use GetProtectedSharedMemoryFromHandle() which
  // allows returning a null value.
  //
  // Translates from a given |dummy_handle| to a shared memory buffer handle.
  // The intended use is for the video decoder to gain access to the input data:
  // a decryption operation can write to this shared memory and then the video
  // decoder can consume it.
  //
  // NOTE: This does not use a shared memory handle for the return type
  // because of incompatibilities between Chrome and Chrome OS mojo versions
  // regarding the structure used for sending shared memory handles.
  //
  // TODO(b/195769334): switch existing clients to
  // GetProtectedSharedMemoryFromHandle().
  DeprecatedGetProtectedSharedMemoryFromHandle@0(handle dummy_handle)
      => (handle shared_memory_handle);

  // Translates from a given |dummy_handle| to a shared memory buffer handle.
  // The intended use is for the video decoder to gain access to the input data:
  // a decryption operation can write to this shared memory and then the video
  // decoder can consume it.
  //
  // Returns null on failure (including if the dummy handle does not correspond
  // to a valid shared memory buffer).
  [MinVersion=1]
  GetProtectedSharedMemoryFromHandle@1(handle dummy_handle)
      => (handle<shared_buffer>? shared_memory_handle);

  // Translates from a given |dummy_handle| to a native pixmap handle. The
  // intended use is for the video decoder to gain access to the output buffer.
  // Returns null on failure (including if the dummy handle does not correspond
  // to a valid native pixmap).
  [MinVersion=1]
  GetProtectedNativePixmapHandleFromHandle@2(handle dummy_handle)
      => (media.stable.mojom.NativePixmapHandle? native_pixmap_handle);

  // This is used by exo in the browser process to determine if a GMB refers to
  // a protected native pixmap so it can set the HW protection properly in the
  // quad if the platform supports HWDRM.
  [MinVersion=2]
  IsProtectedNativePixmapHandle@3(handle dummy_handle) => (bool is_protected);
};