forked from mirrors/gecko-dev
Bug 1659438 introduced an exported function `GetDependentModulePaths` in firefox.exe so that our sandboxBroker can easily access the shared section whose handle is owned by firefox.exe. This patch disallows `GetDependentModulePaths` to be called from someone other than xul.dll in order to harden the attack to tamper our shared section. This cannot prevent all possible attacks, but it's better than nothing. Differential Revision: https://phabricator.services.mozilla.com/D97377
30 lines
925 B
C++
30 lines
925 B
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 https://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "mozilla/LoaderAPIInterfaces.h"
|
|
|
|
#include "freestanding/CheckForCaller.h"
|
|
#include "freestanding/LoaderPrivateAPI.h"
|
|
|
|
namespace mozilla {
|
|
|
|
extern "C" MOZ_EXPORT nt::LoaderAPI* GetNtLoaderAPI(
|
|
nt::LoaderObserver* aNewObserver) {
|
|
const bool isCallerMozglue =
|
|
CheckForAddress(RETURN_ADDRESS(), L"mozglue.dll");
|
|
MOZ_ASSERT(isCallerMozglue);
|
|
if (!isCallerMozglue) {
|
|
return nullptr;
|
|
}
|
|
|
|
freestanding::EnsureInitialized();
|
|
freestanding::LoaderPrivateAPI& api = freestanding::gLoaderPrivateAPI;
|
|
api.SetObserver(aNewObserver);
|
|
|
|
return &api;
|
|
}
|
|
|
|
} // namespace mozilla
|