summaryrefslogtreecommitdiff
path: root/src/backend/port/beos/shm.c
blob: 1611d204f9210ed5016510cbf201bf81f1dc3597 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*-------------------------------------------------------------------------
 *
 * shm.c
 *	  BeOS System V Shared Memory Emulation
 *
 * Copyright (c) 1999-2000, Cyril VELTER
 * 
 *-------------------------------------------------------------------------
 */

#include "postgres.h"
#include <stdio.h>
#include <OS.h>

// Detachement d'une zone de mémoire partagée
// On detruit le clone de l'area dans notre adress-space
int shmdt(char* shmaddr)
{
	// Recherche de l'id de l'area présente à cette adresse
	area_id s;
	s=area_for(shmaddr);
//	printf("detach area %d\n",s);
	
	// Suppression de l'area
	return delete_area(s);
}

// Attachement à une zone de mémoire partagée
// L'area doit bien partie de notre adress-space et on retourne directement l'adress
int* shmat(int memId,int m1,int m2)
{
//	printf("shmat %d %d %d\n",memId,m1,m2);

	// Lecture de notre team_id
	thread_info thinfo;
	team_info teinfo;
	area_info ainfo; 
	
	get_thread_info(find_thread(NULL),&thinfo);
	get_team_info(thinfo.team,&teinfo);
	
	// Lecture du teamid de l'area
	if (get_area_info(memId,&ainfo)!=B_OK)
		printf("AREA %d Invalide\n",memId);
	
	if (ainfo.team==teinfo.team)
	{
		//retour de l'adresse
//		printf("attach area %d add %d\n",memId,ainfo.address);
		return (int*)ainfo.address;
	}	
	else
	{
		// Clone de l'area
		area_id narea;
		narea = clone_area(ainfo.name,&(ainfo.address),B_CLONE_ADDRESS,B_READ_AREA | B_WRITE_AREA,memId);	
		get_area_info(narea,&ainfo);	
//		printf("attach area %d in %d add %d\n",memId,narea,ainfo.address);
		return (int*)ainfo.address;
	}
}

// Utilisé uniquement pour supprimer une zone de mémoire partagée
// On fait la meme chose que le detach mais avec un id direct
int shmctl(int shmid,int flag, struct shmid_ds* dummy)
{
//	printf("shmctl %d %d \n",shmid,flag);
	delete_area(shmid);
	return 0;
}

// Recupération d'une area en fonction de sa référence
// L'area source est identifiée par son nom (convention à moi : SYSV_IPC_SHM : "memId)
int shmget(int memKey,int size,int flag)
{
	int32 n_size;
	char nom[50];
	area_id parea;
	void* Address;
	area_id a;
	
	n_size=((size/4096)+1)*4096;

//	printf("shmget %d %d %d %d\n",memKey,size,flag,nsize);

	// Determination du nom que doit avoir l'area
	sprintf(nom,"SYSV_IPC_SHM : %d",memKey);


	// Recherche de cette area
	parea=find_area(nom);
	
	// L'area existe
	if (parea!=B_NAME_NOT_FOUND)
	{
//		printf("area found\n");
		return parea;
	}	

	// L'area n'existe pas et on n'en demande pas la création : erreur
	if (flag==0)
	{
//		printf("area %s not found\n",nom);
		return -1;
	}
	
	// L'area n'existe pas mais on demande sa création
	a=create_area(nom,&Address,B_ANY_ADDRESS,n_size,B_NO_LOCK,B_READ_AREA | B_WRITE_AREA);		
//	printf("area %s : %d created addresse %d\n",nom,a,Address);
	return a;
}