]>
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"
26 /*--------------------------------------------------------------------------*/
29 __attribute__ ((naked
)) __attribute__ ((section (".init3")))
30 void preset_ram (void)
32 for (uint8_t *p
= RAMSTART
; p
<= (uint8_t *) RAMEND
; p
++)
37 static const FLASH
char * const FLASH rreasons
[] = {
46 void print_reset_reason(void)
48 uint8_t r
= mcusr
& 0x1f;
49 const FLASH
char * const FLASH
*p
= rreasons
;
51 printf_P(PSTR("### Reset reason(s): %s"), r
? "" : "none");
52 for ( ; r
; p
++, r
>>= 1) {
59 printf_P(PSTR(".\n"));
66 Stat
|= S_MSG_PENDING
;
71 Stat
|= S_CON_PENDING
;
77 /* save and clear reset reason(s) */
78 /* TODO: move to init section? */
86 /* Disable JTAG Interface regardless of the JTAGEN fuse setting. */
90 /* Disable peripherals. Enable individually in respective init function. */
92 _BV(PRTIM2
) | _BV(PRTIM0
) | _BV(PRTIM1
) |
93 _BV(PRSPI
) | _BV(PRUSART0
) | _BV(PRADC
);
95 PRR1
= _BV(PRTIM5
) | _BV(PRTIM4
) | _BV(PRTIM3
) |
96 _BV(PRUSART3
) | _BV(PRUSART2
) | _BV(PRUSART1
);
99 /* disable analog comparator */
108 PRR1
&= ~_BV(PRTIM3
);
109 OCR3A
= F_CPU
/ 1000 - 1; /* Timer3: 1000Hz interval (OC3A) */
110 TCCR3B
= (0b01<<WGM32
)|(0b001<<CS30
); /* CTC Mode, Prescaler 1 */
111 TIMSK3
= _BV(OCIE3A
); /* Enable TC2.oca interrupt */
115 SPI_DDR
= (SPI_DDR
& ~_BV(SPI_MISO
))
116 | _BV(SPI_MOSI
) | _BV(SPI_SCK
) | _BV(SPI_SS
);
117 SPI_PORT
= (SPI_PORT
& ~(_BV(SPI_MOSI
) | _BV(SPI_SCK
)))
120 /* INT5, INT6: falling edge */
121 EICRB
= (EICRB
& ~((0b11 << ISC50
) | (0b11 << ISC60
))) |
122 (0b10 << ISC50
) | (0b10 << ISC60
);
123 /* Reset pending ints */
124 EIFR
|= _BV(INTF5
) | _BV(INTF6
);
125 /* Enable INT5, and INT6 */
126 EIMSK
|= _BV(INT5
) | _BV(INT6
);
130 int reset_reason_is_power_on(void)
132 return (mcusr
& _BV(PORF
)) != 0;
135 /*--------------------------------------------------------------------------*/
137 /* Stored value of bootdelay, used by autoboot_command() */
138 static int stored_bootdelay
;
141 /***************************************************************************
142 * Watch for 'delay' seconds for autoboot stop.
143 * returns: 0 - no key, allow autoboot
147 static int abortboot(int bootdelay
)
153 printf_P(PSTR("Hit any key to stop autoboot: %2d "), bootdelay
);
155 #if defined CONFIG_ZERO_BOOTDELAY_CHECK
157 * Check if key already pressed
158 * Don't check if bootdelay < 0
160 if (bootdelay
>= 0) {
161 if (tstc()) { /* we got a key press */
162 (void) my_getchar(1); /* consume input */
163 my_puts_P(PSTR("\b\b\b 0"));
164 abort
= 1; /* don't auto boot */
169 while ((bootdelay
> 0) && (!abort
)) {
174 if (tstc()) { /* we got a key press */
175 abort
= 1; /* don't auto boot */
176 bootdelay
= 0; /* no more delay */
180 } while (!abort
&& get_timer(ts
) < 1000);
182 printf_P(PSTR("\b\b\b%2d "), bootdelay
);
191 const char *bootdelay_process(void)
196 bootdelay
= (int) getenv_ulong(PSTR(ENV_BOOTDELAY
), 10, CONFIG_BOOTDELAY
);
199 debug("### main_loop entered: bootdelay=%d\n\n", bootdelay
);
202 s
= getenv(PSTR(ENV_BOOTCMD
));
203 stored_bootdelay
= bootdelay
;
208 void autoboot_command(const char *s
)
210 debug("### main_loop: bootcmd=\"%s\"\n", s
? s
: PSTR("<UNDEFINED>"));
213 if (stored_bootdelay
!= -1 && s
&& !abortboot(stored_bootdelay
)) {
214 run_command_list(s
, -1);
224 s
= bootdelay_process();
233 for (int i
= 0; i
< GPIO_MAX
; i
++)
234 gpio_config(i
, INPUT_PULLUP
);
237 if (reset_reason_is_power_on())
238 _delay_ms(CONFIG_PWRON_DELAY
);
240 serial_setup(getenv_ulong(PSTR(ENV_BAUDRATE
), 10, CONFIG_BAUDRATE
));
244 debug("\n=========================< (RE)START DEBUG >=========================\n");
245 print_reset_reason();
249 unsigned long i_speed
= getenv_ulong(PSTR("i2c_clock"), 10, CONFIG_SYS_I2C_CLOCK
);
250 debug("### Setting I2C clock Frequency to %lu Hz.\n", i_speed
);
253 i2c_init(CONFIG_SYS_I2C_CLOCK
);
256 printf_P(PSTR("\nATMEGA1281+Z8S180 Stamp Monitor\n\n"));