Skip to content

Commit

Permalink
Fix and clarify function comment on LogicalTapeSetCreate.
Browse files Browse the repository at this point in the history
Commit c4649cc removed the "shared" and "ntapes" arguments, but the
comment still talked about "shared". It also talked about "a shared
file handle", which was technically correct because even before commit
c4649cc, the "shared file handle" referred to the "fileset"
argument, not "shared". But it was very confusing. Improve the
comment.

Also add a comment on what the "preallocate" argument does.

Backpatch to v15, just to make backpatching other patches easier in
the future.

Discussion: https://www.postgresql.org/message-id/af989685-91d5-aad4-8f60-1d066b5ec309@enterprisedb.com
Reviewed-by: Peter Eisentraut
  • Loading branch information
hlinnaka committed Jan 23, 2023
1 parent 9e4288c commit 95f62b1
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions src/backend/utils/sort/logtape.c
Expand Up @@ -544,14 +544,20 @@ ltsInitReadBuffer(LogicalTape *lt)
* The tape set is initially empty. Use LogicalTapeCreate() to create
* tapes in it.
*
* Serial callers pass NULL argument for shared, and -1 for worker. Parallel
* worker callers pass a shared file handle and their own worker number.
* In a single-process sort, pass NULL argument for fileset, and -1 for
* worker.
*
* Leader callers pass a shared file handle and -1 for worker. After creating
* the tape set, use LogicalTapeImport() to import the worker tapes into it.
* In a parallel sort, parallel workers pass the shared fileset handle and
* their own worker number. After the workers have finished, create the
* tape set in the leader, passing the shared fileset handle and -1 for
* worker, and use LogicalTapeImport() to import the worker tapes into it.
*
* Currently, the leader will only import worker tapes into the set, it does
* not create tapes of its own, although in principle that should work.
*
* If preallocate is true, blocks for each individual tape are allocated in
* batches. This avoids fragmentation when writing multiple tapes at the
* same time.
*/
LogicalTapeSet *
LogicalTapeSetCreate(bool preallocate, SharedFileSet *fileset, int worker)
Expand Down

0 comments on commit 95f62b1

Please sign in to comment.