Linux Man на русском

  User    Syst    Libr    Device    Files    Other    Admin  



   nptl - библиотека нитей POSIX

nptl(7) библиотека нитей POSIX


ОПИСАНИЕ

NPTL (Native POSIX Threads Library — библиотека нитей POSIX) это библиотека GNU C, в которой реализованы нити POSIX, используется в современных версиях Linux.

NPTL и сигналы

Внутри NPTL используются два первых сигнала реального времени (с номерами 32 и 33). Один из них служит для поддержки удаления (cancellation) нитей и таймеров POSIX (смотрите timer_create(2)); второй используется как часть механизма обеспечения всех нитей в одном процессе единым UID и GID, как того требует POSIX. Данные сигналы нельзя использовать в приложениях.

Чтобы не допустить случайного использования этих сигналов в приложениях, что может помешать работе реализации NPTL, в различных функциях библиотеки glibc и обёрточных функциях системных вызовов добавлено сокрытие этих сигналов от приложений:

  • Сигнал SIGRTMIN определён со значением 34 (а не 32).
  • Интерфейсы sigwaitinfo(2), sigtimedwait(2) и sigwait(3) игнорируют запросы на ожидание этих сигналов, если но указаны в аргументе набора сигналов.
  • Интерфейсы sigprocmask(2) и pthread_sigmask(3) игнорируют попытки блокировки этих сигналов.
  • Интерфейсы sigaction(2), pthread_kill(3) и pthread_sigqueue(3) завершаются с ошибкой EINVAL (указан некорректный номер сигнала), если заданы эти сигналы.
  • Функция sigfillset(3) не включает эти сигналы при создании полного набора сигналов.

    NPTL и изменение идентификаторов процесса

    На уровне ядра Linux идентификаторы (пользовательский и групповой ID) являются атрибутов нити. Однако в POSIX требуется, чтобы все нити POSIX одного процесса имели одинаковые идентификаторы. Для удовлетворения этого требования в реализации NPTL для всех системных вызовов, изменяющих идентификаторы процесса, созданы обёрточные функции, которые при обращении к нижележащим вызовам, также изменяют идентификаторы и всем остальным нитям процесса.

    В реализации каждого из этих системных вызовов используется сигнал реального времени, который посылается (с помощью tgkill(2)) всем остальным нитях, которым нужно изменить идентификаторы. Перед отправкой этих сигналов, нить, у которой изменяются идентификаторы, сохраняет новые идентификаторы и записывает использующийся системный вызов в глобальный буфер. Обработчик сигнала в принимающей нити извлекает эту информацию и использует тот же системный вызов для изменения своих идентификаторов.

    Обёрточные функции, использующие такую же технику: setgid(2), setuid(2), setegid(2), seteuid(2), setregid(2), setreuid(2), setresgid(2), setresuid(2) и setgroups(2).


    СООТВЕТСТВИЕ СТАНДАРТАМ

    Дополнительную информацию о соответствии NPTL стандарту POSIX находится в pthreads(7).


    ЗАМЕЧАНИЯ

    В POSIX сказано, что всем нитям процесса с доступом к памяти, содержащей общие для процесса (PTHREAD_PROCESS_SHARED) мьютексы, доступны эти мьютексы. Однако в 64-битных системах с архитектурой x86 определение мьютекса для x86-64 несовместимо с определением для i386, что означает, что исполняемые 32-битные и 64-битные файлы не могут иметь общих мьютексов в системах x86-64.