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

 
 
 
Reply to this topicStart new topic
> linux spi chip_select, как заставить ядро не поднимать cs между транзакциями?
R6L-025
сообщение Jul 1 2017, 17:32
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 76
Регистрация: 8-04-11
Из: Ростов-на-Дону
Пользователь №: 64 227



Добрый день!
Столкнулся с проблемой: есть устройство на ArriaV SoC, есть ядро 3.10 поднятое на ней, есть spi. Нужно совершить несколько транзакций не поднимая ChipSelect между ними.
В экземпле из документации ядра (Documentation/spi/spidev_test.c) транзакции осуществляются через передачу структуры сообщения "spi_ioc_transfer". В ней есть поле "cs_change". Как я понял через это поле можно управлять CS, однако... не вышло smile3046.gif . Драйвер упорно поднимает CS между посылками при любых значениях поля. Еще есть подозрение что это еще можно сделать через вызов ioctl(fd, SPI_IOC_WR_MODE, &mode), где переменной mode передать флаг "SPI_READY". Вот только ядро начинает ругаться на некорректный аргумент "mode". Запускал экземпл spidev_test.c с разными флагами mode - та же история, ругается на любые флаги.
Кто нибудь знает как можно заставить ядро не поднимать CS?
Go to the top of the page
 
+Quote Post
Jury093
сообщение Jul 1 2017, 17:47
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 959
Регистрация: 11-01-06
Из: Санкт-Петербург
Пользователь №: 13 050



Цитата(R6L-025 @ Jul 1 2017, 20:32) *
Кто нибудь знает как можно заставить ядро не поднимать CS?

я с год назад боролся с подобным на Cyc V SOC, пришел к выводу, что это не побороть. в моем случае помогло откусить CS от SPI интерфейса (командой в юбуте) и вывести этот пин в режим GPIO, а т.к. канал был один, то просто вывел в 0, через value..
вам возможно поможет, если сможете включить CS-GPIO, когда драйвер дергает CS не через аппаратный ресурс, а в режиме GPIO и там подкрутить под требуемое поведение
а если система не требовательна к ресурсам, то можно просто перейти на SPI-GPIO, но это нагрузка на проц и не очень стабильные времянки
Go to the top of the page
 
+Quote Post
R6L-025
сообщение Jul 2 2017, 08:45
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 76
Регистрация: 8-04-11
Из: Ростов-на-Дону
Пользователь №: 64 227



Jury093, спасибо!
А вы не помните последовательность как отключать CS в uboot-е? sm.gif
Go to the top of the page
 
+Quote Post
Jury093
сообщение Jul 2 2017, 17:20
Сообщение #4


Знающий
****

Группа: Участник
Сообщений: 959
Регистрация: 11-01-06
Из: Санкт-Петербург
Пользователь №: 13 050



Цитата(R6L-025 @ Jul 2 2017, 11:45) *
А вы не помните последовательность как отключать CS в uboot-е? sm.gif

поищите в мануале на камень или хидерах исходников юбута - адрес регистра, который отвечает на режим для CS и соседних GPIO.
после qsys и запуска юбута, там будет значение для работы в составе SPI (если не вру, 3 бита для multifunction mode), вот в этом битовом поле надо поменять на gpio mode
в моем случае была последовательность из одной команды - записать в память значение, значение предварительно считано стандартной командой чтения памяти в юбут и откорректировано (кажись команды "md/mw" с аргументами)
Go to the top of the page
 
+Quote Post
R6L-025
сообщение Jul 2 2017, 17:56
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 76
Регистрация: 8-04-11
Из: Ростов-на-Дону
Пользователь №: 64 227



Спасибо, попробую. Еще пришла идея после старта ОС напрямую в контроллер SPI постучаться чтоб подергать CS, а передавать данные уже силами драйвера
Go to the top of the page
 
+Quote Post
Jury093
сообщение Jul 2 2017, 19:05
Сообщение #6


Знающий
****

Группа: Участник
Сообщений: 959
Регистрация: 11-01-06
Из: Санкт-Петербург
Пользователь №: 13 050



