]>
cloudbase.mooo.com Git - z180-stamp.git/blob - avr/main.c
7 #include <avr/interrupt.h>
15 #include "con-utils.h"
20 #include "z180-serv.h"
24 /*--------------------------------------------------------------------------*/
27 __attribute__ ((naked
)) __attribute__ ((section (".init3")))
28 void preset_ram (void)
30 for (uint8_t *p
= RAMSTART
; p
<= (uint8_t *) RAMEND
; p
++)
35 static const FLASH
char * const FLASH rreasons
[] = {
44 void print_reset_reason(void)
46 uint8_t r
= mcusr
& 0x1f;
47 const FLASH
char * const FLASH
*p
= rreasons
;
49 printf_P(PSTR("### Reset reason(s): %s"), r
? "" : "none");
50 for ( ; r
; p
++, r
>>= 1) {
57 printf_P(PSTR(".\n"));
64 Stat
|= S_MSG_PENDING
;
69 Stat
|= S_CON_PENDING
;
75 /* save and clear reset reason(s) */
76 /* TODO: move to init section? */
84 /* Disable JTAG Interface regardless of the JTAGEN fuse setting. */
88 /* Disable peripherals. Enable individually in respective init function. */
90 _BV(PRTIM2
) | _BV(PRTIM0
) | _BV(PRTIM1
) |
91 _BV(PRSPI
) | _BV(PRUSART0
) | _BV(PRADC
);
93 PRR1
= _BV(PRTIM5
) | _BV(PRTIM4
) | _BV(PRTIM3
) |
94 _BV(PRUSART3
) | _BV(PRUSART2
) | _BV(PRUSART1
);
97 /* disable analog comparator */
106 PRR1
&= ~_BV(PRTIM3
);
107 OCR3A
= F_CPU
/ 1000 - 1; /* Timer3: 1000Hz interval (OC3A) */
108 TCCR3B
= (0b01<<WGM32
)|(0b001<<CS30
); /* CTC Mode, Prescaler 1 */
109 TIMSK3
= _BV(OCIE3A
); /* Enable TC2.oca interrupt */
111 /* INT5, INT6: falling edge */
112 EICRB
= (EICRB
& ~((0b11 << ISC50
) | (0b11 << ISC60
))) |
113 (0b10 << ISC50
) | (0b10 << ISC60
);
114 /* Reset pending ints */
115 EIFR
|= _BV(INTF5
) | _BV(INTF6
);
116 /* Enable INT5, and INT6 */
117 EIMSK
|= _BV(INT5
) | _BV(INT6
);
121 int reset_reason_is_power_on(void)
123 return (mcusr
& _BV(PORF
)) != 0;
126 /*--------------------------------------------------------------------------*/
128 /* Stored value of bootdelay, used by autoboot_command() */
129 static int stored_bootdelay
;
132 /***************************************************************************
133 * Watch for 'delay' seconds for autoboot stop.
134 * returns: 0 - no key, allow autoboot
138 static int abortboot(int bootdelay
)
144 printf_P(PSTR("Hit any key to stop autoboot: %2d "), bootdelay
);
146 #if defined CONFIG_ZERO_BOOTDELAY_CHECK
148 * Check if key already pressed
149 * Don't check if bootdelay < 0
151 if (bootdelay
>= 0) {
152 if (tstc()) { /* we got a key press */
153 (void) my_getchar(1); /* consume input */
154 my_puts_P(PSTR("\b\b\b 0"));
155 abort
= 1; /* don't auto boot */
160 while ((bootdelay
> 0) && (!abort
)) {
165 if (tstc()) { /* we got a key press */
166 abort
= 1; /* don't auto boot */
167 bootdelay
= 0; /* no more delay */
171 } while (!abort
&& get_timer(ts
) < 1000);
173 printf_P(PSTR("\b\b\b%2d "), bootdelay
);
182 const char *bootdelay_process(void)
187 bootdelay
= (int) getenv_ulong(PSTR(ENV_BOOTDELAY
), 10, CONFIG_BOOTDELAY
);
190 debug("### main_loop entered: bootdelay=%d\n\n", bootdelay
);
193 s
= getenv(PSTR(ENV_BOOTCMD
));
194 stored_bootdelay
= bootdelay
;
199 void autoboot_command(const char *s
)
201 debug("### main_loop: bootcmd=\"%s\"\n", s
? s
: PSTR("<UNDEFINED>"));
204 if (stored_bootdelay
!= -1 && s
&& !abortboot(stored_bootdelay
)) {
205 run_command_list(s
, -1);
215 s
= bootdelay_process();
228 if (reset_reason_is_power_on())
229 _delay_ms(CONFIG_PWRON_DELAY
);
231 serial_setup(getenv_ulong(PSTR(ENV_BAUDRATE
), 10, CONFIG_BAUDRATE
));
235 debug("\n=========================< (RE)START DEBUG >=========================\n");
236 print_reset_reason();
240 unsigned long i_speed
= getenv_ulong(PSTR("i2c_clock"), 10, CONFIG_SYS_I2C_CLOCK
);
241 debug("### Setting I2C clock Frequency to %lu Hz.\n", i_speed
);
244 i2c_init(CONFIG_SYS_I2C_CLOCK
);
247 printf_P(PSTR("\nATMEGA1281+Z8S180 Stamp Monitor\n\n"));