реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> модуль ядра, работа по SPI
TigerSHARC
сообщение Jul 29 2012, 16:16
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 688
Регистрация: 4-09-09
Пользователь №: 52 195



В учебных целях хочу написать драйвер(модуль ядра), который работал бы слейвом в режиме SPI и записывал данные с мастера в буфер. Прочитал тольковую статью http://dmilvdv.narod.ru/Translate/WDDL/index.html но как применительно к моему процессору (SAM9G45) написать модуль SPI-slave не знаю.
Драйверы для Linux до этого момента не писал.
У меня есть standalone-приложение, реализующее требуемые функции.
Если просто перенести соотвествующие процессору *.h файлы, описывающие перифирийные регистры, и, написать функции опроса и записи в эти регистры (как в standalone-приложении) в код модуля ядра? такое будет работать?
где можно примеры посмотреть?
Go to the top of the page
 
+Quote Post
Idle
сообщение Jul 30 2012, 03:18
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



подсистема spi не поддерживает slave http://lxr.linux.no/linux+v3.5/Documentati...pi-summary#L158, драйвер будет полностью свой

Сообщение отредактировал Idle - Jul 30 2012, 03:20
Go to the top of the page
 
+Quote Post
xor.kruger
сообщение Jul 30 2012, 07:46
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 290
Регистрация: 17-08-08
Из: Чернигов
Пользователь №: 39 647



В свое время разобрался с SPI в GNU/Linux с помощью драйвера от пользователя sasamy для дисплея ls020.
Принцип очень простой. Есть структура spi_device описывающая сам SPI и его режим работы. Сами функции для работы с SPI описаны в linux/spi/spi.h
Естественно, перед тем как юзать SPI его нужно описать в файле platform.
Думаю sasamy будет не против если я выложу здесь его исходник sm.gif Посмотрите и вы сразу все поймете sm.gif

Прикрепленные файлы
Прикрепленный файл  ls020.zip ( 3.39 килобайт ) Кол-во скачиваний: 31
 
Go to the top of the page
 
+Quote Post
TigerSHARC
сообщение Jul 30 2012, 09:01
Сообщение #4


Знающий
****

Группа: Свой
Сообщений: 688
Регистрация: 4-09-09
Пользователь №: 52 195



Цитата(xor.kruger @ Jul 30 2012, 11:46) *
В свое время разобрался с SPI в GNU/Linux с помощью драйвера от пользователя sasamy для дисплея ls020.
Принцип очень простой. Есть структура spi_device описывающая сам SPI и его режим работы. Сами функции для работы с SPI описаны в linux/spi/spi.h
Естественно, перед тем как юзать SPI его нужно описать в файле platform.
Думаю sasamy будет не против если я выложу здесь его исходник sm.gif Посмотрите и вы сразу все поймете sm.gif

Интересно, а позволяет ли подсистема Linux для работы с SPI работать в режиме slave? и можно увидеть примеры работы с драйвером который вы привели в пример.
Мне нужно от мастера принимать данные, складывать в кольцевой буфер и по запросу пользователя отдавать данные "наверх"

Сообщение отредактировал TigerSHARC - Jul 30 2012, 09:08
Go to the top of the page
 
+Quote Post
Idle
сообщение Jul 31 2012, 07:06
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



Цитата(TigerSHARC @ Jul 30 2012, 13:01) *

http://electronix.ru/forum/index.php?showt...t&p=1080226
а как сформулировал учебную цель? может прицепить что-нибудь простое на spi слейвом?
Go to the top of the page
 
+Quote Post
TigerSHARC
сообщение Jul 31 2012, 08:41
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 688
Регистрация: 4-09-09
Пользователь №: 52 195



Цитата(Idle @ Jul 31 2012, 11:06) *
http://electronix.ru/forum/index.php?showt...t&p=1080226
а как сформулировал учебную цель? может прицепить что-нибудь простое на spi слейвом?

