Кто любит 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-блоку точно так же пофиг. Он получил информацию о том, что поступил новый байт, схватил его и поволок выталкивать в линию. Что это за байт, какая у него судьба, что в нем и т.п. абсолютно никого внутри МК не интересует.

Re: NRF51822 SPI

Ср июн 29, 2022 20:38:42

Добрый день. Подниму тему. Чип NRF52833, поднимаю SPI Master.
Прописываю настройки и адреса буферов чтения и записи, количество посылок. Но после записи START task ничего не происходит. В регистрах состояния видно, что SPI пытается стартовать, но ему что-то мешает. Никак не пойму, что.
Код настройки SPI (используется только одна ножка MOSI):

Код запуска проще некуда:

Re: NRF51833 SPI

Чт июн 30, 2022 18:00:04

Я попроовал запустить просто SPI, без дма.
Настроил по простому:
Код:
    // Setup SPI0             
    NRF_SPI0->PSEL.SCK = 13 << SPI_PSEL_MOSI_PIN_Pos
                        | 0 << SPI_PSEL_MOSI_PORT_Pos
                        | SPI_PSEL_MOSI_CONNECT_Connected;      // Yes MOSI   
    NRF_SPI0->PSEL.MISO = SPI_PSEL_MISO_CONNECT_Disconnected;   // No MISO
    NRF_SPI0->PSEL.MOSI = 0 << SPI_PSEL_MOSI_PIN_Pos
                        | 1 << SPI_PSEL_MOSI_PORT_Pos
                        | SPI_PSEL_MOSI_CONNECT_Connected;      // Yes MOSI                       
    NRF_SPI0->FREQUENCY = SPI_FREQUENCY_FREQUENCY_M8;           // 8 Mbps                                                               /

    NRF_SPI0->CONFIG = SPI_CONFIG_ORDER_MsbFirst << SPI_CONFIG_ORDER_Pos
                        | SPI_CONFIG_CPOL_ActiveHigh << SPI_CONFIG_CPOL_Pos
                        | SPI_CONFIG_CPHA_Leading << SPI_CONFIG_CPHA_Pos;       // MSB first                                                           
    NRF_SPI0->INTENSET = SPI_INTENSET_READY_Disabled << SPI_INTENSET_READY_Pos;      // disable IRQ                                           
    NRF_SPI0->ENABLE = SPI_ENABLE_ENABLE_Enabled;                               // enable SPI

Теперь, чтобы запустить 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 не запускается. Ну и порядок установки регистров некоторый должен быть.
Ответить