mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
058eb0d0e1
- Bug 1192101 - Part 1 - Support PresentationRequest / PresentationAvailability / getSession(s). Part 1 - WebIDL Bindings. r=smaug (966c9ef0cc) - Bug 1192101 - Part 2 - Support PresentationRequest / PresentationAvailability / getSession(s). Part 2 - Change notification & event dispatching. r=smaug (884dc29bbf) - Bug 1192101 - Part 3 - Support PresentationRequest / PresentationAvailability / getSession(s). Part 3 - Adjust errors. r=smaug (deff3602fb) - Bug 1201805 - [Presentation WebAPI] Fix collaboration issues with control channel. Part 2 - Adjust the timing to send offer. r=smaug (12fd6daaf6) - Bug 1192101 - Part 4 -Support PresentationRequest / PresentationAvailability / getSession(s). Part 4 - Rename PresentationSessionInfo relevant classes. r=smaug (426ecdf6bc) - Bug 1202582 - Part 2 - [Presentation WebAPI] Ensure incoming messages are well delivered to receiver pages. Part 2 - PresentationSessionInfo. r=smaug (8063fb8b0c) - Bug 1202582 - Part 1 - Presentation WebAPI] Ensure incoming messages are well delivered to receiver pages. Part 1 - PresentationSessionTransport. r=jdm (4557d46a69) - Bug 1192101 - Part 5 - Support PresentationRequest / PresentationAvailability / getSession(s). Part 5 - Tests. r=smaug (09ed937625) - Bg 950660: Part 1: Support bind in TCPSocket from content process r=jdm (a4c5a6e59d) - Bug 950660: Part 1: Support bind in TCPSocket from content process r=jdm Bug 950660: Part 2 - Change TCPSocket interface to TCPSocketChild and unbitrot r=jdm Bug 950660: Part 3 - make TCPSocket/TCPSocketChild interface an IDL interface r=jdm (4694a7afa8) - Bug 885982 - Part 4: Remove all traces of JS implementation. r=asuth (0b4308ac2b) - Bug 1171760: P6. Use MediaSourceSamples logging in ContainerParser. r=cpearce (83abe7a45f) - Bug 1186257 - Fix formatting. r=jya (33715d7cd7) - Bug 1171760: P5. Add MediaSourceSamples logging. r=cpearce (5ebfc707ec) - Bug 1197563 - Polyfill __func__ for MSVC 2013 and earlier. r=froydnj (c5d0f4edde) - Bug 1186257 - Use default dtor in ContainerParser. r=jya (270678ff2a) - Bug 1188150 - Move ContainerParser dtor to implementation. r=jya (67ece68407) - Bug 1183196: [MSE] P3. Slightly increase debugging information. r=kentuckyfriedtakahe (dbc73818a3) - fix spacing (7407c57db7)
212 lines
5.4 KiB
C++
212 lines
5.4 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "nsDeque.h"
|
|
#include "MediaData.h"
|
|
#include "mozilla/Logging.h"
|
|
|
|
extern PRLogModuleInfo* GetSourceBufferResourceLog();
|
|
|
|
#define SBR_DEBUG(arg, ...) MOZ_LOG(GetSourceBufferResourceLog(), mozilla::LogLevel::Debug, ("ResourceQueue(%p)::%s: " arg, this, __func__, ##__VA_ARGS__))
|
|
#define SBR_DEBUGV(arg, ...) MOZ_LOG(GetSourceBufferResourceLog(), mozilla::LogLevel::Verbose, ("ResourceQueue(%p)::%s: " arg, this, __func__, ##__VA_ARGS__))
|
|
|
|
namespace mozilla {
|
|
|
|
ResourceItem::ResourceItem(MediaLargeByteBuffer* aData)
|
|
: mData(aData)
|
|
{
|
|
}
|
|
|
|
size_t
|
|
ResourceItem::SizeOfIncludingThis(MallocSizeOf aMallocSizeOf) const
|
|
{
|
|
// size including this
|
|
size_t size = aMallocSizeOf(this);
|
|
|
|
// size excluding this
|
|
size += mData->ShallowSizeOfExcludingThis(aMallocSizeOf);
|
|
|
|
return size;
|
|
}
|
|
|
|
class ResourceQueueDeallocator : public nsDequeFunctor {
|
|
virtual void* operator() (void* aObject) {
|
|
delete static_cast<ResourceItem*>(aObject);
|
|
return nullptr;
|
|
}
|
|
};
|
|
|
|
ResourceQueue::ResourceQueue()
|
|
: nsDeque(new ResourceQueueDeallocator())
|
|
, mLogicalLength(0)
|
|
, mOffset(0)
|
|
{
|
|
}
|
|
|
|
uint64_t
|
|
ResourceQueue::GetOffset()
|
|
{
|
|
return mOffset;
|
|
}
|
|
|
|
uint64_t
|
|
ResourceQueue::GetLength()
|
|
{
|
|
return mLogicalLength;
|
|
}
|
|
|
|
void
|
|
ResourceQueue::CopyData(uint64_t aOffset, uint32_t aCount, char* aDest)
|
|
{
|
|
uint32_t offset = 0;
|
|
uint32_t start = GetAtOffset(aOffset, &offset);
|
|
uint32_t end = std::min(GetAtOffset(aOffset + aCount, nullptr) + 1, uint32_t(GetSize()));
|
|
for (uint32_t i = start; i < end; ++i) {
|
|
ResourceItem* item = ResourceAt(i);
|
|
uint32_t bytes = std::min(aCount, uint32_t(item->mData->Length() - offset));
|
|
if (bytes != 0) {
|
|
memcpy(aDest, &(*item->mData)[offset], bytes);
|
|
offset = 0;
|
|
aCount -= bytes;
|
|
aDest += bytes;
|
|
}
|
|
}
|
|
}
|
|
|
|
void
|
|
ResourceQueue::AppendItem(MediaLargeByteBuffer* aData)
|
|
{
|
|
mLogicalLength += aData->Length();
|
|
Push(new ResourceItem(aData));
|
|
}
|
|
|
|
uint32_t
|
|
ResourceQueue::Evict(uint64_t aOffset, uint32_t aSizeToEvict,
|
|
ErrorResult& aRv)
|
|
{
|
|
SBR_DEBUG("Evict(aOffset=%llu, aSizeToEvict=%u)",
|
|
aOffset, aSizeToEvict);
|
|
return EvictBefore(std::min(aOffset, mOffset + (uint64_t)aSizeToEvict), aRv);
|
|
}
|
|
|
|
uint32_t ResourceQueue::EvictBefore(uint64_t aOffset, ErrorResult& aRv)
|
|
{
|
|
SBR_DEBUG("EvictBefore(%llu)", aOffset);
|
|
uint32_t evicted = 0;
|
|
while (ResourceItem* item = ResourceAt(0)) {
|
|
SBR_DEBUG("item=%p length=%d offset=%llu",
|
|
item, item->mData->Length(), mOffset);
|
|
if (item->mData->Length() + mOffset >= aOffset) {
|
|
if (aOffset <= mOffset) {
|
|
break;
|
|
}
|
|
uint32_t offset = aOffset - mOffset;
|
|
mOffset += offset;
|
|
evicted += offset;
|
|
nsRefPtr<MediaLargeByteBuffer> data = new MediaLargeByteBuffer;
|
|
if (!data->AppendElements(item->mData->Elements() + offset,
|
|
item->mData->Length() - offset,
|
|
fallible)) {
|
|
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
|
|
return 0;
|
|
}
|
|
|
|
item->mData = data;
|
|
break;
|
|
}
|
|
mOffset += item->mData->Length();
|
|
evicted += item->mData->Length();
|
|
delete PopFront();
|
|
}
|
|
return evicted;
|
|
}
|
|
|
|
uint32_t
|
|
ResourceQueue::EvictAll()
|
|
{
|
|
SBR_DEBUG("EvictAll()");
|
|
uint32_t evicted = 0;
|
|
while (ResourceItem* item = ResourceAt(0)) {
|
|
SBR_DEBUG("item=%p length=%d offset=%llu",
|
|
item, item->mData->Length(), mOffset);
|
|
mOffset += item->mData->Length();
|
|
evicted += item->mData->Length();
|
|
delete PopFront();
|
|
}
|
|
return evicted;
|
|
}
|
|
|
|
size_t
|
|
ResourceQueue::SizeOfExcludingThis(MallocSizeOf aMallocSizeOf) const
|
|
{
|
|
// Calculate the size of the internal deque.
|
|
size_t size = nsDeque::SizeOfExcludingThis(aMallocSizeOf);
|
|
|
|
// Sum the ResourceItems.
|
|
for (uint32_t i = 0; i < uint32_t(GetSize()); ++i) {
|
|
const ResourceItem* item = ResourceAt(i);
|
|
size += item->SizeOfIncludingThis(aMallocSizeOf);
|
|
}
|
|
|
|
return size;
|
|
}
|
|
|
|
#if defined(DEBUG)
|
|
void
|
|
ResourceQueue::Dump(const char* aPath)
|
|
{
|
|
for (uint32_t i = 0; i < uint32_t(GetSize()); ++i) {
|
|
ResourceItem* item = ResourceAt(i);
|
|
|
|
char buf[255];
|
|
PR_snprintf(buf, sizeof(buf), "%s/%08u.bin", aPath, i);
|
|
FILE* fp = fopen(buf, "wb");
|
|
if (!fp) {
|
|
return;
|
|
}
|
|
fwrite(item->mData->Elements(), item->mData->Length(), 1, fp);
|
|
fclose(fp);
|
|
}
|
|
}
|
|
#endif
|
|
|
|
ResourceItem*
|
|
ResourceQueue::ResourceAt(uint32_t aIndex) const
|
|
{
|
|
return static_cast<ResourceItem*>(ObjectAt(aIndex));
|
|
}
|
|
|
|
uint32_t
|
|
ResourceQueue::GetAtOffset(uint64_t aOffset, uint32_t *aResourceOffset)
|
|
{
|
|
MOZ_RELEASE_ASSERT(aOffset >= mOffset);
|
|
uint64_t offset = mOffset;
|
|
for (uint32_t i = 0; i < uint32_t(GetSize()); ++i) {
|
|
ResourceItem* item = ResourceAt(i);
|
|
// If the item contains the start of the offset we want to
|
|
// break out of the loop.
|
|
if (item->mData->Length() + offset > aOffset) {
|
|
if (aResourceOffset) {
|
|
*aResourceOffset = aOffset - offset;
|
|
}
|
|
return i;
|
|
}
|
|
offset += item->mData->Length();
|
|
}
|
|
return GetSize();
|
|
}
|
|
|
|
ResourceItem*
|
|
ResourceQueue::PopFront()
|
|
{
|
|
return static_cast<ResourceItem*>(nsDeque::PopFront());
|
|
}
|
|
|
|
#undef SBR_DEBUG
|
|
#undef SBR_DEBUGV
|
|
|
|
} // namespace mozilla
|