Declare AnonymousShmem pointer as "void *".

The original coding had it as "PGShmemHeader *", but that doesn't offer any
notational benefit because we don't dereference it.  And it was resulting
in compiler warnings on some platforms, notably buildfarm member
castoroides, where mmap() and munmap() are evidently declared to take and
return "char *".
This commit is contained in:
Tom Lane 2012-06-30 17:19:46 -04:00
parent 541ffa65c3
commit 81e8264383

View File

@ -65,7 +65,7 @@ typedef int IpcMemoryId; /* shared memory ID returned by shmget(2) */
unsigned long UsedShmemSegID = 0; unsigned long UsedShmemSegID = 0;
void *UsedShmemSegAddr = NULL; void *UsedShmemSegAddr = NULL;
static Size AnonymousShmemSize; static Size AnonymousShmemSize;
static PGShmemHeader *AnonymousShmem; static void *AnonymousShmem;
static void *InternalIpcMemoryCreate(IpcMemoryKey memKey, Size size); static void *InternalIpcMemoryCreate(IpcMemoryKey memKey, Size size);
static void IpcMemoryDetach(int status, Datum shmaddr); static void IpcMemoryDetach(int status, Datum shmaddr);
@ -382,7 +382,7 @@ PGSharedMemoryCreate(Size size, bool makePrivate, int port)
PGShmemHeader *hdr; PGShmemHeader *hdr;
IpcMemoryId shmid; IpcMemoryId shmid;
struct stat statbuf; struct stat statbuf;
Size allocsize = size; Size sysvsize = size;
/* Room for a header? */ /* Room for a header? */
Assert(size > MAXALIGN(sizeof(PGShmemHeader))); Assert(size > MAXALIGN(sizeof(PGShmemHeader)));
@ -440,7 +440,7 @@ PGSharedMemoryCreate(Size size, bool makePrivate, int port)
AnonymousShmemSize = size; AnonymousShmemSize = size;
/* Now we need only allocate a minimal-sized SysV shmem block. */ /* Now we need only allocate a minimal-sized SysV shmem block. */
allocsize = sizeof(PGShmemHeader); sysvsize = sizeof(PGShmemHeader);
} }
#endif #endif
@ -453,7 +453,7 @@ PGSharedMemoryCreate(Size size, bool makePrivate, int port)
for (NextShmemSegID++;; NextShmemSegID++) for (NextShmemSegID++;; NextShmemSegID++)
{ {
/* Try to create new segment */ /* Try to create new segment */
memAddress = InternalIpcMemoryCreate(NextShmemSegID, allocsize); memAddress = InternalIpcMemoryCreate(NextShmemSegID, sysvsize);
if (memAddress) if (memAddress)
break; /* successful create and attach */ break; /* successful create and attach */
@ -492,7 +492,7 @@ PGSharedMemoryCreate(Size size, bool makePrivate, int port)
/* /*
* Now try again to create the segment. * Now try again to create the segment.
*/ */
memAddress = InternalIpcMemoryCreate(NextShmemSegID, allocsize); memAddress = InternalIpcMemoryCreate(NextShmemSegID, sysvsize);
if (memAddress) if (memAddress)
break; /* successful create and attach */ break; /* successful create and attach */
@ -540,8 +540,7 @@ PGSharedMemoryCreate(Size size, bool makePrivate, int port)
if (AnonymousShmem == NULL) if (AnonymousShmem == NULL)
return hdr; return hdr;
memcpy(AnonymousShmem, hdr, sizeof(PGShmemHeader)); memcpy(AnonymousShmem, hdr, sizeof(PGShmemHeader));
return AnonymousShmem; return (PGShmemHeader *) AnonymousShmem;
} }
#ifdef EXEC_BACKEND #ifdef EXEC_BACKEND