NicMicola

Вопрос по аппаратному SPI в PIC

32 сообщения в этой теме

NicMicola    0

Подключаемое изделие к микроконтроллеру, может поддерживать SPI только ведомым.

Вопрос как настроить регистры интерфейса  SPI  в микроконтроллере. Что бы импульсы синхронизации выдавал микроконтроллер и одновременно принимал данные.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Vascom    647

В даташите разве этого нет?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Неужели вы думаете что я не читал перед тем как задавать вопрос.

Естественно читал но не понял.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551
1 час назад, NicMicola сказал:

Что бы импульсы синхронизации выдавал микроконтроллер и одновременно принимал данные

Так и есть у ведущего. Он сам синхронизирует ведомых и принимает (ну или передаёт) данные. Иначе быть не может.

Проблема не понятна.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
UTSource

Найдите миллионы труднодоступных

электронных компонентов

ARV    472
18 минут назад, NicMicola сказал:

как настроить регистры интерфейса  SPI  в микроконтроллере. Что бы импульсы синхронизации выдавал микроконтроллер и одновременно принимал данные.

Надо сконфигурировать в Master-mode

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Подключаемое устройство не может работать ведущим.

Значит микроконтроллер должен синхронизировать и принимать

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551

@NicMicola , микроконтроллер и будет ведущим. А значит только он будет синхронизировать передачу !

Настраивайте его мастером и всё.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Подключаемое изделие к микроконтроллеру, может поддерживать SPI только ведомым.

Мне же нужно прочитать его.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551

@NicMicola , ведущий ТОЖЕ МОЖЕТ ЧИТАТЬ ВЕДОМОГО !

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Микроконтроллер начинает выдавать синхронизацию (SCK), после загрузки байта в SSP1BUF.

Мне нужно загрузить SSP1BUF  во время синхронизации. Подключенное изделие не может выдавать синхроимпульсы.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551

Такое ощущение, что Вы сами не понимаете что пишете.

Почитайте раздел даташита по SPI. И покурите там диаграммки. Всё станет ясно, как белый день. У Микрочипа отличнейшая документация. Не понимать её просто нереально.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Микроконтроллер должен выдать SCK, и в это же время прочитать SSP1BUF.

Обычно ведущий генерирует SCK и загружает SSP1BUF (передает).

Обычно ведомый принимает (читает SSP1BUF) и считывает SCK импульсы (SCK это и есть синхронизация). Я же писал подключаемое изделие может работать только ведомым.

Значит не может генерировать SCK (синхронизировать импульсы )

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551
2 минуты назад, NicMicola сказал:

Я же писал подключаемое изделие может работать только ведомым.

Значит не может генерировать SCK (синхронизировать импульсы )

А вам писали, что генерирует синхроимпульсы ведущий и при этом он читает данные ! Просто настройте его мастером !

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551

Экстрасенсы все на тНт уехали :)

PS: Информацию из Вас никто не будет вытягивать. Пишите больше инфы, быстрее получите ответ. А на вопрос "как ?" обычно отвечают "Так.".

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Yurkin2015    313
18 минут назад, NicMicola сказал:

ведущий генерирует SCK и загружает SSP1BUF (передает)

Всё происходит одновременно.

С каждым SCK импульсом ведущий выдаёт SSP1BUF  буфер наружу по-битно и одновременно задвигает внутрь SSP1BUF биты от ведомого.

Поэтому в момент окончания передачи собственного байта в буфере ведущего уже будет байт от ведомого, который задвинулся в процессе передачи.

  • Лайк 1

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
Alex    551

Даже не знаю, что может быть непонятного в подобных картинках :

2018-02-14_22-34-27.png.ae2b6eb4d85a346456fc703f4e719ed3.png

2018-02-14_22-37-36.thumb.png.a688828f3b7dc5edc54daffe8ef6999d.png

:unknw:
Тут никакого Англицкого не нужно знать, всё разрисовано и разжёвано.

PS: Нас, походу, троллят...

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Активный Alex .

Я не хочу вас обидеть, но поправлю вас  сдвиговый регистр не может одновременно принимать и выдавать данные. Если у вас закрались сомнения, то включите осциллограф и на практике попробуйте.

Вообще то я задавал вопрос для людей сталкивающимся с этой проблемой.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
ARV    472
Только что, NicMicola сказал:

сдвиговый регистр не может одновременно принимать и выдавать данные

