2004-06-15 23:24:06 +00:00
|
|
|
|
/***************************************************************************
|
|
|
|
|
* __________ __ ___.
|
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
|
* $Id$
|
|
|
|
|
*
|
|
|
|
|
* Copyright (C) 2004 Bj<EFBFBD>rn Stenberg
|
|
|
|
|
*
|
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
|
*
|
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
|
* KIND, either express or implied.
|
|
|
|
|
*
|
|
|
|
|
****************************************************************************/
|
|
|
|
|
#include "plugin.h"
|
|
|
|
|
|
|
|
|
|
/* This plugin is designed to measure your battery performance in real-time.
|
|
|
|
|
It will create a big file, read it every ~90 seconds and log the
|
|
|
|
|
battery level in /battery.log
|
|
|
|
|
|
|
|
|
|
When battery level goes below 5% the plugin exits, to avoid writing to
|
|
|
|
|
disk in very low battery situations.
|
|
|
|
|
|
|
|
|
|
Note that this test will run for 10-15 hours or more and is very boring
|
|
|
|
|
to watch.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
static struct plugin_api* rb;
|
|
|
|
|
|
|
|
|
|
void* buffer;
|
|
|
|
|
int buffersize;
|
|
|
|
|
|
|
|
|
|
int init(void)
|
|
|
|
|
{
|
|
|
|
|
int f;
|
|
|
|
|
buffer = rb->plugin_get_mp3_buffer(&buffersize);
|
|
|
|
|
|
|
|
|
|
/* create a big dummy file */
|
|
|
|
|
f = rb->creat("/battery.dummy", 0);
|
|
|
|
|
if (f<0) {
|
|
|
|
|
rb->splash(HZ, true, "Can't create /battery.dummy");
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
rb->write(f, buffer, buffersize);
|
|
|
|
|
rb->close(f);
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2004-06-23 08:49:55 +00:00
|
|
|
|
enum plugin_status loop(void)
|
2004-06-15 23:24:06 +00:00
|
|
|
|
{
|
|
|
|
|
while (true) {
|
|
|
|
|
struct tm* t;
|
|
|
|
|
char buf[80];
|
|
|
|
|
int f;
|
|
|
|
|
int batt = rb->battery_level();
|
2004-06-23 08:49:55 +00:00
|
|
|
|
int button;
|
2004-06-15 23:24:06 +00:00
|
|
|
|
|
|
|
|
|
/* stop measuring when <5% battery left */
|
|
|
|
|
if ((batt > 0) && (batt < 5))
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
/* log current time */
|
|
|
|
|
f = rb->open("/battery.log", O_WRONLY | O_APPEND | O_CREAT);
|
|
|
|
|
if (f<0) {
|
|
|
|
|
rb->splash(HZ, true, "Failed creating /battery.log");
|
|
|
|
|
break;
|
|
|
|
|
}
|
2004-06-22 05:37:44 +00:00
|
|
|
|
#ifdef HAVE_RTC
|
2004-06-15 23:24:06 +00:00
|
|
|
|
t = rb->get_time();
|
2004-06-22 05:37:44 +00:00
|
|
|
|
#else
|
|
|
|
|
{
|
|
|
|
|
static struct tm temp;
|
|
|
|
|
long t2 = *rb->current_tick/HZ;
|
|
|
|
|
temp.tm_hour=t2/3600;
|
|
|
|
|
temp.tm_min=(t2/60)%60;
|
|
|
|
|
temp.tm_sec=t2%60;
|
|
|
|
|
t=&temp;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2004-06-15 23:24:06 +00:00
|
|
|
|
rb->snprintf(buf, sizeof buf, "%02d:%02d:%02d Battery %d%%\n",
|
|
|
|
|
t->tm_hour, t->tm_min, t->tm_sec, batt);
|
|
|
|
|
rb->write(f, buf, rb->strlen(buf));
|
|
|
|
|
rb->close(f);
|
|
|
|
|
|
2004-06-22 05:37:44 +00:00
|
|
|
|
rb->snprintf(buf, sizeof buf, "%02d:%02d:%02d Battery %d%%%%",
|
|
|
|
|
t->tm_hour, t->tm_min, t->tm_sec, batt);
|
2004-06-15 23:24:06 +00:00
|
|
|
|
rb->splash(0, true, buf);
|
|
|
|
|
|
|
|
|
|
/* simulate 128kbit/s (16kbyte/s) playback duration */
|
2004-06-23 08:49:55 +00:00
|
|
|
|
do {
|
|
|
|
|
button = rb->button_get_w_tmo(HZ * (buffersize / 16384) - HZ*10);
|
|
|
|
|
|
|
|
|
|
/* Check if we shall exit the plugin */
|
|
|
|
|
if (button==BUTTON_ON ||
|
2004-09-28 22:13:26 +00:00
|
|
|
|
#if CONFIG_KEYPAD == RECORDER_PAD
|
2004-06-23 08:49:55 +00:00
|
|
|
|
button==BUTTON_OFF
|
|
|
|
|
#else
|
|
|
|
|
button==BUTTON_STOP
|
|
|
|
|
#endif
|
|
|
|
|
)
|
|
|
|
|
return PLUGIN_OK;
|
2004-07-26 23:35:15 +00:00
|
|
|
|
|
|
|
|
|
if (rb->default_event_handler(button) == SYS_USB_CONNECTED) {
|
2004-06-23 08:49:55 +00:00
|
|
|
|
return PLUGIN_USB_CONNECTED;
|
|
|
|
|
}
|
|
|
|
|
} while (!(button&(BUTTON_REL|BUTTON_REPEAT)));
|
2004-06-15 23:24:06 +00:00
|
|
|
|
|
|
|
|
|
/* simulate filling the mp3 buffer */
|
|
|
|
|
f = rb->open("/battery.dummy", O_RDONLY);
|
|
|
|
|
if (f<0) {
|
|
|
|
|
rb->splash(HZ, true, "Failed opening /battery.dummy");
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
rb->read(f, buffer, buffersize);
|
|
|
|
|
rb->close(f);
|
|
|
|
|
}
|
2004-06-23 08:49:55 +00:00
|
|
|
|
return PLUGIN_OK;
|
2004-06-15 23:24:06 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
enum plugin_status plugin_start(struct plugin_api* api, void* parameter)
|
|
|
|
|
{
|
|
|
|
|
TEST_PLUGIN_API(api);
|
|
|
|
|
(void)parameter;
|
|
|
|
|
rb = api;
|
|
|
|
|
|
|
|
|
|
if (init() < 0)
|
|
|
|
|
return PLUGIN_OK;
|
|
|
|
|
|
2004-06-23 08:49:55 +00:00
|
|
|
|
return loop();
|
2004-06-15 23:24:06 +00:00
|
|
|
|
}
|
|
|
|
|
|