Blog Infos
Author
Published
Topics
Published
Topics

The ADB command “dumpsys alarm” provides comprehensive data on the alarms scheduled on Android devices.

adb shell dumpsys alarm

Before diving into the blog, run the given command to see the output. It’ll help you grasp the content better.

command specifically gives the following information

  1. Settings: Includes the constraint information, minimum and maximum alarm intervals and quota limits
  2. Exempted Packages: Includes list containing White-Listed apps and apps having USE_EXACT_ALARM permission
  3. Pending Alarms: Includes all the alarms | batches that are pending
  4. Top Alarms: Includes top 10 apps having maximum alarm usage
  5. Alarm Stats: Includes Overview of Triggered Alarms
1. Settings
min_futurity=+5s0ms
min_interval=+1m0s0ms
max_interval=+365d0h0m0s0ms
listener_timeout=+5s0ms
allow_while_idle_short_time=+5s0ms
allow_while_idle_long_time=+9m0s0ms
allow_while_idle_whitelist_duration=+10s0ms
max_alarms_per_uid=500
app_standby_window=+1h0m0s0ms
standby_active_quota=720
standby_working_quota=10
standby_frequent_quota=2
standby_rare_quota=1
standby_never_quota=0
standby_restricted_quota=1
app_standby_restricted_window=+1d0h0m0s0ms
  • min_futurity: the minimum time in the future for which the alarm can be scheduled
  • min_interval: the shortest gap between two repeating alarms
  • maximum_interval: the longest gap between two repeating alarms
  • standby_active_quota, standby_working_quotastandby_frequent_quotastandby_rare_quotastandby_never_quota, and standby_restricted_quota indicate the number of alarms triggered per hour by the package with the given standby bucket
  • The above quota limits can also be validated through Power Management Restrictions documentation

 

2. Exempted Packages

Exempted packages contain a list of all the White-Listed apps and apps having USE_EXACT_ALARM permission.

Exempted packages:
  User 0
    com.google.android.youtube
    com.whatsapp
    com.android.providers.calendar
    com.nikhil.here.myalarammanager
    ...
  • Exempted packages can ignore battery optimization and power management restrictions
  • so the app standby quota is not applicable to exempted apps
3. Pending Alarms
Pending alarm batches: 42
Batch{58a4ec6 num=1 start=5061218010 end=5061218010 flgs=0x5}:
    RTC_WAKEUP #0: Alarm{17b4f24 type 0 when 1690717200000 com.nikhil.here.myalarammanager}
      tag=*walarm*:com.nikhil.here.myalarammanager/.domain.receivers.AlarmBroadcastReceiver
      type=0 expectedWhenElapsed=+6m55s702ms expectedMaxWhenElapsed=+6m55s702ms whenElapsed=+6m55s702ms maxWhenElapsed=+6m55s702ms when=2023-07-30 17:10:00.000
      window=0 repeatInterval=0 count=0 flags=0x5
      operation=PendingIntent{3080e87: PendingIntentRecord{24581b4 com.nikhil.here.myalarammanager broadcastIntent}}
  • Starting from API 19, all the inexact alarms are deferred, and the system attempts to batch multiple alarms together across the entire system. This reduces the number of times the device needs to “wake up,” minimizing overall battery drain.
  • Pending alarm batches : 42 indicates that there are 42 pending batches, each batch has a unique identifier and the start-end time
  • RTC_WAKEUP #0 Alarm{17b4f24 type 0 when 1690717200000 com.nikhil.here.myalarmmanager gives the information on the type and execution time of the alarm
  • there are four different types of the alarm mentioned below
| Type                     | value  |
|------------------------- |------- |
| RTC_WAKEUP               | 0      |
| RTC                      | 1      |
| ELAPSED_REALTIME_WAKEUP  | 2      |
| ELAPSED_REALTIME         | 3      |
  • about execution time, when 1690717200000 for RTC and RTC_WAKEUP type alarms, the execution time is based on the device wall time i.e using System.currentTimeinMillis() method, for ELAPSED type of alarms the execution time is given based on the device reboot time.
  • expectedWhenElapsed | whenElapsed gives the expected remaining time for the alarm execution
  • expectedMaxWhenElapsed | maxWhenElapsed gives the expected remaining time plus the expected delay for the given alarm execution.
  • in our example expectedWhenElapsed and expectedMaxWhenElapsed both are equal indicating that the given alarm is the Exact alarm, for which we don’t expect any delay in execution
  • window = 0 the value will be > 0 for alarms set using setWindow method indicating the window time.
  • repeatInterval = 0 the value will be > 1 for repeating alarms indicating repeating intervals. this repeating interval cannot be less than 1 as the minimum interval mentioned in the output of the setting is 1 minute min_interval=+1m0s0ms
  • count = 0 indicates broadcast intent which is in the queue, whenever any alarm is triggered system basically adds the alarm broadcast intent to the queue and increments the counter value, and once the intent is delivered count value is again decremented, the system holds wake-lock while the count is greater than zero
  • operation=PendingINtent{3080e87:PendingIntentRecord{24581b4 com.nikhil.here.myalarmmanager.broadcastIntent}} gives the broadcast intent, flag information
