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

 
 
> 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
 
Start new topic
Ответов
R6L-025
сообщение Jul 2 2017, 20:38
Сообщение #2


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

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



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


Знающий
****

Группа: Участник
Сообщений: 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 Текстовая версия Сейчас: 21st July 2025 - 19:39
Рейтинг@Mail.ru


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