robert@cheviot.UUCP (Robert Stroud) (01/10/85)
<This line is a figment of your imagination> Recently there has been a spate of criticism of the Perq which in my opinion has been unfair, if only because of ignorance of what goes on on this side of the Atlantic. Here is an example from John Zsarnay of CMU. > I second the opinion made by Henry Spencer (@ U of Toronto Zoology) > about the Perq. I disagree with both of you. > ... I also have investigated writing a C compiler for > this machine and can personally attest to it being brain-damaged. As I pointed out in net.lang.c (and if you read Henry Spencer's reply to my article I think you will find he agreed with me), it is not the machine that is brain damaged, but rather the *particular* set of microcode defining a *particular* high-level language machine (Pascal) that is brain-damaged. I might go further and say that anyone who seriously tries to implement a *real* C compiler on a microcoded architecture which was *specifically* designed (and therefore optimised) towards another language is brain-damaged. With an appropriate *general purpose* high-level microcoded architecture it is quite possible to implement Pascal, C and Fortran 77 simultaneously on a Perq - mine has all three. > Furthermore, if ANYONE is considering buying one of these pieces > of junk I suggest you check first with me or anyone here at CMU. I might also suggest that you be slightly less insular and consult some of us on the other side of the Atlantic. There is more than one set of microcode and more than one implementation of Unix available for the Perq. [There is more than one sort of Perq for that matter]. > We (unfortunately) have a great deal of experience using > these machines. So have we. I don't suppose you've heard of the Common Base Policy by any chance? I thought not. > John Zsarnay > (Zsarnay@CMU-CS-A.ARPA) For anyone who is wondering what all the smoke and flames are about, let me try and explain calmly and objectively. First, some words of introduction, (for those who don't know what a Perq is). The Perq was one of the first attempts to produce a machine like the Alto outside Xerox PARC. In other words, it is a powerful single user machine with a large bit mapped screen and a mouse. Its basic graphics primitive (rasterop or bitblt) was designed to be as fast as possible, and these capabilities are demonstrated by several fancy "painting" programs, (like MacPaint for the Macintosh) which are very impressive. It can also be microcoded. This means that the entire architecture is "soft", not even the assembly language is fixed. It is therefore meaningless to make statements such as "The Perq is brain-damaged because you can't implement a C compiler on it". However, microcoding is not a panacea. With the tools available at present it is extremely hard work and very tricky, and microcoding an entire architecture is not something to be undertaken lightly. On the other hand, writing compilers and operating systems used to be hard as well. Please note that a Perq is not a Blit-like machine. The Blit is an extremely intelligent terminal representing a completly different approach to the problem of adding a window manager to Unix. The Perq is a workstation with a hard disk and various other interfaces. Anyway, so much for the introduction. Now for some history... About three years ago, the UK Science & Engineering Research Council (who are responsible for funding a lot of research in this country) decided that it was about time that the various projects they funded stopped re-inventing the wheel and started sharing tools and programs, and using modern Software Engineering techniques. This led to the Common Base Policy. Anyone requesting computing facilities would be "encouraged" if not persuaded to use the same machine, operating system, programming language, graphics package and local area network as everybody else, linked together nationally by wide area networks. The particular combination they chose was... Perq Unix Pascal (& Fortran 77) GKS Cambridge Ring X.25 You may well disagree with some of the specific choices. You may be happier if I tell you that C and Ethernet have become a "de-facto" part of the Common Base Policy even though they are not officially recognised. Three years ago the Perq was in a class of its own (at least in the UK), looking into the future rather than the past. The Lisa and the Macintosh were still a gleam in someone's eye. I think the Perq arrived on the scene before the Sun and the Apollo but I wouldn't swear to it. Anyway, having chosen their machine, SERC had a problem. It was microcoded as a specialised Pascal machine rather than a general purpose machine, and only ran a *single process* operating system called POS which was little more than a collection of subroutines written in an extremely non-standard version of Pascal. Early versions of POS were extremely shaky and full of bugs, and the whole system philosophy was alien to the Unix way of doing things. However, there was a message-passing kernel called Accent floating around (it came from CMU actually) which ran on Perqs and was written in Pascal, and someone thought it would be a good idea to implement Unix on top of Accent, getting all sorts of nice benefits. Meanwhile, ICL (a large British computer manufacturer) made an agreement with Three Rivers who made Perqs in the US and set about implementing their own version of Unix on the Perq. However, they threw away POS and the Pascal microcode and after microcoding the Perq as a C machine, ported a mixture of Version 7 (mainly) and System III to the machine, added a window manager (perhaps one of the earliest Unix window managers) and called the result PNX. The Accent/Unix project was a failure. Since I have heard conflicting versions of the reasons for this failure, from people intimately involved, I don't think it is fair for me to comment further. PNX was accepted for the Common Base, even though at that time it didn't have a Pascal compiler, (it now supports full ISO Pascal). The rest is history. In the UK (and Europe for that matter) there are a lot of people in Universities and elsewhere using Perqs with PNX and a perfectly normal C, ISO Pascal and Fortran 77 implementation. Perqs can be connected by Ethernet and ICL will shortly be releasing a version of PNX with the Newcastle Connection integrated. The Cambridge Ring implementation ran into all sorts of problems (again I won't go into details) but our fieldtrial version now works and also runs the Newcastle Connection adequately, if slowly. PNX has been available in one form or another with the window manager for nearly two years, and with the Newcastle Connection for nearly as long, (at least here in Newcastle!). So what is all the fuss about? Well, to be perfectly honest, in the interests of objectivity I have glossed over a few details! Early Perqs had a bad record of hardware reliability, and the original version of the I/O firmware lacked functionality, (some would say didn't work!). Consequently, the first release of Unix, PNX 1.5 was not all that it might be. A new version of the hardware, the Perq 2, dealt with many of the early problems. For those people who already had the old Perq 1's, ICL has now almost completed an extensive programme of hardware and firmware upgrades, and there is a new version of PNX called PNX 2, (and several more releases in the pipeline). There are still some problem areas, (notably performance) but I am sure that ICL and Three Rivers (now Perq Computer Corporation) are aware of this. Personally I believe a really good fast disk would make an immense difference, (I use an old Perq 1 and the disk is incredibly slow). I think disk access time is more of a limiting factor for performance in this type of Unix workstation than CPU speed. Of course, in the intervening years machines like the Sun and the Apollo have arrived on the scene, and some British machines which I expect most of you have never heard of (Whitechapel and Orion) are lurking in the wings. The Orion is based on the same technology as the Perq and runs 4.1BSD. The manufacturers, High Level Hardware claim that it can execute C at the speed of a Vax 750 for a quarter the price. The Whitechapel MG-1 comes in various configurations starting from 5000 pounds, but a system comparable with the Perq probably costs more like 15000 pounds. It runs System III and uses the new Nat Semi 32 bit chip. Neither of these systems offer window managers or a distributed operating system (yet!). In my opinion, although the Perq has lost its massive lead it still probably has the edge in what it can deliver right now in your hand, at least in terms of the sheer functionality offered. Probably the Sun is the only serious contender. Unfortunately, this news does not seem to have crossed the Atlantic and Perq sales are not what they should be. I could suggest all sorts of reasons why this might be, but I shall keep them to myself. As various manufacturers deliver their promises, the next six months could be very interesting. But the Perq is available now, and has been available for several years, so is likely to have had the bugs shaken out. I wouldn't be surprised if PCC and ICL had a few surprises up their sleeves for the next six months as well. I do know that at CMU there is a pseudo-Unix built on Accent called Spoonix, (about which I know very little, including how to spell it!), and that PCC are planning a System V implementation on top of Accent called QNX which should be quite something. However, as far as I know QNX is not working yet. I am writing this because I am sick and tired of seeing biassed, unfair, unjustified criticism of the Perq based on ignorance. I am not saying it's perfect by any means. As a fieldtrial site for various versions of PNX, we have probably been more critical than virtually anybody else, inside or outside ICL. But we still like the machine, (and SERC are showing no sign of dropping it from their Common Base Policy either, despite a recent survey of the competition). If something which is clearly better and faster but cheaper comes along, then the Perq will have to take its chances in the market place, like any other product. I shall end with a quote from a UK computer magazine. In the true spirit of objectivity I have taken it out of context, (from a news item about one of the Perq's future competitors!). "The Perq is a machine which is so wonderful that everybody weeps about it, but so expensive that nobody writes any programs for it" Perhaps in future people flaming about the Perq would be a little bit more specific about which version of the hardware, firmware, microcode and operating system they are basing their judgements on. However, such flames would be better directed to ICL, PCC or /dev/null. Now can we talk about something more interesting, like how best to integrate window managers into Unix without compromising either? Robert Stroud, Computing Laboratory, University of Newcastle upon Tyne. ARPA robert%cheviot%newcastle.mailnet@mit-multics.arpa UUCP ..!ukc!cheviot!robert JANET robert@neda