Не только может, но и делает это - это его основной режим работы! Даже у дискретных сдвиговых регистров, например, популярного 74HC595 есть ВХОД и ВЫХОД последовательных данных, работающих ОДНОВРЕМЕННО.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
ruhi    34
1 час назад, NicMicola сказал:

сдвиговый регистр не может одновременно принимать и выдавать данные.

Вот посмотрите на картинке у Алекса красным обведено:

SDIx - это вход сдвигового регистра

SDOx - это вЫход сдвигового регистра

И, соответственно, между ними SSPxSR что (SR - shift register) и обозначает/переводится "сдвиговый регистр"!

Так вам надо претензии Микрочипу предъявлять, а не Алексу! : Что они(Микрочип, Атмел, Тексас, ...) десятки лет эти сдвиговые регистры делают и до сих пор не знают как он работает!!!

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
NicMicola    0

Я не кому претензии не предъявляю.  

Микроконтроллер начинает выдавать тактовые импульсы, после загрузки в SSPxBUF байт сразу сдвигается в  SSPxSR и начинает сдвигаться в  CDO синхронно выдаваемым тактовым импульсам.

Мне же в этот момент нужно принять из SDI .В кластическом виде тот кто передает тот и генерирует тактовые импульсы. То есть  ведомый генерирует.

Сдвиговый регистр в каждый тактовый импульс может или принимать или выдавать 1 импульс.

Вся загвоздка в том что выход тактовых импульсов начитается только после загрузки в SSPxBUF.

Другим способом запустить выход тактовых импульсов я не знаю как.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
StationX    3

Отсылайте нули,получится что не передавая полезных данных Вы принимаете полезные данные от ведомого устройства.

  • Одобряю 2

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
ARV    472

Блин, ну ведь просто все, как репа: загрузили в SSPxBUF ведущего данные, он начал выдавать тактовые импульсы и синхронно с этими импульсами выдвигать биты данных, одновременно задвигая приходящие от ведомого биты. Ведомый получает тактовые от мастера и выталкивает свои данные, принимая от ведущего новые. КОЛЬЦО. Что не понятно? 

Чтобы ПРИНЯТЬ от ВЕДОМОГО данные, ВЕДУЩИЙ должен ПОСЛАТЬ ВЕДОМОМУ ЛЮБОЙ БАЙТ. После того, как передача завершится, в SSPxBUF ведущего будут принятые от ведомого данные.

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
ruhi    34
5 минут назад, NicMicola сказал:

после загрузки в SSPxBUF байт сразу сдвигается в  SSPxSR и начинает сдвигаться в  CDO синхронно выдаваемым тактовым импульсам.

а на освободившееся место в этом байте начинает ВВВВдвигаться из  CDI также синхронно выдаваемым тактовым импульсам!!!

В конце концов на линию SDO выдается сигнал соответствующий байту ИЗ регистра,

А в регистре оказывается байт соответствующий сигналу на линии SDI. Если например закоротить линию SDI на землю, там окажется значение 0x00, если на питание то 0xFF!!!

Действительно, чтобы принять байт надо запустить передачу! (Видимо это и не укладывается у вас в голове, но старайтесь, реальность не всегда такова какой ее хочется видеть! :)

Но линию SDO подключать не обязательно, и передавать можно какой то произвольный байт, только чтобы принимать нужный байт, и формировать сигнал тактирования (он, действительно, формируется автоматически при запуске передачи мастером).

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах
StationX    3

То есть данные которые Вы помещаете в буфер,заменятся на данные от ведомого устройства)

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

Для примера можно взять внешнюю флеш подключенную по спи.Мы отсылаем ей команду (байт) и после этого память должна нам передать определённые данные.Но передать она не может,так как тактовые импульсы прекратились и она их сама генерировать не может,так как она ведомая.Значит нужно дать понять микроконтроллеру что от него ждут тактовые импульсы,а они появляются только при передаче.Значит нужно передавать что угодно,к примеру нули,флешь же эти нули не будет воспринимать как полезную информацию и будет спокойно передавать свои полезные данные ведомому устройству.

  • Одобряю 1

Поделиться сообщением


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

Создайте аккаунт или войдите в него для комментирования

Вы должны быть пользователем, чтобы оставить комментарий

Создать аккаунт

Зарегистрируйтесь для получения аккаунта. Это просто!

Зарегистрировать аккаунт

Войти

Уже зарегистрированы? Войдите здесь.

Войти сейчас