On Mon, Nov 21, 2022 at 1:12 PM Tom Lane <t...@sss.pgh.pa.us> wrote: > Andres Freund <and...@anarazel.de> writes: > > On 2022-11-21 12:52:01 -0500, Robert Haas wrote: > >> On Mon, Nov 21, 2022 at 12:35 PM Tom Lane <t...@sss.pgh.pa.us> wrote: > >>> Why in the world is get_raw_page() marked as parallel safe? > >>> It clearly isn't, given this restriction. > > > It's somewhat sad to add this restriction - I've used get_raw_page() (+ > > other functions) to scan a whole database for a bug. IIRC that actually > > did end up using parallelism, albeit likely not very efficiently. > > Don't really have a better idea though. > > Me either. > > > It may be worth inventing a framework where a function could analyze its > > arguments (presumably via prosupport) to determine the degree of > > parallel safety, but this doesn't seem sufficient reason... > > Maybe, but in this example you could only decide you were parallel > safe if the argument is an OID constant, which'd be pretty limiting. > > If I were trying to find a better fix I'd be looking for ways for > parallel workers to be able to read the parent's temp tables. > (Perhaps that could tie in with the blue-sky discussion we had > the other day about allowing autovacuum on temp tables??) > > > I don't suppose we want to just document the fact that these power-user non-core functions are unable to process temporary tables safely without first disabling parallelism for the session.
David J.