172 похожих чатов

Ля, товарищи, скажите мне такую вешь: (а то я курю

гугл и сей гайд, но вопросов больше чем ответов.)
Дано:
Дровина. В ней обработчик ioctl. В нём мы
1. читаем что прислал юзер через copy_from_user
2. В зависимости от cmd и присланных данных делаем что он просит. (в основоном это либо pci_read/write_config либо readl/writel
3. Пихаемся в него ответом через copy_to_user

Вопрос в том, что у меня в начала этих мероприятий стоит spin_lock, в конце spin_unlock, оно врооде как бы работает, но гугл говорит. что лочить спин на столь длинное время - идея, конечно, забавная, но может иметь неожиданные последствия в виде полного зависания компа при удачном стечении обстоятельств.

В качестве решения, как я понял, предлагается mutex_lock/unlock но я не могу вкурить что и как лочить, с учётом того, что так же в кернел-хакинге говорится, что Avoid holding spinlock for more than 5 lines of code and across any function call (except accessors like readb()). (то есть, как я понял, функции доступа аля readb нужно лочить спинлоком)

Собственно, непонятно, что из этого выбрать:
1. Заменить spin_lock на spin_lock_irqsave и так же лочить всю функцию.
2. Лочить мьютексы на copy_from/to_user, а доступ к регистрам или read/writeb лочить спинлоком (Или spin_lock_irqsave)
3. Лочить всю функцию мьютексом.
4. Иное?

6 ответов

12 просмотров

Лочить только куски, читающте/пишущие глобальный state. То есть хочешь измегить какую-нибудь скорость — лочишь структуру со скоростью в памяти, меняешь, меняешь регистр в девайсе, разлочиваешь.

Если реально девайс по миллисекунде реагирует — устраивай очереди или выкидывай лишних писателей.

S.E.- Автор вопроса
Ilya Anfimov
Если реально девайс по миллисекунде реагирует — ус...

Товарищи, а как правильно опакететь `.ko-`шку в дебиано-подобных дистрах? Просто идея "зашвырнуть .ko-шатину в /usr/lib/modules/$(uname -r)/ мне кажется мягко говоря, странной.

S.E.- Автор вопроса
Ilya Anfimov
dkms mkdeb / dkms mkbmdeb

и вот так просто при наличии только Makefile и .c-шных сорсов должен появиться пакет?

S.E.- Автор вопроса
Ilya Anfimov
dkms mkdeb / dkms mkbmdeb

Я вот что не понял - а если я нехороший человек и не хочу шарить сорсы - это тоже работает?

Похожие вопросы

Обсуждают сегодня

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
Помогите, пожалуйста, делаю программу для для подсчёта корней квадратного уравнения, знаю, что есть куча недочётов, недоработок, но основная проблема в том, что почему-то при ...
NYC
13
#include <stdio.h> int main(void) { int n; scanf("%d", &n); int digits1[n] = {0}; int digits2[n] = {0}; я не могу таким образом заранее массив нулями заполнить?
Linus
12
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
читать файл максимально быстро? странный вопрос))
zamtmn
53
я про форму записи. смысл указывать что 8 байтный регистр 8 байт?
Aiwan \ (•◡•) / _bot
10
Вроде бы вопрос уже заезжанный, но тем не менее У меня есть функция menu() которая выводит набор возможных действий, а затем спрашивает у пользователя что он хотел бы сделать....
David Golovatin
3
а как бы вылезти из ИО, что то типа IO -> Ether или в какую сторону смотреть ? что то туплю
Fedor
14
Карта сайта