4. Top Alarms
 Top Alarms:

+23m34s64ms running, 0 wakeups, 244 alarms: u0a216:com.google.android.calendar
  *alarm*:com.google.android.calendar.APPWIDGET_SCHEDULED_UPDATE

+23m29s238ms running, 278 wakeups, 278 alarms: u0a103:com.android.providers.calendar
  *walarm*:com.android.providers.calendar.intent.CalendarProvider2

+21m23s110ms running, 222 wakeups, 222 alarms: u0a207:com.google.android.gms
  *walarm*:com.google.android.location.ALARM_WAKEUP_ACTIVITY_DETECTION

+21m22s194ms running, 0 wakeups, 135 alarms: u0a227:com.google.android.apps.maps
  *alarm*:com.google.android.apps.gmm.plugins.serverrecovery.SCHEDULED_CHECK

+20m48s456ms running, 0 wakeups, 2204 alarms: u0a207:com.google.android.gms
  *alarm*:com.google.android.gms.gcm.ACTION_CHECK_QUEUE

+14m33s314ms running, 0 wakeups, 58 alarms: u0a216:com.google.android.calendar
  *alarm*:com.google.android.calendar.intent.action.MIDNIGHT

+13m32s76ms running, 0 wakeups, 55 alarms: u0a216:com.google.android.calendar
  *alarm*:MonthViewWidgetProvider.MIDNIGHT

+11m57s119ms running, 0 wakeups, 53 alarms: u0a154:com.facebook.appmanager
  *alarm*:check

+9m54s957ms running, 4896 wakeups, 4896 alarms: u0a184:com.xiaomi.xmsf
  *walarm*:com.xiaomi.push.PING_TIMER

+9m25s850ms running, 0 wakeups, 21051 alarms: 1000:android
  *alarm*:*job.delay*
  • The top alarms section list ten packages, which have maximum running time, wake locks and number of alarms
+23m34s64ms running, 0 wakeups, 244 alarms: u0a216:com.google.android.calendar
*alarm*:com.google.android.calendar.APPWIDGET_SCHEDULED_UPDATE

Job Offers

Job Offers

There are currently no vacancies.

OUR VIDEO RECOMMENDATION

,

Practical ADB usage to enhance your life!

ADB is an incredibly underutilized tool that can dramatically improve your Android development experience! Maybe you know some basic ADB commands, perhaps even a couple of nifty advanced ones or possibly, you don’t know what…
Watch Video

Practical ADB usage to enhance your life!

Benjamin Kadel
Principal Platform Engineer
Babbel

Practical ADB usage to enhance your life!

Benjamin Kadel
Principal Platform E ...
Babbel

Practical ADB usage to enhance your life!

Benjamin Kadel
Principal Platform Engine ...
Babbel

Jobs

  • 23m34s64ms runningindicates the total amount of time for which the process was running while executing the given 244 alarms with 0 wakelocks
  • Apps with longer running times and frequent wake-locks are major contributors to battery drain.
  • In the above log you can see the Google Calendar app has executed multiple alarms, as I use google calendar heavily and also its whitelisted app which ignores all the battery optimizations
5. Alarm Stats
  • Alarm stats gives the overview of all the alarms that are triggered recently,
Alarm Stats: 
u0a578:com.nikhil.here.myalarammanager +7s115ms running, 1 wakeups:
 +7s115ms 1 wakes 1 alarms, last -13m51s866ms:
   *walarm*:com.nikhil.here.myalarammanager/.domain.receivers.AlarmBroadcastReceiver
  • The key point is the running time +7s115ms running, which represents the execution time of our onReceive method that receives the alarm intent. To reduce battery drain we must try to keep this execution time as low as possible.

That’s it, i have covered most of the important details, if you feel anything is missing and requires further explanation, feel free to comment.

Thank You

This article was previously published on proandrdoiddev.com

YOU MAY BE INTERESTED IN

YOU MAY BE INTERESTED IN

blog
If you’re developing Android apps, you might often wonder how does our PC communicate…
READ MORE
blog
A while back I wrote an article about how to set up wireless ADB…
READ MORE
blog
This is the first article from the advanced section, where we’ll talk about the…
READ MORE
Menu