Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #include "base/logging.h" | 5 #include "base/logging.h" |
| 6 #include "services/media/framework/packet.h" | 6 #include "services/media/framework/packet.h" |
| 7 #include "services/media/framework/payload_allocator.h" | 7 #include "services/media/framework/payload_allocator.h" |
| 8 | 8 |
| 9 namespace mojo { | 9 namespace mojo { |
| 10 namespace media { | 10 namespace media { |
| 11 | 11 |
| 12 Packet::Packet( | |
| 13 int64_t pts, | |
| 14 bool end_of_stream, | |
| 15 size_t size, | |
| 16 void* payload) : | |
| 17 pts_(pts), | |
| 18 end_of_stream_(end_of_stream), | |
| 19 size_(size), | |
| 20 payload_(payload) { | |
| 21 DCHECK((size == 0) == (payload == nullptr)); | |
| 22 } | |
| 23 | |
| 12 class PacketImpl : public Packet { | 24 class PacketImpl : public Packet { |
| 13 public: | 25 public: |
| 14 PacketImpl( | 26 PacketImpl( |
| 15 int64_t presentation_time, | 27 int64_t pts, |
| 16 uint64_t duration, | |
| 17 bool end_of_stream, | 28 bool end_of_stream, |
| 18 size_t size, | 29 size_t size, |
| 19 void* payload, | 30 void* payload, |
| 20 PayloadAllocator* allocator) : | 31 PayloadAllocator* allocator) : |
| 21 presentation_time_(presentation_time), | 32 Packet(pts, end_of_stream, size, payload), |
| 22 duration_(duration), | 33 allocator_(allocator) {} |
| 23 end_of_stream_(end_of_stream), | |
| 24 size_(size), | |
| 25 payload_(payload), | |
| 26 allocator_(allocator) { | |
| 27 DCHECK((size == 0) == (payload == nullptr)); | |
| 28 } | |
| 29 | 34 |
| 35 protected: | |
| 30 ~PacketImpl() override {}; | 36 ~PacketImpl() override {}; |
| 31 | 37 |
| 32 int64_t presentation_time() const override { return presentation_time_; } | |
| 33 | |
| 34 uint64_t duration() const override { return duration_; } | |
| 35 | |
| 36 bool end_of_stream() const override { return end_of_stream_; } | |
| 37 | |
| 38 size_t size() const override { return size_; } | |
| 39 | |
| 40 void* payload() const override { return payload_; } | |
| 41 | |
| 42 protected: | |
| 43 void Release() override { | 38 void Release() override { |
| 44 if (payload_ != nullptr && allocator_ != nullptr) { | 39 if (payload() != nullptr && allocator_ != nullptr) { |
|
johngro
2016/03/21 19:47:56
we lost the DCHECK(allocator_) here.
dalesat
2016/03/21 22:30:58
It seemed unnecessary - the previous line checks t
johngro
2016/03/21 22:56:05
fair enough. What is the intended behavior if pay
dalesat
2016/03/22 00:06:56
The code is correct but unclear. Added a comment t
| |
| 45 DCHECK(allocator_); | 40 allocator_->ReleasePayloadBuffer(size(), payload()); |
| 46 allocator_->ReleasePayloadBuffer(size_, payload_); | |
| 47 } | 41 } |
| 48 delete this; | 42 delete this; |
| 49 } | 43 } |
| 50 | 44 |
| 51 private: | 45 private: |
| 52 int64_t presentation_time_; | |
| 53 uint64_t duration_; | |
| 54 bool end_of_stream_; | |
| 55 size_t size_; | |
| 56 void* payload_; | |
| 57 PayloadAllocator* allocator_; | 46 PayloadAllocator* allocator_; |
| 58 }; | 47 }; |
| 59 | 48 |
| 60 // static | 49 // static |
| 61 PacketPtr Packet::Create( | 50 PacketPtr Packet::Create( |
| 62 int64_t presentation_time, | 51 int64_t pts, |
| 63 uint64_t duration, | |
| 64 bool end_of_stream, | 52 bool end_of_stream, |
| 65 size_t size, | 53 size_t size, |
| 66 void* payload, | 54 void* payload, |
| 67 PayloadAllocator* allocator) { | 55 PayloadAllocator* allocator) { |
| 68 DCHECK(payload == nullptr || allocator != nullptr); | 56 DCHECK(payload == nullptr || allocator != nullptr); |
| 69 return PacketPtr(new PacketImpl( | 57 return PacketPtr(new PacketImpl( |
| 70 presentation_time, | 58 pts, |
| 71 duration, | |
| 72 end_of_stream, | 59 end_of_stream, |
| 73 size, | 60 size, |
| 74 payload, | 61 payload, |
| 75 allocator)); | 62 allocator)); |
| 76 } | 63 } |
| 77 | 64 |
| 78 // static | 65 // static |
| 79 PacketPtr Packet::CreateNoAllocator( | 66 PacketPtr Packet::CreateNoAllocator( |
| 80 int64_t presentation_time, | 67 int64_t pts, |
| 81 uint64_t duration, | |
| 82 bool end_of_stream, | 68 bool end_of_stream, |
| 83 size_t size, | 69 size_t size, |
| 84 void* payload) { | 70 void* payload) { |
| 85 return PacketPtr(new PacketImpl( | 71 return PacketPtr(new PacketImpl( |
| 86 presentation_time, | 72 pts, |
| 87 duration, | |
| 88 end_of_stream, | 73 end_of_stream, |
| 89 size, | 74 size, |
| 90 payload, | 75 payload, |
| 91 nullptr)); | 76 nullptr)); |
| 92 } | 77 } |
| 93 | 78 |
| 94 // static | 79 // static |
| 95 PacketPtr Packet::CreateEndOfStream(int64_t presentation_time) { | 80 PacketPtr Packet::CreateEndOfStream(int64_t pts) { |
| 96 return PacketPtr(new PacketImpl( | 81 return PacketPtr(new PacketImpl( |
| 97 presentation_time, | 82 pts, |
| 98 0, // duration | |
| 99 true, // end_of_stream | 83 true, // end_of_stream |
| 100 0, // size | 84 0, // size |
| 101 nullptr, // payload | 85 nullptr, // payload |
| 102 nullptr)); // allocator | 86 nullptr)); // allocator |
| 103 } | 87 } |
| 104 | 88 |
| 105 } // namespace media | 89 } // namespace media |
| 106 } // namespace mojo | 90 } // namespace mojo |
| OLD | NEW |