- Notifications
You must be signed in to change notification settings - Fork5
Commit202dbdb
committed
Make pgwin32_putenv() follow DLL loading and unloading.
Until now, the first putenv() call of a given postgres.exe process wouldcache the set of loaded CRTs. If a CRT unloaded after that call, thenext putenv() would crash. That risk was largely theoretical, becausethe first putenv() precedes all PostgreSQL-initiated module loading.However, this might explain bad interactions with antivirus and othersoftware that injects threads asynchronously. If an additional CRTloaded after the first putenv(), pgwin32_putenv() would not discover it.That CRT would have all environment changes predating its load, but itwould not receive later PostgreSQL-initiated changes. An additional CRTloading concurrently with the first putenv() might miss that change inaddition to missing later changes. Fix all those problems. Thisremoves the cache mechanism from pgwin32_putenv(); the cost, less than100 μs per backend startup, is negligible.No resulting misbehavior was known to be user-visible given the coredistribution alone, but one can readily construct an affected extensionmodule. No back-patch given the lack of complaints and the potentialfor behavior changes in non-PostgreSQL code running in the backend.Christian Ullrich, reviewed by Michael Paquier.1 parent95b9b8a commit202dbdb
1 file changed
+48
-112
lines changedLines changed: 48 additions & 112 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
21 | 21 |
| |
22 | 22 |
| |
23 | 23 |
| |
24 |
| - | |
25 |
| - | |
26 |
| - | |
27 |
| - | |
28 |
| - | |
29 |
| - | |
30 |
| - | |
31 | 24 |
| |
32 | 25 |
| |
33 |
| - | |
34 |
| - | |
35 |
| - | |
36 |
| - | |
37 |
| - | |
38 |
| - | |
39 |
| - | |
40 |
| - | |
41 |
| - | |
42 |
| - | |
43 |
| - | |
44 |
| - | |
45 |
| - | |
46 |
| - | |
47 |
| - | |
48 |
| - | |
49 |
| - | |
50 |
| - | |
51 |
| - | |
52 |
| - | |
53 |
| - | |
54 |
| - | |
55 |
| - | |
56 |
| - | |
57 |
| - | |
58 |
| - | |
59 |
| - | |
60 |
| - | |
61 |
| - | |
62 |
| - | |
63 |
| - | |
64 |
| - | |
65 |
| - | |
66 |
| - | |
67 |
| - | |
68 |
| - | |
69 |
| - | |
70 |
| - | |
71 |
| - | |
72 |
| - | |
73 |
| - | |
74 |
| - | |
75 |
| - | |
76 |
| - | |
77 |
| - | |
78 |
| - | |
79 |
| - | |
80 |
| - | |
81 |
| - | |
82 |
| - | |
83 |
| - | |
84 |
| - | |
85 |
| - | |
86 |
| - | |
87 |
| - | |
88 |
| - | |
89 |
| - | |
90 |
| - | |
91 |
| - | |
92 |
| - | |
93 |
| - | |
94 |
| - | |
95 |
| - | |
96 |
| - | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
97 | 46 |
| |
98 | 47 |
| |
99 |
| - | |
100 |
| - | |
101 |
| - | |
102 |
| - | |
103 |
| - | |
104 |
| - | |
105 |
| - | |
106 |
| - | |
107 |
| - | |
108 |
| - | |
109 |
| - | |
110 |
| - | |
111 |
| - | |
112 |
| - | |
113 |
| - | |
114 |
| - | |
115 |
| - | |
116 |
| - | |
117 |
| - | |
118 |
| - | |
119 |
| - | |
120 |
| - | |
121 |
| - | |
122 |
| - | |
123 |
| - | |
124 |
| - | |
125 |
| - | |
126 |
| - | |
127 |
| - | |
128 |
| - | |
129 |
| - | |
130 |
| - | |
131 |
| - | |
132 |
| - | |
133 |
| - | |
134 |
| - | |
135 |
| - | |
136 |
| - | |
137 |
| - | |
138 |
| - | |
139 | 48 |
| |
140 | 49 |
| |
141 | 50 |
| |
142 | 51 |
| |
143 |
| - | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
144 | 55 |
| |
145 | 56 |
| |
146 | 57 |
| |
| |||
170 | 81 |
| |
171 | 82 |
| |
172 | 83 |
| |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
173 | 109 |
| |
174 | 110 |
| |
175 | 111 |
| |
|
0 commit comments
Comments
(0)