diff --git a/src/backend/utils/mmgr/dsa.c b/src/backend/utils/mmgr/dsa.c index 9095da0f77..0e49e7020d 100644 --- a/src/backend/utils/mmgr/dsa.c +++ b/src/backend/utils/mmgr/dsa.c @@ -1099,9 +1099,10 @@ dsa_dump(dsa_area *area) span = dsa_get_address(area, span_pointer); fprintf(stderr, - " span descriptor at %016lx, " - "superblock at %016lx, pages = %zu, " - "objects free = %hu/%hu\n", + " span descriptor at " + DSA_POINTER_FORMAT ", superblock at " + DSA_POINTER_FORMAT + ", pages = %zu, objects free = %hu/%hu\n", span_pointer, span->start, span->npages, span->nallocatable, span->nmax); span_pointer = span->nextspan; diff --git a/src/include/utils/dsa.h b/src/include/utils/dsa.h index b05ab2c7f4..a6d674df57 100644 --- a/src/include/utils/dsa.h +++ b/src/include/utils/dsa.h @@ -54,6 +54,7 @@ typedef pg_atomic_uint32 dsa_pointer_atomic; #define dsa_pointer_atomic_write pg_atomic_write_u32 #define dsa_pointer_atomic_fetch_add pg_atomic_fetch_add_u32 #define dsa_pointer_atomic_compare_exchange pg_atomic_compare_exchange_u32 +#define DSA_POINTER_FORMAT "%08x" #else typedef uint64 dsa_pointer; typedef pg_atomic_uint64 dsa_pointer_atomic; @@ -62,6 +63,7 @@ typedef pg_atomic_uint64 dsa_pointer_atomic; #define dsa_pointer_atomic_write pg_atomic_write_u64 #define dsa_pointer_atomic_fetch_add pg_atomic_fetch_add_u64 #define dsa_pointer_atomic_compare_exchange pg_atomic_compare_exchange_u64 +#define DSA_POINTER_FORMAT "%016" INT64_MODIFIER "x" #endif /* A sentinel value for dsa_pointer used to indicate failure to allocate. */