Producenci urządzeń muszą podać profil poboru mocy komponentu w pliku /frameworks/base/core/res/res/xml/power_profile.xml
.
Aby określić wartości profili zasilania, użyj sprzętu, który mierzy moc wykorzystywaną przez urządzenie, i wykonuj różne operacje, do których potrzebne są informacje. Zmierz zużycie energii podczas tych operacji i oblicz wartości (odpowiednio oblicz różnice w porównaniu z innymi wartościami bazowymi zużycia energii).
Celem profilu zasilania jest odpowiednie oszacowanie zużycia baterii, dlatego wartości profilu zasilania są podawane w amperach. Platforma Android mnoży bieżącą wartość przez czas, przez który podsystem był aktywny, i oblicza wartość w mAh, która jest następnie używana do oszacowania ilości energii zużytej przez aplikację lub podsystem.
Urządzenia z kontrolerami Bluetooth, modemu i Wi-Fi z Androidem 7.0 lub nowszym mogą dostarczać dodatkowe wartości mocy uzyskane na podstawie danych z chipsetu.
Urządzenia z niejednorodnymi procesorami
Profil zasilania dla urządzeń z rdzeniami procesora o różnej architekturze musi zawierać te dodatkowe pola:
- Łączna liczba procesorów w każdym klastrze (wyrażona w cpu.clusters.cores).
- Szybkość procesora obsługiwana przez każdy klaster.
- Aktywny pobór mocy procesora w przypadku każdego klastra.
Aby odróżnić aktywne zużycie energii procesora i obsługiwane prędkości procesora w klastrach, dodaj numer klastra do nazwy tablicy. Numery klastrów są przypisywane według kolejności rdzeni procesora w drzewie urządzenia jądra. Na przykład w przypadku heterogenicznej architektury z 2 klastrami z 4 rdzeniami:
- cluster0 składa się z cpu0-3
- cluster1 składa się z cpu4-7
Framework Androida używa tych numerów rdzeni procesora podczas odczytu statystyk z plików sysfs
w folderze /sys/devices/system/cpu/cpu<number>/cpufreq/stats
.
Przykład procesorów i szybkości klastra:
<array name="cpu.active.cluster0"> <value>200</value> <value>300</value> <value>400</value> </array> <array name="cpu.speeds.cluster0"> <value>600000</value> <value>800000</value> <value>1200000</value> </array> <array name="cpu.active.cluster1"> <value>400</value> <value>500</value> <value>600</value> </array> <array name="cpu.speeds.cluster1"> <value>800000</value> <value>1200000</value> <value>1400000</value> </array>
Wartości mocy
W tabeli poniżej znajdziesz dostępne ustawienia wartości mocy. Aby wyświetlić przykładowy plik w AOSP, zobacz power_profile.xml.
Nazwa | Opis | Przykładowa wartość | Uwagi |
---|---|---|---|
ambient.on | Dodatkowa ilość energii zużywana, gdy ekran jest w trybie Doze/Ambient/Always-On zamiast w trybie wyłączonym. | około 100 mA | - |
screen.on | Dodatkowa ilość energii zużywana, gdy ekran jest włączony z minimalną jasnością. | 200 mA | Obejmuje kontroler dotykowy i podświetlenie wyświetlacza. przy jasności 0, a nie minimalnej jasności Androida, która zwykle wynosi 10–20%. |
screen.full | Dodatkowa ilość energii zużywana, gdy ekran jest ustawiony na maksymalną jasność, w porównaniu z ekranem ustawionym na minimalną jasność. | 100 mA-300 mA | Ułamek tej wartości (na podstawie jasności ekranu) jest dodawany do wartości screen.on w celu obliczenia zużycia energii przez ekran. |
wifi.on | Dodatkowa energia zużywana, gdy Wi-Fi jest włączone, ale nie odbiera, nie transmituje ani nie skanuje. | 2 mA | - |
wifi.active | Dodatkowa moc zużywana podczas przesyłania lub odbierania danych przez Wi-Fi. | 31 mA | - |
wifi.scan | Dodatkowa energia zużywana podczas skanowania przez Wi-Fi punktów dostępu. | 100 mA | - |
dźwięk | Dodatkowa moc używana podczas dekodowania/kodowania dźwięku za pomocą DSP. | około 10 mA | Służy do dźwięku z usług DSP. |
film | Dodatkowa moc używana podczas dekodowania wideo przez DSP. | około 50 mA | Służy do reklam wideo w DSP. |
camera.avg | Średnie zużycie energii przez podsystem aparatu w typowej aplikacji do obsługi aparatu. | 600 mA | Jest to przybliżony szacunek dla aplikacji, która wyświetla podgląd i robi około 10 zdjęć w pełnej rozdzielczości na minutę. |
camera.flashlight | Średnie zużycie energii przez moduł lampy błyskowej aparatu. | 200 mA | - |
gps.signalqualitybased | Dodatkowa moc używana przez GPS w zależności od siły sygnału. Jest to wpis z wieloma wartościami: jedną na każdy poziom sygnału, od najsłabszego do najmocniejszego. | 30 mA, 10 mA | - |
gps.on | Dodatkowa energia zużywana podczas ustalania sygnału przez GPS. | 50 mA | - |
radio.active | Dodatkowa moc używana podczas nadawania/odbierania przez radio komórkowe. | 100 mA-300 mA | - |
radio.scanning | Dodatkowa moc zużywana, gdy radio komórkowe wysyła sygnał do wieży. | 1,2 mA | - |
radio.on | Dodatkowa energia zużywana, gdy radio komórkowe jest włączone. Jest to wpis z wieloma wartościami, po jednym na siłę sygnału (brak sygnału, słaby, średni, silny). | 1,2 mA | Niektóre radioodbiorniki zwiększają moc, gdy szukają wieży komórkowej i nie wykrywają sygnału. Wartości mogą być takie same lub maleć wraz ze wzrostem siły sygnału. Jeśli podasz tylko jedną wartość, ta sama wartość zostanie zastosowana do wszystkich atrybutów. Jeśli podasz 2 wartości, pierwsza będzie używana w przypadku braku sygnału, druga – we wszystkich pozostałych przypadkach i tak dalej. |
bluetooth.controller.idle | Średnie pobieranie prądu (mA) przez kontroler Bluetooth w stanie spoczynku. | - | Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru lub nadawania, obliczana jest średnia z tych stanów. System zbiera teraz też dane o skanowaniu Bluetooth Low Energy (LE) i Bluetooth. Android 7.0 i nowsze nie używają już wartości mocy Bluetooth dla bluetooth.active (używanego podczas odtwarzania dźwięku przez Bluetooth A2DP) i bluetooth.on (używanego, gdy Bluetooth jest włączony, ale nieaktywny). |
bluetooth.controller.rx | Średnie pobieranie prądu (mA) przez kontroler Bluetooth podczas odbierania. | - | |
bluetooth.controller.tx | Średnie pobieranie prądu (mA) przez kontroler Bluetooth podczas transmisji. | - | |
bluetooth.controller.voltage | Średnie napięcie robocze (mV) kontrolera Bluetooth. | - | |
modem.controller.sleep | Średnie pobieranie prądu (mA) przez kontroler modemu w stanie uśpienia. | 0 mA | Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru, obliczana jest ich średnia. Jeśli istnieje kilka stanów transmisji, od Androida 9 można określić wartość dla każdego z nich. |
modem.controller.idle | Średnie pobieranie prądu (mA) przez kontroler modemu w stanie bezczynności. | - | |
modem.controller.rx | Średnie pobieranie prądu (mA) przez kontroler modemu podczas odbierania. | - | |
modem.controller.tx | Średnie pobieranie prądu (mA) przez kontroler modemu podczas transmisji przy różnych poziomach mocy RF. Jest to wpis z wieloma wartościami, z jedną wartością na poziom mocy nadawania. | 100 mA, 200 mA, 300 mA, 400 mA, 500 mA | |
modem.controller.voltage | Średnie napięcie robocze (mV) kontrolera modemu. | - | |
wifi.controller.idle | Średnie pobieranie prądu (mA) przez kontroler Wi-Fi w stanie bezczynności. | - | Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru lub nadawania, obliczana jest średnia z tych stanów. |
wifi.controller.rx | Średnie pobieranie prądu (mA) przez kontroler Wi-Fi podczas odbierania. | - | |
wifi.controller.tx | Średnie pobieranie prądu (mA) przez kontroler Wi-Fi podczas przesyłania danych. | - | |
wifi.controller.voltage | Średnie napięcie robocze (mV) kontrolera Wi-Fi. | - | |
cpu.speeds | Jest to wpis wielowartościowy, który zawiera listę wszystkich możliwych szybkości procesora w kHz. | 125 000 kHz, 250 000 kHz, 500 000 kHz, 10 000 000 kHz, 150 000 kHz | Liczba i kolejność wpisów muszą odpowiadać wpisom mA w pliku cpu.active. |
cpu.idle | Łączna moc pobierana przez system, gdy procesory (i system SoC) są w stanie uśpienia. | 3 mA | - |
cpu.awake | Dodatkowa moc używana, gdy procesory są w stanie bezczynności (pętla bezczynności jądra); system nie jest w stanie zawieszenia. | 50 mA | Platforma może mieć więcej niż 1 stan bezczynności z różnymi poziomami poboru mocy. Wybierz reprezentatywny stan bezczynności na dłuższe okresy bezczynności harmonogramu (kilka milisekund). Przejrzyj wykres mocy na swoim sprzęcie pomiarowym i wybierz próbki, w których procesor ma najniższe zużycie energii. Odrzuć wyższe próbki, w których procesor nie był w stanie bezczynności. |
cpu.active | Dodatkowa moc używana przez procesory podczas działania z różnymi prędkościami. | 100 mA, 120 mA, 140 mA, 160 mA, 200 mA | Wartość reprezentuje moc wykorzystywaną przez szyny procesora podczas pracy z różnymi prędkościami. Ustaw maksymalną prędkość w rdzeniu dla każdej z dozwolonych prędkości i ustaw procesor na tę prędkość. Liczba i kolejność wpisów odpowiadają liczbie i kolejności wpisów w cpu.speeds. |
cpu.clusters.cores | Liczba rdzeni w każdym klastrze procesora. | 4, 2 | Wymagany tylko w przypadku urządzeń z niejednorodnymi architekturami procesorów. Liczba wpisów i ich kolejność powinny odpowiadać liczbie wpisów klastra dla cpu.active i cpu.speeds. Pierwszy wpis reprezentuje liczbę rdzeni procesora w klastrze 0, drugi – liczbę rdzeni procesora w klastrze 1 itd. |
battery.capacity | Łączna pojemność baterii w mAh. | 3000 mAh | - |
Skanowanie w trybie Low Energy (LE) i Bluetooth
W przypadku urządzeń z Androidem 7.0 system zbiera dane o skanowaniu w technologii Low Energy (LE) i ruchu sieci Bluetooth (np. RFCOMM i L2CAP) oraz łączy te działania z aplikacją inicjującą. Skanowania Bluetooth są powiązane z aplikacją, która zainicjowała skanowanie, ale nie są powiązane z skanowaniem zbiorczym (zamiast tego są powiązane z aplikacją Bluetooth). W przypadku aplikacji skanującej przez N milisekund koszt skanowania to N milisekund czasu odbioru i N milisekund czasu nadawania. Pozostały czas pracy kontrolera jest przypisany do ruchu sieciowego lub aplikacji Bluetooth.