diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/libdraw/drawclient.c | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/src/libdraw/drawclient.c b/src/libdraw/drawclient.c index 8fe1b79f..1fb5e080 100644 --- a/src/libdraw/drawclient.c +++ b/src/libdraw/drawclient.c @@ -38,7 +38,12 @@ _displayconnect(Display *d) dup(p[1], 0); dup(p[1], 1); /* execl("strace", "strace", "-o", "drawsrv.out", "drawsrv", nil); */ - execl("devdraw", "devdraw", nil); + /* + * The argv0 has no meaning to devdraw. + * Pass it along only so that the various + * devdraws in psu -a can be distinguished. + */ + execl("devdraw", "devdraw", argv0, nil); sysfatal("exec devdraw: %r"); } close(p[1]); @@ -157,7 +162,28 @@ displayrpc(Display *d, Wsysmsg *tx, Wsysmsg *rx, void **freep) fprint(2, "%r\n"); return -1; } + /* + * This is the only point where we might reschedule. + * Muxrpc might need to acquire d->mux->lk, which could + * be held by some other proc (e.g., the one reading from + * the keyboard via Trdkbd messages). If we need to wait + * for the lock, don't let other threads from this proc + * run. This keeps up the appearance that writes to /dev/draw + * don't cause rescheduling. If you *do* allow rescheduling + * here, then flushimage(display, 1) happening in two different + * threads in the same proc can cause a buffer of commands + * to be written out twice, leading to interesting results + * on the screen. + * + * Threadpin and threadunpin were added to the thread library + * to solve exactly this problem. Be careful! They are dangerous. + * + * _pin and _unpin are aliases for threadpin and threadunpin + * in a threaded program and are no-ops in unthreaded programs. + */ + _pin(); rpkt = muxrpc(d->mux, tpkt); + _unpin(); free(tpkt); if(rpkt == nil){ werrstr("muxrpc: %r"); |