Don't trust CreateFileMapping() to clear the error code on success.
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 23 Sep 2016 14:09:52 +0000 (10:09 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 23 Sep 2016 14:09:52 +0000 (10:09 -0400)
commite7f5d8ea1c75cc341a966897760a812e437c4668
treeabddd5fc41bb6d5677a95e011795ae2a1f0396f5
parentb251379fb44b4893624999f1ba00986c029f11cf
Don't trust CreateFileMapping() to clear the error code on success.

We must test GetLastError() even when CreateFileMapping() returns a
non-null handle.  If that value were left over from some previous system
call, we might be fooled into thinking the segment already existed.
Experimentation on Windows 7 suggests that CreateFileMapping() clears
the error code on success, but it is not documented to do so, so let's
not rely on that happening in all Windows releases.

Amit Kapila

Discussion: <20811.1474390987@sss.pgh.pa.us>
src/backend/storage/ipc/dsm_impl.c