АЦП AD7732 имеет вывод Sync, возможно ли его использовать для синхронизации 3 АЦП?
(Примерно так: скажем удерживаем на нем 1, записываем в каждое АЦП регистры, выставляем Sync=0 и получаем по сигналу RDY результат (время преобразования на много больше времени считывания с 3 АЦП), получили заданную последовательность Sync=1, обработали полученные результаты и опять запустили новую последовательность, причем надо ли заново инициализировать АЦП и записывать регистры?).
Подобное решил, но с помощью аппаратной логики (но 8 корпусов получилось и 1 Atmega640 с 1 SPI) , хочу сделать без доп. корпусов на ATxmega128 (имеется сразу 3 SPI), т.е. каждый АЦП подключен к своему SPI порту (без объединения сигнала DIN и выбора по CS DOUT).
Есть правда еще вариант: когда все три SPI на передачу работают одновременно (а это самое главное: запустить АЦП записью в регистр), но честно не нашел (у Atmel) возможно ли чтобы по всем 3 SPI можно было одновременно послать нужную команду.
(Для Atmega 640 это решаться так: (но необходимы доп. корпуса) DIN обеденены, DOUT выбирается по CS :.
// Функция инициализации 3-х АЦП
void Init_ADC(void)
{
//Запись команд в АЦП
//Общий сброс АЦП
PORTF&=~BIT(0); // CS1 установить в 0 - выбор 1 АЦП
PORTF&=~BIT(1); // CS2 установить в 0 - выбор 2 АЦП
PORTF&=~BIT(2); // CS3 установить в 0 - выбор 3 АЦП
SPCR|=BIT(6);
NOP();
SpiWriteByte(0x00);
SpiWriteByte(0xFF);
SpiWriteByte(0xFF);
SpiWriteByte(0xFF);
SpiWriteByte(0xFF);
// Установка параметров для 3-х АЦП
// Записываем в регистры управления АЦП
// Установка регистра - время преобразования FW=125=0x7D -201 Гц примерно
SpiWriteByte(0x30);// Установка регистра для 1 канала
SpiWriteByte(0x80+0x7D);
SpiWriteByte(0x32);// Установка регистра для 2 канала
SpiWriteByte(0x80+0x7D);
// Установка режима работы -+10В и разрешение работы АЦП
SpiWriteByte(0x28);// Установка регистра для 1 канала
SpiWriteByte(0x08);
SpiWriteByte(0x2A);// Установка регистра для 2 канала
SpiWriteByte(0x08);
//Установка режима работы - непрерывный, самостоятельный, попеременный - Mode=0b00100010
SpiWriteByte(0x38);// Установка регистра для 1 канала
SpiWriteByte(0x02);
NOP();
PORTF|=BIT(0); // CS1 установить в 1
PORTF|=BIT(1); // CS2 установить в 1
PORTF|=BIT(2); // CS3 установить в 1
// режимы заданы, АЦП пока не работает
}
//По внешней команде:
#pragma interrupt_handler int0_isr:iv_INT0
void int0_isr(void)
{
//запуск АЦП на оцифровку данных
PORTF&=~BIT(0); // CS1 установить в 0 - выбор 1 АЦП
PORTF&=~BIT(1); // CS2 установить в 0 - выбор 2 АЦП
PORTF&=~BIT(2); // CS3 установить в 0 - выбор 3 АЦП
SpiWriteByte(0x38);// Установка регистра для 1 канала
SpiWriteByte(0x22); // Запуск АЦП - т.е. все 3 АЦП одновременно начнут преобразовывать.
PORTF|=BIT(0); // CS1 установить в 1
PORTF|=BIT(1); // CS2 установить в 1
PORTF|=BIT(2); // CS3 установить в 1
}
// Функция считывания результата (понятно по CS выбираем тип кристалла).
...