<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[178554] branches/safari-600.5-branch/Source/WebCore</title>
</head>
<body>
<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; }
#msg dl a { font-weight: bold}
#msg dl a:link { color:#fc3; }
#msg dl a:active { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://trac.webkit.org/projects/webkit/changeset/178554">178554</a></dd>
<dt>Author</dt> <dd>matthew_hanson@apple.com</dd>
<dt>Date</dt> <dd>2015-01-15 17:58:05 -0800 (Thu, 15 Jan 2015)</dd>
</dl>
<h3>Log Message</h3>
<pre>Merged <a href="http://trac.webkit.org/projects/webkit/changeset/174346">r174346</a>. rdar://problem/19451946</pre>
<h3>Modified Paths</h3>
<ul>
<li><a href="#branchessafari6005branchSourceWebCoreChangeLog">branches/safari-600.5-branch/Source/WebCore/ChangeLog</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfAVFoundationCFSoftLinkingh">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/AVFoundationCFSoftLinking.h</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfCDMSessionAVFoundationCFcpp">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/CDMSessionAVFoundationCF.cpp</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfInbandTextTrackPrivateAVCFcpp">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/InbandTextTrackPrivateAVCF.cpp</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfMediaPlayerPrivateAVFoundationCFcpp">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.cpp</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfMediaPlayerPrivateAVFoundationCFh">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.h</a></li>
<li><a href="#branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfWebCoreAVCFResourceLoadercpp">branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/WebCoreAVCFResourceLoader.cpp</a></li>
</ul>
</div>
<div id="patch">
<h3>Diff</h3>
<a id="branchessafari6005branchSourceWebCoreChangeLog"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/ChangeLog (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/ChangeLog        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/ChangeLog        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -1,5 +1,76 @@
</span><span class="cx"> 2015-01-15 Matthew Hanson <matthew_hanson@apple.com>
</span><span class="cx">
</span><ins>+ Merge r174346. rdar://problem/19451946
+
+ 2014-10-06 Brent Fulgham <bfulgham@apple.com>
+
+ [Win] Extend AVFoundationCF Media Implementation
+ https://bugs.webkit.org/show_bug.cgi?id=137409
+
+ Reviewed by Eric Carlson.
+
+ This code is not yet being built and tested by our system. Appropriate
+ tests will be activated when we enable the build.
+
+ Most of this patch involves correcting some misuse of the AVFoundationCF API.
+ 1. It is never appropriate in AVCF to pass a null CFErrorRef; instead you must
+ pass a CFErrorRef with error type kCFURLErrorUnknown.
+ 2. Because of the asynchronous way we handle the request/response, it is possible
+ for AVCF to make two AVCF requests while negotiating the key exchange.
+
+ * platform/graphics/avfoundation/cf/AVFoundationCFSoftLinking.h: Add
+ missing declaration.
+ * platform/graphics/avfoundation/cf/CDMSessionAVFoundationCF.cpp:
+ (WebCore::CDMSessionAVFoundationCF::generateKeyRequest): Tighten up scope
+ of 'underlyingError'.
+ (WebCore::CDMSessionAVFoundationCF::update): Add call to complete the
+ loading process.
+ * platform/graphics/avfoundation/cf/InbandTextTrackPrivateAVCF.cpp:
+ (WebCore::InbandTextTrackPrivateAVCF::label): Handle null titles CFArray
+ found during testing.
+ (WebCore::InbandTextTrackPrivateAVCF::language): Ditto for a null locale.
+ * platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.cpp:
+ (WebCore::MediaPlayerPrivateAVFoundationCF::registerMediaEngine): Add support
+ for the new 'supportsKeySystem' method.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::createContextVideoRenderer): Add
+ assertion for mainThread.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::destroyContextVideoRenderer): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::createVideoLayer): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::destroyVideoLayer): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::createAVPlayer): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::createAVPlayerItem): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::platformLayer): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::platformSetVisible): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::paintCurrentFrameInContext): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::paint): Ditto.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::supportsKeySystem): Added.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::sizeChanged): Add assertion that this
+ is being called on the main thread.
+ (WebCore::MediaPlayerPrivateAVFoundationCF::processMediaSelectionOptions): Handle
+ the allows empty media selection properly based on test behavior.
+ (WebCore::AVFWrapper::AVFWrapper): Initialize resource loader callback structure
+ when building with AVFOUNDATION_LOADER_DELEGATE.
+ (WebCore::AVFWrapper::createAssetForURL): Use AVFWrapper's loader callback struct,
+ rather than passing the address of a temporary value.
+ (WebCore::AVFWrapper::processNotification): Stop using the deprecated
+ 'dispatch_get_current_queue' function.
+ (WebCore::AVFWrapper::processCue): Ditto.
+ (WebCore::AVFWrapper::legibleOutputCallback): Ditto.
+ (WebCore::AVFWrapper::processShouldWaitForLoadingOfResource): Pass a valid CFError
+ object; nullptr is not allowed as an argument to the "...FinishedLoadingWithError"
+ method.
+ (WebCore::AVFWrapper::shouldWaitForLoadingOfResource): Add support for multiple
+ in-flight requests.
+ (WebCore::AVFWrapper::platformLayer): Assert we are on the main thread.
+ (WebCore::AVFWrapper::setRequestForKey): Add support for multiple in-flight requests.
+ (WebCore::AVFWrapper::takeRequestForKeyURI): Ditto.
+ (WebCore::LayerClient::platformCALayerLayoutSublayersOfLayer): Ditto.
+ * platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.h:
+ * platform/graphics/avfoundation/cf/WebCoreAVCFResourceLoader.cpp: Make sure we pass
+ valid CFError objects, rather than nullptr.
+
+2015-01-15 Matthew Hanson <matthew_hanson@apple.com>
+
</ins><span class="cx"> Merge r173218. rdar://problem/19451975
</span><span class="cx">
</span><span class="cx"> 2014-09-03 Brent Fulgham <bfulgham@apple.com>
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfAVFoundationCFSoftLinkingh"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/AVFoundationCFSoftLinking.h (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/AVFoundationCFSoftLinking.h        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/AVFoundationCFSoftLinking.h        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -302,6 +302,9 @@
</span><span class="cx"> SOFT_LINK_DLL_IMPORT(AVFoundationCF, AVCFAssetResourceLoadingRequestGetURLRequest, CFURLRequestRef, __cdecl, (AVCFAssetResourceLoadingRequestRef loadingRequest), (loadingRequest))
</span><span class="cx"> #define AVCFAssetResourceLoadingRequestGetURLRequest softLink_AVCFAssetResourceLoadingRequestGetURLRequest
</span><span class="cx">
</span><ins>+SOFT_LINK_DLL_IMPORT(AVFoundationCF, AVCFAssetResourceLoadingRequestFinishLoadingWithResponse, void, __cdecl, (AVCFAssetResourceLoadingRequestRef loadingRequest, CFURLResponseRef response, CFDataRef data, CFURLRequestRef redirect), (loadingRequest, response, data, redirect))
+#define AVCFAssetResourceLoadingRequestFinishLoadingWithResponse softLink_AVCFAssetResourceLoadingRequestFinishLoadingWithResponse
+
</ins><span class="cx"> #endif
</span><span class="cx">
</span><span class="cx"> // Variables
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfCDMSessionAVFoundationCFcpp"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/CDMSessionAVFoundationCF.cpp (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/CDMSessionAVFoundationCF.cpp        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/CDMSessionAVFoundationCF.cpp        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -85,8 +85,7 @@
</span><span class="cx"> userInfo = adoptCF(CFErrorCopyUserInfo(cfError));
</span><span class="cx">
</span><span class="cx"> if (userInfo) {
</span><del>- CFErrorRef underlyingError = (CFErrorRef)CFDictionaryGetValue(userInfo.get(), kCFErrorUnderlyingErrorKey);
- if (underlyingError)
</del><ins>+ if (CFErrorRef underlyingError = (CFErrorRef)CFDictionaryGetValue(userInfo.get(), kCFErrorUnderlyingErrorKey))
</ins><span class="cx"> systemCode = CFErrorGetCode(underlyingError);
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -113,9 +112,7 @@
</span><span class="cx"> RetainPtr<CFMutableDataRef> keyData = adoptCF(CFDataCreateMutable(kCFAllocatorDefault, key->byteLength()));
</span><span class="cx"> CFDataAppendBytes(keyData.get(), reinterpret_cast<const UInt8*>(key->baseAddress()), key->byteLength());
</span><span class="cx">
</span><del>- // TODO: AVCFAssetResourceLoadingDataRequestRespondWithData(m_request.get(), keyData.get());
- // TODO: AVCFAssetResourceLoadingRequestFinishedLoading(m_request.get());
- notImplemented();
</del><ins>+ AVCFAssetResourceLoadingRequestFinishLoadingWithResponse(m_request.get(), nullptr, keyData.get(), nullptr);
</ins><span class="cx">
</span><span class="cx"> errorCode = MediaPlayer::NoError;
</span><span class="cx"> systemCode = 0;
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfInbandTextTrackPrivateAVCFcpp"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/InbandTextTrackPrivateAVCF.cpp (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/InbandTextTrackPrivateAVCF.cpp        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/InbandTextTrackPrivateAVCF.cpp        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -143,6 +143,9 @@
</span><span class="cx">
</span><span class="cx"> RetainPtr<CFArrayRef> commonMetaData = adoptCF(AVCFMediaSelectionOptionCopyCommonMetadata(mediaSelectionOption()));
</span><span class="cx"> RetainPtr<CFArrayRef> titles = adoptCF(AVCFMetadataItemCopyItemsWithKeyAndKeySpace(commonMetaData.get(), AVCFMetadataCommonKeyTitle, AVCFMetadataKeySpaceCommon));
</span><ins>+ if (!titles)
+ return emptyAtom;
+
</ins><span class="cx"> CFIndex titlesCount = CFArrayGetCount(titles.get());
</span><span class="cx"> if (!titlesCount)
</span><span class="cx"> return emptyAtom;
</span><span class="lines">@@ -170,6 +173,9 @@
</span><span class="cx"> return emptyAtom;
</span><span class="cx">
</span><span class="cx"> RetainPtr<CFLocaleRef> locale = adoptCF(AVCFMediaSelectionOptionCopyLocale(mediaSelectionOption()));
</span><ins>+ if (!locale)
+ return emptyAtom;
+
</ins><span class="cx"> return CFLocaleGetIdentifier(locale.get());
</span><span class="cx"> }
</span><span class="cx">
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfMediaPlayerPrivateAVFoundationCFcpp"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.cpp (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.cpp        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.cpp        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -152,6 +152,7 @@
</span><span class="cx">
</span><span class="cx"> #if ENABLE(ENCRYPTED_MEDIA_V2)
</span><span class="cx"> RetainPtr<AVCFAssetResourceLoadingRequestRef> takeRequestForKeyURI(const String&);
</span><ins>+ void setRequestForKey(const String& keyURI, AVCFAssetResourceLoadingRequestRef avRequest);
</ins><span class="cx"> #endif
</span><span class="cx">
</span><span class="cx"> private:
</span><span class="lines">@@ -196,7 +197,8 @@
</span><span class="cx"> InbandTextTrackPrivateAVF* m_currentTextTrack;
</span><span class="cx">
</span><span class="cx"> #if ENABLE(ENCRYPTED_MEDIA_V2)
</span><del>- HashMap<String, RetainPtr<AVCFAssetResourceLoadingRequestRef>> m_keyURIToRequestMap;
</del><ins>+ HashMap<String, Vector<RetainPtr<AVCFAssetResourceLoadingRequestRef>>> m_keyURIToRequestMap;
+ AVCFAssetResourceLoaderCallbacks m_resourceLoaderCallbacks;
</ins><span class="cx"> #endif
</span><span class="cx"> };
</span><span class="cx">
</span><span class="lines">@@ -341,7 +343,7 @@
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::registerMediaEngine(MediaEngineRegistrar registrar)
</span><span class="cx"> {
</span><span class="cx"> if (isAvailable())
</span><del>- registrar(create, getSupportedTypes, supportsType, 0, 0, 0, 0);
</del><ins>+ registrar(create, getSupportedTypes, supportsType, 0, 0, 0, supportsKeySystem);
</ins><span class="cx"> }
</span><span class="cx">
</span><span class="cx"> MediaPlayerPrivateAVFoundationCF::MediaPlayerPrivateAVFoundationCF(MediaPlayer* player)
</span><span class="lines">@@ -406,6 +408,7 @@
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::createContextVideoRenderer()
</span><span class="cx"> {
</span><span class="cx"> LOG(Media, "MediaPlayerPrivateAVFoundationCF::createContextVideoRenderer(%p)", this);
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx">
</span><span class="cx"> if (imageGenerator(m_avfWrapper))
</span><span class="cx"> return;
</span><span class="lines">@@ -416,12 +419,14 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::destroyContextVideoRenderer()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (m_avfWrapper)
</span><span class="cx"> m_avfWrapper->destroyImageGenerator();
</span><span class="cx"> }
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::createVideoLayer()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(supportsAcceleratedRendering());
</span><span class="cx">
</span><span class="cx"> if (m_avfWrapper)
</span><span class="lines">@@ -430,6 +435,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::destroyVideoLayer()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> LOG(Media, "MediaPlayerPrivateAVFoundationCF::destroyVideoLayer(%p) - destroying %p", this, videoLayer(m_avfWrapper));
</span><span class="cx"> if (m_avfWrapper)
</span><span class="cx"> m_avfWrapper->destroyVideoLayer();
</span><span class="lines">@@ -469,6 +475,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::createAVPlayer()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(m_avfWrapper);
</span><span class="cx">
</span><span class="cx"> setDelayCallbacks(true);
</span><span class="lines">@@ -478,6 +485,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::createAVPlayerItem()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(m_avfWrapper);
</span><span class="cx">
</span><span class="cx"> setDelayCallbacks(true);
</span><span class="lines">@@ -528,6 +536,7 @@
</span><span class="cx">
</span><span class="cx"> PlatformLayer* MediaPlayerPrivateAVFoundationCF::platformLayer() const
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (!m_avfWrapper)
</span><span class="cx"> return 0;
</span><span class="cx">
</span><span class="lines">@@ -536,6 +545,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::platformSetVisible(bool isVisible)
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (!m_avfWrapper)
</span><span class="cx"> return;
</span><span class="cx">
</span><span class="lines">@@ -828,6 +838,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::paintCurrentFrameInContext(GraphicsContext* context, const IntRect& rect)
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (!metaDataAvailable() || context->paintingDisabled())
</span><span class="cx"> return;
</span><span class="cx">
</span><span class="lines">@@ -842,6 +853,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::paint(GraphicsContext* context, const IntRect& rect)
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (!metaDataAvailable() || context->paintingDisabled() || !imageGenerator(m_avfWrapper))
</span><span class="cx"> return;
</span><span class="cx">
</span><span class="lines">@@ -910,7 +922,26 @@
</span><span class="cx"> return MediaPlayer::IsNotSupported;
</span><span class="cx"> }
</span><span class="cx">
</span><ins>+bool MediaPlayerPrivateAVFoundationCF::supportsKeySystem(const String& keySystem, const String& mimeType)
+{
+#if ENABLE(ENCRYPTED_MEDIA) || ENABLE(ENCRYPTED_MEDIA_V2)
+ if (keySystem.isEmpty())
+ return false;
</ins><span class="cx">
</span><ins>+ if (!keySystemIsSupported(keySystem))
+ return false;
+
+ if (!mimeType.isEmpty() && !mimeTypeCache().contains(mimeType))
+ return false;
+
+ return true;
+#else
+ UNUSED_PARAM(keySystem);
+ UNUSED_PARAM(mimeType);
+ return false;
+#endif
+}
+
</ins><span class="cx"> bool MediaPlayerPrivateAVFoundationCF::isAvailable()
</span><span class="cx"> {
</span><span class="cx"> return AVFoundationCFLibrary() && CoreMediaLibrary();
</span><span class="lines">@@ -1036,6 +1067,7 @@
</span><span class="cx">
</span><span class="cx"> void MediaPlayerPrivateAVFoundationCF::sizeChanged()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (!avAsset(m_avfWrapper))
</span><span class="cx"> return;
</span><span class="cx">
</span><span class="lines">@@ -1156,11 +1188,8 @@
</span><span class="cx">
</span><span class="cx"> // We enabled automatic media selection because we want alternate audio tracks to be enabled/disabled automatically,
</span><span class="cx"> // but set the selected legible track to nil so text tracks will not be automatically configured.
</span><del>- if (!m_textTracks.size()) {
- ASSERT(AVCFMediaSelectionGroupAllowsEmptySelection(legibleGroup));
- AVCFPlayerItemRef playerItem = avPlayerItem(m_avfWrapper);
-
- if (playerItem)
</del><ins>+ if (!m_textTracks.size() && AVCFMediaSelectionGroupAllowsEmptySelection(legibleGroup)) {
+ if (AVCFPlayerItemRef playerItem = avPlayerItem(m_avfWrapper))
</ins><span class="cx"> AVCFPlayerItemSelectMediaOptionInMediaSelectionGroup(playerItem, 0, legibleGroup);
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -1284,6 +1313,13 @@
</span><span class="cx"> LOG(Media, "AVFWrapper::AVFWrapper(%p)", this);
</span><span class="cx">
</span><span class="cx"> m_notificationQueue = dispatch_queue_create("MediaPlayerPrivateAVFoundationCF.notificationQueue", 0);
</span><ins>+
+#if HAVE(AVFOUNDATION_LOADER_DELEGATE)
+ m_resourceLoaderCallbacks.version = kAVCFAssetResourceLoader_CallbacksVersion_1;
+ m_resourceLoaderCallbacks.context = nullptr;
+ m_resourceLoaderCallbacks.resourceLoaderShouldWaitForLoadingOfRequestedResource = AVFWrapper::resourceLoaderShouldWaitForLoadingOfRequestedResource;
+#endif
+
</ins><span class="cx"> addToMap();
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -1430,14 +1466,11 @@
</span><span class="cx"> m_avAsset = adoptCF(AVCFURLAssetCreateWithURLAndOptions(kCFAllocatorDefault, urlRef.get(), optionsRef.get(), m_notificationQueue));
</span><span class="cx">
</span><span class="cx"> #if HAVE(AVFOUNDATION_LOADER_DELEGATE)
</span><del>- AVCFAssetResourceLoaderCallbacks loaderCallbacks;
- loaderCallbacks.version = kAVCFAssetResourceLoader_CallbacksVersion_1;
</del><span class="cx"> ASSERT(callbackContext());
</span><del>- loaderCallbacks.context = callbackContext();
- loaderCallbacks.resourceLoaderShouldWaitForLoadingOfRequestedResource = AVFWrapper::resourceLoaderShouldWaitForLoadingOfRequestedResource;
</del><ins>+ m_resourceLoaderCallbacks.context = callbackContext();
</ins><span class="cx">
</span><span class="cx"> AVCFAssetResourceLoaderRef resourceLoader = AVCFURLAssetGetResourceLoader(m_avAsset.get());
</span><del>- AVCFAssetResourceLoaderSetCallbacks(resourceLoader, &loaderCallbacks, globalLoaderDelegateQueue());
</del><ins>+ AVCFAssetResourceLoaderSetCallbacks(resourceLoader, &m_resourceLoaderCallbacks, globalLoaderDelegateQueue());
</ins><span class="cx"> #endif
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -1561,7 +1594,7 @@
</span><span class="cx">
</span><span class="cx"> void AVFWrapper::processNotification(void* context)
</span><span class="cx"> {
</span><del>- ASSERT(dispatch_get_main_queue() == dispatch_get_current_queue());
</del><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(context);
</span><span class="cx">
</span><span class="cx"> if (!context)
</span><span class="lines">@@ -1707,7 +1740,7 @@
</span><span class="cx">
</span><span class="cx"> void AVFWrapper::processCue(void* context)
</span><span class="cx"> {
</span><del>- ASSERT(dispatch_get_main_queue() == dispatch_get_current_queue());
</del><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(context);
</span><span class="cx">
</span><span class="cx"> if (!context)
</span><span class="lines">@@ -1730,7 +1763,7 @@
</span><span class="cx">
</span><span class="cx"> void AVFWrapper::legibleOutputCallback(void* context, AVCFPlayerItemLegibleOutputRef legibleOutput, CFArrayRef attributedStrings, CFArrayRef nativeSampleBuffers, CMTime itemTime)
</span><span class="cx"> {
</span><del>- ASSERT(dispatch_get_main_queue() != dispatch_get_current_queue());
</del><ins>+ ASSERT(!isMainThread());
</ins><span class="cx"> MutexLocker locker(mapLock());
</span><span class="cx"> AVFWrapper* self = avfWrapperForCallbackContext(context);
</span><span class="cx"> if (!self) {
</span><span class="lines">@@ -1773,12 +1806,15 @@
</span><span class="cx"> AVFWrapper* self = avfWrapperForCallbackContext(loadRequestData->m_context);
</span><span class="cx"> if (!self) {
</span><span class="cx"> LOG(Media, "AVFWrapper::processShouldWaitForLoadingOfResource invoked for deleted AVFWrapper %d", reinterpret_cast<uintptr_t>(context));
</span><del>- AVCFAssetResourceLoadingRequestFinishLoadingWithError(loadRequestData->m_request.get(), nullptr);
</del><ins>+ RetainPtr<CFErrorRef> error = adoptCF(CFErrorCreate(kCFAllocatorDefault, kCFErrorDomainCFNetwork, kCFURLErrorUnknown, nullptr));
+ AVCFAssetResourceLoadingRequestFinishLoadingWithError(loadRequestData->m_request.get(), error.get());
</ins><span class="cx"> return;
</span><span class="cx"> }
</span><span class="cx">
</span><del>- if (!self->shouldWaitForLoadingOfResource(loadRequestData->m_request.get()))
- AVCFAssetResourceLoadingRequestFinishLoadingWithError(loadRequestData->m_request.get(), nullptr);
</del><ins>+ if (!self->shouldWaitForLoadingOfResource(loadRequestData->m_request.get())) {
+ RetainPtr<CFErrorRef> error = adoptCF(CFErrorCreate(kCFAllocatorDefault, kCFErrorDomainCFNetwork, kCFURLErrorUnknown, nullptr));
+ AVCFAssetResourceLoadingRequestFinishLoadingWithError(loadRequestData->m_request.get(), error.get());
+ }
</ins><span class="cx"> }
</span><span class="cx">
</span><span class="cx"> bool AVFWrapper::shouldWaitForLoadingOfResource(AVCFAssetResourceLoadingRequestRef avRequest)
</span><span class="lines">@@ -1808,7 +1844,7 @@
</span><span class="cx"> if (!m_owner->player()->keyNeeded(initData.get()))
</span><span class="cx"> return false;
</span><span class="cx">
</span><del>- m_keyURIToRequestMap.set(keyURI, avRequest);
</del><ins>+ setRequestForKey(keyURI, avRequest);
</ins><span class="cx"> return true;
</span><span class="cx"> }
</span><span class="cx"> #endif
</span><span class="lines">@@ -1850,6 +1886,7 @@
</span><span class="cx">
</span><span class="cx"> PlatformLayer* AVFWrapper::platformLayer()
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> if (m_videoLayerWrapper)
</span><span class="cx"> return m_videoLayerWrapper->platformLayer();
</span><span class="cx">
</span><span class="lines">@@ -1980,14 +2017,36 @@
</span><span class="cx"> }
</span><span class="cx">
</span><span class="cx"> #if ENABLE(ENCRYPTED_MEDIA_V2)
</span><ins>+void AVFWrapper::setRequestForKey(const String& keyURI, AVCFAssetResourceLoadingRequestRef avRequest)
+{
+ auto requestsIterator = m_keyURIToRequestMap.find(keyURI);
+ if (requestsIterator != m_keyURIToRequestMap.end()) {
+ requestsIterator->value.append(avRequest);
+ return;
+ }
+
+ Vector<RetainPtr<AVCFAssetResourceLoadingRequestRef>> requests;
+ requests.append(avRequest);
+ m_keyURIToRequestMap.set(keyURI, requests);
+}
+
</ins><span class="cx"> RetainPtr<AVCFAssetResourceLoadingRequestRef> AVFWrapper::takeRequestForKeyURI(const String& keyURI)
</span><span class="cx"> {
</span><del>- return m_keyURIToRequestMap.take(keyURI);
</del><ins>+ auto requestsIterator = m_keyURIToRequestMap.find(keyURI);
+ if (requestsIterator == m_keyURIToRequestMap.end())
+ return RetainPtr<AVCFAssetResourceLoadingRequestRef>();
+
+ auto request = requestsIterator->value.takeLast();
+ if (requestsIterator->value.isEmpty())
+ m_keyURIToRequestMap.take(keyURI);
+
+ return request;
</ins><span class="cx"> }
</span><span class="cx"> #endif
</span><span class="cx">
</span><span class="cx"> void LayerClient::platformCALayerLayoutSublayersOfLayer(PlatformCALayer* wrapperLayer)
</span><span class="cx"> {
</span><ins>+ ASSERT(isMainThread());
</ins><span class="cx"> ASSERT(m_parent);
</span><span class="cx"> ASSERT(m_parent->videoLayerWrapper() == wrapperLayer->platformLayer());
</span><span class="cx">
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfMediaPlayerPrivateAVFoundationCFh"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.h (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.h        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/MediaPlayerPrivateAVFoundationCF.h        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -64,6 +64,7 @@
</span><span class="cx"> static PassOwnPtr<MediaPlayerPrivateInterface> create(MediaPlayer*);
</span><span class="cx"> static void getSupportedTypes(HashSet<String>& types);
</span><span class="cx"> static MediaPlayer::SupportsType supportsType(const MediaEngineSupportParameters&);
</span><ins>+ static bool supportsKeySystem(const String& keySystem, const String& mimeType);
</ins><span class="cx"> static bool isAvailable();
</span><span class="cx">
</span><span class="cx"> virtual void cancelLoad();
</span></span></pre></div>
<a id="branchessafari6005branchSourceWebCoreplatformgraphicsavfoundationcfWebCoreAVCFResourceLoadercpp"></a>
<div class="modfile"><h4>Modified: branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/WebCoreAVCFResourceLoader.cpp (178553 => 178554)</h4>
<pre class="diff"><span>
<span class="info">--- branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/WebCoreAVCFResourceLoader.cpp        2015-01-16 01:58:00 UTC (rev 178553)
+++ branches/safari-600.5-branch/Source/WebCore/platform/graphics/avfoundation/cf/WebCoreAVCFResourceLoader.cpp        2015-01-16 01:58:05 UTC (rev 178554)
</span><span class="lines">@@ -81,7 +81,8 @@
</span><span class="cx"> m_resource->addClient(this);
</span><span class="cx"> else {
</span><span class="cx"> LOG_ERROR("Failed to start load for media at url %s", requestURL.string().ascii().data());
</span><del>- AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), nullptr);
</del><ins>+ RetainPtr<CFErrorRef> error = adoptCF(CFErrorCreate(kCFAllocatorDefault, kCFErrorDomainCFNetwork, kCFURLErrorUnknown, nullptr));
+ AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), error.get());
</ins><span class="cx"> }
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -110,7 +111,8 @@
</span><span class="cx">
</span><span class="cx"> int status = response.httpStatusCode();
</span><span class="cx"> if (status && (status < 200 || status > 299)) {
</span><del>- AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), nullptr);
</del><ins>+ RetainPtr<CFErrorRef> error = adoptCF(CFErrorCreate(kCFAllocatorDefault, kCFErrorDomainCFNetwork, status, nullptr));
+ AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), error.get());
</ins><span class="cx"> return;
</span><span class="cx"> }
</span><span class="cx">
</span><span class="lines">@@ -131,7 +133,8 @@
</span><span class="cx"> // FIXME: [[m_avRequest.get() contentInformationRequest] setContentType:@""];
</span><span class="cx"> notImplemented();
</span><span class="cx">
</span><del>- AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), nullptr);
</del><ins>+ RetainPtr<CFErrorRef> error = adoptCF(CFErrorCreate(kCFAllocatorDefault, kCFErrorDomainCFNetwork, kCFURLErrorUnknown, nullptr));
+ AVCFAssetResourceLoadingRequestFinishLoadingWithError(m_avRequest.get(), error.get());
</ins><span class="cx"> } else {
</span><span class="cx"> fulfillRequestWithResource(resource);
</span><span class="cx"> // FIXME: [m_avRequest.get() finishLoading];
</span></span></pre>
</div>
</div>
</body>
</html>