Доброго времени! Возникло недопонимание в плане работы 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 на это реагировать и генерировать такт? Каким образом контроллер распознает факт записи в регистр? Может быть, кто сталкивался с подобным?
KT315B, обычно хоть нули хоть что . В SPI что бы что-то получить надо что нибудь послать. Новичок что ли? Не знаю как в NRF51 , в NRF52 SPI прост до безобразия ну и плюс еще EasyDMA, ну и плюс махаем лапкой SS аппаратно...
Не, не новичок, но, относительно новичок в NRF )) Непонятно, как контроллер опознает (и опознает ли?) факт записи в TXD. Если вариант с записью нулей прокатывает - проблема решена. Смутило отсутствие нечто типа "TASKSTART" по сравнению, с остальной периферией NRF51. Сам АЦП для экспериментов получу только в понедельник (
_________________ R2AIV 73!
Последний раз редактировалось KT315B Пт ноя 16, 2018 14:02:32, всего редактировалось 1 раз.
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.
Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ очень важен контроль процесса заряда и разряда для избегания воздействия внешнего зарядного напряжения после достижения 100% заряда. Инженеры КОМПЭЛ подготовили список таких решений от разных производителей.
Это читал. Просто, допустим, я туда буду слать постоянно [START/SYNC]--пауза--[0][0][0]. Когда будут идти друг за другом нули - содержимое регистра не будет меняться, каким образом контроллер поймет, что туда что-то записано и надо генерировать такт? Стробирование данных TXD не понятно
Компания EVE выпустила новый аккумулятор серии PLM, сочетающий в себе высокую безопасность, длительный срок службы, широкий температурный диапазон и высокую токоотдачу даже при отрицательной температуре.
Эти аккумуляторы поддерживают заряд при температуре от -40/-20°С (сниженным значением тока), безопасны (не воспламеняются и не взрываются) при механическом повреждении (протыкание и сдавливание), устойчивы к вибрации. Они могут применяться как для автотранспорта (трекеры, маячки, сигнализация), так и для промышленных устройств мониторинга, IoT-устройств.
Контроллер вообще не анализирует данные, пока его об этом не попросят специально. Сказано "переслать из ячейки памяти А в регистр Б один байт", он выполняет. SPI-блоку точно так же пофиг. Он получил информацию о том, что поступил новый байт, схватил его и поволок выталкивать в линию. Что это за байт, какая у него судьба, что в нем и т.п. абсолютно никого внутри МК не интересует.
Карма: 16
Рейтинг сообщений: 170
Зарегистрирован: Вс дек 02, 2012 16:58:33 Сообщений: 829 Откуда: Уже не город Белых гор
Рейтинг сообщения:0
Добрый день. Подниму тему. Чип NRF52833, поднимаю SPI Master. Прописываю настройки и адреса буферов чтения и записи, количество посылок. Но после записи START task ничего не происходит. В регистрах состояния видно, что SPI пытается стартовать, но ему что-то мешает. Никак не пойму, что. Код настройки SPI (используется только одна ножка MOSI): Спойлер
Теперь, чтобы запустить SPI, достаточно просто пихнуть данные в регистр.
Код:
NRF_SPI0->TXD = buffer[0];
Действительно, один байт передаётся. Попробовал передать массив , ориентируясь по флагу EVENTS_READY,:
Код:
NRF_SPI0->EVENTS_READY = 0x0UL; NRF_SPI0->TXD = buffer[0]; for (int n = 1; n < 30; n++) { volatile uint32_t stat = 0; while (!stat) { stat = NRF_SPI0->EVENTS_READY; } NRF_SPI0->EVENTS_READY = 0x0UL; NRF_SPI0->TXD = buffer[n]; }
Получил засаду: один байт передаётся, и процесс зависает в цикле проверки флага. Если дебагом остановлю, потом снова запущу, передаётся ещё один байт. Смотрел в библиотеке NRF, там куча бесполезного кода, но принцип такой же. Пробовал добавить нопов в цикл - не помогло. Что не так?
Добавлено after 2 hours 59 minutes 30 seconds: Re: NRF51822 SPI Вручную запустил. Обязательно чтение RXD в цикле. Даже с прерываниями работает. Эх, ДМА запустить бы, цены бы не было...
Добавлено after 4 hours 39 minutes 41 second: Re: NRF51822 SPI Победил, но осадочек остался. Без включённого вывода CLK, SPI не запускается. Ну и порядок установки регистров некоторый должен быть.
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 38
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения