Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: MSP430F2132 и его I2C
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > MSP430
PriBoris
USCI в режиме I2C slave, чтение 64 байт.
На низкой частоте (не выше 20кбит) после некоторых мучений (например связанных с проблемой USCI28 описанной в Errata) стабильно работает. На высокой частоте (хочется работать на 100кбит как минимум), все данные приходят 0xFF, кроме первого байта который равен 0x05. В реальном массиве таких значений вообще нет.

Подскажите, где копать ?

Никаких энергосберегающих режимов не включено. Используются прерывания START,STOP,RX,TX.

Код инициализации:
Код
UCB0CTL1 |= UCSSEL0 | UCSSEL1 | UCSWRST;
UCB0CTL0 = UCMODE0 | UCMODE1 | UCSYNC;
UCB0I2COA = I2C_ADDRESS;
UCB0CTL1 &= ~UCSWRST;
IE2 |= UCB0TXIE | UCB0RXIE;
UCB0I2CIE |= UCSTPIE + UCSTTIE;
Shread
Может опишите подробнее кто и что и откуда читает? Кто выступает хостом? Байты описанные вами - реально то, что видно на шине лог анализатором, или это считано хостом?
PriBoris
Цитата(Shread @ Dec 23 2010, 11:22) *
Может опишите подробнее кто и что и откуда читает? Кто выступает хостом? Байты описанные вами - реально то, что видно на шине лог анализатором, или это считано хостом?

Читаю компьютером, с помощью FT4232H. То, что читаю, вижу осциллографом. Там единственное, что смущает, так это 9-ый клок всегда приходит со значительным опозданием.
rezident
Цитата(PriBoris @ Dec 23 2010, 17:43) *
Там единственное, что смущает, так это 9-ый клок всегда приходит со значительным опозданием.
Частота MCLK у MSP430 какая? USСI какой частотой тактируется? Похоже, что master у вас не совсем "честный". Откуда брали его реализацию? От FTDI?
Shread
В i2c на ftdi не получается выжать большую скорость, т.к там скорость обмена оганичена частотой прохождения ack(а эта в свою очередь упирается в таймауты по USB). Быстрое считывание там возможно только большими пачками данных без разделения пакетов. Плюс к этому ранние реализации I2С от FTDI имели просто некие косяки в работе(по моему опыту c FT2232C)
Так что проблемы, которые вы описали относятся скорее к FT нежели к MSP430. Если нужно отладить именно I2C слейв, то изобретайте более честный мастер(хоть на таком же MSP).
PriBoris
Цитата(rezident)
Частота MCLK у MSP430 какая? USСI какой частотой тактируется? Похоже, что master у вас не совсем "честный". Откуда брали его реализацию? От FTDI?

Частота в районе 2МГц. Реализация с помощью API от FTDI ( I2C_Read ).
Цитата(Shread)
В i2c на ftdi не получается выжать большую скорость, т.к там скорость обмена оганичена частотой прохождения ack(а эта в свою очередь упирается в таймауты по USB). Быстрое считывание там возможно только большими пачками данных без разделения пакетов. Плюс к этому ранние реализации I2С от FTDI имели просто некие косяки в работе(по моему опыту c FT2232C) Так что проблемы, которые вы описали относятся скорее к FT нежели к MSP430. Если нужно отладить именно I2C слейв, то изобретайте более честный мастер(хоть на таком же MSP).

Логично. С помощью FT я просто хотел немного ускорить события, пока мастер еще не готов (платы не пришли). Если при использовании честного мастера проблема останется - я подниму тему. Спасибо откликнувшимся.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.