[Openmcl-devel] Raw-mode terminal weirdness redux
R. Matthew Emerson
rme at acm.org
Tue Mar 27 12:03:46 PDT 2018
> On Mar 27, 2018, at 10:05 AM, David Brown <lisp at davidb.org> wrote:
>
> On Tue, Mar 27, 2018 at 09:32:54AM -0700, Ron Garret wrote:
>> Found a reliable workaround!
>>
>> ...
>> This version is broken. If you comment out the line that says “This
>> breaks it” it will start working properly. Both working and
>> non-working versions are 100% reliable. Using a single RLET to
>> allocate both termios structures also works. It’s only when there is
>> a call to tcgetattr in between the allocations that it breaks. (Note
>> that the “broken” version works in 1.8. But for the fact that C code
>> can reproduce this problem intermittently I would call this slam-dunk
>> evidence that this is a bug in the CCL compiler, most likely in RLET.
>> But since the C code does what it does, I’m not willing to go quite
>> that far.)
>
> The common thread in all of these, is that "raw" is only partially
> initialized (cfmakeraw only initializes c_iflag). Subtle changes in
> stack positioning will make the initial values different, which
> explains both the inconsistent behavior with the C program, and the
> behavior of the lisp programs (and why it matters how you declare it).
>
> You need to either tcgetattr again to fill in the 'raw' with the
> current values, or copy the data from the 'normal' before calling
> cfmakeraw on it.
>
> My guess is that, with c_oflag being set to an uninitialized value, it
> has flags set such that it generates no output.
I was under the faulty impression that #_cfmakeraw would fully initialize the termios structure. Nice catch.
So, we'd want something like
(defun set-tty-raw (tty)
(rlet ((attr :termios))
(#_tcgetattr tty attr)
(#_cfmakeraw attr)
(eql 0 (#_tcsetattr tty #$TCSAFLUSH attr))))
More information about the Openmcl-devel
mailing list