Кто любит RISC в жизни, заходим, не стесняемся.
Ответить

NRF51822 SPI

Пт ноя 16, 2018 13:41:03

Доброго времени! Возникло недопонимание в плане работы SPI в контроллере NRF51822. А именно: в Reference Manual (http://infocenter.nordicsemi.com/pdf/nRF51_RM_v3.0.pdf) написано, что отправка наступает после записи в регистр TXD. Т.е. это можно понимать так: после записи в регистр TXD начинается тактирование SPI, генерируется 8 тактовых импульсов и записанный байт сдвигается в MOSI. Ок, допустим. Мне нужно работать с АЦП ADS1220 (http://www.ti.com/lit/ds/symlink/ads1220.pdf) одиночными запросами. Для этого там есть команда START/SYNC (8 бит). Т.е. по времнной диаграмме на стр 37 даташита имеем следующее: посылаем START/SYNC и, спустя время, генерим 3*8=24 тактовых импульса и забираем свои заветные 24 бита с АЦП. А теперь собственно вопрос: как заставить NRF сгенерировать эти тактовые импульсы? Можно ли писать в регистр TXD просто нули, будет ли SPI на это реагировать и генерировать такт? Каким образом контроллер распознает факт записи в регистр? Может быть, кто сталкивался с подобным?

Re: NRF51822 SPI

Пт ноя 16, 2018 13:50:53

KT315B, обычно хоть нули хоть что . В SPI что бы что-то получить надо что нибудь послать.
Новичок что ли?
Не знаю как в NRF51 , в NRF52 SPI прост до безобразия ну и плюс еще EasyDMA, ну и плюс махаем лапкой SS аппаратно...

Re: NRF51822 SPI

Пт ноя 16, 2018 13:54:20

Не, не новичок, но, относительно новичок в NRF )) Непонятно, как контроллер опознает (и опознает ли?) факт записи в TXD. Если вариант с записью нулей прокатывает - проблема решена. Смутило отсутствие нечто типа "TASKSTART" по сравнению, с остальной периферией NRF51. Сам АЦП для экспериментов получу только в понедельник (
Последний раз редактировалось KT315B Пт ноя 16, 2018 14:02:32, всего редактировалось 1 раз.

Re: NRF51822 SPI

Пт ноя 16, 2018 14:02:04

В мануале же:
26.1.3 SPI master transaction sequence
An SPI master transaction is started by writing the first byte, which is to be transmitted by the SPI master, to
the TXD register. Since the transmitter is double buffered, the second byte can be written to the TXD register
immediately after the first one. The SPI master will then send these bytes in the order they are written to the
TXD register.

Re: NRF51822 SPI

Пт ноя 16, 2018 14:04:19

Это читал. Просто, допустим, я туда буду слать постоянно [START/SYNC]--пауза--[0][0][0]. Когда будут идти друг за другом нули - содержимое регистра не будет меняться, каким образом контроллер поймет, что туда что-то записано и надо генерировать такт? Стробирование данных TXD не понятно :o

Re: NRF51822 SPI

Пт ноя 16, 2018 14:16:12

Фиксируется сам факт записи а не содержимое. Это же для SPI модуля любого производителя справедливо.
Есть лог.анализатор?

Re: NRF51822 SPI

Пт ноя 16, 2018 14:17:45

Ок, спасибо не был уверен, решил убедиться. Думал, запись стробироваться должна.

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

Re: NRF51822 SPI

Пт ноя 16, 2018 14:23:16

Контроллер вообще не анализирует данные, пока его об этом не попросят специально. Сказано "переслать из ячейки памяти А в регистр Б один байт", он выполняет. SPI-блоку точно так же пофиг. Он получил информацию о том, что поступил новый байт, схватил его и поволок выталкивать в линию. Что это за байт, какая у него судьба, что в нем и т.п. абсолютно никого внутри МК не интересует.
Ответить