| Index: third_party/WebKit/Source/core/html/HTMLDialogElement.cpp | 
| diff --git a/third_party/WebKit/Source/core/html/HTMLDialogElement.cpp b/third_party/WebKit/Source/core/html/HTMLDialogElement.cpp | 
| index 1d9e1a693d6210291de5c0bb9ecfeb98bd34a60c..3a89cb9840495b448b1bc4dfb5d911e86769ff1c 100644 | 
| --- a/third_party/WebKit/Source/core/html/HTMLDialogElement.cpp | 
| +++ b/third_party/WebKit/Source/core/html/HTMLDialogElement.cpp | 
| @@ -34,6 +34,7 @@ | 
| #include "core/frame/LocalFrameView.h" | 
| #include "core/frame/UseCounter.h" | 
| #include "core/html/HTMLFormControlElement.h" | 
| +#include "core/html/HTMLFrameOwnerElement.h" | 
| #include "core/style/ComputedStyle.h" | 
|  | 
| namespace blink { | 
| @@ -82,6 +83,13 @@ static void SetFocusForDialog(HTMLDialogElement* dialog) { | 
| } | 
|  | 
| static void InertSubtreesChanged(Document& document) { | 
| +  if (document.GetFrame()) { | 
| +    // SetIsInert recurses through subframes to propagate the inert bit as | 
| +    // needed. | 
| +    document.GetFrame()->SetIsInert(document.LocalOwner() && | 
| +                                    document.LocalOwner()->IsInert()); | 
| +  } | 
| + | 
| // When a modal dialog opens or closes, nodes all over the accessibility | 
| // tree can change inertness which means they must be added or removed from | 
| // the tree. The most foolproof way is to clear the entire tree and rebuild | 
| @@ -189,7 +197,7 @@ void HTMLDialogElement::showModal(ExceptionState& exception_state) { | 
| void HTMLDialogElement::RemovedFrom(ContainerNode* insertion_point) { | 
| HTMLElement::RemovedFrom(insertion_point); | 
| SetNotCentered(); | 
| -  // FIXME: We should call inertSubtreesChanged() here. | 
| +  InertSubtreesChanged(GetDocument()); | 
| } | 
|  | 
| void HTMLDialogElement::SetCentered(LayoutUnit centered_position) { | 
|  |