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 ответов

34 просмотра

Лочить только куски, читающте/пишущие глобальный 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

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

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

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

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
1
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Карта сайта