blob: 13c639ab5635415314426b6113e28d48ac710b48 [file] [log] [blame]
#!/bin/bash
#
# PM-QA validation test suite for the power management on Linux
#
# Copyright (C) 2012, Linaro Limited.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# Contributors:
# Hongbo ZHANG <hongbo.zhang@linaro.org> (ST-Ericsson Corporation)
# - initial API and implementation
#
# URL : https://wiki.linaro.org/WorkingGroups/PowerManagement/Doc/QA/Scripts#suspend_04
source ../include/functions.sh
source ../include/suspend.sh
# test_power: switch on/off this test
test_power=0
auto=1
args_power_sleep=60
if [ "$test_power" -eq 1 -a "$battery_count" -eq 0 ]; then
ECHO "*** no BATTERY detected power test skipped ..."
elif [ "$test_power" -eq 1 ]; then
save_timer_sleep="$timer_sleep"
let timer_sleep="$args_power_sleep"
ac_required 0
phase
# get start values
date_before=`date +%s`
bat_before=`battery_capacity`
# Suspend
check "battery drain during suspend" suspend_system
if [ $? -eq 0 ]; then
rm -f "$LOGFILE"
fi
# get end values
date_after=`date +%s`
bat_after=`battery_capacity`
# do the calculations
let consumed="$bat_before - $bat_after"
let elapsed="$date_after - $date_before"
let usage="($consumed * 60*60) / $elapsed"
# output the results
ECHO "before: $bat_before mWh"
ECHO "after: $bat_after mWh"
ECHO "consumed: $consumed mW"
ECHO "sleep seconds: $elapsed sec"
ECHO "overall usage: $usage mW"
report_battery="$usage mW"
if [ $elapsed -lt 600 ]
then
ECHO "WARNING: the suspend was less than 10 minutes"
ECHO " to get reliable numbers increase the sleep time"
report_battery="$report_battery (unreliable)"
fi
timer_sleep="$save_timer_sleep"
fi