nproc в /etc/security/limits.conf может ограничивать количество процессов на пользователя.
Вы можете проверить наличие ошибок, проверив возврат с форка. 0 означает, что вы являетесь дочерним элементом, положительное число - это pid дочернего элемента и означает, что вы являетесь родителем, а отрицательное число означает, что ответвление не выполнено. Когда fork терпит неудачу, он устанавливает внешнюю переменную errno. Вы можете использовать функции в errno.h для его проверки. Обычно я просто использую perror, чтобы напечатать ошибку (с добавленным к ней текстом) в stderr.
#include <stdio.h>
#include <errno.h>
#include <unistd.h>
int main(int argc, char** argv) {
pid_t pid;
pid = fork();
if (pid == -1) {
perror("Could not fork: ");
return 1;
} else if (pid == 0) {
printf("in child\n");
return 0;
};
printf("in parent, child is %d\n", pid);
return 0;
}