l3.libnazgul/src/nzg_spaces.c

197 lines
4.7 KiB
C
Raw Normal View History

#include "libnazgul.h"
2004-02-21 12:59:43 +00:00
#include "nzg_ids.h"
2004-02-19 21:32:42 +00:00
/* prototypes des f#define MSGSPACE_DEFAULT_MODE 0600
#define MSGSPACE_ID_LEN 32
onctions annexes <EFBFBD> ne pas exporter */
2004-02-19 21:21:52 +00:00
int msgSpaceIdIntern(msgSpaceId dest,const msgSpaceId src );
int msgPoolDataIdIntern(msgSpaceId dest,const msgSpaceId src );
2004-02-16 21:25:11 +00:00
/*
* spaceId : identifiant externe de l'espace de msg
* queueNb : nombre de files de messages
* poolNb : nombre de pool de buffers
* queueNbCar : tableau de caracteristiques des different pool
*/
msgSpace * msgSpaceCreate(
msgSpaceId spaceId,
int queueNb,
int poolNb,
2004-02-19 23:17:05 +00:00
msgPool * poolInfos ){
msgSpaceId nzgId;
2004-02-19 19:52:11 +00:00
/* msgSpaceList mSList; */
2004-02-19 10:39:55 +00:00
int mSFd; // shm file descriptor
2004-02-19 21:45:01 +00:00
int mSPoolDataFd; // shm file descriptor
2004-02-19 11:06:03 +00:00
int i;
2004-02-19 10:24:42 +00:00
static int mSIdNum=-1;
2004-02-19 10:39:55 +00:00
msgSpace * mSAddr;
2004-02-19 21:32:42 +00:00
2004-02-21 18:50:38 +00:00
msgPoolId poolDataTabId;
2004-02-19 21:21:52 +00:00
msgPoolData * mSPoolDataAddr;
2004-02-19 21:32:42 +00:00
2004-02-19 19:52:11 +00:00
fprintf(stderr,"Creating msgSpace with id : %s\n",spaceId);
2004-02-19 10:24:42 +00:00
mSIdNum++;
2004-02-19 10:39:55 +00:00
mSAddr=NULL;
2004-02-19 21:32:42 +00:00
/** recuperation de la liste des msgSpace **/
/* (creation si elle n'existe pas */
/** on cr<63>ee le nouvel element **/
2004-02-17 16:38:08 +00:00
printf("PAGESIZE : %d\n",(int)PAGESIZE);
2004-02-19 19:52:11 +00:00
if (msgSpaceIdIntern(nzgId,spaceId) < 0){
return NULL;
}
printf("Id interne : %s\n",nzgId);
2004-02-19 10:39:55 +00:00
mSFd=shm_open(
nzgId,
2004-02-19 10:39:55 +00:00
O_RDWR|O_CREAT|O_EXCL|O_TRUNC,
MSGSPACE_DEFAULT_MODE
);
2004-02-19 10:39:55 +00:00
if (mSFd == -1 ) {
2004-02-19 10:53:46 +00:00
fprintf( stderr, "msgSpace %s creation failed: %s\n",
2004-02-19 21:32:42 +00:00
(char*)nzgId,
2004-02-19 10:39:55 +00:00
strerror( errno ) );
2004-02-17 16:38:08 +00:00
return NULL;
}
2004-02-16 21:25:11 +00:00
2004-02-19 19:52:11 +00:00
/* on redimentionne l'element */
2004-02-19 19:25:57 +00:00
if (ftruncate(mSFd, sizeof(* mSAddr)) == -1){
2004-02-19 10:39:55 +00:00
fprintf( stderr, "msgSpace resizing failed: %s\n",
strerror( errno ) );
return NULL;
}
2004-02-19 21:32:42 +00:00
2004-02-19 10:39:55 +00:00
/* Map the memory object */
mSAddr = mmap( 0, sizeof( *mSAddr ),
2004-02-19 21:32:42 +00:00
PROT_READ | PROT_WRITE,
MAP_SHARED, mSFd, 0 );
if( mSAddr == MAP_FAILED ) {
fprintf( stderr, "mmap failed: %s\n",
strerror( errno ) );
return NULL;
}
2004-02-19 23:05:13 +00:00
printf( "msgSpace map addr is 0x%08x : %d\n", (int)mSAddr,mSFd);
2004-02-19 21:32:42 +00:00
/* on ferme le descripteur du fichier */
close(mSFd);
/* on remplit la structure */
strncpy(mSAddr->id,nzgId,MSGSPACE_ID_LEN);
mSAddr->poolNb=poolNb;
mSAddr->queueNb=queueNb;
mSAddr->pid=getpid();
/* creation du poolData */
2004-02-21 18:50:38 +00:00
msgPoolDataIdIntern(poolDataTabId,spaceId);
strcpy(mSAddr->poolDataTabId,poolDataTabId);
2004-02-19 21:32:42 +00:00
mSPoolDataFd=shm_open(
2004-02-21 18:50:38 +00:00
poolDataTabId,
2004-02-19 21:32:42 +00:00
O_RDWR|O_CREAT|O_EXCL|O_TRUNC,
MSGSPACE_DEFAULT_MODE
);
if (mSPoolDataFd == -1 ) {
fprintf( stderr, "poolData %s creation failed: %s\n",
2004-02-21 18:50:38 +00:00
(char*)poolDataTabId,
2004-02-19 21:32:42 +00:00
strerror( errno ) );
return NULL;
}
2004-02-19 23:26:27 +00:00
2004-02-19 22:37:56 +00:00
/* allocation de la bonne zone m<>moire pour le poolData */
2004-02-19 22:41:16 +00:00
if (ftruncate(mSPoolDataFd, poolNb*sizeof(msgPoolData)) == -1){
2004-02-19 22:37:56 +00:00
fprintf( stderr, "msgSpace resizing failed: %s\n",
strerror( errno ) );
return NULL;
}
2004-02-19 21:32:42 +00:00
2004-02-19 22:37:56 +00:00
/* TODO: attacher chacun des msgPoolData :
* - y <EFBFBD>crire les informations pass<EFBFBD>es en param
* - creer les zones m<EFBFBD>moires de chacune des pool
*/
2004-02-19 23:26:27 +00:00
mSPoolDataAddr = mmap( 0, sizeof( *mSAddr ),
2004-02-19 22:37:56 +00:00
PROT_READ | PROT_WRITE,
MAP_SHARED, mSFd, 0 );
if( mSPoolDataAddr == MAP_FAILED ) {
fprintf( stderr, "mmap failed: %s\n",
strerror( errno ) );
return NULL;
}
2004-02-19 23:17:05 +00:00
close(mSPoolDataFd);
2004-02-19 23:05:13 +00:00
printf( "msgPoolData map addr is 0x%08x\n", (int)mSPoolDataAddr );
2004-02-19 21:32:42 +00:00
2004-02-19 23:26:27 +00:00
for (i=0;i<poolNb;i++){
2004-02-19 21:32:42 +00:00
// creation d'une pool
2004-02-19 23:17:05 +00:00
mSPoolDataAddr[i].bufferNb=poolInfos[i].bufferNb;
mSPoolDataAddr[i].bufferSize=poolInfos[i].bufferSize;
mSPoolDataAddr[i].allocDispBuffer=0;
2004-02-21 21:07:40 +00:00
2004-02-21 18:50:38 +00:00
msgPoolId poolId;
2004-02-21 21:07:40 +00:00
if (msgPoolIdIntern(poolId,spaceId,i) == -1){
fprintf( stderr, "msgPoolId creation failed for id %s\n",
(char*)poolId );
return NULL;
}
msgPoolCreate(spaceId,i,poolInfos[i].bufferNb,poolInfos[i].bufferSize);
2004-02-21 18:50:38 +00:00
strcpy(mSPoolDataAddr[i].id,poolId);
2004-02-19 21:32:42 +00:00
}
2004-02-19 22:37:56 +00:00
/* TODO: on ajoute spaceId a la liste des msgSpace connus */
/* TODO: on cr<63>e queueNb files de messages */
2004-02-19 21:32:42 +00:00
/* on renvoie un pointeur sur le bon spaceId */
return mSAddr;
2004-02-16 21:25:11 +00:00
}
/*
* spaceId : blabla
*/
2004-02-17 16:38:08 +00:00
msgSpace * msgSpaceOpen(msgSpaceId spaceId){
2004-02-21 18:50:38 +00:00
int shmFd;
msgSpaceId nzgId;
2004-02-21 18:50:38 +00:00
msgSpace * mSAddr;
2004-02-19 19:52:11 +00:00
if (msgSpaceIdIntern(nzgId,spaceId) < 0){
return NULL;
}
2004-02-21 18:50:38 +00:00
if ((shmFd=shm_open(nzgId,O_RDWR,MSGSPACE_DEFAULT_MODE)) < 0){
2004-02-17 16:38:08 +00:00
perror("shm_open");
return NULL;
}
2004-02-21 18:50:38 +00:00
mSAddr=mmap(NULL,sizeof(msgSpace),PROT_READ|PROT_WRITE,MAP_SHARED,shmFd,(off_t)0);
return mSAddr;
2004-02-17 15:44:20 +00:00
}
int msgSpaceDelete(msgSpaceId spaceId){
2004-02-19 19:52:11 +00:00
fprintf(stderr,"Deleting msgSpace with id : %s\n",spaceId);
//int shmId;
msgSpaceId nzgId;
2004-02-21 18:50:38 +00:00
msgSpace * space;
2004-02-19 19:52:11 +00:00
if (msgSpaceIdIntern(nzgId,spaceId) == -1){
//TODO: message d'erreur
return -1;
2004-02-19 21:32:42 +00:00
}
2004-02-21 18:50:38 +00:00
space = msgSpaceOpen(spaceId);
2004-02-21 21:07:40 +00:00
/* TODO: supprimer chaque pool */
2004-02-21 18:50:38 +00:00
printf("openned successfully !\n");
printf("Unlinking DataTab... ");
if (shm_unlink(space->poolDataTabId) < 0){
perror("shm_unlink");
return -1;
}
printf("ok\n");
if (shm_unlink(nzgId)<0){
2004-02-17 19:42:25 +00:00
perror("shm_unlink");
return -1;
2004-02-17 19:42:25 +00:00
};
return 0;
2004-02-17 15:44:20 +00:00
}