2007-09-20 04:46:41 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id: $
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 by Karl Kurbjun
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2007-09-20 14:16:25 +00:00
|
|
|
#include "inttypes.h"
|
2007-09-20 04:46:41 +00:00
|
|
|
#include "string.h"
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "system.h"
|
|
|
|
#include "lcd.h"
|
|
|
|
#include "kernel.h"
|
|
|
|
#include "thread.h"
|
|
|
|
#include "ata.h"
|
|
|
|
#include "fat.h"
|
|
|
|
#include "disk.h"
|
|
|
|
#include "font.h"
|
|
|
|
#include "adc.h"
|
|
|
|
#include "backlight.h"
|
|
|
|
#include "backlight-target.h"
|
|
|
|
#include "button.h"
|
|
|
|
#include "panic.h"
|
|
|
|
#include "power.h"
|
|
|
|
#include "file.h"
|
|
|
|
#include "common.h"
|
|
|
|
#include "rbunicode.h"
|
|
|
|
#include "usb.h"
|
2007-09-22 14:21:07 +00:00
|
|
|
#include "spi.h"
|
2007-09-21 09:09:59 +00:00
|
|
|
#include "uart-target.h"
|
2007-09-22 14:21:07 +00:00
|
|
|
#include "tsc2100.h"
|
2007-10-01 07:52:39 +00:00
|
|
|
#include "time.h"
|
2007-10-26 05:17:15 +00:00
|
|
|
#include "system-arm.h"
|
2007-09-20 04:46:41 +00:00
|
|
|
|
2007-10-18 05:14:10 +00:00
|
|
|
#define MRDEBUG
|
2007-10-13 16:27:41 +00:00
|
|
|
|
|
|
|
#if defined(MRDEBUG)
|
|
|
|
|
2007-09-22 06:04:14 +00:00
|
|
|
extern int line;
|
2007-10-22 07:01:59 +00:00
|
|
|
#if 0
|
2007-10-01 07:52:39 +00:00
|
|
|
struct touch_calibration_point tl, br;
|
|
|
|
|
|
|
|
void touchpad_get_one_point(struct touch_calibration_point *p)
|
|
|
|
{
|
|
|
|
int data = 0;
|
|
|
|
int start = current_tick;
|
|
|
|
while (TIME_AFTER(start+(HZ/3), current_tick))
|
|
|
|
{
|
|
|
|
if (button_read_device()&BUTTON_TOUCHPAD)
|
|
|
|
{
|
|
|
|
data = button_get_last_touch();
|
|
|
|
p->val_x = data>>16;
|
|
|
|
p->val_y = data&0xffff;
|
|
|
|
start = current_tick;
|
|
|
|
}
|
|
|
|
else if (data == 0)
|
|
|
|
start = current_tick;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#define MARGIN 25
|
|
|
|
#define LEN 7
|
|
|
|
void touchpad_calibrate_screen(void)
|
|
|
|
{
|
|
|
|
reset_screen();
|
|
|
|
printf("touch the center of the crosshairs to calibrate");
|
|
|
|
/* get the topleft value */
|
|
|
|
lcd_hline(MARGIN-LEN, MARGIN+LEN, MARGIN);
|
|
|
|
lcd_vline(MARGIN, MARGIN-LEN, MARGIN+LEN);
|
|
|
|
lcd_update();
|
|
|
|
tl.px_x = MARGIN; tl.px_y = MARGIN;
|
|
|
|
touchpad_get_one_point(&tl);
|
|
|
|
reset_screen();
|
|
|
|
printf("touch the center of the crosshairs to calibrate");
|
|
|
|
/* get the topright value */
|
|
|
|
lcd_hline(LCD_WIDTH-MARGIN-LEN, LCD_WIDTH-MARGIN+LEN, LCD_HEIGHT-MARGIN);
|
|
|
|
lcd_vline(LCD_WIDTH-MARGIN, LCD_HEIGHT-MARGIN-LEN, LCD_HEIGHT-MARGIN+LEN);
|
|
|
|
lcd_update();
|
|
|
|
br.px_x = LCD_WIDTH-MARGIN; br.px_y = LCD_HEIGHT-MARGIN;
|
|
|
|
touchpad_get_one_point(&br);
|
|
|
|
reset_screen();
|
|
|
|
line++;
|
|
|
|
printf("tl %d %d", tl.val_x, tl.val_y);
|
|
|
|
printf("br %d %d", br.val_x, br.val_y);
|
|
|
|
line++;
|
|
|
|
set_calibration_points(&tl, &br);
|
|
|
|
}
|
2007-10-22 07:01:59 +00:00
|
|
|
#endif
|
2007-10-18 05:14:10 +00:00
|
|
|
void mrdebug(void)
|
2007-10-13 16:27:41 +00:00
|
|
|
{
|
|
|
|
int button=0, *address=0x0;
|
2007-10-18 05:14:10 +00:00
|
|
|
#if 0
|
2007-10-13 16:27:41 +00:00
|
|
|
use_calibration(false);
|
|
|
|
touchpad_calibrate_screen();
|
|
|
|
use_calibration(true);
|
2007-10-18 05:14:10 +00:00
|
|
|
#endif
|
2007-10-13 16:27:41 +00:00
|
|
|
while(true)
|
|
|
|
{
|
2007-10-18 05:14:10 +00:00
|
|
|
#if 0
|
2007-10-13 16:27:41 +00:00
|
|
|
struct tm *t = get_time();
|
|
|
|
printf("%d:%d:%d %d %d %d", t->tm_hour, t->tm_min, t->tm_sec, t->tm_mday, t->tm_mon, t->tm_year);
|
|
|
|
printf("time: %d", mktime(t));
|
2007-10-18 05:14:10 +00:00
|
|
|
#endif
|
2007-10-18 12:15:56 +00:00
|
|
|
button = button_get(false);
|
2007-10-13 16:27:41 +00:00
|
|
|
if (button == BUTTON_POWER)
|
|
|
|
{
|
|
|
|
printf("reset");
|
|
|
|
IO_GIO_BITSET1|=1<<10;
|
|
|
|
}
|
|
|
|
if(button==BUTTON_RC_PLAY)
|
|
|
|
address+=0x02;
|
|
|
|
else if (button==BUTTON_RC_DOWN)
|
|
|
|
address-=0x02;
|
|
|
|
else if (button==BUTTON_RC_FF)
|
|
|
|
address+=0x1000;
|
|
|
|
else if (button==BUTTON_RC_REW)
|
|
|
|
address-=0x1000;
|
2007-10-22 07:01:59 +00:00
|
|
|
// {
|
|
|
|
// short x,y,z1,z2;
|
|
|
|
// tsc2100_read_values(&x, &y, &z1, &z2);
|
|
|
|
// printf("x: %04x y: %04x z1: %04x z2: %04x", x, y, z1, z2);
|
|
|
|
// printf("tsadc: %4x", tsc2100_readreg(TSADC_PAGE, TSADC_ADDRESS)&0xffff);
|
|
|
|
// printf("current tick: %04x", current_tick);
|
|
|
|
// printf("Address: 0x%08x Data: 0x%08x", address, *address);
|
|
|
|
// printf("Address: 0x%08x Data: 0x%08x", address+1, *(address+1));
|
|
|
|
// printf("Address: 0x%08x Data: 0x%08x", address+2, *(address+2));
|
|
|
|
// // tsc2100_keyclick(); /* doesnt work :( */
|
|
|
|
// line -= 6;
|
|
|
|
// }
|
2007-10-18 12:15:56 +00:00
|
|
|
#if 1
|
2007-10-13 16:27:41 +00:00
|
|
|
if (button&BUTTON_TOUCHPAD)
|
|
|
|
{
|
2007-10-22 07:01:59 +00:00
|
|
|
if (button&BUTTON_REL)
|
|
|
|
continue;
|
2007-10-18 12:15:56 +00:00
|
|
|
unsigned int data = button_get_data();
|
|
|
|
int x = (data&0xffff0000)>>16, y = data&0x0000ffff;
|
|
|
|
reset_screen();
|
2007-10-22 07:01:59 +00:00
|
|
|
line = 9;
|
|
|
|
printf("%x %d %d\n", button, x,y);
|
2007-10-18 12:15:56 +00:00
|
|
|
lcd_hline(x-5, x+5, y);
|
|
|
|
lcd_vline(x, y-5, y+5);
|
|
|
|
lcd_update();
|
2007-10-13 16:27:41 +00:00
|
|
|
}
|
2007-10-18 05:14:10 +00:00
|
|
|
#endif
|
2007-10-13 16:27:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2007-10-01 07:52:39 +00:00
|
|
|
|
2007-09-20 04:46:41 +00:00
|
|
|
void main(void)
|
|
|
|
{
|
2007-09-23 23:08:39 +00:00
|
|
|
unsigned char* loadbuffer;
|
2007-09-20 04:46:41 +00:00
|
|
|
int buffer_size;
|
|
|
|
int rc;
|
|
|
|
int(*kernel_entry)(void);
|
2007-09-23 23:08:39 +00:00
|
|
|
|
2007-09-20 04:46:41 +00:00
|
|
|
power_init();
|
2007-09-23 23:08:39 +00:00
|
|
|
lcd_init();
|
2007-09-20 04:46:41 +00:00
|
|
|
system_init();
|
|
|
|
kernel_init();
|
2007-10-26 05:17:15 +00:00
|
|
|
|
|
|
|
set_irq_level(0);
|
|
|
|
set_fiq_status(FIQ_ENABLED);
|
|
|
|
|
2007-09-20 04:46:41 +00:00
|
|
|
adc_init();
|
|
|
|
button_init();
|
|
|
|
backlight_init();
|
2007-09-23 23:08:39 +00:00
|
|
|
|
2007-09-20 04:46:41 +00:00
|
|
|
font_init();
|
|
|
|
|
|
|
|
lcd_setfont(FONT_SYSFIXED);
|
|
|
|
|
|
|
|
/* Show debug messages if button is pressed */
|
|
|
|
// if(button_read_device())
|
|
|
|
verbose = true;
|
|
|
|
|
|
|
|
printf("Rockbox boot loader");
|
|
|
|
printf("Version %s", APPSVERSION);
|
|
|
|
|
|
|
|
usb_init();
|
|
|
|
|
|
|
|
/* Enter USB mode without USB thread */
|
|
|
|
if(usb_detect())
|
|
|
|
{
|
|
|
|
const char msg[] = "Bootloader USB mode";
|
|
|
|
reset_screen();
|
|
|
|
lcd_putsxy( (LCD_WIDTH - (SYSFONT_WIDTH * strlen(msg))) / 2,
|
|
|
|
(LCD_HEIGHT - SYSFONT_HEIGHT) / 2, msg);
|
|
|
|
lcd_update();
|
|
|
|
|
|
|
|
ide_power_enable(true);
|
|
|
|
ata_enable(false);
|
|
|
|
sleep(HZ/20);
|
|
|
|
usb_enable(true);
|
|
|
|
|
|
|
|
while (usb_detect())
|
|
|
|
{
|
|
|
|
ata_spin(); /* Prevent the drive from spinning down */
|
|
|
|
sleep(HZ);
|
|
|
|
}
|
|
|
|
|
|
|
|
usb_enable(false);
|
|
|
|
|
|
|
|
reset_screen();
|
|
|
|
lcd_update();
|
|
|
|
}
|
2007-10-13 16:27:41 +00:00
|
|
|
#if defined(MRDEBUG)
|
|
|
|
mrdebug();
|
2007-09-25 01:44:57 +00:00
|
|
|
#endif
|
2007-09-23 23:08:39 +00:00
|
|
|
printf("ATA");
|
2007-09-20 04:46:41 +00:00
|
|
|
rc = ata_init();
|
|
|
|
if(rc)
|
|
|
|
{
|
|
|
|
reset_screen();
|
|
|
|
error(EATA, rc);
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("disk");
|
|
|
|
disk_init();
|
|
|
|
|
|
|
|
printf("mount");
|
|
|
|
rc = disk_mount_all();
|
|
|
|
if (rc<=0)
|
|
|
|
{
|
|
|
|
error(EDISK,rc);
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("Loading firmware");
|
|
|
|
|
|
|
|
loadbuffer = (unsigned char*) 0x00900000;
|
2007-10-17 05:19:20 +00:00
|
|
|
buffer_size = (unsigned char*)0x01900000 - loadbuffer;
|
2007-09-20 04:46:41 +00:00
|
|
|
|
|
|
|
rc = load_firmware(loadbuffer, BOOTFILE, buffer_size);
|
|
|
|
if(rc < 0)
|
|
|
|
error(EBOOTFILE, rc);
|
|
|
|
|
|
|
|
if (rc == EOK)
|
|
|
|
{
|
|
|
|
kernel_entry = (void*) loadbuffer;
|
|
|
|
rc = kernel_entry();
|
|
|
|
}
|
|
|
|
}
|