Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1202)

Unified Diff: services/media/framework/stages/transform_stage.cc

Issue 1678433002: Motown: Remove LPCM optimizations, fix prepare, add flush, add ActiveMultistreamSink model/stage (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Sync Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « services/media/framework/stages/transform_stage.h ('k') | services/media/framework/stream_type.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/media/framework/stages/transform_stage.cc
diff --git a/services/media/framework/stages/transform_stage.cc b/services/media/framework/stages/transform_stage.cc
new file mode 100644
index 0000000000000000000000000000000000000000..dce82545d8eec7cb2273052ebbd0079ebe28792d
--- /dev/null
+++ b/services/media/framework/stages/transform_stage.cc
@@ -0,0 +1,104 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "services/media/framework/stages/transform_stage.h"
+
+namespace mojo {
+namespace media {
+
+TransformStage::TransformStage(
+ std::shared_ptr<Transform> transform) :
+ transform_(transform),
+ allocator_(nullptr),
+ input_packet_is_new_(true) {
+ DCHECK(transform_);
+}
+
+TransformStage::~TransformStage() {}
+
+size_t TransformStage::input_count() const {
+ return 1;
+};
+
+Input& TransformStage::input(size_t index) {
+ DCHECK_EQ(index, 0u);
+ return input_;
+}
+
+size_t TransformStage::output_count() const {
+ return 1;
+}
+
+Output& TransformStage::output(size_t index) {
+ DCHECK_EQ(index, 0u);
+ return output_;
+}
+
+PayloadAllocator* TransformStage::PrepareInput(size_t index) {
+ DCHECK_EQ(index, 0u);
+ return nullptr;
+}
+
+void TransformStage::PrepareOutput(
+ size_t index,
+ PayloadAllocator* allocator,
+ const UpstreamCallback& callback) {
+ DCHECK_EQ(index, 0u);
+
+ allocator_ =
+ allocator == nullptr ? PayloadAllocator::GetDefault() : allocator;
+
+ callback(0);
+}
+
+void TransformStage::UnprepareOutput(
+ size_t index,
+ const UpstreamCallback& callback) {
+ allocator_ = nullptr;
+ callback(0);
+}
+
+void TransformStage::Update(Engine* engine) {
+ DCHECK(engine);
+ DCHECK(allocator_);
+
+ if (input_.packet_from_upstream() && output_.demand() != Demand::kNegative) {
+ PacketPtr output_packet;
+ if (transform_->TransformPacket(
+ input_.packet_from_upstream(),
+ input_packet_is_new_,
+ allocator_,
+ &output_packet)) {
+ input_.packet_from_upstream().reset();
+ input_packet_is_new_ = true;
+ } else {
+ input_packet_is_new_ = false;
+ }
+
+ if (output_packet) {
+ output_.SupplyPacket(std::move(output_packet), engine);
+ }
+ }
+
+ input_.SetDemand(output_.demand(), engine);
+}
+
+void TransformStage::FlushInput(
+ size_t index,
+ const DownstreamCallback& callback) {
+ DCHECK_EQ(index, 0u);
+ input_.Flush();
+ callback(0);
+}
+
+void TransformStage::FlushOutput(size_t index) {
+ DCHECK_EQ(index, 0u);
+ DCHECK(transform_);
+ output_.Flush();
+ transform_->Flush();
+ input_packet_is_new_ = true;
+}
+
+} // namespace media
+} // namespace mojo
« no previous file with comments | « services/media/framework/stages/transform_stage.h ('k') | services/media/framework/stream_type.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698