rob@alice.UUCP (02/03/84)
I have been implicated in the TTY paging discussion in some private mail, so here is how the (to you) unobtainable Blit affects my world view: Bart Locanthi and I built the Blit to provide cheap high-performance interactive graphics in our time-shared Unix computing environment. I think that, looking back, we are both surprised at how it turned out, and particularly that it is so popular and useful. The surprise is because the important decisions, from a systems point of view, were made in almost complete ignorance of how the terminal would be used. We were at least as lucky as we were capable. The Blit runs much like an extension of the Unix kernel, off-loading the expensive computation required for high-performance interaction, but staying tightly coupled (at least in function; it can run over 1200 baud telephone lines) to the Unix host. Many people, perhaps most, ask why we didn't just make the Blit a personal computer. The answer is that we didn't want personal computers, but the question can be rephrased as, "Why don't you turn it into a personal computer?" and the answer becomes more interesting, and unexpected: The division of function enforced by the architecture of a programmable terminal separated by an RS-232 line forces some design decisions that would not be made otherwise. We were lucky in that many of those decisions result in better interaction, simpler function and much simpler software than what would develop were the same functionality provided on the host. This is hard to defend in a brief note, because the reasons are many small things rather than a couple of obvious advantages, but one exemplary effect is that the operating system running in the terminal (sic) has a much simpler structure than Unix -- in fact, it is a real-time system; getting such good interaction from Unix would require a fair bit of real-time functionality in the Unix kernel. We were able to avoid that morass altogether. So where does terminal paging come in? The Blit is the interaction box, but is tightly coupled to Unix. In (at least the research version of) the Blit software, the tty driver runs in the terminal itself, connecting directly to the bare I/O system in the kernel. As a result, characters can be echoed locally (by the terminal) although the terminal is running full-duplex -- the Blit interprets the stty structure itself -- and Unix programs are completely unaware that the tty driver is running in the terminal. This architecture has enabled us to write a Unix tty driver that employs high-quality interactive computer graphics. The Blit lets you copy text from window to window, edit text on the screen and retransmit it (unlike csh history, this works for any command and on output as well as input), and interactively control when the terminal scrolls. The default is to never scroll without an explicit command, but if you want it to always scroll, just say so with the mouse. All this is achieved without adding special-purpose code to the kernel, although it does depend on the IPC mechanisms of the current research Unix system. Although the Blit is renowned for its windowing, this high-level support for interactive text manipulation is closer to the original spirit of the terminal, and, I feel, at least as important. This is probably a religious issue; the terminal feels so different that many users don't run this new software on their Blits, but they will in time. Paper terminals aren't too common any more. So discussing whether paging belongs in the kernel is skirting the real issue. Paging is only an instance of control over the contents of the display, and convenient though it may or may not be, it opens the door to a bewildering array of features that do not belong in the Unix kernel, but that fit perfectly into a different architecture: one that admits that interaction is important. I never used display editors until my terminal had a mouse, because two-dimensional output is too clumsy to manipulate with one-dimensional input. Since all the interaction with Unix involves text in one form or another, the obvious step is to develop the interactive components of the system until the `text editor' merely couples the general text- editing capabilities to files on disk. Such integration is difficult, of course, and I offer no solace to those without Blits. But I encourage those who would hack the kernel for more interaction to at least be aware of what they should be trying to achieve, and how much they can realistically accomplish. Rob Pike
guy@rlgvax.UUCP (Guy Harris) (02/05/84)
> Many people, perhaps most, ask why we didn't just make the Blit a personal > computer. The answer is that we didn't want personal computers, > but the question can be rephrased as, "Why don't you turn it into > a personal computer?" and the answer becomes more interesting, and > unexpected: > The division of function enforced by the architecture of a > programmable terminal separated by an RS-232 line forces some > design decisions that would not be made otherwise. We were > lucky in that many of those decisions result in better > interaction, simpler function and much simpler software > than what would develop were the same functionality provided > on the host. Actually, the question I'd ask is "why is the Blit different from a personal computer?" I consider it to be as different from what is called a "terminal" as it is from a personal computer. In a lot of the type of software one runs on a very intelligent terminal, there is a lot of computation involved in interacting with the user. A word processor, for instance, must recompute line endings and possibly even page breaks as the user types; a graphics editor must move, rescale, and otherwise modify figures; and so forth. Most "smart" terminals provide little more than forms fill-in capability and some local reformatting of text, but for "dumb" and "smart" terminals, and even a lot of "intelligent" terminals, the only processing done in the terminal is the limited rearrangement of text already formatted at the host. > This is hard to defend in a brief note, because the reasons are many > small things rather than a couple of obvious advantages, but one > exemplary effect is that the operating system running in the terminal > (sic) has a much simpler structure than Unix -- in fact, it is a real-time > system; getting such good interaction from Unix would require a fair > bit of real-time functionality in the Unix kernel. We were able to > avoid that morass altogether. Many desktop workstations running UNIX are now coming out; they may have modified UNIX specifically so that it can provide this sort of real-time response. There is nothing in the structure of UNIX that absolutely requires it to be oriented to multi-user time-shared operations; to some degree, that is merely a policy decision made by the UNIX scheduler. The simplicity of the Blit OS is probably due to its not having to provide all the features of a multi-user system supporting a file system and similar services. This does, however, raise an interesting discussion about what the appropriate architecture for "desktop computing" is; what operations should be performed in a centralized host and what operations should be performed in the desktop computer (which I count the Blit as, based on the assumption that in a text editor the reformatting of text under insertions and deletions is done in the Blit and that in graphic applications the movement of figures is also done in the Blit). Guy Harris {seismo,ihnp4,allegra}!rlgvax!guy
rpw3@fortune.UUCP (02/08/84)
#R:alice:-256800:fortune:11600063:000:269 fortune!rpw3 Feb 7 23:51:00 1984 Hmmm... who's going to be the first to (try to?) support the Mac as an S5R2 terminal with windows? Rob Warnock UUCP: {sri-unix,amd70,hpda,harpo,ihnp4,allegra}!fortune!rpw3 DDD: (415)595-8444 USPS: Fortune Systems Corp, 101 Twin Dolphins Drive, Redwood City, CA 94065