Scroll to navigation

IPC(5) Manual do Programador Linux IPC(5)

NOME

ipc - Mecanismo de inter-comunicação do System V

SINOPSE


# include <sys/types.h>

# include <sys/ipc.h>

# include <sys/msg.h>

# include <sys/sem.h>

# include <sys/shm.h>

DESCRIÇÃO

Esta página do manual referese a implementação para o Linux do mecanismo de inter-comunicação usado no System V: fila de mensagens, sinalização por semáfaros e segmentos compartilhados de memória. Na seqüencia, a palavra resource significa uma instância de um entre muitos mecanismos.

Permissão de Acessos aos Recursos

Para cada recurso o sistema usa uma estrutura comum do tipo struct ipc_perm para armazernar informações necessárias na determincação das permissões para executar uma operação ipc. A estrutura ipc_perm , definida pelo arquivo de cabeçalho do sistema <sys/ipc.h> , incluí os seguintes membros:

ushort cuid; /* identificação numérica do usuário criador*/
ushort cgid; /* identificação numérica do grupo criador*/
ushort uid; /* identificação numérica do usuário proprietário*/
ushort gid; /* identificação numérica do grupo proprietário*/
ushort mode; /* r/w permissões */

O modo membro da estrutura ipc_perm determina, com ele abaixo de 9 bits, a permissão de acesso para o recurso para um processo executando uma chamada de sistema ipc. As permissões são interpretadas como segue:

	0400	Leitura pelo usuário.
	0200	Escrita pelo usuário.

	0040	Leitura pelo grupo.
	0020	Escrita pelo grupo.

	0004	Leitura pelos demais.
	0002	Escrita pelos demais.

Os bits 0100, 0010 e 0001 (os bits para execução) não são usados pelo sistema. Furthermore "escrita" significa efetivamente "modificar" para um conjunto de sinalizações.

O arquivo cabeçalho de sistema define as seguintes constantes simbólicas:

Criar a entrada se a chave não existe.
Falhar se a chave existe.
Errar se a requesição esperar muito.
Chave privada.
Remover recurso.
Fixar opção do recurso.
Pegar opção do recurso.

Note que IPC_PRIVATE é um tipo key_t , enquanto todos as outras constantes simbólicas são campos flag ou-hábil dentro de uma variável tipo int

Fila de mensagens

Uma fila de mensagens é unicamente identificada por un inteiro positivo (its msqid) e possui uma estrutura de dados associada do tipo struct msquid_ds, definida em <sys/msg.h>, contendo os seguintes membros:

struct ipc_perm msg_perm;
ushort msg_qnum; /* nada de mensagens na fila */
ushort msg_qbytes; /* máximo de bytes na fila */
ushort msg_lspid; /* pid da última chamada msgsnd */
ushort msg_lrpid; /* pid da última chamada msgrcv */
time_t msg_stime; /* última hora de msgsnd */
time_t msg_rtime; /* última hora de msgrcv */
time_t msg_ctime; /* úlitma hora de alteração */

ipc_perm estruturas que especificam a permissão de acesso na fila de mensagem.
Número de mensagems atualmente na fila de mensagens.
Número máximo de bytes de texto de mensagem texto permetida na fila de mensagens.
ID do processo que executou a última chamada de sistema msgsnd
ID do processo que executou a última chamada de sistema msgrcv
A hora da última chamada de sistema msgsnd
A hora da última chamada de sistema msgcv
A hora da última chamada de sistema que alterou um membro da estrutura msqid_ds

Conjunto sinalizador

Um conjunto sinalizador é unicamente identificado por um inteiro positivo (its semid) e possui uma estrutura de dados associada do tipo struct semid_ds, definida em <sys/sem.h>, contendo os seguintes membros:

struct ipc_perm sem_perm;
time_t sem_otime; /* tempo da última operação */
time_t sem_ctime; /* tempo da última alteração */
ushort sem_nsems; /* contagem de sems no conjunto */

ipc_perm estruturas que especificam a permissão de acesso no conjunto sinalizador.
Hora da última chamada de sistema semop
Hora da última chamada de sistema semctl que alterou um membro de uma estrutura citada acima ou um dos sinais pertencentes ao conjunto.
Número de sinais no conjunto. Cada sinal de um conjunto é referenciado por um inteiro não negativo desde 0 até sem_nsems-1.

Um sianl é uma estrutura de dados do tipo struct sem contendo os seguintes membros:

ushort semval; /* valor do sinal */
short sempid; /* pid para a última operação */
ushort semncnt; /* número de espera semval para adicionar */
ushort semzcnt; /* número de espera semval = 0 */

Valor do sinal: um interio não negativo.
ID do último processo que executou uma operação sinalizada neste sinal.
Número de processos supendidos aguardando por semval para adicionar.
Número de processos supendidos aguardando por semval para se transformar em zero.

Segmentos Compartilhados de Memória

Um segmento compartilhado de memória é unicamente identificado por um inteiro positivo (its shmid) e possui uma estrutura de dados associada do tipo struct shmid_ds, definida em <sys/shm.h>, contendo os seguintes membros:

struct ipc_perm shm_perm;
int shm_segsz; /* tamanho do segmento */
ushort shm_cpid; /* pid do criador */
ushort shm_lpid; /* pid, da última operação */
short shm_nattch; /* número atual de uniões */
time_t shm_atime; /* hora da última união */
time_t shm_dtime; /* hora da úlitma desunião */
time_t shm_ctime; /* hora da úlitma alteração */

ipc_perm estrutura que especifica as permissões de acesso no segmento compartilhado de memória.
Tamanho em bytes do segmento compartilhado de memória.
ID do processo que criou o segmento compartilhado de memória
ID do úlitmo processo que executou uma chamada de sistema shmat ou shmdt
Número de uniões atuais ativas para este segmento compartilhado de memória.
Hora da úlitma chamada de sistema shmat
Hora da úlitma chamada de sistema shmdt
Hora da última chamada de sistema shmctl que alterou shmid_ds.

VEJA TAMBÉM

ftok(3), msgctl(2), msgget(2), msgrcv(2), msgsnd(2), semctl(2), semget(2), semop(2), shmat(2), shmctl(2), shmget(2), shmdt(2).

TRADUZIDO POR LDP-BR em 21/08/2000.

André L. Fassone Canova <lonelywolf@blv.com.br> (tradução) Carlos Augusto Horylka <horylka@conectiva.com.br> (revisão)

1/11/1993 Linux 0.99.13