blob: f7d8057e985e30e5ae159ee4df2718a557e9bcfb [file] [log] [blame]
Stuart Martin614acaa2002-04-30 19:23:44 +00001/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
9 *
10 * Copyright (C) 2002 by wavey@wavey.org
Dominik Riebeling551319c2008-05-18 16:21:52 +000011 *
Daniel Stenberg2acc0ac2008-06-28 18:10:04 +000012 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
Stuart Martin614acaa2002-04-30 19:23:44 +000016 *
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
19 *
20 ****************************************************************************/
21
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +000022#include "config.h"
Stuart Martin614acaa2002-04-30 19:23:44 +000023#include <stdio.h>
24#include <stdarg.h>
Björn Stenberg42510d92002-11-12 09:04:06 +000025#include <string.h>
Stuart Martin614acaa2002-04-30 19:23:44 +000026#include "panic.h"
Björn Stenberg697dd702002-05-02 14:05:51 +000027#include "lcd.h"
Daniel Stenberg93b231c2002-09-12 13:33:59 +000028#include "font.h"
Stuart Martin614acaa2002-04-30 19:23:44 +000029#include "debug.h"
Björn Stenberg42510d92002-11-12 09:04:06 +000030#include "led.h"
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +000031#include "power.h"
32#include "system.h"
Stuart Martin614acaa2002-04-30 19:23:44 +000033
Björn Stenberg6b25f792002-07-15 11:02:12 +000034static char panic_buf[128];
Stuart Martin614acaa2002-04-30 19:23:44 +000035
36/*
37 * "Dude. This is pretty fucked-up, right here."
38 */
Jens Arnoldc76c5682004-08-16 23:37:23 +000039void panicf( const char *fmt, ...)
Stuart Martin614acaa2002-04-30 19:23:44 +000040{
41 va_list ap;
Linus Nielsen Feltzing6c2accf2002-05-05 17:51:23 +000042
Linus Nielsen Feltzing011f1d32002-05-05 17:52:59 +000043#ifndef SIMULATOR
Jonathan Gordonbd47d482007-02-18 05:07:19 +000044#if (CONFIG_LED == LED_REAL)
Jens Arnoldf4e77592006-10-08 21:34:26 +000045 bool state = false;
46 int i = 0;
Jens Arnold5690f782005-06-04 23:15:52 +000047#endif
Björn Stenberg42510d92002-11-12 09:04:06 +000048
Linus Nielsen Feltzing6c2accf2002-05-05 17:51:23 +000049 /* Disable interrupts */
Michael Sevakisbfb281f2007-05-12 05:20:04 +000050#ifdef CPU_ARM
51 disable_fiq();
Linus Nielsen Feltzing011f1d32002-05-05 17:52:59 +000052#endif
Michael Sevakisbfb281f2007-05-12 05:20:04 +000053
54 set_irq_level(DISABLE_INTERRUPTS);
55#endif /* SIMULATOR */
Linus Nielsen Feltzingb2ffaa92004-11-02 21:43:37 +000056
Stuart Martin614acaa2002-04-30 19:23:44 +000057 va_start( ap, fmt );
Björn Stenberg824a0032002-05-02 11:44:15 +000058 vsnprintf( panic_buf, sizeof(panic_buf), fmt, ap );
Stuart Martin614acaa2002-04-30 19:23:44 +000059 va_end( ap );
60
Daniel Stenberg7a186cb2002-05-05 11:17:10 +000061#ifdef HAVE_LCD_CHARCELLS
Björn Stenbergb3745a02002-08-08 15:32:15 +000062 lcd_double_height(false);
Daniel Stenberg1a29cfb2005-11-25 00:10:12 +000063 lcd_puts(0, 0, "*PANIC*");
64 lcd_puts(0, 1, panic_buf);
Daniel Stenberg7a186cb2002-05-05 11:17:10 +000065#elif defined(HAVE_LCD_BITMAP)
66 lcd_clear_display();
Björn Stenberga4c3b032002-09-24 18:04:15 +000067 lcd_setfont(FONT_SYSFIXED);
Daniel Stenberg1a29cfb2005-11-25 00:10:12 +000068 lcd_puts(0, 0, (unsigned char *)"*PANIC*");
Björn Stenberg42510d92002-11-12 09:04:06 +000069 {
70 /* wrap panic line */
71 int i, y=1, len = strlen(panic_buf);
72 for (i=0; i<len; i+=18) {
73 unsigned char c = panic_buf[i+18];
74 panic_buf[i+18] = 0;
Daniel Stenberg1a29cfb2005-11-25 00:10:12 +000075 lcd_puts(0, y++, (unsigned char *)panic_buf+i);
Björn Stenberg42510d92002-11-12 09:04:06 +000076 panic_buf[i+18] = c;
77 }
78 }
Daniel Stenberg7a186cb2002-05-05 11:17:10 +000079#else
80 /* no LCD */
81#endif
Jens Arnoldf9b90e92007-04-06 22:55:00 +000082 lcd_update();
Björn Stenberg697dd702002-05-02 14:05:51 +000083 DEBUGF(panic_buf);
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +000084
85 set_cpu_frequency(0);
86
87#ifdef HAVE_ATA_POWER_OFF
88 ide_power_enable(false);
89#endif
90
Björn Stenberg42510d92002-11-12 09:04:06 +000091 while (1)
92 {
Jens Arnold0b001082005-11-09 00:54:43 +000093#ifndef SIMULATOR
Jonathan Gordonbd47d482007-02-18 05:07:19 +000094#if (CONFIG_LED == LED_REAL)
Jens Arnoldf4e77592006-10-08 21:34:26 +000095 if (--i <= 0)
96 {
97 state = !state;
98 led(state);
99 i = 240000;
100 }
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000101#endif
Jens Arnold0b001082005-11-09 00:54:43 +0000102
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000103 /* try to restart firmware if ON is pressed */
Michael Sevakisbfb281f2007-05-12 05:20:04 +0000104#if defined (CPU_PP)
105 /* For now, just sleep the core */
Jens Arnoldcea07eb2008-04-20 17:53:05 +0000106 sleep_core(CURRENT_CORE);
Michael Sevakisbfb281f2007-05-12 05:20:04 +0000107 #define system_reboot() nop
108#elif defined (TOSHIBA_GIGABEAT_F)
109 if ((GPGDAT & (1 << 0)) != 0)
Jens Arnoldc6b6bad2008-03-17 00:19:23 +0000110#elif defined(IRIVER_H100_SERIES) || defined(IRIVER_H300_SERIES)
Jens Arnold0b001082005-11-09 00:54:43 +0000111 if ((GPIO1_READ & 0x22) == 0) /* check for ON button and !hold */
Jens Arnoldc6b6bad2008-03-17 00:19:23 +0000112#elif defined(IAUDIO_X5) || defined(IAUDIO_M5)
113 if ((GPIO_READ & 0x0c000000) == 0x08000000) /* check for ON button and !hold */
114#elif defined(IAUDIO_M3)
115 if ((GPIO1_READ & 0x202) == 0x200) /* check for ON button and !hold */
Rob Purchase3f7f5d72008-05-31 11:30:24 +0000116#elif defined(COWON_D2)
117 if (GPIOA & 0x10) /* check for power button */
Jens Arnold0b001082005-11-09 00:54:43 +0000118#elif CONFIG_CPU == SH7034
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000119#if CONFIG_KEYPAD == PLAYER_PAD
Jens Arnold0b001082005-11-09 00:54:43 +0000120 if (!(PADRL & 0x20))
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000121#elif CONFIG_KEYPAD == RECORDER_PAD
122#ifdef HAVE_FMADC
123 if (!(PCDR & 0x0008))
124#else
Jens Arnold0b001082005-11-09 00:54:43 +0000125 if (!(PBDRH & 0x01))
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000126#endif
Jens Arnold0b001082005-11-09 00:54:43 +0000127#elif CONFIG_KEYPAD == ONDIO_PAD
128 if (!(PCDR & 0x0008))
129#endif /* CONFIG_KEYPAD */
Maurus Cuelenaeree031db42008-05-14 18:55:19 +0000130#elif defined(CREATIVE_ZVx)
Maurus Cuelenaere95167e02008-04-24 20:08:28 +0000131 if(false)
Jens Arnold0b001082005-11-09 00:54:43 +0000132#endif /* CPU */
Linus Nielsen Feltzinge6c6d222005-09-12 10:34:27 +0000133 system_reboot();
Jens Arnold0b001082005-11-09 00:54:43 +0000134#endif /* !SIMULATOR */
Björn Stenberg42510d92002-11-12 09:04:06 +0000135 }
Stuart Martin614acaa2002-04-30 19:23:44 +0000136}