c14430a9c1
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15512 a1c6a512-1295-4272-9138-f99709370657
307 lines
5.2 KiB
C
307 lines
5.2 KiB
C
/***************************************************************************
|
|
* __________ __ ___.
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
* \/ \/ \/ \/ \/
|
|
* $Id$
|
|
*
|
|
* Copyright (C) 2002 by Björn Stenberg <bjorn@haxx.se>
|
|
*
|
|
* 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 <stdio.h>
|
|
#include <time.h>
|
|
#include <stdbool.h>
|
|
|
|
#include "debug.h"
|
|
|
|
#include "screens.h"
|
|
#include "button.h"
|
|
|
|
#include "string.h"
|
|
#include "lcd.h"
|
|
|
|
#include "ata.h" /* for volume definitions */
|
|
|
|
extern char having_new_lcd;
|
|
|
|
#if CONFIG_CODEC != SWCODEC
|
|
void audio_set_buffer_margin(int seconds)
|
|
{
|
|
(void)seconds;
|
|
}
|
|
#endif
|
|
|
|
int fat_startsector(void)
|
|
{
|
|
return 63;
|
|
}
|
|
|
|
bool fat_ismounted(int volume)
|
|
{
|
|
(void)volume;
|
|
return true;
|
|
}
|
|
|
|
int ata_write_sectors(IF_MV2(int drive,)
|
|
unsigned long start,
|
|
int count,
|
|
const void* buf)
|
|
{
|
|
IF_MV((void)drive;)
|
|
int i;
|
|
|
|
for (i=0; i<count; i++ ) {
|
|
FILE* f;
|
|
char name[32];
|
|
|
|
sprintf(name,"sector%lX.bin",start+i);
|
|
f=fopen(name,"wb");
|
|
if (f) {
|
|
fwrite(buf,512,1,f);
|
|
fclose(f);
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
int ata_read_sectors(IF_MV2(int drive,)
|
|
unsigned long start,
|
|
int count,
|
|
void* buf)
|
|
{
|
|
IF_MV((void)drive;)
|
|
int i;
|
|
|
|
for (i=0; i<count; i++ ) {
|
|
FILE* f;
|
|
char name[32];
|
|
|
|
DEBUGF("Reading sector %lX\n",start+i);
|
|
sprintf(name,"sector%lX.bin",start+i);
|
|
f=fopen(name,"rb");
|
|
if (f) {
|
|
fread(buf,512,1,f);
|
|
fclose(f);
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
void ata_delayed_write(unsigned long sector, const void* buf)
|
|
{
|
|
ata_write_sectors(IF_MV2(0,) sector, 1, buf);
|
|
}
|
|
|
|
void ata_flush(void)
|
|
{
|
|
}
|
|
|
|
void ata_spin(void)
|
|
{
|
|
}
|
|
|
|
void ata_spindown(int s)
|
|
{
|
|
(void)s;
|
|
}
|
|
|
|
void rtc_init(void)
|
|
{
|
|
}
|
|
|
|
int rtc_read(int address)
|
|
{
|
|
return address ^ 0x55;
|
|
}
|
|
|
|
int rtc_write(int address, int value)
|
|
{
|
|
(void)address;
|
|
(void)value;
|
|
return 0;
|
|
}
|
|
|
|
int rtc_read_datetime(unsigned char* buf)
|
|
{
|
|
time_t now = time(NULL);
|
|
struct tm *teem = localtime(&now);
|
|
|
|
buf[0] = (teem->tm_sec%10) | ((teem->tm_sec/10) << 4);
|
|
buf[1] = (teem->tm_min%10) | ((teem->tm_min/10) << 4);
|
|
buf[2] = (teem->tm_hour%10) | ((teem->tm_hour/10) << 4);
|
|
buf[3] = (teem->tm_wday);
|
|
buf[4] = (teem->tm_mday%10) | ((teem->tm_mday/10) << 4);
|
|
buf[5] = ((teem->tm_year-100)%10) | (((teem->tm_year-100)/10) << 4);
|
|
buf[6] = ((teem->tm_mon+1)%10) | (((teem->tm_mon+1)/10) << 4);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int rtc_write_datetime(unsigned char* buf)
|
|
{
|
|
(void)buf;
|
|
return 0;
|
|
}
|
|
|
|
#ifdef HAVE_RTC_ALARM
|
|
void rtc_get_alarm(int *h, int *m)
|
|
{
|
|
*h = 11;
|
|
*m = 55;
|
|
}
|
|
|
|
void rtc_set_alarm(int h, int m)
|
|
{
|
|
(void)h;
|
|
(void)m;
|
|
}
|
|
|
|
bool rtc_enable_alarm(bool enable)
|
|
{
|
|
return enable;
|
|
}
|
|
|
|
extern bool sim_alarm_wakeup;
|
|
bool rtc_check_alarm_started(bool release_alarm)
|
|
{
|
|
(void)release_alarm;
|
|
return sim_alarm_wakeup;
|
|
}
|
|
|
|
bool rtc_check_alarm_flag(void)
|
|
{
|
|
return true;
|
|
}
|
|
#endif
|
|
|
|
#ifdef HAVE_HEADPHONE_DETECTION
|
|
bool headphones_inserted(void)
|
|
{
|
|
return true;
|
|
}
|
|
#endif
|
|
|
|
#ifdef HAVE_LCD_ENABLE
|
|
bool lcd_enabled(void)
|
|
{
|
|
return true;
|
|
}
|
|
#endif
|
|
|
|
bool charging_state(void)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
bool charger_inserted(void)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
#ifdef HAVE_SPDIF_POWER
|
|
void spdif_power_enable(bool on)
|
|
{
|
|
(void)on;
|
|
}
|
|
|
|
bool spdif_powered(void)
|
|
{
|
|
return false;
|
|
}
|
|
#endif
|
|
|
|
bool is_new_player(void)
|
|
{
|
|
return having_new_lcd;
|
|
}
|
|
|
|
#ifdef HAVE_USB_POWER
|
|
bool usb_powered(void)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
#if CONFIG_CHARGING
|
|
bool usb_charging_enable(bool on)
|
|
{
|
|
(void)on;
|
|
return false;
|
|
}
|
|
#endif
|
|
#endif
|
|
|
|
bool usb_inserted(void)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
#ifdef HAVE_REMOTE_LCD_TICKING
|
|
void lcd_remote_emireduce(bool state)
|
|
{
|
|
(void)state;
|
|
}
|
|
#endif
|
|
|
|
void lcd_set_contrast( int x )
|
|
{
|
|
(void)x;
|
|
}
|
|
|
|
void mpeg_set_pitch(int pitch)
|
|
{
|
|
(void)pitch;
|
|
}
|
|
|
|
static int sleeptime;
|
|
void set_sleep_timer(int seconds)
|
|
{
|
|
sleeptime = seconds;
|
|
}
|
|
|
|
int get_sleep_timer(void)
|
|
{
|
|
return sleeptime;
|
|
}
|
|
|
|
#ifdef HAVE_LCD_CHARCELLS
|
|
void lcd_clearrect (int x, int y, int nx, int ny)
|
|
{
|
|
/* Reprint char if you want to change anything */
|
|
(void)x;
|
|
(void)y;
|
|
(void)nx;
|
|
(void)ny;
|
|
}
|
|
|
|
void lcd_fillrect (int x, int y, int nx, int ny)
|
|
{
|
|
/* Reprint char if you want to change display anything */
|
|
(void)x;
|
|
(void)y;
|
|
(void)nx;
|
|
(void)ny;
|
|
}
|
|
#endif
|
|
|
|
void cpu_sleep(bool enabled)
|
|
{
|
|
(void)enabled;
|
|
}
|
|
|
|
void button_set_flip(bool yesno)
|
|
{
|
|
(void)yesno;
|
|
}
|
|
|
|
/* assure an unused place to direct virtual pointers to */
|
|
#define VIRT_SIZE 0xFFFF /* more than enough for our string ID range */
|
|
unsigned char vp_dummy[VIRT_SIZE];
|
|
|