Mark panic() as never returning so that code analysis might be able to do a smarter job. It required splitting done() into two routines since the first part really can return (but not if PANICKED was the reason it got called). done() is now much shorter and ends with a call to new really_done(), and panic() skips done()'s might-return part by calling really_done() directly. Noticed in passing: the "report error to <list of SYSCF WIZARDS>" code calls a routine which uses alloc(), which won't work very well if the reason for panic was because malloc() ran out of memory.
1.4 KiB
1.4 KiB