Add command and play around with shit. Change atoi() with strtol() because it is safer.
§
This commit is contained in:
parent
6d8e00b162
commit
ee8f6387ad
@ -25,8 +25,6 @@ void cmd_collect_char(char c)
|
|||||||
|
|
||||||
|
|
||||||
if (c == 0xD) {
|
if (c == 0xD) {
|
||||||
printf("\n\r");
|
|
||||||
|
|
||||||
/* Null-terminate the string */
|
/* Null-terminate the string */
|
||||||
command.buf[command.index-1] = '\0';
|
command.buf[command.index-1] = '\0';
|
||||||
cmd_handle(&command);
|
cmd_handle(&command);
|
||||||
@ -48,15 +46,41 @@ void cmd_handle(cmd_t *command)
|
|||||||
|
|
||||||
void cmd_handle_set(char *op1, char *op2)
|
void cmd_handle_set(char *op1, char *op2)
|
||||||
{
|
{
|
||||||
int val;
|
long int val;
|
||||||
|
char *end;
|
||||||
|
|
||||||
if (0 == strcmp(op1, "t0_top")) {
|
if (0 == strcmp(op1, "t0_top")) {
|
||||||
val = atoi(op2);
|
val = strtol(op2, &end, 10);
|
||||||
if (val) {
|
if (op2 != end) {
|
||||||
OCR0A = val;
|
OCR0A = val;
|
||||||
printf("Setting Timer0 TOP to %i\r\n", val);
|
printf("Setting Timer0 TOP to %li\r\n", val);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
printf("No valid value for t0_top given\n\r");
|
printf("No valid value for t0_top given\n\r");
|
||||||
}
|
}
|
||||||
|
else if (0 == strcmp(op1, "t0_ps")) {
|
||||||
|
val = strtol(op2, &end, 10);
|
||||||
|
TCCR0B &= ~((1 << CS00) | (1 << CS01) | (1 << CS02));
|
||||||
|
switch (val)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
TCCR0B |= (1 << CS00);
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
TCCR0B |= (1 << CS01);
|
||||||
|
break;
|
||||||
|
case 64:
|
||||||
|
TCCR0B |= (1 << CS00) | (1 << CS01);
|
||||||
|
break;
|
||||||
|
case 256:
|
||||||
|
TCCR0B |= (1 << CS02);
|
||||||
|
break;
|
||||||
|
case 1024:
|
||||||
|
TCCR0B |= (1 << CS02) | (1 << CS00);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("No valid prescaler value.\n\r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -20,7 +20,7 @@ int main()
|
|||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
if ((PORTB & (1<<PB2))>1) {
|
if ((PORTB & (1<<PB2))>1) {
|
||||||
_delay_us(10);
|
_delay_us(1);
|
||||||
PORTB &= ~(1<<PB2);
|
PORTB &= ~(1<<PB2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -33,10 +33,3 @@ ISR(TIMER0_COMPA_vect)
|
|||||||
PORTB |= (1 << PB2);
|
PORTB |= (1 << PB2);
|
||||||
}
|
}
|
||||||
|
|
||||||
ISR(USART1_RX_vect)
|
|
||||||
{
|
|
||||||
char u;
|
|
||||||
u = UDR1;
|
|
||||||
|
|
||||||
cmd_collect_char(u);
|
|
||||||
}
|
|
||||||
|
@ -9,8 +9,8 @@ void initCtcTimer0(void)
|
|||||||
/* Enable Counter0 Compare Match A Interrupt */
|
/* Enable Counter0 Compare Match A Interrupt */
|
||||||
TIMSK0 |= (1 << OCIE0A);
|
TIMSK0 |= (1 << OCIE0A);
|
||||||
|
|
||||||
/* Select clock. Prescaler of 1024 */
|
/* Select clock. Prescaler of 8 */
|
||||||
TCCR0B |= (1 << CS02) | (1 << CS00);
|
TCCR0B |= (1 << CS01);
|
||||||
|
|
||||||
/* Use CTC Mode */
|
/* Use CTC Mode */
|
||||||
TCCR0A |= (1 << WGM01);
|
TCCR0A |= (1 << WGM01);
|
||||||
@ -18,7 +18,7 @@ void initCtcTimer0(void)
|
|||||||
/*
|
/*
|
||||||
* OCR0A contains TOP value for counter:
|
* OCR0A contains TOP value for counter:
|
||||||
*/
|
*/
|
||||||
OCR0A = 78;
|
OCR0A = 25;
|
||||||
}
|
}
|
||||||
|
|
||||||
void initOverflowTimer0(void)
|
void initOverflowTimer0(void)
|
||||||
@ -34,4 +34,4 @@ void initOverflowTimer1(void)
|
|||||||
{
|
{
|
||||||
TCCR1B |= (1<<CS11);
|
TCCR1B |= (1<<CS11);
|
||||||
TIMSK1 |= (1<<TOIE1);
|
TIMSK1 |= (1<<TOIE1);
|
||||||
}
|
}
|
@ -1,6 +1,8 @@
|
|||||||
#include <avr/io.h>
|
#include <avr/io.h>
|
||||||
|
#include <avr/interrupt.h>
|
||||||
|
|
||||||
#include "include/uart.h"
|
#include "include/uart.h"
|
||||||
|
#include "include/commands.h"
|
||||||
|
|
||||||
static FILE stream = FDEV_SETUP_STREAM(uart_printf, NULL, _FDEV_SETUP_WRITE);
|
static FILE stream = FDEV_SETUP_STREAM(uart_printf, NULL, _FDEV_SETUP_WRITE);
|
||||||
|
|
||||||
@ -40,3 +42,10 @@ int uart_printf(char var, FILE *stream)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ISR(USART1_RX_vect)
|
||||||
|
{
|
||||||
|
char u;
|
||||||
|
u = UDR1;
|
||||||
|
|
||||||
|
cmd_collect_char(u);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user