i.MX31: Add a debug menu to play around with DVFS/DPTC settings for fun, testing...
[kugel-rb.git] / firmware / target / arm / debug-pp.c
blob3b9250c0fb3202c6013e32dc0a2bfaaea857e22f
1 /***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
10 * Copyright (C) 2006 Dave Chapman
12 * 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.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
22 #include "config.h"
23 #include "system.h"
24 #include <stdbool.h>
25 #include "font.h"
26 #include "lcd.h"
27 #include "button.h"
28 #include "powermgmt.h"
29 #include "adc.h"
30 #include "iap.h"
31 #include "debug-target.h"
33 bool dbg_ports(void)
35 int line;
37 lcd_clear_display();
38 lcd_setfont(FONT_SYSFIXED);
40 while(1)
42 line = 0;
43 #if defined(CPU_PP502x)
44 #if (LCD_HEIGHT >= 176) /* Only for displays with appropriate height. */
45 lcd_puts(0, line++, "GPIO ENABLE:");
46 lcd_putsf(0, line++, "A: %02x E: %02x I: %02x",
47 (unsigned int)GPIOA_ENABLE,
48 (unsigned int)GPIOE_ENABLE,
49 (unsigned int)GPIOI_ENABLE);
50 lcd_putsf(0, line++, "B: %02x F: %02x J: %02x",
51 (unsigned int)GPIOB_ENABLE,
52 (unsigned int)GPIOF_ENABLE,
53 (unsigned int)GPIOJ_ENABLE);
54 lcd_putsf(0, line++, "C: %02x G: %02x K: %02x",
55 (unsigned int)GPIOC_ENABLE,
56 (unsigned int)GPIOG_ENABLE,
57 (unsigned int)GPIOK_ENABLE);
58 lcd_putsf(0, line++, "D: %02x H: %02x L: %02x",
59 (unsigned int)GPIOD_ENABLE,
60 (unsigned int)GPIOH_ENABLE,
61 (unsigned int)GPIOL_ENABLE);
62 line++;
63 #endif
64 lcd_puts(0, line++, "GPIO INPUT VAL:");
65 lcd_putsf(0, line++, "A: %02x E: %02x I: %02x",
66 (unsigned int)GPIOA_INPUT_VAL,
67 (unsigned int)GPIOE_INPUT_VAL,
68 (unsigned int)GPIOI_INPUT_VAL);
69 lcd_putsf(0, line++, "B: %02x F: %02x J: %02x",
70 (unsigned int)GPIOB_INPUT_VAL,
71 (unsigned int)GPIOF_INPUT_VAL,
72 (unsigned int)GPIOJ_INPUT_VAL);
73 lcd_putsf(0, line++, "C: %02x G: %02x K: %02x",
74 (unsigned int)GPIOC_INPUT_VAL,
75 (unsigned int)GPIOG_INPUT_VAL,
76 (unsigned int)GPIOK_INPUT_VAL);
77 lcd_putsf(0, line++, "D: %02x H: %02x L: %02x",
78 (unsigned int)GPIOD_INPUT_VAL,
79 (unsigned int)GPIOH_INPUT_VAL,
80 (unsigned int)GPIOL_INPUT_VAL);
81 line++;
82 lcd_putsf(0, line++, "GPO32_VAL: %08lx", GPO32_VAL);
83 lcd_putsf(0, line++, "GPO32_EN: %08lx", GPO32_ENABLE);
84 lcd_putsf(0, line++, "DEV_EN: %08lx", DEV_EN);
85 lcd_putsf(0, line++, "DEV_EN2: %08lx", DEV_EN2);
86 lcd_putsf(0, line++, "DEV_EN3: %08lx", inl(0x60006044)); /* to be verified */
87 lcd_putsf(0, line++, "DEV_INIT1: %08lx", DEV_INIT1);
88 lcd_putsf(0, line++, "DEV_INIT2: %08lx", DEV_INIT2);
89 #ifdef ADC_ACCESSORY
90 lcd_putsf(0, line++, "ACCESSORY: %d", adc_read(ADC_ACCESSORY));
91 #endif
92 #ifdef IPOD_VIDEO
93 lcd_putsf(0, line++, "4066_ISTAT: %d", adc_read(ADC_4066_ISTAT));
94 #endif
96 #if defined(IPOD_ACCESSORY_PROTOCOL)
97 const unsigned char *serbuf = iap_get_serbuf();
98 lcd_putsf(0, line++, "IAP PACKET: %02x %02x %02x %02x %02x %02x %02x %02x",
99 serbuf[0], serbuf[1], serbuf[2], serbuf[3], serbuf[4], serbuf[5],
100 serbuf[6], serbuf[7]);
101 #endif
103 #if defined(IRIVER_H10) || defined(IRIVER_H10_5GB)
104 line++;
105 lcd_putsf(0, line++, "BATT: %03x UNK1: %03x",
106 adc_read(ADC_BATTERY), adc_read(ADC_UNKNOWN_1));
107 lcd_putsf(0, line++, "REM: %03x PAD: %03x",
108 adc_read(ADC_REMOTE), adc_read(ADC_SCROLLPAD));
109 #elif defined(PHILIPS_HDD1630) || defined(PHILIPS_HDD6330)
110 line++;
111 lcd_putsf(0, line++, "BATT: %03x UNK1: %03x",
112 adc_read(ADC_BATTERY), adc_read(ADC_UNKNOWN_1));
113 #elif defined(SANSA_E200) || defined(PHILIPS_SA9200)
114 lcd_putsf(0, line++, "ADC_BVDD: %4d", adc_read(ADC_BVDD));
115 lcd_putsf(0, line++, "ADC_RTCSUP: %4d", adc_read(ADC_RTCSUP));
116 lcd_putsf(0, line++, "ADC_UVDD: %4d", adc_read(ADC_UVDD));
117 lcd_putsf(0, line++, "ADC_CHG_IN: %4d", adc_read(ADC_CHG_IN));
118 lcd_putsf(0, line++, "ADC_CVDD: %4d", adc_read(ADC_CVDD));
119 lcd_putsf(0, line++, "ADC_BATTEMP: %4d", adc_read(ADC_BATTEMP));
120 lcd_putsf(0, line++, "ADC_MICSUP1: %4d", adc_read(ADC_MICSUP1));
121 lcd_putsf(0, line++, "ADC_MICSUP2: %4d", adc_read(ADC_MICSUP2));
122 lcd_putsf(0, line++, "ADC_VBE1: %4d", adc_read(ADC_VBE1));
123 lcd_putsf(0, line++, "ADC_VBE2: %4d", adc_read(ADC_VBE2));
124 lcd_putsf(0, line++, "ADC_I_MICSUP1:%4d", adc_read(ADC_I_MICSUP1));
125 #if !defined(PHILIPS_SA9200)
126 lcd_putsf(0, line++, "ADC_I_MICSUP2:%4d", adc_read(ADC_I_MICSUP2));
127 lcd_putsf(0, line++, "ADC_VBAT: %4d", adc_read(ADC_VBAT));
128 #endif
129 #endif
131 #elif CONFIG_CPU == PP5002
132 lcd_putsf(0, line++, "GPIO_A: %02x GPIO_B: %02x",
133 (unsigned int)GPIOA_INPUT_VAL, (unsigned int)GPIOB_INPUT_VAL);
134 lcd_putsf(0, line++, "GPIO_C: %02x GPIO_D: %02x",
135 (unsigned int)GPIOC_INPUT_VAL, (unsigned int)GPIOD_INPUT_VAL);
137 lcd_putsf(0, line++, "DEV_EN: %08lx", DEV_EN);
138 lcd_putsf(0, line++, "CLOCK_ENABLE: %08lx", CLOCK_ENABLE);
139 lcd_putsf(0, line++, "CLOCK_SOURCE: %08lx", CLOCK_SOURCE);
140 lcd_putsf(0, line++, "PLL_CONTROL: %08lx", PLL_CONTROL);
141 lcd_putsf(0, line++, "PLL_DIV: %08lx", PLL_DIV);
142 lcd_putsf(0, line++, "PLL_MULT: %08lx", PLL_MULT);
143 lcd_putsf(0, line++, "TIMING1_CTL: %08lx", TIMING1_CTL);
144 lcd_putsf(0, line++, "TIMING2_CTL: %08lx", TIMING2_CTL);
145 #endif
146 lcd_update();
147 if (button_get_w_tmo(HZ/10) == (DEBUG_CANCEL|BUTTON_REL))
149 lcd_setfont(FONT_UI);
150 return false;
153 return false;