[PATCH 2/5] Make relpathbackend return a statically result instead of palloc()'ing it - Mailing list pgsql-hackers
From | Andres Freund |
---|---|
Subject | [PATCH 2/5] Make relpathbackend return a statically result instead of palloc()'ing it |
Date | |
Msg-id | 1357672187-7693-3-git-send-email-andres@2ndquadrant.com Whole thread Raw |
In response to | [PATCH] xlogreader-v4 (Andres Freund <andres@2ndquadrant.com>) |
Responses |
Re: [PATCH 2/5] Make relpathbackend return a statically result instead of palloc()'ing it
|
List | pgsql-hackers |
From: Andres Freund <andres@anarazel.de> relpathbackend() (via some of its wrappers) is used in *_desc routines which we want to be useable without a backend environment arround. Change signature to return a 'const char *' to make misuse easier to detect. That necessicates also changing the 'FileName' typedef to 'const char *' which seems to be a good idea anyway. ---src/backend/access/rmgrdesc/smgrdesc.c | 6 ++---src/backend/access/rmgrdesc/xactdesc.c | 6 ++---src/backend/access/transam/xlogutils.c| 9 +++----src/backend/catalog/catalog.c | 49 +++++++++++-----------------------src/backend/storage/buffer/bufmgr.c | 12 +++------src/backend/storage/file/fd.c | 6 ++---src/backend/storage/smgr/md.c | 23 +++++-----------src/backend/utils/adt/dbsize.c | 4 +--src/include/catalog/catalog.h | 2 +-src/include/storage/fd.h | 9 +++----10 files changed, 42 insertions(+),84 deletions(-) diff --git a/src/backend/access/rmgrdesc/smgrdesc.c b/src/backend/access/rmgrdesc/smgrdesc.c index bcabf89..490c8c7 100644 --- a/src/backend/access/rmgrdesc/smgrdesc.c +++ b/src/backend/access/rmgrdesc/smgrdesc.c @@ -26,19 +26,17 @@ smgr_desc(StringInfo buf, uint8 xl_info, char *rec) if (info == XLOG_SMGR_CREATE) { xl_smgr_create*xlrec = (xl_smgr_create *) rec; - char *path = relpathperm(xlrec->rnode, xlrec->forkNum); + const char *path = relpathperm(xlrec->rnode, xlrec->forkNum); appendStringInfo(buf, "file create: %s", path); - pfree(path); } else if (info == XLOG_SMGR_TRUNCATE) { xl_smgr_truncate *xlrec = (xl_smgr_truncate*) rec; - char *path = relpathperm(xlrec->rnode, MAIN_FORKNUM); + const char *path = relpathperm(xlrec->rnode, MAIN_FORKNUM); appendStringInfo(buf, "file truncate: %s to %ublocks", path, xlrec->blkno); - pfree(path); } else appendStringInfo(buf, "UNKNOWN"); diff --git a/src/backend/access/rmgrdesc/xactdesc.c b/src/backend/access/rmgrdesc/xactdesc.c index 2471279..b86a53e 100644 --- a/src/backend/access/rmgrdesc/xactdesc.c +++ b/src/backend/access/rmgrdesc/xactdesc.c @@ -35,10 +35,9 @@ xact_desc_commit(StringInfo buf, xl_xact_commit *xlrec) appendStringInfo(buf, "; rels:"); for (i = 0; i < xlrec->nrels; i++) { - char *path = relpathperm(xlrec->xnodes[i], MAIN_FORKNUM); + const char *path = relpathperm(xlrec->xnodes[i], MAIN_FORKNUM); appendStringInfo(buf, " %s", path); - pfree(path); } } if (xlrec->nsubxacts > 0) @@ -105,10 +104,9 @@ xact_desc_abort(StringInfo buf, xl_xact_abort *xlrec) appendStringInfo(buf, "; rels:"); for (i = 0; i < xlrec->nrels; i++) { - char *path = relpathperm(xlrec->xnodes[i], MAIN_FORKNUM); + const char *path = relpathperm(xlrec->xnodes[i], MAIN_FORKNUM); appendStringInfo(buf, " %s", path); - pfree(path); } } if (xlrec->nsubxacts > 0) diff --git a/src/backend/access/transam/xlogutils.c b/src/backend/access/transam/xlogutils.c index f9a6e62..8266f3c 100644 --- a/src/backend/access/transam/xlogutils.c +++ b/src/backend/access/transam/xlogutils.c @@ -57,7 +57,7 @@ static voidreport_invalid_page(int elevel, RelFileNode node, ForkNumber forkno, BlockNumberblkno, bool present){ - char *path = relpathperm(node, forkno); + const char *path = relpathperm(node, forkno); if (present) elog(elevel, "page %u of relation %s is uninitialized", @@ -65,7 +65,6 @@ report_invalid_page(int elevel, RelFileNode node, ForkNumber forkno, else elog(elevel, "page%u of relation %s does not exist", blkno, path); - pfree(path);}/* Log a reference to an invalid page */ @@ -153,11 +152,10 @@ forget_invalid_pages(RelFileNode node, ForkNumber forkno, BlockNumber minblkno) { if (log_min_messages <= DEBUG2 || client_min_messages <= DEBUG2) { - char *path = relpathperm(hentry->key.node, forkno); + const char *path = relpathperm(hentry->key.node, forkno); elog(DEBUG2, "page %u of relation%s has been dropped", hentry->key.blkno, path); - pfree(path); } if (hash_search(invalid_page_tab, @@ -186,11 +184,10 @@ forget_invalid_pages_db(Oid dbid) { if (log_min_messages <= DEBUG2 || client_min_messages<= DEBUG2) { - char *path = relpathperm(hentry->key.node, hentry->key.forkno); + const char *path = relpathperm(hentry->key.node, hentry->key.forkno); elog(DEBUG2, "page%u of relation %s has been dropped", hentry->key.blkno, path); - pfree(path); } if (hash_search(invalid_page_tab, diff --git a/src/backend/catalog/catalog.c b/src/backend/catalog/catalog.c index 9686486..6455ef0 100644 --- a/src/backend/catalog/catalog.c +++ b/src/backend/catalog/catalog.c @@ -112,54 +112,45 @@ forkname_chars(const char *str, ForkNumber *fork)/* * relpathbackend - construct path to a relation'sfile * - * Result is a palloc'd string. + * Result is a pointer to a statically allocated string. */ -char * +const char *relpathbackend(RelFileNode rnode, BackendId backend, ForkNumber forknum){ - int pathlen; - char *path; + static char path[MAXPGPATH]; if (rnode.spcNode == GLOBALTABLESPACE_OID) { /* Shared system relations livein {datadir}/global */ Assert(rnode.dbNode == 0); Assert(backend == InvalidBackendId); - pathlen = 7 + OIDCHARS + 1 + FORKNAMECHARS + 1; - path = (char *) palloc(pathlen); if (forknum != MAIN_FORKNUM) - snprintf(path, pathlen, "global/%u_%s", + snprintf(path, MAXPGPATH, "global/%u_%s", rnode.relNode, forkNames[forknum]); else - snprintf(path, pathlen, "global/%u", rnode.relNode); + snprintf(path, MAXPGPATH, "global/%u", rnode.relNode); } else if (rnode.spcNode == DEFAULTTABLESPACE_OID) { /* The default tablespace is {datadir}/base */ if (backend == InvalidBackendId) { - pathlen = 5 + OIDCHARS + 1 + OIDCHARS + 1 + FORKNAMECHARS + 1; - path = (char *) palloc(pathlen); if (forknum != MAIN_FORKNUM) - snprintf(path, pathlen, "base/%u/%u_%s", + snprintf(path, MAXPGPATH, "base/%u/%u_%s", rnode.dbNode, rnode.relNode, forkNames[forknum]); else - snprintf(path, pathlen, "base/%u/%u", + snprintf(path, MAXPGPATH, "base/%u/%u", rnode.dbNode, rnode.relNode); } else { - /* OIDCHARS will suffice for an integer, too */ - pathlen = 5 + OIDCHARS + 2 + OIDCHARS + 1 + OIDCHARS + 1 - + FORKNAMECHARS + 1; - path = (char *) palloc(pathlen); if (forknum != MAIN_FORKNUM) - snprintf(path, pathlen, "base/%u/t%d_%u_%s", + snprintf(path, MAXPGPATH, "base/%u/t%d_%u_%s", rnode.dbNode, backend, rnode.relNode, forkNames[forknum]); else - snprintf(path, pathlen, "base/%u/t%d_%u", + snprintf(path, MAXPGPATH, "base/%u/t%d_%u", rnode.dbNode, backend, rnode.relNode); } } @@ -168,38 +159,30 @@ relpathbackend(RelFileNode rnode, BackendId backend, ForkNumber forknum) /* All other tablespacesare accessed via symlinks */ if (backend == InvalidBackendId) { - pathlen = 9 + 1 + OIDCHARS + 1 - + strlen(TABLESPACE_VERSION_DIRECTORY) + 1 + OIDCHARS + 1 - + OIDCHARS + 1 + FORKNAMECHARS + 1; - path = (char *) palloc(pathlen); if (forknum != MAIN_FORKNUM) - snprintf(path, pathlen, "pg_tblspc/%u/%s/%u/%u_%s", + snprintf(path, MAXPGPATH, "pg_tblspc/%u/%s/%u/%u_%s", rnode.spcNode, TABLESPACE_VERSION_DIRECTORY, rnode.dbNode, rnode.relNode, forkNames[forknum]); else - snprintf(path, pathlen, "pg_tblspc/%u/%s/%u/%u", + snprintf(path, MAXPGPATH, "pg_tblspc/%u/%s/%u/%u", rnode.spcNode, TABLESPACE_VERSION_DIRECTORY, rnode.dbNode, rnode.relNode); } else { - /* OIDCHARS will suffice for an integer, too */ - pathlen = 9 + 1 + OIDCHARS + 1 - + strlen(TABLESPACE_VERSION_DIRECTORY) + 1 + OIDCHARS + 2 - + OIDCHARS + 1 + OIDCHARS + 1 + FORKNAMECHARS + 1; - path = (char *) palloc(pathlen); if (forknum != MAIN_FORKNUM) - snprintf(path, pathlen, "pg_tblspc/%u/%s/%u/t%d_%u_%s", + snprintf(path, MAXPGPATH, "pg_tblspc/%u/%s/%u/t%d_%u_%s", rnode.spcNode, TABLESPACE_VERSION_DIRECTORY, rnode.dbNode, backend, rnode.relNode, forkNames[forknum]); else - snprintf(path, pathlen, "pg_tblspc/%u/%s/%u/t%d_%u", + snprintf(path, MAXPGPATH, "pg_tblspc/%u/%s/%u/t%d_%u", rnode.spcNode, TABLESPACE_VERSION_DIRECTORY, rnode.dbNode, backend, rnode.relNode); } } + return path;} @@ -534,7 +517,7 @@ OidGetNewRelFileNode(Oid reltablespace, Relation pg_class, char relpersistence){ RelFileNodeBackendrnode; - char *rpath; + const char *rpath; int fd; bool collides; BackendId backend; @@ -599,8 +582,6 @@ GetNewRelFileNode(Oid reltablespace, Relation pg_class, char relpersistence) */ collides = false; } - - pfree(rpath); } while (collides); return rnode.node.relNode; diff --git a/src/backend/storage/buffer/bufmgr.c b/src/backend/storage/buffer/bufmgr.c index 03ed41d..6c2620d 100644 --- a/src/backend/storage/buffer/bufmgr.c +++ b/src/backend/storage/buffer/bufmgr.c @@ -1757,7 +1757,7 @@ PrintBufferLeakWarning(Buffer buffer){ volatile BufferDesc *buf; int32 loccount; - char *path; + const char *path; BackendId backend; Assert(BufferIsValid(buffer)); @@ -1782,7 +1782,6 @@ PrintBufferLeakWarning(Buffer buffer) buffer, path, buf->tag.blockNum, buf->flags, buf->refcount, loccount); - pfree(path);}/* @@ -2901,7 +2900,7 @@ AbortBufferIO(void) if (sv_flags & BM_IO_ERROR) { /* Buffer ispinned, so we can read tag without spinlock */ - char *path; + const char *path; path = relpathperm(buf->tag.rnode, buf->tag.forkNum); ereport(WARNING, @@ -2909,7 +2908,6 @@ AbortBufferIO(void) errmsg("could not write block %u of %s", buf->tag.blockNum, path), errdetail("Multiple failures --- write error might bepermanent."))); - pfree(path); } } TerminateBufferIO(buf, false, BM_IO_ERROR); @@ -2927,11 +2925,10 @@ shared_buffer_write_error_callback(void *arg) /* Buffer is pinned, so we can read the tag withoutlocking the spinlock */ if (bufHdr != NULL) { - char *path = relpathperm(bufHdr->tag.rnode, bufHdr->tag.forkNum); + const char *path = relpathperm(bufHdr->tag.rnode, bufHdr->tag.forkNum); errcontext("writing block %u of relation%s", bufHdr->tag.blockNum, path); - pfree(path); }} @@ -2945,11 +2942,10 @@ local_buffer_write_error_callback(void *arg) if (bufHdr != NULL) { - char *path = relpathbackend(bufHdr->tag.rnode, MyBackendId, + const char *path = relpathbackend(bufHdr->tag.rnode, MyBackendId, bufHdr->tag.forkNum); errcontext("writing block %u of relation %s", bufHdr->tag.blockNum, path); - pfree(path); }} diff --git a/src/backend/storage/file/fd.c b/src/backend/storage/file/fd.c index c026731..64d2a1e 100644 --- a/src/backend/storage/file/fd.c +++ b/src/backend/storage/file/fd.c @@ -556,7 +556,7 @@ set_max_safe_fds(void) * this module wouldn't have any open files to close at that point anyway. */int -BasicOpenFile(FileName fileName, int fileFlags, int fileMode) +BasicOpenFile(const char *fileName, int fileFlags, int fileMode){ int fd; @@ -878,7 +878,7 @@ FileInvalidate(File file) * (which should always be $PGDATA when this code is running). */File -PathNameOpenFile(FileName fileName, int fileFlags, int fileMode) +PathNameOpenFile(const char *fileName, int fileFlags, int fileMode){ char *fnamecopy; File file; @@ -1548,7 +1548,7 @@ TryAgain: * Like AllocateFile, but returns an unbuffered fd like open(2) */int -OpenTransientFile(FileName fileName, int fileFlags, int fileMode) +OpenTransientFile(const char *fileName, int fileFlags, int fileMode){ int fd; diff --git a/src/backend/storage/smgr/md.c b/src/backend/storage/smgr/md.c index 20eb36a..4ef47b1 100644 --- a/src/backend/storage/smgr/md.c +++ b/src/backend/storage/smgr/md.c @@ -264,7 +264,7 @@ mdexists(SMgrRelation reln, ForkNumber forkNum)voidmdcreate(SMgrRelation reln, ForkNumber forkNum, boolisRedo){ - char *path; + const char *path; File fd; if (isRedo && reln->md_fd[forkNum] != NULL) @@ -298,8 +298,6 @@ mdcreate(SMgrRelation reln, ForkNumber forkNum, bool isRedo) } } - pfree(path); - reln->md_fd[forkNum] = _fdvec_alloc(); reln->md_fd[forkNum]->mdfd_vfd = fd; @@ -380,7 +378,7 @@ mdunlink(RelFileNodeBackend rnode, ForkNumber forkNum, bool isRedo)static voidmdunlinkfork(RelFileNodeBackendrnode, ForkNumber forkNum, bool isRedo){ - char *path; + const char *path; int ret; path = relpath(rnode, forkNum); @@ -449,8 +447,6 @@ mdunlinkfork(RelFileNodeBackend rnode, ForkNumber forkNum, bool isRedo) } pfree(segpath); } - - pfree(path);}/* @@ -545,7 +541,7 @@ static MdfdVec *mdopen(SMgrRelation reln, ForkNumber forknum, ExtensionBehavior behavior){ MdfdVec *mdfd; - char *path; + const char *path; File fd; /* No work if already open */ @@ -571,7 +567,6 @@ mdopen(SMgrRelation reln, ForkNumber forknum, ExtensionBehavior behavior) if (behavior ==EXTENSION_RETURN_NULL && FILE_POSSIBLY_DELETED(errno)) { - pfree(path); return NULL; } ereport(ERROR, @@ -580,8 +575,6 @@ mdopen(SMgrRelation reln, ForkNumber forknum, ExtensionBehavior behavior) } } - pfree(path); - reln->md_fd[forknum] = mdfd = _fdvec_alloc(); mdfd->mdfd_vfd = fd; @@ -1279,7 +1272,7 @@ mdpostckpt(void) while (pendingUnlinks != NIL) { PendingUnlinkEntry *entry = (PendingUnlinkEntry*) linitial(pendingUnlinks); - char *path; + const char *path; /* * New entries are appended to the end, so if the entry is new we've @@ -1309,7 +1302,6 @@ mdpostckpt(void) (errcode_for_file_access(), errmsg("couldnot remove file \"%s\": %m", path))); } - pfree(path); /* And remove the list entry */ pendingUnlinks = list_delete_first(pendingUnlinks); @@ -1634,8 +1626,8 @@ _fdvec_alloc(void)static char *_mdfd_segpath(SMgrRelation reln, ForkNumber forknum, BlockNumber segno){ - char *path, - *fullpath; + const char *path; + char *fullpath; path = relpath(reln->smgr_rnode, forknum); @@ -1644,10 +1636,9 @@ _mdfd_segpath(SMgrRelation reln, ForkNumber forknum, BlockNumber segno) /* be sure we haveenough space for the '.segno' */ fullpath = (char *) palloc(strlen(path) + 12); sprintf(fullpath, "%s.%u",path, segno); - pfree(path); } else - fullpath = path; + fullpath = pstrdup(path); return fullpath;} diff --git a/src/backend/utils/adt/dbsize.c b/src/backend/utils/adt/dbsize.c index 89ad386..c285007 100644 --- a/src/backend/utils/adt/dbsize.c +++ b/src/backend/utils/adt/dbsize.c @@ -268,7 +268,7 @@ static int64calculate_relation_size(RelFileNode *rfn, BackendId backend, ForkNumber forknum){ int64 totalsize = 0; - char *relationpath; + const char *relationpath; char pathname[MAXPGPATH]; unsigned int segcount = 0; @@ -756,7 +756,7 @@ pg_relation_filepath(PG_FUNCTION_ARGS) Form_pg_class relform; RelFileNode rnode; BackendId backend; - char *path; + const char *path; tuple = SearchSysCache1(RELOID, ObjectIdGetDatum(relid)); if (!HeapTupleIsValid(tuple)) diff --git a/src/include/catalog/catalog.h b/src/include/catalog/catalog.h index 5d506fe..299cb03 100644 --- a/src/include/catalog/catalog.h +++ b/src/include/catalog/catalog.h @@ -31,7 +31,7 @@ extern const char *forkNames[];extern ForkNumber forkname_to_number(char *forkName);extern int forkname_chars(constchar *str, ForkNumber *); -extern char *relpathbackend(RelFileNode rnode, BackendId backend, +extern const char *relpathbackend(RelFileNode rnode, BackendId backend, ForkNumber forknum);extern char *GetDatabasePath(OiddbNode, Oid spcNode); diff --git a/src/include/storage/fd.h b/src/include/storage/fd.h index bd36c9d..b2565c4 100644 --- a/src/include/storage/fd.h +++ b/src/include/storage/fd.h @@ -45,9 +45,6 @@/* * FileSeek uses the standard UNIX lseek(2) flags. */ - -typedef char *FileName; -typedef int File; @@ -65,7 +62,7 @@ extern int max_safe_fds; *//* Operations on virtual Files --- equivalent to Unix kernel file ops */ -extern File PathNameOpenFile(FileName fileName, int fileFlags, int fileMode); +extern File PathNameOpenFile(const char *fileName, int fileFlags, int fileMode);extern File OpenTemporaryFile(bool interXact);externvoid FileClose(File file);extern int FilePrefetch(File file, off_t offset, int amount); @@ -86,11 +83,11 @@ extern struct dirent *ReadDir(DIR *dir, const char *dirname);extern int FreeDir(DIR *dir);/* Operationsto allow use of a plain kernel FD, with automatic cleanup */ -extern int OpenTransientFile(FileName fileName, int fileFlags, int fileMode); +extern int OpenTransientFile(const char *fileName, int fileFlags, int fileMode);extern int CloseTransientFile(intfd);/* If you've really really gotta have a plain kernel FD, use this */ -extern int BasicOpenFile(FileName fileName, int fileFlags, int fileMode); +extern int BasicOpenFile(const char *fileName, int fileFlags, int fileMode);/* Miscellaneous support routines */externvoid InitFileAccess(void); -- 1.7.12.289.g0ce9864.dirty
pgsql-hackers by date: