avr: Add support for atmega1284p
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
afac81c161
commit
fb0f344346
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue