]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Use "ssize_t" not "long" in max_stack_depth-related code.
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 30 Jan 2025 21:44:47 +0000 (16:44 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 30 Jan 2025 21:44:47 +0000 (16:44 -0500)
commitb9d232b9de89aa9282f9a2e7c85f783bcd334af2
treef80e8c9c53e69761113beed93118beb33897dc09
parentb9aa4166fa3823d4f1f76286ca21fcfa991ce036
Use "ssize_t" not "long" in max_stack_depth-related code.

This change adapts these functions to the machine's address width
without depending on "long" to be the right size.  (It isn't on
Win64, for example.)  While it seems unlikely anyone would care
to run with a stack depth limit exceeding 2GB, this is part of a
general push to avoid using type "long" to represent memory sizes.

It's convenient to use ssize_t rather than the perhaps-more-obvious
choice of size_t/Size, because the code involved depends on working
with a signed data type.  Our MAX_KILOBYTES limit already ensures
that ssize_t will be sufficient to represent the maximum value of
max_stack_depth.

Extracted from a larger patch by Vladlen, plus additional hackery
by me.

Author: Vladlen Popolitov <v.popolitov@postgrespro.ru>
Author: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/1a01f0-66ec2d80-3b-68487680@27595217
src/backend/utils/misc/guc.c
src/backend/utils/misc/stack_depth.c
src/include/miscadmin.h