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

 
 
 
Reply to this topicStart new topic
> Планировщик задач в модулях ядра
leonopulos
сообщение Mar 16 2010, 11:37
Сообщение #1





Группа: Участник
Сообщений: 11
Регистрация: 25-11-08
Пользователь №: 41 958



Проблема в том, что мой драйвер общается с прогой через файл устройства. это очень замечательно. очень удобно. я в модуле ядра, соответственно, описал процедуры read и write. всё как обычно. но получается так, на данный момент, что из пользовательской программы через select() идут постоянные обращения чтения из устройства с нулевым результатом, которые подгружают сильно проц.
что-бы этого не происходило - необходимо в модуле задействовать ядерный планировщик задач и модуль сделать фактически блокируемым. но по всем книжкам у меня получается пока так, что мне придётся в этом случае отказаться от файлового устройства и взаимодействовать с модулем через файловую структуру /proc. то есть полностью поменять интерфейс работы с модулем. вот не могу понять - так ли это на самом деле?

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

ядро - Linux 2.6.23
проц - ARM9 sam9260
Go to the top of the page
 
+Quote Post
Dima_G
сообщение Mar 16 2010, 11:48
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 279
Регистрация: 2-07-08
Из: Новосибирск
Пользователь №: 38 699



Если я правильно понял проблему - у Вас идут бесконечные срабатывания функции select(), которые и подгружают систему.

А вы описали функцию драйвера poll?

static unsigned int device_poll (struct file *filp, poll_table *wait) ?
Go to the top of the page
 
+Quote Post
leonopulos
сообщение Mar 16 2010, 12:03
Сообщение #3





Группа: Участник
Сообщений: 11
Регистрация: 25-11-08
Пользователь №: 41 958



Цитата(Dima_G @ Mar 16 2010, 14:48) *
Если я правильно понял проблему - у Вас идут бесконечные срабатывания функции select(), которые и подгружают систему.

А вы описали функцию драйвера poll?

static unsigned int device_poll (struct file *filp, poll_table *wait) ?


да. select() постоянно обращается к драйверу и возвращается с нулевым результатом.
насчёт device_poll щас буду копать, спасибо.
Go to the top of the page
 
+Quote Post
dch
сообщение Mar 16 2010, 12:59
Сообщение #4


Профессионал
*****

Группа: Участник
Сообщений: 1 179
Регистрация: 15-09-04
Из: 141070 г. Королев МО, улица Горького 39-121
Пользователь №: 661



Цитата(leonopulos @ Mar 16 2010, 15:03) *
да. select() постоянно обращается к драйверу и возвращается с нулевым результатом.

там же в селекте есть последний параметр указатель на структурку с задержкой, те если нет данных на приеме и задана только одна маска на чтение, то вернетесь как данные появятся.
Go to the top of the page
 
+Quote Post
leonopulos
сообщение Mar 17 2010, 10:14
Сообщение #5





Группа: Участник
Сообщений: 11
Регистрация: 25-11-08
Пользователь №: 41 958



Спасибо, разобрался.
В общем-то, ларчик открывался просто.
Действительно, надо описывать метод poll в драйвере, но перед этим надо создать очереди ожидания и в read вставить вызов interruptible_sleep_on (или аналогичный).
Go to the top of the page
 
+Quote Post

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

 


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


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