2011-10-06 02:15:45 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2011-09-30 11:00:48 +04:00
|
|
|
/* vim: set sw=2 ts=8 et ft=cpp : */
|
2012-02-10 14:04:44 +04:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
2012-02-02 10:09:00 +04:00
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
2012-02-10 14:04:44 +04:00
|
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2011-10-06 02:15:45 +04:00
|
|
|
|
|
|
|
#ifndef mozilla_Hal_h
|
2012-02-10 14:04:44 +04:00
|
|
|
#define mozilla_Hal_h
|
2011-10-06 02:15:45 +04:00
|
|
|
|
|
|
|
#include "base/basictypes.h"
|
2015-05-07 16:53:47 +03:00
|
|
|
#include "base/platform_thread.h"
|
2011-10-06 02:15:45 +04:00
|
|
|
#include "nsTArray.h"
|
2011-11-02 19:14:01 +04:00
|
|
|
#include "mozilla/dom/battery/Types.h"
|
2016-02-15 09:33:00 +03:00
|
|
|
#include "mozilla/dom/MozPowerManagerBinding.h"
|
2012-01-16 17:39:57 +04:00
|
|
|
#include "mozilla/dom/network/Types.h"
|
2012-03-07 15:03:25 +04:00
|
|
|
#include "mozilla/dom/power/Types.h"
|
2012-03-13 20:42:46 +04:00
|
|
|
#include "mozilla/dom/ScreenOrientation.h"
|
2016-02-15 09:33:00 +03:00
|
|
|
#include "mozilla/hal_sandbox/PHal.h"
|
2013-11-01 06:07:10 +04:00
|
|
|
#include "mozilla/HalScreenConfiguration.h"
|
2016-02-15 09:33:00 +03:00
|
|
|
#include "mozilla/HalTypes.h"
|
|
|
|
#include "mozilla/Observer.h"
|
|
|
|
#include "mozilla/Types.h"
|
2011-10-06 02:15:45 +04:00
|
|
|
|
2011-12-18 01:04:51 +04:00
|
|
|
/*
|
|
|
|
* Hal.h contains the public Hal API.
|
|
|
|
*
|
|
|
|
* By default, this file defines its functions in the hal namespace, but if
|
|
|
|
* MOZ_HAL_NAMESPACE is defined, we'll define our functions in that namespace.
|
|
|
|
*
|
|
|
|
* This is used by HalImpl.h and HalSandbox.h, which define copies of all the
|
|
|
|
* functions here in the hal_impl and hal_sandbox namespaces.
|
|
|
|
*/
|
2011-09-30 11:00:48 +04:00
|
|
|
|
2016-01-30 20:05:36 +03:00
|
|
|
class nsPIDOMWindowInner;
|
2011-12-18 01:04:26 +04:00
|
|
|
|
2011-12-18 01:04:51 +04:00
|
|
|
#ifndef MOZ_HAL_NAMESPACE
|
2011-10-06 02:15:45 +04:00
|
|
|
# define MOZ_HAL_NAMESPACE hal
|
|
|
|
# define MOZ_DEFINED_HAL_NAMESPACE 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace mozilla {
|
2011-11-02 19:14:01 +04:00
|
|
|
|
|
|
|
namespace hal {
|
2011-12-18 01:04:51 +04:00
|
|
|
|
|
|
|
class WindowIdentifier;
|
|
|
|
|
2012-10-23 11:15:43 +04:00
|
|
|
typedef Observer<int64_t> SystemClockChangeObserver;
|
|
|
|
typedef Observer<SystemTimezoneChangeInformation> SystemTimezoneChangeObserver;
|
2012-09-11 10:40:00 +04:00
|
|
|
|
2011-11-02 19:14:01 +04:00
|
|
|
} // namespace hal
|
|
|
|
|
2011-12-18 01:04:51 +04:00
|
|
|
namespace MOZ_HAL_NAMESPACE {
|
2011-10-06 02:15:45 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Turn the default vibrator device on/off per the pattern specified
|
|
|
|
* by |pattern|. Each element in the pattern is the number of
|
|
|
|
* milliseconds to turn the vibrator on or off. The first element in
|
|
|
|
* |pattern| is an "on" element, the next is "off", and so on.
|
|
|
|
*
|
|
|
|
* If |pattern| is empty, any in-progress vibration is canceled.
|
2011-09-30 11:00:48 +04:00
|
|
|
*
|
|
|
|
* Only an active window within an active tab may call Vibrate; calls
|
|
|
|
* from inactive windows and windows on inactive tabs do nothing.
|
|
|
|
*
|
|
|
|
* If you're calling hal::Vibrate from the outside world, pass an
|
2011-12-18 01:04:26 +04:00
|
|
|
* nsIDOMWindow* in place of the WindowIdentifier parameter.
|
|
|
|
* The method with WindowIdentifier will be called automatically.
|
2011-10-06 02:15:45 +04:00
|
|
|
*/
|
2012-05-25 11:18:30 +04:00
|
|
|
void Vibrate(const nsTArray<uint32_t>& pattern,
|
2016-01-30 20:05:36 +03:00
|
|
|
nsPIDOMWindowInner* aWindow);
|
2012-05-25 11:18:30 +04:00
|
|
|
void Vibrate(const nsTArray<uint32_t>& pattern,
|
2011-09-30 11:00:48 +04:00
|
|
|
const hal::WindowIdentifier &id);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Cancel a vibration started by the content window identified by
|
|
|
|
* WindowIdentifier.
|
|
|
|
*
|
|
|
|
* If the window was the last window to start a vibration, the
|
|
|
|
* cancellation request will go through even if the window is not
|
|
|
|
* active.
|
|
|
|
*
|
2011-12-18 01:04:26 +04:00
|
|
|
* As with hal::Vibrate(), if you're calling hal::CancelVibrate from the outside
|
|
|
|
* world, pass an nsIDOMWindow*. The method with WindowIdentifier will be called
|
|
|
|
* automatically.
|
2011-09-30 11:00:48 +04:00
|
|
|
*/
|
2016-01-30 20:05:36 +03:00
|
|
|
void CancelVibrate(nsPIDOMWindowInner* aWindow);
|
2011-09-30 11:00:48 +04:00
|
|
|
void CancelVibrate(const hal::WindowIdentifier &id);
|
2011-10-06 02:15:45 +04:00
|
|
|
|
2011-11-02 19:14:01 +04:00
|
|
|
/**
|
|
|
|
* Inform the battery backend there is a new battery observer.
|
|
|
|
* @param aBatteryObserver The observer that should be added.
|
|
|
|
*/
|
|
|
|
void RegisterBatteryObserver(BatteryObserver* aBatteryObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inform the battery backend a battery observer unregistered.
|
|
|
|
* @param aBatteryObserver The observer that should be removed.
|
|
|
|
*/
|
|
|
|
void UnregisterBatteryObserver(BatteryObserver* aBatteryObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current battery information.
|
|
|
|
*/
|
|
|
|
void GetCurrentBatteryInformation(hal::BatteryInformation* aBatteryInfo);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notify of a change in the battery state.
|
|
|
|
* @param aBatteryInfo The new battery information.
|
|
|
|
*/
|
|
|
|
void NotifyBatteryChange(const hal::BatteryInformation& aBatteryInfo);
|
|
|
|
|
2011-12-04 21:07:00 +04:00
|
|
|
/**
|
|
|
|
* Determine whether the device's screen is currently enabled.
|
|
|
|
*/
|
|
|
|
bool GetScreenEnabled();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable or disable the device's screen.
|
|
|
|
*
|
|
|
|
* Note that it may take a few seconds for the screen to turn on or off.
|
|
|
|
*/
|
2014-05-30 07:11:23 +04:00
|
|
|
void SetScreenEnabled(bool aEnabled);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine whether the device's keypad/button backlight is currently enabled.
|
|
|
|
*/
|
|
|
|
bool GetKeyLightEnabled();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable or disable the device's keypad/button backlight.
|
|
|
|
*/
|
|
|
|
void SetKeyLightEnabled(bool aEnabled);
|
2011-12-04 21:07:00 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the brightness of the device's screen's backlight, on a scale from 0
|
|
|
|
* (very dim) to 1 (full blast).
|
|
|
|
*
|
|
|
|
* If the display is currently disabled, this returns the brightness the
|
|
|
|
* backlight will have when the display is re-enabled.
|
|
|
|
*/
|
|
|
|
double GetScreenBrightness();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the brightness of the device's screen's backlight, on a scale from 0
|
|
|
|
* (very dimm) to 1 (full blast). Values larger than 1 are treated like 1, and
|
|
|
|
* values smaller than 0 are treated like 0.
|
|
|
|
*
|
|
|
|
* Note that we may reduce the resolution of the given brightness value before
|
|
|
|
* sending it to the screen. Therefore if you call SetScreenBrightness(x)
|
|
|
|
* followed by GetScreenBrightness(), the value returned by
|
|
|
|
* GetScreenBrightness() may not be exactly x.
|
|
|
|
*/
|
2014-05-30 07:11:23 +04:00
|
|
|
void SetScreenBrightness(double aBrightness);
|
2011-12-04 21:07:00 +04:00
|
|
|
|
2012-04-17 02:35:33 +04:00
|
|
|
/**
|
|
|
|
* Determine whether the device is allowed to sleep.
|
|
|
|
*/
|
|
|
|
bool GetCpuSleepAllowed();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set whether the device is allowed to suspend automatically after
|
|
|
|
* the screen is disabled.
|
|
|
|
*/
|
2014-05-30 07:11:23 +04:00
|
|
|
void SetCpuSleepAllowed(bool aAllowed);
|
2012-04-17 02:35:33 +04:00
|
|
|
|
2012-02-05 23:51:06 +04:00
|
|
|
/**
|
|
|
|
* Register an observer for the sensor of given type.
|
|
|
|
*
|
|
|
|
* The observer will receive data whenever the data generated by the
|
|
|
|
* sensor is avaiable.
|
|
|
|
*/
|
|
|
|
void RegisterSensorObserver(hal::SensorType aSensor,
|
|
|
|
hal::ISensorObserver *aObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unregister an observer for the sensor of given type.
|
|
|
|
*/
|
|
|
|
void UnregisterSensorObserver(hal::SensorType aSensor,
|
|
|
|
hal::ISensorObserver *aObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Post a value generated by a sensor.
|
|
|
|
*
|
|
|
|
* This API is internal to hal; clients shouldn't call it directly.
|
|
|
|
*/
|
|
|
|
void NotifySensorChange(const hal::SensorData &aSensorData);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable sensor notifications from the backend
|
|
|
|
*
|
|
|
|
* This method is only visible from implementation of sensor manager.
|
|
|
|
* Rest of the system should not try this.
|
|
|
|
*/
|
|
|
|
void EnableSensorNotifications(hal::SensorType aSensor);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable sensor notifications from the backend
|
|
|
|
*
|
|
|
|
* This method is only visible from implementation of sensor manager.
|
|
|
|
* Rest of the system should not try this.
|
|
|
|
*/
|
|
|
|
void DisableSensorNotifications(hal::SensorType aSensor);
|
|
|
|
|
|
|
|
|
2012-01-16 17:39:57 +04:00
|
|
|
/**
|
|
|
|
* Inform the network backend there is a new network observer.
|
|
|
|
* @param aNetworkObserver The observer that should be added.
|
|
|
|
*/
|
|
|
|
void RegisterNetworkObserver(NetworkObserver* aNetworkObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inform the network backend a network observer unregistered.
|
|
|
|
* @param aNetworkObserver The observer that should be removed.
|
|
|
|
*/
|
|
|
|
void UnregisterNetworkObserver(NetworkObserver* aNetworkObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current network information.
|
|
|
|
*/
|
|
|
|
void GetCurrentNetworkInformation(hal::NetworkInformation* aNetworkInfo);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notify of a change in the network state.
|
|
|
|
* @param aNetworkInfo The new network information.
|
|
|
|
*/
|
|
|
|
void NotifyNetworkChange(const hal::NetworkInformation& aNetworkInfo);
|
|
|
|
|
2012-02-17 14:44:00 +04:00
|
|
|
/**
|
|
|
|
* Adjusting system clock.
|
|
|
|
* @param aDeltaMilliseconds The difference compared with current system clock.
|
|
|
|
*/
|
2012-09-26 07:51:29 +04:00
|
|
|
void AdjustSystemClock(int64_t aDeltaMilliseconds);
|
2012-02-17 14:44:00 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set timezone
|
2013-05-10 02:57:31 +04:00
|
|
|
* @param aTimezoneSpec The definition can be found in
|
2012-02-17 14:44:00 +04:00
|
|
|
* http://en.wikipedia.org/wiki/List_of_tz_database_time_zones
|
|
|
|
*/
|
|
|
|
void SetTimezone(const nsCString& aTimezoneSpec);
|
|
|
|
|
2012-08-23 13:00:00 +04:00
|
|
|
/**
|
|
|
|
* Get timezone
|
|
|
|
* http://en.wikipedia.org/wiki/List_of_tz_database_time_zones
|
|
|
|
*/
|
|
|
|
nsCString GetTimezone();
|
|
|
|
|
2013-10-15 12:43:53 +04:00
|
|
|
/**
|
|
|
|
* Get timezone offset
|
|
|
|
* returns the timezone offset relative to UTC in minutes (DST effect included)
|
|
|
|
*/
|
|
|
|
int32_t GetTimezoneOffset();
|
|
|
|
|
2012-09-11 10:40:00 +04:00
|
|
|
/**
|
2012-10-23 11:15:43 +04:00
|
|
|
* Register observer for system clock changed notification.
|
2012-09-11 10:40:00 +04:00
|
|
|
* @param aObserver The observer that should be added.
|
|
|
|
*/
|
2012-10-23 11:15:43 +04:00
|
|
|
void RegisterSystemClockChangeObserver(
|
|
|
|
hal::SystemClockChangeObserver* aObserver);
|
2012-09-11 10:40:00 +04:00
|
|
|
|
|
|
|
/**
|
2012-10-23 11:15:43 +04:00
|
|
|
* Unregister the observer for system clock changed.
|
2012-09-11 10:40:00 +04:00
|
|
|
* @param aObserver The observer that should be removed.
|
|
|
|
*/
|
2012-10-23 11:15:43 +04:00
|
|
|
void UnregisterSystemClockChangeObserver(
|
|
|
|
hal::SystemClockChangeObserver* aObserver);
|
2012-09-11 10:40:00 +04:00
|
|
|
|
|
|
|
/**
|
2012-10-23 11:15:43 +04:00
|
|
|
* Notify of a change in the system clock.
|
|
|
|
* @param aClockDeltaMS
|
2012-09-11 10:40:00 +04:00
|
|
|
*/
|
2012-10-23 11:15:43 +04:00
|
|
|
void NotifySystemClockChange(const int64_t& aClockDeltaMS);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Register observer for system timezone changed notification.
|
|
|
|
* @param aObserver The observer that should be added.
|
|
|
|
*/
|
|
|
|
void RegisterSystemTimezoneChangeObserver(
|
|
|
|
hal::SystemTimezoneChangeObserver* aObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unregister the observer for system timezone changed.
|
|
|
|
* @param aObserver The observer that should be removed.
|
|
|
|
*/
|
|
|
|
void UnregisterSystemTimezoneChangeObserver(
|
|
|
|
hal::SystemTimezoneChangeObserver* aObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notify of a change in the system timezone.
|
|
|
|
* @param aSystemTimezoneChangeInfo
|
|
|
|
*/
|
|
|
|
void NotifySystemTimezoneChange(
|
|
|
|
const hal::SystemTimezoneChangeInformation& aSystemTimezoneChangeInfo);
|
2012-09-11 10:40:00 +04:00
|
|
|
|
2012-01-31 10:08:00 +04:00
|
|
|
/**
|
|
|
|
* Reboot the device.
|
2013-05-10 02:57:31 +04:00
|
|
|
*
|
2012-09-26 13:12:33 +04:00
|
|
|
* This API is currently only allowed to be used from the main process.
|
2012-01-31 10:08:00 +04:00
|
|
|
*/
|
|
|
|
void Reboot();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Power off the device.
|
2013-05-10 02:57:31 +04:00
|
|
|
*
|
2012-09-26 13:12:33 +04:00
|
|
|
* This API is currently only allowed to be used from the main process.
|
2012-01-31 10:08:00 +04:00
|
|
|
*/
|
|
|
|
void PowerOff();
|
|
|
|
|
2012-03-07 15:03:25 +04:00
|
|
|
/**
|
|
|
|
* Enable wake lock notifications from the backend.
|
|
|
|
*
|
|
|
|
* This method is only used by WakeLockObserversManager.
|
|
|
|
*/
|
|
|
|
void EnableWakeLockNotifications();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable wake lock notifications from the backend.
|
|
|
|
*
|
|
|
|
* This method is only used by WakeLockObserversManager.
|
|
|
|
*/
|
|
|
|
void DisableWakeLockNotifications();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inform the wake lock backend there is a new wake lock observer.
|
|
|
|
* @param aWakeLockObserver The observer that should be added.
|
|
|
|
*/
|
|
|
|
void RegisterWakeLockObserver(WakeLockObserver* aObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inform the wake lock backend a wake lock observer unregistered.
|
|
|
|
* @param aWakeLockObserver The observer that should be removed.
|
|
|
|
*/
|
|
|
|
void UnregisterWakeLockObserver(WakeLockObserver* aObserver);
|
|
|
|
|
|
|
|
/**
|
2013-02-15 00:41:30 +04:00
|
|
|
* Adjust a wake lock's counts on behalf of a given process.
|
|
|
|
*
|
|
|
|
* In most cases, you shouldn't need to pass the aProcessID argument; the
|
|
|
|
* default of CONTENT_PROCESS_ID_UNKNOWN is probably what you want.
|
|
|
|
*
|
2012-03-07 15:03:25 +04:00
|
|
|
* @param aTopic lock topic
|
|
|
|
* @param aLockAdjust to increase or decrease active locks
|
|
|
|
* @param aHiddenAdjust to increase or decrease hidden locks
|
2013-02-15 00:41:30 +04:00
|
|
|
* @param aProcessID indicates which process we're modifying the wake lock
|
|
|
|
* on behalf of. It is interpreted as
|
|
|
|
*
|
|
|
|
* CONTENT_PROCESS_ID_UNKNOWN: The current process
|
|
|
|
* CONTENT_PROCESS_ID_MAIN: The root process
|
|
|
|
* X: The process with ContentChild::GetID() == X
|
2012-03-07 15:03:25 +04:00
|
|
|
*/
|
|
|
|
void ModifyWakeLock(const nsAString &aTopic,
|
|
|
|
hal::WakeLockControl aLockAdjust,
|
2013-02-15 00:41:30 +04:00
|
|
|
hal::WakeLockControl aHiddenAdjust,
|
2013-02-15 00:41:30 +04:00
|
|
|
uint64_t aProcessID = hal::CONTENT_PROCESS_ID_UNKNOWN);
|
2012-11-17 19:05:18 +04:00
|
|
|
|
2012-03-07 15:03:25 +04:00
|
|
|
/**
|
|
|
|
* Query the wake lock numbers of aTopic.
|
|
|
|
* @param aTopic lock topic
|
|
|
|
* @param aWakeLockInfo wake lock numbers
|
|
|
|
*/
|
|
|
|
void GetWakeLockInfo(const nsAString &aTopic, hal::WakeLockInformation *aWakeLockInfo);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Notify of a change in the wake lock state.
|
|
|
|
* @param aWakeLockInfo The new wake lock information.
|
|
|
|
*/
|
|
|
|
void NotifyWakeLockChange(const hal::WakeLockInformation& aWakeLockInfo);
|
|
|
|
|
2012-03-13 20:42:46 +04:00
|
|
|
/**
|
2012-05-09 01:36:07 +04:00
|
|
|
* Inform the backend there is a new screen configuration observer.
|
|
|
|
* @param aScreenConfigurationObserver The observer that should be added.
|
2012-03-13 20:42:46 +04:00
|
|
|
*/
|
2012-05-09 01:36:07 +04:00
|
|
|
void RegisterScreenConfigurationObserver(hal::ScreenConfigurationObserver* aScreenConfigurationObserver);
|
2012-03-13 20:42:46 +04:00
|
|
|
|
|
|
|
/**
|
2012-05-09 01:36:07 +04:00
|
|
|
* Inform the backend a screen configuration observer unregistered.
|
|
|
|
* @param aScreenConfigurationObserver The observer that should be removed.
|
2012-03-13 20:42:46 +04:00
|
|
|
*/
|
2012-05-09 01:36:07 +04:00
|
|
|
void UnregisterScreenConfigurationObserver(hal::ScreenConfigurationObserver* aScreenConfigurationObserver);
|
2012-03-13 20:42:46 +04:00
|
|
|
|
|
|
|
/**
|
2012-05-09 01:36:07 +04:00
|
|
|
* Returns the current screen configuration.
|
2012-03-13 20:42:46 +04:00
|
|
|
*/
|
2012-05-09 01:36:07 +04:00
|
|
|
void GetCurrentScreenConfiguration(hal::ScreenConfiguration* aScreenConfiguration);
|
2012-03-13 20:42:46 +04:00
|
|
|
|
|
|
|
/**
|
2012-05-09 01:36:07 +04:00
|
|
|
* Notify of a change in the screen configuration.
|
|
|
|
* @param aScreenConfiguration The new screen orientation.
|
2012-03-13 20:42:46 +04:00
|
|
|
*/
|
2012-05-09 01:36:07 +04:00
|
|
|
void NotifyScreenConfigurationChange(const hal::ScreenConfiguration& aScreenConfiguration);
|
2012-03-13 20:42:46 +04:00
|
|
|
|
2012-03-29 23:43:16 +04:00
|
|
|
/**
|
|
|
|
* Lock the screen orientation to the specific orientation.
|
|
|
|
* @return Whether the lock has been accepted.
|
|
|
|
*/
|
2016-05-16 12:24:03 +03:00
|
|
|
MOZ_MUST_USE bool LockScreenOrientation(const dom::ScreenOrientationInternal& aOrientation);
|
2012-03-29 23:43:16 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlock the screen orientation.
|
|
|
|
*/
|
|
|
|
void UnlockScreenOrientation();
|
|
|
|
|
2012-04-22 22:09:22 +04:00
|
|
|
/**
|
|
|
|
* Register an observer for the switch of given SwitchDevice.
|
|
|
|
*
|
|
|
|
* The observer will receive data whenever the data generated by the
|
|
|
|
* given switch.
|
|
|
|
*/
|
|
|
|
void RegisterSwitchObserver(hal::SwitchDevice aDevice, hal::SwitchObserver *aSwitchObserver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unregister an observer for the switch of given SwitchDevice.
|
|
|
|
*/
|
|
|
|
void UnregisterSwitchObserver(hal::SwitchDevice aDevice, hal::SwitchObserver *aSwitchObserver);
|
|
|
|
|
|
|
|
/**
|
2013-05-10 02:57:31 +04:00
|
|
|
* Notify the state of the switch.
|
2012-04-22 22:09:22 +04:00
|
|
|
*
|
|
|
|
* This API is internal to hal; clients shouldn't call it directly.
|
|
|
|
*/
|
|
|
|
void NotifySwitchChange(const hal::SwitchEvent& aEvent);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get current switch information.
|
|
|
|
*/
|
|
|
|
hal::SwitchState GetCurrentSwitchState(hal::SwitchDevice aDevice);
|
|
|
|
|
2014-01-20 13:35:24 +04:00
|
|
|
/**
|
|
|
|
* Notify switch status change from input device.
|
|
|
|
*/
|
|
|
|
void NotifySwitchStateFromInputDevice(hal::SwitchDevice aDevice,
|
|
|
|
hal::SwitchState aState);
|
|
|
|
|
2012-08-05 09:09:39 +04:00
|
|
|
/**
|
2015-02-26 14:43:22 +03:00
|
|
|
* Set the priority of the given process.
|
2012-08-05 09:09:39 +04:00
|
|
|
*
|
|
|
|
* Exactly what this does will vary between platforms. On *nix we might give
|
|
|
|
* background processes higher nice values. On other platforms, we might
|
|
|
|
* ignore this call entirely.
|
|
|
|
*/
|
2013-05-10 00:27:06 +04:00
|
|
|
void SetProcessPriority(int aPid,
|
|
|
|
hal::ProcessPriority aPriority,
|
2013-10-01 07:54:59 +04:00
|
|
|
uint32_t aLRU = 0);
|
2012-08-05 09:09:39 +04:00
|
|
|
|
2014-05-05 19:37:00 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the current thread's priority to appropriate platform-specific value for
|
|
|
|
* given functionality. Instead of providing arbitrary priority numbers you
|
|
|
|
* must specify a type of function like THREAD_PRIORITY_COMPOSITOR.
|
|
|
|
*/
|
|
|
|
void SetCurrentThreadPriority(hal::ThreadPriority aThreadPriority);
|
|
|
|
|
2015-05-07 16:53:47 +03:00
|
|
|
/**
|
|
|
|
* Set a thread priority to appropriate platform-specific value for
|
|
|
|
* given functionality. Instead of providing arbitrary priority numbers you
|
|
|
|
* must specify a type of function like THREAD_PRIORITY_COMPOSITOR.
|
|
|
|
*/
|
|
|
|
void SetThreadPriority(PlatformThreadId aThreadId,
|
|
|
|
hal::ThreadPriority aThreadPriority);
|
|
|
|
|
2012-10-02 11:26:32 +04:00
|
|
|
/**
|
|
|
|
* Start a watchdog to compulsively shutdown the system if it hangs.
|
|
|
|
* @param aMode Specify how to shutdown the system.
|
|
|
|
* @param aTimeoutSecs Specify the delayed seconds to shutdown the system.
|
2013-05-10 02:57:31 +04:00
|
|
|
*
|
2012-10-02 11:26:32 +04:00
|
|
|
* This API is currently only allowed to be used from the main process.
|
|
|
|
*/
|
|
|
|
void StartForceQuitWatchdog(hal::ShutdownMode aMode, int32_t aTimeoutSecs);
|
|
|
|
|
2012-10-04 13:28:34 +04:00
|
|
|
/**
|
|
|
|
* Perform Factory Reset to wipe out all user data.
|
|
|
|
*/
|
2014-07-18 05:30:47 +04:00
|
|
|
void FactoryReset(mozilla::dom::FactoryResetReason& aReason);
|
2012-10-04 13:28:34 +04:00
|
|
|
|
2013-05-10 02:57:31 +04:00
|
|
|
/**
|
|
|
|
* Start monitoring disk space for low space situations.
|
|
|
|
*
|
|
|
|
* This API is currently only allowed to be used from the main process.
|
|
|
|
*/
|
|
|
|
void StartDiskSpaceWatcher();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stop monitoring disk space for low space situations.
|
|
|
|
*
|
|
|
|
* This API is currently only allowed to be used from the main process.
|
|
|
|
*/
|
|
|
|
void StopDiskSpaceWatcher();
|
|
|
|
|
2013-10-22 23:15:24 +04:00
|
|
|
/**
|
|
|
|
* Get total system memory of device being run on in bytes.
|
|
|
|
*
|
|
|
|
* Returns 0 if we are unable to determine this information from /proc/meminfo.
|
|
|
|
*/
|
|
|
|
uint32_t GetTotalSystemMemory();
|
|
|
|
|
2014-07-01 21:52:00 +04:00
|
|
|
/**
|
|
|
|
* Determine whether the headphone switch event is from input device
|
|
|
|
*/
|
|
|
|
bool IsHeadphoneEventFromInputDev();
|
|
|
|
|
2016-01-04 18:08:21 +03:00
|
|
|
/**
|
|
|
|
* Start the system service with the specified name and arguments.
|
|
|
|
*/
|
|
|
|
nsresult StartSystemService(const char* aSvcName, const char* aArgs);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stop the system service with the specified name.
|
|
|
|
*/
|
|
|
|
void StopSystemService(const char* aSvcName);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine whether the system service with the specified name is running.
|
|
|
|
*/
|
|
|
|
bool SystemServiceIsRunning(const char* aSvcName);
|
|
|
|
|
2011-09-30 11:00:48 +04:00
|
|
|
} // namespace MOZ_HAL_NAMESPACE
|
|
|
|
} // namespace mozilla
|
2011-10-06 02:15:45 +04:00
|
|
|
|
|
|
|
#ifdef MOZ_DEFINED_HAL_NAMESPACE
|
|
|
|
# undef MOZ_DEFINED_HAL_NAMESPACE
|
|
|
|
# undef MOZ_HAL_NAMESPACE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // mozilla_Hal_h
|