а если замахнуться и написать свой slave драйвер? с чего начать? если без ОС понятно как инициализировать периферию соответствующим образом, то для Linux непонятно как осуществить приём от мастера.
Go to the top of the page
 
+Quote Post
Idle
сообщение Jul 31 2012, 10:11
Сообщение #7


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



с драйвером слейва проблема в том, что надо успеть ответить на запрос
Цитата
There's an issue
of response time ... since SPI has no flow control, typical types of
request/response protocol have hard response time limits. So the RT
stack may be implicitly required, except for very slow slave.

вот здесь, например, обсуждение
http://www.mail-archive.com/spi-devel-gene...t/msg00368.html

а если по-простому, то выключите spi в линуксе совсем, чтобы ОС не знала ничего о нём и оформите исходники, которые работают с регистрами SPI-контроллера в виде модуля ядра
просто в этом случае линуксовый фреймворк spi не будет использоваться, тогда не понятно в чём учебная цель
Go to the top of the page
 
+Quote Post
TigerSHARC
сообщение Jul 31 2012, 17:33
Сообщение #8


Знающий
****

Группа: Свой
Сообщений: 688
Регистрация: 4-09-09
Пользователь №: 52 195



Цитата(Idle @ Jul 31 2012, 14:11) *
а если по-простому, то выключите spi в линуксе совсем, чтобы ОС не знала ничего о нём и оформите исходники, которые работают с регистрами SPI-контроллера в виде модуля ядра
просто в этом случае линуксовый фреймворк spi не будет использоваться, тогда не понятно в чём учебная цель

Вот это наверное то что надо!
Но насколько я понял из вашей ссылки то проблема в латентности Linux. Если писать с нуля без фреймворка ОСи то эта проблема будет решена?
Но как такое сделать нигде не видел. Так же как и в standalone приложении? просто добавить файл *.h где определены регистры и работать с ними?
нужно принимать данные на уровне ядра от SPI мастера и писать в кольцевой буфер и по запросу выдавать.

Сообщение отредактировал TigerSHARC - Jul 31 2012, 17:55
Go to the top of the page
 
+Quote Post
Idle
сообщение Jul 31 2012, 17:54
Сообщение #9


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



Цитата(TigerSHARC @ Jul 31 2012, 21:33) *
просто добавить файл *.h где определены регистры и работать с ними?

да, работать с регистрами, они же промаплены в память; здесь лучше уточнить у работавших непосредственно с arm, возможно там есть какие-то тонкости, как достучаться до этих регистров

Go to the top of the page
 
+Quote Post
Zelepuk
сообщение Aug 2 2012, 17:15
Сообщение #10


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Цитата(Idle @ Jul 31 2012, 21:54) *
да, работать с регистрами, они же промаплены в память; здесь лучше уточнить у работавших непосредственно с arm, возможно там есть какие-то тонкости, как достучаться до этих регистров

Насколько я знаю работать напрямую с регистрами можно только из пространства пользователя, предварительно вручную промапив регистры в память. Думаю на уровне ядра такое не получится.
Go to the top of the page
 
+Quote Post
Idle
сообщение Aug 2 2012, 17:29
Сообщение #11


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



Цитата(Zelepuk @ Aug 2 2012, 21:15) *
Насколько я знаю работать напрямую с регистрами можно только из пространства пользователя, предварительно вручную промапив регистры в память. Думаю на уровне ядра такое не получится.

это не так, как дрова-то писать тогда heh sm.gif sm.gif

тебя, наверное, спутали примеры под арм где народ дёргает gpio промапив регистры на память в юзерспейсе, друг-другу скидывают на это ссылки и делают по аналогии sm.gif я пять лет назад, когда только начинал, пытался что-то промапить под mips, ничего не вышло sm.gif

в mips и blackfin это делается напрямую, с arm не работал, поэтому лучше уточнить у армоводов

Сообщение отредактировал Idle - Aug 2 2012, 17:30
Go to the top of the page
 
