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

Отмена передачи байта по SPI в STM32F030


User_1

Рекомендуемые сообщения

Доброго времени суток!

Вкратце: нужно после того, как я записал байт данных в SPI1->DR, отменить передачу этого байта и вместо него отправить 0х00

Подробно: Смысл вот в чём: некий контроллер, с которым я пытаюсь наладить общение по SPI, запрашивает произвольный участок массива байт и считывает их сплошным потоком. Ну примерно как считывается микросхема EEPROM: задаёшь начальный адрес, а потом просто шлёшь сплошные 0xFF, а она сама инкрементирует адрес и прямо непрерывным потоком байт выдаёт содержимое памяти. Только тут в роли этой микросхемы мой stm32f030 и мне нужно следующий байт отправлять в SPI1->DR сразу после отправки предыдущего. Но когда поток заканчивается (а он каждый раз разной длины и длина эта заранее неизвестна), один байт остаётся не переданным и отправится первым при следующем запросе. А мне нужно, чтобы первым байтом всегда отправлялся 0х00

Пином (ну то есть битом) NSS управляю программно, его выставление в единичку и снова в ноль, очевидно, не помогает вообще никак. Пока решил проблему так: деинициализирую модуль SPI и выключаю его тактирование, затем включаю тактирование и снова инициализирую. Работает, скорости хватает. Но должно же быть менее костыльное решение?)

Может кто сталкивался с такой проблемой?

Курение даташита, reference manual и результатов поиска в гугле, не особо помогло.

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

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

51 минуту назад, User_1 сказал:

Пином (ну то есть битом) NSS управляю программн

Кто подчиненный? Если МК, то nSS управлять не надо вообще, его надо считывать.

 

Каким образом данные вообще попадают в регистр данных? Что будет, если в него поверх прежних данных положить 0 программно?

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

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

15 минут назад, Стальной сказал:

Кто подчиненный? Если МК, то nSS управлять не надо вообще, его надо считывать.

Каким образом данные вообще попадают в регистр данных? Что будет, если в него поверх прежних данных положить 0 программно?

Верно, модуль SPI в микроконтроллере считывает бит SSI в регистре CR1 - так я могу программно управлять модулем.

Подчинённый как раз мой STM32F030, а устройство, с которым он общается - мастер

Данные в SPI1->DR я просто копирую. Там есть 32-х битный буфер FIFO, то есть в него умещается четыре байта (размер посылки можно сделать например, 16 бит, тогда в буфер поместится две посылки). Можно просто забить этот буфер нулями, но тогда он и передаст 0х00 четыре раза при первой возможности

Изменено пользователем User_1
Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

1 час назад, Стальной сказал:

Ну а если по одному байту за раз класть?

Они просто сохраняются в буфере. Положил два байта - не важно, за раз или по одному - сначала отправится первый, а за ним - второй.

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

можно попробовать только отслеживать состояние буфере по счетчику и отправлять байт только если счетчик нулевой и регистр данных пуст. Тогда гарантированно отправится только один байт. Но могут быть перерывы в передаче, а SPI шина жесткая. Поэтому и буферизированная

И вообще она не очень подходит для обмена данными между контроллерами, да еще и с неопределенным протоколом. Там все должно быть четко и по правилам. Если так не получается, то используются другие шины.

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

Нужно делать то, что нужно. А то, что не нужно, делать не нужно. (С) Винни Пух

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

8 часов назад, mail_robot сказал:

можно попробовать только отслеживать состояние буфере по счетчику и отправлять байт только если счетчик нулевой и регистр данных пуст. Тогда гарантированно отправится только один байт. Но могут быть перерывы в передаче, а SPI шина жесткая. Поэтому и буферизированная

И вообще она не очень подходит для обмена данными между контроллерами, да еще и с неопределенным протоколом. Там все должно быть четко и по правилам. Если так не получается, то используются другие шины.

Вы меня не совсем поняли либо я не понял вас)

Вот прикрепил скрин записи обмена, это конец пакета. Мастер - внешнее устройство, ведомый - мой подопытный. Условно пронумеровал последние три байта. Сразу как только байт номер 1 отправился в шину, я должен положить в буфер байт номер два, иначе он не успеет отправиться. И как только второй улетел в шину - я должен положить в буфер третий. Но я не могу знать, будет ли третий последним, а потому вынужден после отправки третьего перемещать в буфер четвёртый байт. И если третий окажется последним в пакете - нужно отменить передачу четвёртого, иначе он окажется первым в следующем пакете2018-06-22_11-55-04.png.1c1ba8a00ea754ec68df4d1f7ea0d9dc.png

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

15 hours ago, User_1 said:

Но должно же быть менее костыльное решение?

Похоже нет. Программная очичтка ФИФО буфера не предусмотрена. На буржуйских сайтах встечал такой вопрос, а ответа нет. Делают как вы.

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

18 часов назад, User_1 сказал:

деинициализирую модуль SPI и выключаю его тактирование, затем включаю тактирование и снова инициализирую.

Сбросить с помощью 

RCC_APBхRSTR

вместо деинициализации и тырканья тактирования, затем инит .

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

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

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

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

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

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

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

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...