mirror of
				https://github.com/Rockbox/rockbox.git
				synced 2025-10-24 15:37:38 -04:00 
			
		
		
		
	git-svn-id: svn://svn.rockbox.org/rockbox/trunk@20118 a1c6a512-1295-4272-9138-f99709370657
		
			
				
	
	
		
			293 lines
		
	
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			293 lines
		
	
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***************************************************************************
 | |
|  *             __________               __   ___.
 | |
|  *   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"
 | |
| #include "storage.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"
 | |
| #include "spi.h"
 | |
| #include "uart-target.h"
 | |
| #include "tsc2100.h"
 | |
| #include "time.h"
 | |
| #include "system-arm.h"
 | |
| 
 | |
| //#define MRDEBUG
 | |
| 
 | |
| #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);
 | |
| 
 | |
|     /* Make sure interrupts are disabled */
 | |
|     set_irq_level(IRQ_DISABLED);
 | |
|     set_fiq_status(FIQ_DISABLED);
 | |
|     system_init();
 | |
|     kernel_init();
 | |
|     
 | |
|     /* Now enable interrupts */
 | |
|     set_irq_level(IRQ_ENABLED);
 | |
|     set_fiq_status(FIQ_ENABLED);
 | |
| 
 | |
|     backlight_init();
 | |
|     lcd_init();
 | |
|     font_init();
 | |
|     button_init();
 | |
|     usb_init();
 | |
|     
 | |
|     
 | |
|     power_init();
 | |
| //    enable_irq();
 | |
| //    enable_fiq();
 | |
| 
 | |
|     adc_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);
 | |
| 
 | |
|     /* 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);
 | |
|         storage_enable(false);
 | |
|         sleep(HZ/20);
 | |
|         usb_enable(true);
 | |
| 
 | |
|         while (usb_detect() == USB_INSERTED)
 | |
|         {
 | |
|             storage_spin(); /* Prevent the drive from spinning down */
 | |
|             sleep(HZ);
 | |
|         }
 | |
| 
 | |
|         usb_enable(false);
 | |
| 
 | |
|         reset_screen();
 | |
|         lcd_update();
 | |
|     }
 | |
|     
 | |
| #if defined(MRDEBUG)
 | |
|     mrdebug();
 | |
| #endif
 | |
| 
 | |
|     sleep(50);
 | |
| 
 | |
|     printf("ATA");
 | |
|     rc = storage_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;
 | |
|     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();
 | |
|     }
 | |
| }
 |