Цитата(R6L-025 @ Jul 2 2017, 20:56) *
Спасибо, попробую. Еще пришла идея после старта ОС напрямую в контроллер SPI постучаться чтоб подергать CS, а передавать данные уже силами драйвера

кстати, да, о ядре то я и забыл, конечно можно и из ядра - просто в моем случае всё было на уровне тестов и ядро лень было пересобирать sm.gif
Go to the top of the page
 
+Quote Post
R6L-025
сообщение Jul 2 2017, 19:19
Сообщение #7


Частый гость
**

Группа: Свой
Сообщений: 76
Регистрация: 8-04-11
Из: Ростов-на-Дону
Пользователь №: 64 227



Ну я в ядре не силен, хочу попробовать отобразить на виртуальную память адресное пространство контроллера, и насильно придавить CS. Подсмотрел в альтеровском hwlib для baremetall как они это далают, завтра буду пробовать sm.gif
Go to the top of the page
 
+Quote Post
Jury093
сообщение Jul 2 2017, 20:25
Сообщение #8


Знающий
****

Группа: Участник
Сообщений: 959
Регистрация: 11-01-06
Из: Санкт-Петербург
Пользователь №: 13 050



Цитата(R6L-025 @ Jul 2 2017, 22:19) *
Ну я в ядре не силен, хочу попробовать отобразить на виртуальную память адресное пространство контроллера, и насильно придавить CS. Подсмотрел в альтеровском hwlib для baremetall как они это далают, завтра буду пробовать sm.gif

если я в ядре поддержана и включена опция gpio, то можно посчитать номер и поэхать
Код
echo XXX > /sys/class/gpio/export

где ХХХ логический номер GPIO для физического пина
если команда пройдет успешно, то вы получили контроль над пином в режиме gpio - его можно перестроить на выход и прописать уровень
метод тормозной, но если все включено в ядре, то пересобирать не надо..
или прописать в исходниках этот пин, тогда он автоматом появится в том же /sys/class/gpio, если его не перехватит spi
Go to the top of the page
 
+Quote Post
R6L-025
сообщение Jul 2 2017, 20:38
Сообщение #9


Частый гость
**

Группа: Свой
Сообщений: 76
Регистрация: 8-04-11
Из: Ростов-на-Дону
Пользователь №: 64 227



Хм, но ведь пин настроен в qsys как принадлежащий spi, и мультиплексор периферии сконфигурирован соответствующе, или ядру всеравно?
Go to the top of the page
 
+Quote Post
Jury093
сообщение Jul 2 2017, 22:41
Сообщение #10


Знающий
****

Группа: Участник
Сообщений: 959
Регистрация: 11-01-06
Из: Санкт-Петербург
Пользователь №: 13 050



Цитата(R6L-025 @ Jul 2 2017, 23:38) *
Хм, но ведь пин настроен в qsys как принадлежащий spi, и мультиплексор периферии сконфигурирован соответствующе, или ядру всеравно?

дак а вопрос то в чём?
ядру на все наплевать, если его не будут грузить назойливые драйверы, драйвер может расстроиться и не загрузиться, если не будет нужных ресурсов..
в случае, который описываю я все условия соблюдены
в qsys разрешен аппаратный интерфейс SPI
в юбут у SPI отключается CS
да, забыл упомянуть (давно это было), в dts для ядра в секции spi прописано (для моего случая)
Код
&spi0 {
   status = "okay";
   num-cs = <1>;
/*   cs-gpios = <&portc 2 GPIO_ACTIVE_LOW>;*/

потом через echo я конфигурю пин CS вручную под себя (выход, 0)
и чип-слейв бодро работает..

в теории, можно перекрутить пин не из юбута, а прямо из линукса (через mmap), но "Ну я в ядре не силен", тут надо писать несложную программу и если вам хватил скилла, то возможно это ваш путь, а не через юбут..
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 6th July 2025 - 01:51
Рейтинг@Mail.ru


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