[d-kernel] shmctl: Invalid argument

Dmitry V. Levin ldv at altlinux.org
Tue Dec 9 17:50:52 MSK 2003


Hi,

On Tue, Dec 09, 2003 at 05:29:32PM +0300, Grigory Batalov wrote:
> Здравствуйте!
> 
> После переезда с ядра 2.4.20-alt10-smp на 2.4.22-std-smp-alt12
> от программы amdump (пакет amanda) наблюдаются сообщения:
> 
> taper: FATAL shmctl: Invalid argument
> 
> Я просмотрел исходники taper, его манипуляции с памятью
> можно упростить до прилагаемого файла.
> Указанное сообщение соответствует коду в taper.c:
> 
>     if(shmid == -1) return;     /* nothing to destroy */
>     if(shmctl(shmid, IPC_RMID, NULL) == -1) {
>         error("shmctl: %s", strerror(errno));
>     }
> 
> При запуске shmtest обычным пользователем видно, что память
> выделяется и затем (через заданные 5 сек.) освобождается:
> 
> $ ipcs
> ------ Shared Memory Segments --------
> key        shmid      owner      perms      bytes      nattch     status      
> 0x00000000 262150     bga       700        1048576    1
> <skip>
> 
> Однако, на ядре 2.4.20-alt10-smp программа завершается
> молча, а на 2.4.22-std-smp-alt12 выходит сообщение:
> 
> ./shmtest: : Unknown error 2339276
> 
> С чем это может быть связано?

Это, скорее всего, связано с CONFIG_HARDEN_SHM=y в конфигурации ядра:
разделяемая память освобождается, если она не используется ни одним
процессом.


-- 
ldv
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 189 bytes
Desc: not available
Url : /pipermail/devel-kernel/attachments/20031209/94c9bf02/attachment.bin


More information about the devel-kernel mailing list