forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commitfaa189c
committed
Move libpq's write_failed mechanism down to pqsecure_raw_write().
Commit1f39a1c implemented write-failure postponement in pqSendSome,which is above SSL/GSS processing. However, we've now seen failuresindicating that (some versions of?) OpenSSL have a tendency to reportwrite failures prematurely too. Hence, move the primary responsibilityfor postponing write failures down to pqsecure_raw_write(), belowSSL/GSS processing. pqSendSome now sets write_failed only in cornercases where we'd lost the connection already.A side-effect of this change is that errors detected in the SSL/GSSlayer itself will be reported immediately (as if they were readerrors) rather than being postponed like write errors. That'sreverting an effect of1f39a1c, and I think it's fine: if there'snot a socket-level error, it's hard to be sure whether an OpenSSLerror ought to be considered a read or write failure anyway.Another important point is that write-failure postponement is noweffective during connection setup. OpenSSL's misbehavior of thissort occurs during SSL_connect(), so that's a change we want.Per bug #17391 from Nazir Bilal Yavuz. Possibly this should beback-patched, but I think it prudent to let it age awhile in HEADfirst.Discussion:https://postgr.es/m/17391-304f81bcf724b58b@postgresql.org1 parent335fa5a commitfaa189c
2 files changed
+90
-38
lines changedLines changed: 20 additions & 27 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
777 | 777 |
| |
778 | 778 |
| |
779 | 779 |
| |
780 |
| - | |
781 |
| - | |
782 |
| - | |
783 |
| - | |
784 |
| - | |
785 |
| - | |
| 780 | + | |
| 781 | + | |
| 782 | + | |
| 783 | + | |
| 784 | + | |
| 785 | + | |
| 786 | + | |
786 | 787 |
| |
787 | 788 |
| |
788 | 789 |
| |
789 | 790 |
| |
790 | 791 |
| |
791 | 792 |
| |
792 |
| - | |
793 | 793 |
| |
794 | 794 |
| |
795 | 795 |
| |
| |||
817 | 817 |
| |
818 | 818 |
| |
819 | 819 |
| |
820 |
| - | |
| 820 | + | |
821 | 821 |
| |
822 | 822 |
| |
823 | 823 |
| |
| |||
859 | 859 |
| |
860 | 860 |
| |
861 | 861 |
| |
862 |
| - | |
863 |
| - | |
864 |
| - | |
865 |
| - | |
866 |
| - | |
867 |
| - | |
868 |
| - | |
869 |
| - | |
870 |
| - | |
871 |
| - | |
872 |
| - | |
873 |
| - | |
874 |
| - | |
875 |
| - | |
876 |
| - | |
877 |
| - | |
878 |
| - | |
879 |
| - | |
880 | 862 |
| |
881 | 863 |
| |
882 | 864 |
| |
| |||
886 | 868 |
| |
887 | 869 |
| |
888 | 870 |
| |
889 |
| - | |
| 871 | + | |
| 872 | + | |
| 873 | + | |
| 874 | + | |
| 875 | + | |
| 876 | + | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
| 882 | + | |
890 | 883 |
| |
891 | 884 |
| |
892 | 885 |
| |
|
Lines changed: 70 additions & 11 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
280 | 280 |
| |
281 | 281 |
| |
282 | 282 |
| |
283 |
| - | |
284 |
| - | |
285 |
| - | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
286 | 299 |
| |
287 | 300 |
| |
288 | 301 |
| |
| |||
310 | 323 |
| |
311 | 324 |
| |
312 | 325 |
| |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
313 | 349 |
| |
314 | 350 |
| |
315 | 351 |
| |
316 | 352 |
| |
317 | 353 |
| |
318 | 354 |
| |
| 355 | + | |
319 | 356 |
| |
320 | 357 |
| |
321 | 358 |
| |
322 | 359 |
| |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
323 | 370 |
| |
324 | 371 |
| |
325 | 372 |
| |
| |||
369 | 416 |
| |
370 | 417 |
| |
371 | 418 |
| |
372 |
| - | |
373 |
| - | |
374 |
| - | |
375 |
| - | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
376 | 429 |
| |
377 | 430 |
| |
378 | 431 |
| |
379 |
| - | |
380 |
| - | |
381 |
| - | |
382 |
| - | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
383 | 442 |
| |
384 | 443 |
| |
385 | 444 |
| |
|
0 commit comments
Comments
(0)