2008-09-10 19:35:15 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 by Karl Kurbjun
|
|
|
|
*
|
|
|
|
* 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 software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "inttypes.h"
|
|
|
|
#include "string.h"
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "system.h"
|
|
|
|
#include "lcd.h"
|
|
|
|
#include "kernel.h"
|
|
|
|
#include "thread.h"
|
2008-11-01 16:14:28 +00:00
|
|
|
#include "storage.h"
|
2008-09-10 19:35:15 +00:00
|
|
|
#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"
|
|
|
|
#include "spi.h"
|
|
|
|
#include "uart-target.h"
|
|
|
|
#include "tsc2100.h"
|
|
|
|
#include "time.h"
|
|
|
|
#include "system-arm.h"
|
|
|
|
|
2009-02-26 21:24:40 +00:00
|
|
|
//#define MRDEBUG
|
2008-09-10 19:35:15 +00:00
|
|
|
|
|
|
|
#if defined(MRDEBUG)
|
|
|
|
|
|
|
|
extern int line;
|
|
|
|
#if 0
|
|
|
|
struct touch_calibration_point tl, br;
|
|
|
|
|
|
|
|
void touchscreen_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_TOUCHSCREEN)
|
|
|
|
{
|
|
|
|
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 touchscreen_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;
|
|
|
|
touchscreen_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;
|
|
|
|
touchscreen_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);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
static uint8_t bl_command[] = {0xa4, 0x00, 0x00, 0xbb};
|
|
|
|
int brightness = 0;
|
|
|
|
|
|
|
|
void mrdebug(void)
|
|
|
|
{
|
|
|
|
int button=0;
|
|
|
|
#if 0
|
|
|
|
use_calibration(false);
|
|
|
|
touchscreen_calibrate_screen();
|
|
|
|
use_calibration(true);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
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));
|
|
|
|
#endif
|
|
|
|
button = button_get(false);
|
|
|
|
if (button == BUTTON_POWER)
|
|
|
|
{
|
|
|
|
printf("reset");
|
|
|
|
IO_GIO_BITSET1|=1<<10;
|
|
|
|
}
|
|
|
|
if (button==BUTTON_RC_VOL_DOWN)
|
|
|
|
{
|
|
|
|
brightness = (brightness - 5) & 0x7f;
|
|
|
|
bl_command[2] = brightness;
|
|
|
|
spi_block_transfer(SPI_target_BACKLIGHT, bl_command, 4, 0, 0);
|
|
|
|
}
|
|
|
|
else if (button==BUTTON_RC_VOL_UP)
|
|
|
|
{
|
|
|
|
brightness = (brightness + 5) & 0x7f;
|
|
|
|
bl_command[2] = brightness;
|
|
|
|
spi_block_transfer(SPI_target_BACKLIGHT, bl_command, 4, 0, 0);
|
|
|
|
}
|
|
|
|
// {
|
|
|
|
// 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);
|
|
|
|
// // tsc2100_keyclick(); /* doesnt work :( */
|
|
|
|
// line -= 6;
|
|
|
|
// }
|
|
|
|
else if (button == BUTTON_RC_HEART)
|
|
|
|
{
|
|
|
|
printf("POINT");
|
|
|
|
touchscreen_set_mode(TOUCHSCREEN_POINT);
|
|
|
|
}
|
|
|
|
else if (button == BUTTON_RC_MODE)
|
|
|
|
{
|
|
|
|
printf("BUTTON");
|
|
|
|
touchscreen_set_mode(TOUCHSCREEN_BUTTON);
|
|
|
|
}
|
|
|
|
#if 1
|
|
|
|
else if (button&BUTTON_TOUCHSCREEN)
|
|
|
|
{
|
|
|
|
if (button&BUTTON_REL)
|
|
|
|
continue;
|
|
|
|
unsigned int data = button_get_data();
|
|
|
|
int x = (data&0xffff0000)>>16, y = data&0x0000ffff;
|
|
|
|
reset_screen();
|
|
|
|
line = 9;
|
|
|
|
printf("BB: %x %d %d", button, x,y);
|
|
|
|
lcd_hline(x-5, x+5, y);
|
|
|
|
lcd_vline(x, y-5, y+5);
|
|
|
|
lcd_update();
|
|
|
|
}
|
|
|
|
else if (button == BUTTON_RC_PLAY)
|
|
|
|
{
|
|
|
|
reset_screen();
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (button)
|
|
|
|
{
|
|
|
|
// if (button&BUTTON_REL)
|
|
|
|
{
|
|
|
|
printf("%08x %s\n", button, (button&BUTTON_REL)?"yes":"no");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void main(void)
|
|
|
|
{
|
|
|
|
unsigned char* loadbuffer;
|
|
|
|
int buffer_size;
|
|
|
|
int rc;
|
|
|
|
int(*kernel_entry)(void);
|
|
|
|
|
2009-02-26 21:24:40 +00:00
|
|
|
/* Make sure interrupts are disabled */
|
|
|
|
set_irq_level(IRQ_DISABLED);
|
|
|
|
set_fiq_status(FIQ_DISABLED);
|
2008-09-10 19:35:15 +00:00
|
|
|
system_init();
|
|
|
|
kernel_init();
|
|
|
|
|
2009-02-26 21:24:40 +00:00
|
|
|
/* Now enable interrupts */
|
|
|
|
set_irq_level(IRQ_ENABLED);
|
|
|
|
set_fiq_status(FIQ_ENABLED);
|
2008-09-10 19:35:15 +00:00
|
|
|
|
|
|
|
backlight_init();
|
2009-02-26 21:24:40 +00:00
|
|
|
lcd_init();
|
2008-09-10 19:35:15 +00:00
|
|
|
font_init();
|
2009-02-26 21:24:40 +00:00
|
|
|
button_init();
|
|
|
|
usb_init();
|
|
|
|
|
|
|
|
|
|
|
|
power_init();
|
|
|
|
// enable_irq();
|
|
|
|
// enable_fiq();
|
|
|
|
|
|
|
|
adc_init();
|
2008-09-10 19:35:15 +00:00
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
/* Enter USB mode without USB thread */
|
|
|
|
if(usb_detect() == USB_INSERTED)
|
|
|
|
{
|
|
|
|
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);
|
2008-11-01 16:14:28 +00:00
|
|
|
storage_enable(false);
|
2008-09-10 19:35:15 +00:00
|
|
|
sleep(HZ/20);
|
|
|
|
usb_enable(true);
|
|
|
|
|
|
|
|
while (usb_detect() == USB_INSERTED)
|
|
|
|
{
|
2008-11-01 16:14:28 +00:00
|
|
|
storage_spin(); /* Prevent the drive from spinning down */
|
2008-09-10 19:35:15 +00:00
|
|
|
sleep(HZ);
|
|
|
|
}
|
|
|
|
|
|
|
|
usb_enable(false);
|
|
|
|
|
|
|
|
reset_screen();
|
|
|
|
lcd_update();
|
|
|
|
}
|
2009-02-26 21:24:40 +00:00
|
|
|
|
2008-09-10 19:35:15 +00:00
|
|
|
#if defined(MRDEBUG)
|
|
|
|
mrdebug();
|
|
|
|
#endif
|
2009-02-26 21:24:40 +00:00
|
|
|
|
|
|
|
sleep(50);
|
|
|
|
|
2008-09-10 19:35:15 +00:00
|
|
|
printf("ATA");
|
2008-11-01 16:14:28 +00:00
|
|
|
rc = storage_init();
|
2008-09-10 19:35:15 +00:00
|
|
|
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;
|
|
|
|
buffer_size = (unsigned char*)0x01900000 - loadbuffer;
|
|
|
|
|
|
|
|
rc = load_firmware(loadbuffer, BOOTFILE, buffer_size);
|
|
|
|
if(rc < 0)
|
|
|
|
error(EBOOTFILE, rc);
|
|
|
|
|
|
|
|
if (rc == EOK)
|
|
|
|
{
|
|
|
|
kernel_entry = (void*) loadbuffer;
|
|
|
|
rc = kernel_entry();
|
|
|
|
}
|
|
|
|
}
|