В модуле ядра Linux я определил несколько системных вызовов, которые вызываются из внешнего пользовательского кода. Пользовательский код вызывает (один из) системных вызовов, передавая ему первые два аргумента из командной строки, то есть argv[1] и argv[2].
Например, если я запускаю ./usercode first Second, я хочу, чтобы first и Second отправлялись в качестве аргументов системному вызову.
Я хочу проверить количество аргументов и их достоверность на стороне ядра (т.е., завершая системный вызов кодом ошибки, если аргументы на самом деле больше 2 или меньше 2,
-подобно, или если некоторые аргументы имеют значение NULL или несколько недействительны для моих целей), так как это более безопасно, но я думаю передать массив argv напрямую в системный вызов был бы... немного небезопасным. Как лучше всего передавать эти аргументы системному вызову? Я думал объединить их в строку (возможно, через \0), но это кажется излишним.
(Очевидно, что в режиме ядра copy_from_user() — это первое, что я делаю для проверки безопасности)
Подробнее здесь:
https://stackoverflow.com/questions/790 ... nel-module