Microsoft WDS can end up calling PXENV_RESTART_TFTP to execute a second-stage NBP which then exits. Specifically, wdsnbp.com uses PXENV_RESTART_TFTP to execute pxeboot.com, which will exit if the user does not press F12. iPXE currently treats PXENV_RESTART_TFTP as a normal PXE API call, and so attempts to return to wdsnbp.com, which has just been vaporised by pxeboot.com. Use rmsetjmp/rmlongjmp to preserve the stack state as of the initial NBP execution, and to restore this state immediately prior to executing the NBP loaded via PXENV_RESTART_TFTP. This matches the behaviour in the PXE spec (which says that "if TFTP is restarted, control is never returned to the caller"), and allows pxeboot.com to exit relatively cleanly back to iPXE. As with all usage of setjmp/longjmp, there may be subtle corner case bugs due to not gracefully unwinding any state accumulated by the time of the longjmp call, but this seems to be the only viable way to provide the specified behaviour. Signed-off-by: Michael Brown <mcb30@ipxe.org>tags/v1.20.1
|
||
10 | 10 |
|
11 | 11 |
|
12 | 12 |
|
13 |
|
|
13 | 14 |
|
14 | 15 |
|
15 | 16 |
|
|
||
30 | 31 |
|
31 | 32 |
|
32 | 33 |
|
34 |
|
|
35 |
|
|
36 |
|
|
33 | 37 |
|
34 | 38 |
|
35 | 39 |
|
|
||
20 | 20 |
|
21 | 21 |
|
22 | 22 |
|
23 |
|
|
23 | 24 |
|
24 | 25 |
|
25 | 26 |
|
|
||
480 | 481 |
|
481 | 482 |
|
482 | 483 |
|
484 |
|
|
485 |
|
|
486 |
|
|
483 | 487 |
|
484 | 488 |
|
485 | 489 |
|
486 | 490 |
|
487 | 491 |
|
488 | 492 |
|
493 |
|
|
489 | 494 |
|
490 | 495 |
|
491 | 496 |
|
497 |
|
|
498 |
|
|
499 |
|
|
500 |
|
|
501 |
|
|
492 | 502 |
|
493 | 503 |
|
494 | 504 |
|
|
||
28 | 28 |
|
29 | 29 |
|
30 | 30 |
|
31 |
|
|
31 | 32 |
|
32 | 33 |
|
33 | 34 |
|
|
||
227 | 228 |
|
228 | 229 |
|
229 | 230 |
|
230 |
|
|
231 |
|
|
232 |
|
|
233 |
|
|
234 |
|
|
235 |
|
|
236 |
|
|
231 |
|
|
232 |
|
|
237 | 233 |
|
238 | 234 |
|
239 | 235 |
|