There is a quite nasty condition that can happen particularly if some program misbehaves and eats all the kva space, leaving affected system live-locked and admin with no breadcrumbs to follow. In general, whichever pid is eating it out should be killed with extreme prejudice, since right now it's basically a system-wide deadlock implementation, as it blocks any fork+exec from completing. :(
As documented: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=272332
Upon further investigation it seems that the root of the issue is some recent changes in the login that would shift error to allocate pipe buffer into the popen(), from the write() handler (c6d3d601c). Arguably, popen() being in the critical path of typical UNIX life, it needs to be absolutely robust. If some presumably user-level code cannot deal with failures of the write() later on, well, that's the problems of that code and should be handled there.