Перейти к содержанию
    

странно работает USI в ATTINY26

Пишу SPI master для ATTINY26, делаю, прямо как написано в примере из даташита:

 

void write_spi(unsigned char data)

{

unsigned char tmp;

 

USIDR = data;

 

USISR |= 0x40; // clear interrupt flag

 

tmp = USICR | (1 << USITC) | (1 << USICLK) | (1 << USIOIE);

 

while ((USISR & 0x40) != 0x40) {

USICR = tmp;

}

}

 

SLK вижу, а DO - всякая фигня не соответствующая действительности. вернее, если data = 1 или 5, то ворде как нормально, а все остальное - прыгает и скачет как хочет. в чем проблема?

 

USICR изначально сконфигурен так:

// Universal Serial Interface initialization

// Mode: Three Wire (SPI)

// Clock source: Register & Counter=USICLK

// USI Counter Overflow Interrupt: Off

USICR=0x12;

Изменено пользователем QuadMan

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...