+Quote Post
Zelepuk
сообщение Aug 2 2012, 18:27
Сообщение #12


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Цитата(Idle @ Aug 2 2012, 21:29) *
это не так, как дрова-то писать тогда heh sm.gif sm.gif

тебя, наверное, спутали примеры под арм где народ дёргает gpio промапив регистры на память в юзерспейсе, друг-другу скидывают на это ссылки и делают по аналогии sm.gif я пять лет назад, когда только начинал, пытался что-то промапить под mips, ничего не вышло sm.gif

в mips и blackfin это делается напрямую, с arm не работал, поэтому лучше уточнить у армоводов

Как пишутся драйвера пока не до конца понимаю, так как в книгах все равно дается подход высокого уровня. Ниразу еще не видел, чтобы кто-то писал в регистры напрямую, а хочется разобраться досконально что происходит в драйверах, да и привычнее мне писать в регистры напрямую.
Да, все именно та как вы пишите. Мне дали ссылку на пример ногодрынга из пользовательской программы. Получается для blackfin даже вручную мапить ничего не надо?
Про арм спросить не у кого... Ау! Армоводы!
Go to the top of the page
 
+Quote Post
Idle
сообщение Aug 2 2012, 19:02
Сообщение #13


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



тут история такая что, регистры soc ведь находятся в памяти по определённым адресам в любом случае

из юзеспейса получить доступ к ним напрямую нельзя(тут спецы по блекфину меня поправят, возможно, т.к. там линукс без мму), поскольку пользовательские приложения выполняются в своём отдельном для каждого процесса адресном пространстве
однако (не уверен что на всех архитектурах), можно при помощи системного вызова mmap запросить отображение региона памяти с регистрами soc на регион памяти пользовательского процесса

в ядре же этот регион доступен напрямую (опять же лучше уточнять), и драйверы пишут и читают сразу по этим адресам
Go to the top of the page
 
+Quote Post
ubobrov
сообщение Nov 23 2012, 13:04
Сообщение #14


Участник
*

Группа: Свой
Сообщений: 64
Регистрация: 15-08-05
Пользователь №: 7 636



Вот, я переделывал драйвер SPI от атмела чтоб он работал как слейв. Все то же самое, что и мастер, тока ждет CS. Все работает.

Прикрепленные файлы
Прикрепленный файл  atmel_mpi.c.zip ( 8.88 килобайт ) Кол-во скачиваний: 24
 
Go to the top of the page
 
+Quote Post
alx2
сообщение Dec 9 2012, 12:30
Сообщение #15


Местный
***

Группа: Участник
Сообщений: 340
Регистрация: 25-10-05
Из: Пермь, Россия
Пользователь №: 10 091



Цитата(ubobrov @ Nov 23 2012, 18:04) *
Вот, я переделывал драйвер SPI от атмела чтоб он работал как слейв. Все то же самое, что и мастер, тока ждет CS. Все работает.

Не могли бы Вы пояснить работу вашего драйвера с таймерами?
А именно, что происходит при возникновении таймаута?

И еще один момент мне непонятен. В обработчике прерываний RXBUFF/ENDRX/NSSR Вы запрещаете только фактически возникшие прерывания (spi_writel(as, IDR, pending)wink.gif. Допустим, принят/передан последний байт последней транзакции, и возникло прерывание по RXBUFF/ENDRX, но сигнал CS еще активен. В результате RXBUFF/ENDRX будут запрещены обработчиком, но NSSR останется разрешенным. as->current_transfer становится равным NULL. Далее мастер снимает сигнал CS, в результате возникает прерывание NSSR, и мы снова попадаем в ту же ветку обработчика, в которой падаем, так как xfer равен NULL! Я что-то где-то не учел или неправильно понял?


--------------------
Всего наилучшего,
Alex Mogilnikov
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 22:21
Рейтинг@Mail.ru


Страница сгенерированна за 0.01488 секунд с 7
ELECTRONIX ©2004-2016