avr: Add support for atmega1284p

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2017-10-05 13:51:05 -04:00
parent afac81c161
commit fb0f344346
2 changed files with 13 additions and 5 deletions

View File

@ -23,6 +23,8 @@ choice
bool "atmega1280" bool "atmega1280"
config MACH_at90usb1286 config MACH_at90usb1286
bool "at90usb1286" bool "at90usb1286"
config MACH_atmega1284p
bool "atmega1284p"
config MACH_atmega644p config MACH_atmega644p
bool "atmega644p" bool "atmega644p"
config MACH_atmega328 config MACH_atmega328
@ -35,6 +37,7 @@ config MCU
string string
default "atmega168" if MACH_atmega168 default "atmega168" if MACH_atmega168
default "atmega328" if MACH_atmega328 default "atmega328" if MACH_atmega328
default "atmega1284p" if MACH_atmega1284p
default "atmega644p" if MACH_atmega644p default "atmega644p" if MACH_atmega644p
default "at90usb1286" if MACH_at90usb1286 default "at90usb1286" if MACH_at90usb1286
default "atmega1280" if MACH_atmega1280 default "atmega1280" if MACH_atmega1280
@ -44,7 +47,7 @@ choice
prompt "Processor speed" prompt "Processor speed"
config AVR_FREQ_20000000 config AVR_FREQ_20000000
bool "20Mhz" bool "20Mhz"
depends on MACH_atmega168 || MACH_atmega328 || MACH_atmega644p depends on MACH_atmega168 || MACH_atmega328 || MACH_atmega644p || MACH_atmega1284p
config AVR_FREQ_16000000 config AVR_FREQ_16000000
bool "16Mhz" bool "16Mhz"
config AVR_FREQ_8000000 config AVR_FREQ_8000000
@ -98,7 +101,7 @@ config SERIAL_BAUD_U2X
default y default y
config SIMULAVR config SIMULAVR
depends on MACH_atmega168 || MACH_atmega328 || MACH_atmega644p depends on MACH_atmega168 || MACH_atmega328 || MACH_atmega644p || MACH_atmega1284p
bool "Compile for simulavr software emulation" bool "Compile for simulavr software emulation"
default n default n
help help

View File

@ -126,6 +126,8 @@ static const struct gpio_pwm_info pwm_regs[] PROGMEM = {
#ifdef OCR3A #ifdef OCR3A
{ &OCR3A, &TCCR3A, &TCCR3B, 1<<COM3A1, 0 }, { &OCR3A, &TCCR3A, &TCCR3B, 1<<COM3A1, 0 },
{ &OCR3B, &TCCR3A, &TCCR3B, 1<<COM3B1, 0 }, { &OCR3B, &TCCR3A, &TCCR3B, 1<<COM3B1, 0 },
#endif
#ifdef OCR3C
{ &OCR3C, &TCCR3A, &TCCR3B, 1<<COM3C1, 0 }, { &OCR3C, &TCCR3A, &TCCR3B, 1<<COM3C1, 0 },
#endif #endif
#ifdef OCR4A #ifdef OCR4A
@ -143,10 +145,13 @@ static const uint8_t pwm_pins[ARRAY_SIZE(pwm_regs)] PROGMEM = {
GPIO('D', 6), GPIO('D', 5), GPIO('D', 6), GPIO('D', 5),
GPIO('B', 1), GPIO('B', 2), GPIO('B', 1), GPIO('B', 2),
GPIO('B', 3), GPIO('D', 3), GPIO('B', 3), GPIO('D', 3),
#elif CONFIG_MACH_atmega644p #elif CONFIG_MACH_atmega644p || CONFIG_MACH_atmega1284p
GPIO('B', 3), GPIO('B', 4), GPIO('B', 3), GPIO('B', 4),
GPIO('D', 5), GPIO('D', 4), GPIO('D', 5), GPIO('D', 4),
GPIO('D', 7), GPIO('D', 6), GPIO('D', 7), GPIO('D', 6),
# ifdef OCR3A
GPIO('B', 6), GPIO('B', 7),
# endif
#elif CONFIG_MACH_at90usb1286 #elif CONFIG_MACH_at90usb1286
GPIO('B', 7), GPIO('D', 0), GPIO('B', 7), GPIO('D', 0),
GPIO('B', 5), GPIO('B', 6), GPIO('B', 7), GPIO('B', 5), GPIO('B', 6), GPIO('B', 7),
@ -244,7 +249,7 @@ static const uint8_t adc_pins[] PROGMEM = {
#if CONFIG_MACH_atmega168 || CONFIG_MACH_atmega328 #if CONFIG_MACH_atmega168 || CONFIG_MACH_atmega328
GPIO('C', 0), GPIO('C', 1), GPIO('C', 2), GPIO('C', 3), GPIO('C', 0), GPIO('C', 1), GPIO('C', 2), GPIO('C', 3),
GPIO('C', 4), GPIO('C', 5), GPIO('E', 0), GPIO('E', 1), GPIO('C', 4), GPIO('C', 5), GPIO('E', 0), GPIO('E', 1),
#elif CONFIG_MACH_atmega644p #elif CONFIG_MACH_atmega644p || CONFIG_MACH_atmega1284p
GPIO('A', 0), GPIO('A', 1), GPIO('A', 2), GPIO('A', 3), GPIO('A', 0), GPIO('A', 1), GPIO('A', 2), GPIO('A', 3),
GPIO('A', 4), GPIO('A', 5), GPIO('A', 6), GPIO('A', 7), GPIO('A', 4), GPIO('A', 5), GPIO('A', 6), GPIO('A', 7),
#elif CONFIG_MACH_at90usb1286 #elif CONFIG_MACH_at90usb1286
@ -345,7 +350,7 @@ gpio_adc_cancel_sample(struct gpio_adc g)
#if CONFIG_MACH_atmega168 || CONFIG_MACH_atmega328 #if CONFIG_MACH_atmega168 || CONFIG_MACH_atmega328
static const uint8_t SS = GPIO('B', 2), SCK = GPIO('B', 5), MOSI = GPIO('B', 3); static const uint8_t SS = GPIO('B', 2), SCK = GPIO('B', 5), MOSI = GPIO('B', 3);
#elif CONFIG_MACH_atmega644p #elif CONFIG_MACH_atmega644p || CONFIG_MACH_atmega1284p
static const uint8_t SS = GPIO('B', 4), SCK = GPIO('B', 7), MOSI = GPIO('B', 5); static const uint8_t SS = GPIO('B', 4), SCK = GPIO('B', 7), MOSI = GPIO('B', 5);
#elif CONFIG_MACH_at90usb1286 || CONFIG_MACH_atmega1280 || CONFIG_MACH_atmega2560 #elif CONFIG_MACH_at90usb1286 || CONFIG_MACH_atmega1280 || CONFIG_MACH_atmega2560
static const uint8_t SS = GPIO('B', 0), SCK = GPIO('B', 1), MOSI = GPIO('B', 2); static const uint8_t SS = GPIO('B', 0), SCK = GPIO('B', 1), MOSI = GPIO('B', 2);